nouveau-theatre-de-besancon/assets/js/script.js
isUnknown 1d01de1217 styles : mise à jour CSS et JS
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-04 15:24:54 +02:00

50 lines
1.5 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"),
};
// 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));
});
document.querySelectorAll("img").forEach((image) => {
if (image.complete && image.naturalWidth > 0) {
show(image);
} else {
image.addEventListener("load", () => show(image));
}
});
// 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 > 130 &&
!nodes.nav.classList.contains("main-nav--small")
) {
nodes.nav.classList.add("main-nav--small");
} else if (window.scrollY < 90) {
nodes.nav.classList.remove("main-nav--small");
}
});
});