-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathThemeToggle.tsx
26 lines (24 loc) · 916 Bytes
/
ThemeToggle.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
import { MoonIcon, SunIcon } from "lucide-react";
import { Button } from "./ui/button";
export default function ThemeToggle() {
function toggleTheme() {
if (
document.documentElement.classList.contains("dark") ||
(!("theme" in localStorage) &&
window.matchMedia("(prefers-color-scheme: dark)").matches)
) {
document.documentElement.classList.remove("dark");
localStorage.theme = "light";
} else {
document.documentElement.classList.add("dark");
localStorage.theme = "dark";
}
}
return (
<Button variant="outline" size="icon" type="button" onClick={toggleTheme}>
<SunIcon className="size-4 rotate-0 scale-100 transition-all dark:-rotate-90 dark:scale-0" />
<MoonIcon className="absolute size-4 rotate-90 scale-0 transition-all dark:rotate-0 dark:scale-100" />
<span className="sr-only">Toggle theme</span>
</Button>
);
}