"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( localStorage.getItem("theme") || (window.matchMedia("(prefers-color-scheme: dark)").matches ? "dark" : "light") ); useEffect(() => { document.body.setAttribute("data-theme", theme); localStorage.setItem("theme", theme); const mediaQuery = window.matchMedia("(prefers-color-scheme: dark)"); const handleChange = (e: MediaQueryListEvent) => { const newTheme = e.matches ? "dark" : "light"; setTheme(newTheme); }; mediaQuery.addEventListener("change", handleChange); return () => { mediaQuery.removeEventListener("change", handleChange); }; }, [theme]); const handleTheme = () => { setTheme(theme === "light" ? "dark" : "light"); }; return ( <>
handleTheme()} className="theme">
) }