155 lines
4.7 KiB
JavaScript
155 lines
4.7 KiB
JavaScript
/*
|
|
* Sticky navbar
|
|
*
|
|
*/
|
|
|
|
// When the user scrolls the page, execute navbarSticky
|
|
window.onscroll = function() {navbarSticky()};
|
|
|
|
// Get the navbar
|
|
var navbar = document.getElementsByClassName("navbar")[0];
|
|
|
|
// Get the offset position of the navbar
|
|
var sticky = navbar.offsetTop ? navbar.offsetTop : navbar.offsetHeight;
|
|
|
|
function toggleNavbarTheme () {
|
|
if (navbar.classList.contains("navbar-dark")) {
|
|
navbar.classList.add("navbar-light");
|
|
navbar.classList.remove("navbar-dark");
|
|
} else if (navbar.classList.contains("navbar-light")) {
|
|
navbar.classList.add("navbar-dark");
|
|
navbar.classList.remove("navbar-light");
|
|
}
|
|
}
|
|
|
|
|
|
// Add the sticky class to the navbar when you reach its scroll position. Remove "sticky" when you leave the scroll position
|
|
function navbarSticky(isSticky) {
|
|
if (isSticky == undefined) {
|
|
isSticky = (window.pageYOffset >= sticky);
|
|
}
|
|
|
|
if (isSticky) {
|
|
if (!navbar.classList.contains("sticky")) {
|
|
navbar.classList.add("sticky");
|
|
toggleNavbarTheme();
|
|
}
|
|
} else {
|
|
if (navbar.classList.contains("sticky")) {
|
|
navbar.classList.remove("sticky");
|
|
toggleNavbarTheme();
|
|
}
|
|
}
|
|
}
|
|
|
|
function setCookie(name, value) {
|
|
document.cookie = name + "=" + value + ";";
|
|
//try to set cookie to all subdomains
|
|
document.cookie = name + "=" + value + ";path=/;domain=." + window.location.host.replace(/^.*?\./, '') + ";";
|
|
}
|
|
|
|
let themeSwitch = document.querySelector("#color-theme-switch i");
|
|
let theme = document.documentElement.dataset.bsTheme;
|
|
let themeCookie = document.cookie.match(/theme=(.*?);/);
|
|
if (themeCookie && themeCookie[1]) {
|
|
theme = themeCookie[1];
|
|
}
|
|
|
|
if (theme) {
|
|
if (theme == "dark") {
|
|
let themeSwitch = document.querySelector("#color-theme-switch i");
|
|
themeSwitch.classList.remove("la-sun")
|
|
themeSwitch.classList.add("la-moon");
|
|
document.documentElement.dataset.bsTheme = theme;
|
|
}
|
|
}
|
|
|
|
|
|
document.addEventListener("click", function (e) {
|
|
let link = e.target.closest("#color-theme-switch");
|
|
if (link) {
|
|
let themeSwitch = link.querySelector("i");
|
|
let theme = document.documentElement.dataset.bsTheme;
|
|
|
|
if (theme == "dark") {
|
|
theme = "light";
|
|
themeSwitch.classList.remove("la-moon");
|
|
themeSwitch.classList.add("la-sun");
|
|
} else if (theme == "light" || theme == "auto" || !theme) {
|
|
theme = "dark";
|
|
themeSwitch.classList.remove("la-sun");
|
|
themeSwitch.classList.add("la-moon");
|
|
} else {
|
|
theme = "auto";
|
|
}
|
|
|
|
document.documentElement.dataset.bsTheme = theme;
|
|
//localStorage.setItem("theme", theme);
|
|
setCookie("theme", theme);
|
|
//serverStorage.setItem();
|
|
}
|
|
});
|
|
|
|
|
|
if ('serviceWorker' in navigator) {
|
|
navigator.serviceWorker.register('/service-worker.js', { scope: '/' })
|
|
.then(function (registration){console.log('Service worker registered successfully');})
|
|
.catch(function (e){console.error('Error during service worker registration:', e);});
|
|
}
|
|
|
|
function togglePasswordInput(element, input) {
|
|
let password = document.getElementById(input);
|
|
if (password.type == "password") {
|
|
password.type = "text";
|
|
let i = element.querySelector("i")
|
|
i.classList.add("la-eye")
|
|
i.classList.remove("la-eye-slash");
|
|
} else {
|
|
password.type = "password";
|
|
let i = element.querySelector("i")
|
|
i.classList.remove("la-eye")
|
|
i.classList.add("la-eye-slash");
|
|
}
|
|
}
|
|
|
|
document.addEventListener("click", function (e) {
|
|
let link = e.target.closest(".dropdown-toggle");
|
|
if (link) {
|
|
let parent = link.closest(".nav-toggle");
|
|
if (link.classList.contains("show")) {
|
|
parent.classList.add("show");
|
|
} else {
|
|
parent.classList.remove("show");
|
|
}
|
|
}
|
|
});
|
|
|
|
function updateProgressStatus(percent) {
|
|
const progressElement = document.getElementById('page-loading-status');
|
|
progressElement.style.width = percent + '%';
|
|
/*
|
|
if (percent == 0) {
|
|
progressElement.classList.add("d-none");
|
|
} else {
|
|
progressElement.classList.remove("d-none");
|
|
}
|
|
*/
|
|
}
|
|
|
|
//init specific page js code after page is loaded through ajax
|
|
function afterPageLoad() {
|
|
//get navbar for sticky
|
|
navbar = document.getElementsByClassName("navbar")[0];
|
|
}
|
|
|
|
//theme ajax configuration
|
|
|
|
//include elements that will be updated on ajax calls, include body > section to trigger whole page update if sections mismatch between different page structures
|
|
VvvebTheme.ajax.siteContainer = ["#site-content", ".inner-page-hero", "body > section", "body > nav"];
|
|
VvvebTheme.ajax.progressStatus = updateProgressStatus;
|
|
VvvebTheme.ajax.afterLoad = afterPageLoad;
|
|
//include posts, product and menu items for ajax
|
|
//VvvebTheme.ajax.selector = "a[data-url], a[data-page-url], a[data-v-menu-item-url], a[data-v-post-url], a[data-v-product-url], a[data-v-cat-url], a[data-v-archive-url], a[data-v-admin-url], a[data-v-post-author-url], a[data-v-breadcrumb-item-url]";
|
|
//skip home for dark hero and contact form for google js code
|
|
//VvvebTheme.ajax.skipUrl = ["/", "/page/contact"];
|