Files
Epicnabbo-Catalogus-Updated…/cms update/resources/themes/atom/js/components/ThemeSwitcher.js
T
Remco b67e0ec2b9 🆙 Add fixed cms 🆙
2026-02-02 19:30:21 +01:00

37 lines
1.0 KiB
JavaScript

const ThemeSwitcher = {
currentTheme: "light",
init() {
if (
localStorage.theme === "dark" ||
(typeof window.matchMedia != "undefined" &&
window.matchMedia("(prefers-color-scheme: dark)").matches &&
localStorage.theme !== "light")
) {
this.toggleTheme();
}
document.addEventListener("turbolinks:load", () => this.initButton());
},
initButton() {
let themeSwitcher = document.getElementById("theme-switcher");
themeSwitcher?.addEventListener("click", () => this.toggleTheme());
},
toggleTheme() {
if (this.currentTheme === "light") {
this.currentTheme = "dark";
document.documentElement.classList.add("dark");
} else {
this.currentTheme = "light";
document.documentElement.classList.remove("dark");
}
localStorage.setItem("theme", this.currentTheme);
},
};
export { ThemeSwitcher as default };