diff options
Diffstat (limited to 'components/layout/mode-switcher.tsx')
| -rw-r--r-- | components/layout/mode-switcher.tsx | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/components/layout/mode-switcher.tsx b/components/layout/mode-switcher.tsx new file mode 100644 index 00000000..d27b6a73 --- /dev/null +++ b/components/layout/mode-switcher.tsx @@ -0,0 +1,35 @@ +"use client" + +import * as React from "react" +import { MoonIcon, SunIcon } from "lucide-react" +import { useTheme } from "next-themes" + +import { META_THEME_COLORS } from "@/config/site" +import { useMetaColor } from "@/hooks/use-meta-color" +import { Button } from "@/components/ui/button" + +export function ModeSwitcher() { + const { setTheme, resolvedTheme } = useTheme() + const { setMetaColor } = useMetaColor() + + const toggleTheme = React.useCallback(() => { + setTheme(resolvedTheme === "dark" ? "light" : "dark") + setMetaColor( + resolvedTheme === "dark" + ? META_THEME_COLORS.light + : META_THEME_COLORS.dark + ) + }, [resolvedTheme, setTheme, setMetaColor]) + + return ( + <Button + variant="ghost" + className="group/toggle h-8 w-8 px-0" + onClick={toggleTheme} + > + <SunIcon className="hidden [html.dark_&]:block" /> + <MoonIcon className="hidden [html.light_&]:block" /> + <span className="sr-only">Toggle theme</span> + </Button> + ) +} |
