2025-04-19 17:39:08 -04:00

240 lines
5.7 KiB
JavaScript

/*
Multiverse by HTML5 UP
html5up.net | @ajlkn
Free for personal and commercial use under the CCA 3.0 license (html5up.net/license)
*/
(function ($) {
var $window = $(window),
$body = $("body"),
$wrapper = $("#wrapper");
// Breakpoints.
breakpoints({
xlarge: ["1281px", "1680px"],
large: ["981px", "1280px"],
medium: ["737px", "980px"],
small: ["481px", "736px"],
xsmall: [null, "480px"],
});
// Hack: Enable IE workarounds.
if (browser.name == "ie") $body.addClass("ie");
// Touch?
if (browser.mobile) $body.addClass("touch");
// Transitions supported?
if (browser.canUse("transition")) {
// Play initial animations on page load.
$window.on("load", function () {
window.setTimeout(function () {
$body.removeClass("is-preload");
}, 100);
});
// Prevent transitions/animations on resize.
var resizeTimeout;
$window.on("resize", function () {
window.clearTimeout(resizeTimeout);
$body.addClass("is-resizing");
resizeTimeout = window.setTimeout(function () {
$body.removeClass("is-resizing");
}, 100);
});
}
// Scroll back to top.
$window.scrollTop(0);
// Panels.
var $panels = $(".panel");
$panels.each(function () {
var $this = $(this),
$toggles = $('[href="#' + $this.attr("id") + '"]'),
$closer = $('<div class="closer" />').appendTo($this);
// Closer.
$closer.on("click", function (event) {
$this.trigger("---hide");
});
// Events.
$this
.on("click", function (event) {
event.stopPropagation();
})
.on("---toggle", function () {
if ($this.hasClass("active")) $this.triggerHandler("---hide");
else $this.triggerHandler("---show");
})
.on("---show", function () {
// Hide other content.
if ($body.hasClass("content-active")) $panels.trigger("---hide");
// Activate content, toggles.
$this.addClass("active");
$toggles.addClass("active");
// Activate body.
$body.addClass("content-active");
})
.on("---hide", function () {
// Deactivate content, toggles.
$this.removeClass("active");
$toggles.removeClass("active");
// Deactivate body.
$body.removeClass("content-active");
});
// Toggles.
$toggles
.removeAttr("href")
.css("cursor", "pointer")
.on("click", function (event) {
event.preventDefault();
event.stopPropagation();
$this.trigger("---toggle");
});
});
// Global events.
$body.on("click", function (event) {
if ($body.hasClass("content-active")) {
event.preventDefault();
event.stopPropagation();
$panels.trigger("---hide");
}
});
$window.on("keyup", function (event) {
if (event.keyCode == 27 && $body.hasClass("content-active")) {
event.preventDefault();
event.stopPropagation();
$panels.trigger("---hide");
}
});
// Header.
var $header = $("#header");
// Links.
$header.find("a").each(function () {
var $this = $(this),
href = $this.attr("href");
// Internal link? Skip.
if (!href || href.charAt(0) == "#") return;
// Redirect on click.
$this
.removeAttr("href")
.css("cursor", "pointer")
.on("click", function (event) {
event.preventDefault();
event.stopPropagation();
window.location.href = href;
});
});
// Footer.
var $footer = $("#footer");
// Copyright.
// This basically just moves the copyright line to the end of the *last* sibling of its current parent
// when the "medium" breakpoint activates, and moves it back when it deactivates.
$footer.find(".copyright").each(function () {
var $this = $(this),
$parent = $this.parent(),
$lastParent = $parent.parent().children().last();
breakpoints.on("<=medium", function () {
$this.appendTo($lastParent);
});
breakpoints.on(">medium", function () {
$this.appendTo($parent);
});
});
// Main.
var $main = $("#main");
// Thumbs.
$main.children(".thumb").each(function () {
var $this = $(this),
$image = $this.find(".image"),
$image_img = $image.children("img"),
x;
// No image? Bail.
if ($image.length == 0) return;
// Image.
// This sets the background of the "image" <span> to the image pointed to by its child
// <img> (which is then hidden). Gives us way more flexibility.
// Set background.
$image.css("background-image", "url(" + $image_img.attr("src") + ")");
// Set background position.
if ((x = $image_img.data("position"))) $image.css("background-position", x);
// Hide original img.
$image_img.hide();
});
// Poptrox.
$main.poptrox({
baseZIndex: 20000,
caption: function ($a) {
var s = "";
$a.nextAll().each(function () {
s += this.outerHTML;
});
return s;
},
fadeSpeed: 300,
onPopupClose: function () {
$body.removeClass("modal-active");
},
onPopupOpen: function () {
$body.addClass("modal-active");
},
overlayOpacity: 0,
popupCloserText: "",
popupHeight: 150,
popupLoaderText: "",
popupSpeed: 300,
popupWidth: 150,
selector: ".thumb > a.image",
usePopupCaption: true,
usePopupCloser: true,
usePopupDefaultStyling: false,
usePopupForceClose: true,
usePopupLoader: true,
usePopupNav: true,
windowMargin: 50,
});
// Hack: Set margins to 0 when 'xsmall' activates.
breakpoints.on("<=xsmall", function () {
$main[0]._poptrox.windowMargin = 0;
});
breakpoints.on(">xsmall", function () {
$main[0]._poptrox.windowMargin = 50;
});
})(jQuery);