"use client" import Image from "next/image"; import { useEffect, useState } from "react"; import { icons } from "#/assets/icons" export default function Theme() { const [theme, setTheme] = useState(null); useEffect(() => { if (typeof window !== "undefined") { const savedTheme = localStorage.getItem("theme") || (window.matchMedia("(prefers-color-scheme: dark)").matches ? "dark" : "light"); setTheme(savedTheme); document.body.setAttribute("data-theme", savedTheme); } }, []); const handleTheme = () => { const newTheme = theme === "light" ? "dark" : "light"; setTheme(newTheme); localStorage.setItem("theme", newTheme); document.body.setAttribute("data-theme", newTheme); }; useEffect(() => { if (theme === null) return; const mediaQuery = window.matchMedia("(prefers-color-scheme: dark)"); const handleChange = (e: MediaQueryListEvent) => { const newTheme = e.matches ? "dark" : "light"; setTheme(newTheme); localStorage.setItem("theme", newTheme); document.body.setAttribute("data-theme", newTheme); }; mediaQuery.addEventListener("change", handleChange); return () => mediaQuery.removeEventListener("change", handleChange); }, [theme]); if (theme === null) return null; return (
); }