Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 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 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 | 1x 5x 5x 2x 2x 2x 5x | "use client";
import { useTheme } from "@/components/theme-provider";
// Components
import { Button } from "@/components/ui/button";
import { MoonIcon, SunIcon } from "@/components/ui/icons";
// Constants
import {
getThemeToggleAriaLabel,
isDarkTheme,
ThemeMode,
type Theme,
} from "@/constants/theme";
export function ThemeToggle({
className,
onToggle,
}: {
className?: string;
onToggle?: (theme: Theme) => void;
}) {
const { theme, toggleTheme } = useTheme();
const isDark = isDarkTheme(theme);
function handleToggle() {
const nextTheme = isDark ? ThemeMode.Light : ThemeMode.Dark;
toggleTheme();
onToggle?.(nextTheme);
}
return (
<Button
type="button"
variant="themeToggle"
role="switch"
aria-checked={isDark}
aria-label={getThemeToggleAriaLabel(theme)}
data-state={theme}
onClick={handleToggle}
className={className}
>
<SunIcon className="theme-toggle-icon" />
<MoonIcon className="theme-toggle-icon" />
</Button>
);
}
|