61 lines
1.7 KiB
JavaScript
61 lines
1.7 KiB
JavaScript
import { expandNav, closeNav, show } from "./functions.js";
|
|
|
|
document.addEventListener("DOMContentLoaded", () => {
|
|
// Variables
|
|
const nodes = {
|
|
burgerBtn: document.querySelector(".burger-btn"),
|
|
closeNavBtn: document.querySelector("#expanded-nav .close-btn"),
|
|
expandedNav: document.querySelector("#expanded-nav"),
|
|
main: document.querySelector("main"),
|
|
footer: document.querySelector(".main-footer"),
|
|
nav: document.querySelector(".main-nav"),
|
|
jsLinks: document.querySelectorAll(".js-link"),
|
|
};
|
|
|
|
setTimeout(() => {
|
|
nodes.images = document.querySelectorAll("img");
|
|
}, 0);
|
|
|
|
// Listeners
|
|
nodes.burgerBtn.addEventListener("click", () => expandNav(nodes));
|
|
nodes.closeNavBtn.addEventListener("click", () => closeNav(nodes));
|
|
nodes.jsLinks.forEach((jsLink) => {
|
|
const to = jsLink.dataset.href;
|
|
jsLink.addEventListener("click", () => (location.href = to));
|
|
});
|
|
|
|
setTimeout(() => {
|
|
nodes.images.forEach((image) => {
|
|
console.log(image);
|
|
console.log(image.complete);
|
|
if (image.complete) {
|
|
show(image);
|
|
} else {
|
|
image.addEventListener("load", () => {
|
|
console.log("image loaded");
|
|
show(image);
|
|
});
|
|
}
|
|
});
|
|
}, 50);
|
|
|
|
// Key shortcuts
|
|
window.addEventListener("keyup", (event) => {
|
|
if (event.key === "Escape") {
|
|
closeNav(nodes);
|
|
}
|
|
});
|
|
window.addEventListener("scroll", (event) => {
|
|
if (nodes.expandedNav.classList.contains("open")) {
|
|
closeNav(nodes);
|
|
}
|
|
if (
|
|
(window.scrollY > 120) &
|
|
!nodes.nav.classList.contains("main-nav--small")
|
|
) {
|
|
nodes.nav.classList.add("main-nav--small");
|
|
} else if (window.scrollY < 100) {
|
|
nodes.nav.classList.remove("main-nav--small");
|
|
}
|
|
});
|
|
});
|