aboutsummaryrefslogtreecommitdiff
path: root/hp_assets/js/main.js
blob: 5b502f737fcaf2200743b68d7984be9e2c916f9e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
var menuHidden = true;
var randBgTimer = null;

// Simulates PHP's date function - http://jacwright.com/projects/javascript/date_format/
Date.prototype.format=function(e){var t="";var n=Date.replaceChars;for(var r=0;r<e.length;r++){var i=e.charAt(r);if(r-1>=0&&e.charAt(r-1)=="\\"){t+=i}else if(n[i]){t+=n[i].call(this)}else if(i!="\\"){t+=i}}return t};Date.replaceChars={shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],longMonths:["January","February","March","April","May","June","July","August","September","October","November","December"],shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],longDays:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],d:function(){return(this.getDate()<10?"0":"")+this.getDate()},D:function(){return Date.replaceChars.shortDays[this.getDay()]},j:function(){return this.getDate()},l:function(){return Date.replaceChars.longDays[this.getDay()]},N:function(){return this.getDay()+1},S:function(){return this.getDate()%10==1&&this.getDate()!=11?"st":this.getDate()%10==2&&this.getDate()!=12?"nd":this.getDate()%10==3&&this.getDate()!=13?"rd":"th"},w:function(){return this.getDay()},z:function(){var e=new Date(this.getFullYear(),0,1);return Math.ceil((this-e)/864e5)},W:function(){var e=new Date(this.getFullYear(),0,1);return Math.ceil(((this-e)/864e5+e.getDay()+1)/7)},F:function(){return Date.replaceChars.longMonths[this.getMonth()]},m:function(){return(this.getMonth()<9?"0":"")+(this.getMonth()+1)},M:function(){return Date.replaceChars.shortMonths[this.getMonth()]},n:function(){return this.getMonth()+1},t:function(){var e=new Date;return(new Date(e.getFullYear(),e.getMonth(),0)).getDate()},L:function(){var e=this.getFullYear();return e%400==0||e%100!=0&&e%4==0},o:function(){var e=new Date(this.valueOf());e.setDate(e.getDate()-(this.getDay()+6)%7+3);return e.getFullYear()},Y:function(){return this.getFullYear()},y:function(){return(""+this.getFullYear()).substr(2)},a:function(){return this.getHours()<12?"am":"pm"},A:function(){return this.getHours()<12?"AM":"PM"},B:function(){return Math.floor(((this.getUTCHours()+1)%24+this.getUTCMinutes()/60+this.getUTCSeconds()/3600)*1e3/24)},g:function(){return this.getHours()%12||12},G:function(){return this.getHours()},h:function(){return((this.getHours()%12||12)<10?"0":"")+(this.getHours()%12||12)},H:function(){return(this.getHours()<10?"0":"")+this.getHours()},i:function(){return(this.getMinutes()<10?"0":"")+this.getMinutes()},s:function(){return(this.getSeconds()<10?"0":"")+this.getSeconds()},u:function(){var e=this.getMilliseconds();return(e<10?"00":e<100?"0":"")+e},e:function(){return"Not Yet Supported"},I:function(){var e=null;for(var t=0;t<12;++t){var n=new Date(this.getFullYear(),t,1);var r=n.getTimezoneOffset();if(e===null)e=r;else if(r<e){e=r;break}else if(r>e)break}return this.getTimezoneOffset()==e|0},O:function(){return(-this.getTimezoneOffset()<0?"-":"+")+(Math.abs(this.getTimezoneOffset()/60)<10?"0":"")+Math.abs(this.getTimezoneOffset()/60)+"00"},P:function(){return(-this.getTimezoneOffset()<0?"-":"+")+(Math.abs(this.getTimezoneOffset()/60)<10?"0":"")+Math.abs(this.getTimezoneOffset()/60)+":00"},T:function(){var e=this.getMonth();this.setMonth(0);var t=this.toTimeString().replace(/^.+ \(?([^\)]+)\)?$/,"$1");this.setMonth(e);return t},Z:function(){return-this.getTimezoneOffset()*60},c:function(){return this.format("Y-m-d\\TH:i:sP")},r:function(){return this.toString()},U:function(){return this.getTime()/1e3}}

Mousetrap.bind('esc', function() {
  setMenuVisibility(false);
});

Mousetrap.bind('1', function() {
  if (!menuHidden) {
    var link = $(".link:eq(0) a").attr("href");
    window.location = link;
  }
});

Mousetrap.bind('2', function() {
  if (!menuHidden) {
    var link = $(".link:eq(1) a").attr("href");
    window.location = link;
  }
});

Mousetrap.bind('3', function() {
  if (!menuHidden) {
    var link = $(".link:eq(2) a").attr("href");
    window.location = link;
  }
});

Mousetrap.bind('4', function() {
  if (!menuHidden) {
    var link = $(".link:eq(3) a").attr("href");
    window.location = link;
  }
});

Mousetrap.bind('5', function() {
  if (!menuHidden) {
    var link = $(".link:eq(4) a").attr("href");
    window.location = link;
  }
});

Mousetrap.bind('6', function() {
  if (!menuHidden) {
    var link = $(".link:eq(5) a").attr("href");
    window.location = link;
  }
});

function toggleMenu() {
  if (menuHidden) {
    setMenuVisibility(true);
  } else {
    setMenuVisibility(false);
  }
}

function setMenuVisibility(visible) {
  if (visible) {
    $(".menu-item").fadeIn();
    $("body").addClass("menu-shown");
    menuHidden = false;
  } else {
    $(".menu-item").fadeOut();
    $("body").removeClass("menu-shown");
    menuHidden = true;
  }
}

// Set random background image
function setBgImg() {
  var bg = "";

  $.getJSON("hp_assets/lib/ajax_get_image.php").done(function(data) {
    if (data['success']) {
      bg = data['url'];
      if (bg != "" && bg != null) {
        preloadimages([bg]).done(function(images) {
          $("#homepage").css("background-image", "url(" + bg + ")").css("background-size", "cover");
          $("#pic-info-wrap").removeClass("hidden");
          $("#pic-info-url").attr("href", data['image_user_url']).text(data['image_user_name']);
        });
      }
    }
  });
}

// http://www.javascriptkit.com/javatutors/preloadimagesplus.shtml
function preloadimages(arr){
  var newimages=[], loadedimages=0
  var postaction=function(){}
  var arr=(typeof arr!="object")? [arr] : arr
  function imageloadpost(){
    loadedimages++
    if (loadedimages==arr.length){
      postaction(newimages) //call postaction and pass in newimages array as parameter
    }
  }
  for (var i=0; i<arr.length; i++){
    newimages[i]=new Image()
    newimages[i].src=arr[i]
    newimages[i].onload=function(){
        imageloadpost()
    }
    newimages[i].onerror=function(){
      imageloadpost()
    }
  }
  return { //return blank object with done() method
    done:function(f){
      postaction=f || postaction //remember user defined callback functions to be called when images load
    }
  }
}

$(function() {
  $("#mobile-menu-wrap a").click(function(e) {
    e.preventDefault();
    toggleMenu();
  });

  setBgImg();
});