// Get the theme switcher button element. const themeSwitcher = document.querySelector(".theme-switcher"); // Retrieve theme from localStorage. let currentTheme = localStorage.getItem("theme"); // Function to switch between dark and light themes. function switchTheme() { // Set the new theme based on the current theme. currentTheme = currentTheme === "dark" ? "light" : "dark"; document.documentElement.setAttribute("data-theme", currentTheme); localStorage.setItem("theme", currentTheme); } // Initialize the theme switcher button. themeSwitcher.addEventListener("click", switchTheme, false); // Update the theme based on system preference if the user hasn't manually changed the theme. window.matchMedia("(prefers-color-scheme: dark)").addEventListener("change", e => { if (!localStorage.getItem("theme")) { currentTheme = e.matches ? "dark" : "light"; document.documentElement.setAttribute("data-theme", currentTheme); } }); // Fix the theme switcher button not working on the first click by updating currentTheme. if (!currentTheme) { currentTheme = document.documentElement.getAttribute("data-theme"); }