46 lines
1.3 KiB
TypeScript
46 lines
1.3 KiB
TypeScript
"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<string>(
|
|
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 (
|
|
<>
|
|
<div onClick={() => handleTheme()} className="theme">
|
|
<button type="button" className="icon-border">
|
|
{theme === "light" ?
|
|
<Image src={icons.sunIcon} alt="Light Mode" width={20} height={20} className="m-[2px]" />
|
|
:
|
|
<Image src={icons.moonIcon} alt="Dark Mode" width={20} height={20} className="m-[2px]" />
|
|
}
|
|
</button>
|
|
</div>
|
|
</>
|
|
)
|
|
} |