mirror of
https://github.com/Ellpeck/TinyLifeWeb.git
synced 2024-11-05 12:29:09 +01:00
35 lines
1.1 KiB
JavaScript
35 lines
1.1 KiB
JavaScript
|
const sw = document.getElementById("switch-style"), sw_mobile = document.getElementById("switch-style-m"), b = document.body;
|
||
|
if (b) {
|
||
|
function toggleTheme(target, dark) {
|
||
|
target.classList.toggle("dark-theme", dark)
|
||
|
target.classList.toggle("light-theme", !dark)
|
||
|
}
|
||
|
|
||
|
function switchEventListener() {
|
||
|
toggleTheme(b, this.checked);
|
||
|
if (window.localStorage) {
|
||
|
this.checked ? localStorage.setItem("theme", "dark-theme") : localStorage.setItem("theme", "light-theme")
|
||
|
}
|
||
|
}
|
||
|
|
||
|
var isDarkTheme = !window.localStorage || !window.localStorage.getItem("theme") || window.localStorage && localStorage.getItem("theme") === "dark-theme";
|
||
|
|
||
|
if(sw && sw_mobile){
|
||
|
sw.checked = isDarkTheme;
|
||
|
sw_mobile.checked = isDarkTheme;
|
||
|
|
||
|
sw.addEventListener("change", switchEventListener);
|
||
|
sw_mobile.addEventListener("change", switchEventListener);
|
||
|
|
||
|
// sync state between switches
|
||
|
sw.addEventListener("change", function() {
|
||
|
sw_mobile.checked = this.checked;
|
||
|
});
|
||
|
|
||
|
sw_mobile.addEventListener("change", function() {
|
||
|
sw.checked = this.checked;
|
||
|
});
|
||
|
}
|
||
|
|
||
|
toggleTheme(b, isDarkTheme);
|
||
|
}
|