aboutsummaryrefslogtreecommitdiff
path: root/hp_assets/js/main.js
diff options
context:
space:
mode:
authorUnknown <philipp_kutyla@gmx.de>2017-02-20 14:57:52 +0100
committerUnknown <philipp_kutyla@gmx.de>2017-02-20 14:57:52 +0100
commit7675aad8555d1943c0d06a9fc662aa9164cfce7f (patch)
tree04384d22c690a5f5def439fd59b436ec2c81b24f /hp_assets/js/main.js
parentef8940a0035d95f08f204601c8a7168ffd9058d8 (diff)
downloadsimple-dash-fork-7675aad8555d1943c0d06a9fc662aa9164cfce7f.zip
Responsiveness, scrolling in link-wrapper
Diffstat (limited to 'hp_assets/js/main.js')
-rw-r--r--hp_assets/js/main.js126
1 files changed, 126 insertions, 0 deletions
diff --git a/hp_assets/js/main.js b/hp_assets/js/main.js
new file mode 100644
index 0000000..5b502f7
--- /dev/null
+++ b/hp_assets/js/main.js
@@ -0,0 +1,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();
+});