"use client"; import { useEffect, useState } from "react"; import type { Language } from "@/data/portfolio"; type Theme = "light" | "dark"; const STORAGE_KEY = "grace-portfolio-theme"; function applyTheme(theme: Theme) { document.documentElement.dataset.theme = theme; document.documentElement.style.colorScheme = theme; } export function ThemeToggle({ language }: { language: Language }) { const [theme, setTheme] = useState("light"); useEffect(() => { const savedTheme = window.localStorage.getItem(STORAGE_KEY); const nextTheme = savedTheme === "dark" ? "dark" : "light"; applyTheme(nextTheme); setTheme(nextTheme); }, []); const nextTheme: Theme = theme === "dark" ? "light" : "dark"; const label = language === "ar" ? theme === "dark" ? "\u062a\u0641\u0639\u064a\u0644 \u0627\u0644\u0648\u0636\u0639 \u0627\u0644\u0641\u0627\u062a\u062d" : "\u062a\u0641\u0639\u064a\u0644 \u0627\u0644\u0648\u0636\u0639 \u0627\u0644\u062f\u0627\u0643\u0646" : theme === "dark" ? "Switch to light mode" : "Switch to dark mode"; function handleToggle() { applyTheme(nextTheme); window.localStorage.setItem(STORAGE_KEY, nextTheme); setTheme(nextTheme); } return ( ); }