Difference between revisions of "Template:TU Dresden/JS"

Line 18: Line 18:
 
         if(window.location.hash.length > 1) {
 
         if(window.location.hash.length > 1) {
 
           console.log("Hash longer 1");
 
           console.log("Hash longer 1");
          pos = window.pageYOffset || document.documentElement.scrollTop;
+
           $('body,html').animate({scrollTop: $(window.location.hash).offset().top-150}, 1000);
           $('body,html').animate({scrollTop: pos-150}, 1000);
+
 
           console.log("Window scrolled");
 
           console.log("Window scrolled");
 
         }else{
 
         }else{

Revision as of 03:02, 1 November 2017

$(document).ready(function() {

   $("#HQ_page").attr('id',);
   resizeDiv();
   setNavigation();
   ufoLinks();
   $('.back-to-top').click(function () {
       $('body,html').animate({scrollTop: 0}, 1000);

return false;

   });

});

$(window).on("load", function() {

   console.log("Done loading!");
   fixPagePosition(); 

});

function fixPagePosition() {

       if(window.location.hash.length > 1) {
          console.log("Hash longer 1");
          $('body,html').animate({scrollTop: $(window.location.hash).offset().top-150}, 1000);
          console.log("Window scrolled");
       }else{
          console.log("Nothing to do.");
       }

}

function ufoLinks() {

   var ufo = ;
   for (var i = 1; i <= $("h1").length - 1; i++) {
       if($("h1")[i].id == ) {
           $("h1")[i].setAttribute("id","section"+i);
       }
       ufo += "<a href='#" + $("h1")[i].id + "'>" + $("h1")[i].innerHTML + "</a>
"; } $(".ufo-links").html(ufo); $(".ufo-links").on("click", "a", function(e) { fixPagePosition(); });

}

function toggleNav() {

   var x = document.getElementById("nav-toggle");
   if (x.className === "closed") {
   	x.className = "open";
   }else{
   	x.className = "closed";
   }
   $(".navbar").slideToggle();

}

window.onresize = function(event) {

   resizeDiv();

}

function resizeDiv() {

   if(window.innerHeight > 0.55 * window.innerWidth) {
       if(150 > 0.55 * window.innerWidth - 210) {
           var divHeight =  150;
       }else{
           var divHeight = 0.55 * window.innerWidth - 210;
       }
   }else{
       var divHeight = window.innerHeight - 210;
   }
   $("#bannerspace").css({"height": divHeight});
   $("#pagebanner").css({"min-height": window.innerWidth});
   setFullscreenValues();

}

function setNavigation() {

   var path = $(location).attr('href');
   $("nav a").each(function () {
       var href = $(this).attr('href');
       if (path === href) {
           $(this).addClass('active');
           var section = $(this).closest('nav > div > ul > li');
           if (section){
           section.addClass('active');
           }
       }
   });

}

document.onscroll = function() {

       pos = window.pageYOffset || document.documentElement.scrollTop;
       if (pos < 263) {
           $("#ufo").css({"bottom": -253+pos});
       }else{
           if (pos >= ($('.footerbar').offset().top-window.innerHeight)){
               $("#ufo").css({"bottom": pos-($('.footerbar').offset().top-window.innerHeight)+10});
           }else{
               $("#ufo").css({"bottom": 10});
           }
       }

};

function setFullscreenValues(){

   if ((window.innerWidth / window.innerHeight) < 1.75) {
       $('#fullscreen').parent().css({"flex-wrap": "wrap"});
       $('#fullscreen').parent().css({"align-items": "center"});
       document.getElementById("fullscreen-caption").style.minHeight = "20vh";
       document.getElementById("fullscreen").style.maxHeight = "80vh";
       document.getElementById("fullscreen-caption").style.minWidth = "0";
       document.getElementById("fullscreen").style.maxWidth = "100%";
   } else {
       $('#fullscreen').parent().css({"flex-wrap": "nowrap"});
       $('#fullscreen').parent().css({"align-items": "flex-end"});
       document.getElementById("fullscreen-caption").style.minWidth = "30%";
       document.getElementById("fullscreen").style.maxWidth = "70%";
       document.getElementById("fullscreen-caption").style.minHeight = "0";
       document.getElementById("fullscreen").style.maxHeight = "90vh";
   }

}

var fullscreen = false;

$('.zoom').on('click', function (){

   document.getElementById("fullscreen").setAttribute("src", $(this).attr('src'));
   if ($(this).next().is('figcaption')) {
       setFullscreenValues();
       document.getElementById("fullscreen-caption").innerHTML = $(this).next().html();
   }else{
       document.getElementById("fullscreen-caption").innerHTML = ;
       document.getElementById("fullscreen-caption").style.minWidth = 0;
       document.getElementById("fullscreen").style.maxWidth = "100%";
       document.getElementById("fullscreen-caption").style.minHeight = "0";
       document.getElementById("fullscreen").style.maxHeight = "90vh";
   }
   $('#modal').slideToggle();
   fullscreen = true;

});

$(document).on('keyup',function(evt) {

   if (evt.keyCode == 27) {
       if (fullscreen) {
           $('#modal').slideToggle();
           fullscreen = false;
       }
   }

});

$('#fullscreen').on('click', function (){

   $('#modal').slideToggle();
   fullscreen = false;

});

$('#close-fullscreen').on('click', function (){

   $('#modal').slideToggle();
   fullscreen = false;

});