summaryrefslogtreecommitdiff
path: root/components/layout/mode-switcher.tsx
diff options
context:
space:
mode:
authordujinkim <dujin.kim@dtsolution.co.kr>2025-03-26 00:37:41 +0000
committerdujinkim <dujin.kim@dtsolution.co.kr>2025-03-26 00:37:41 +0000
commite0dfb55c5457aec489fc084c4567e791b4c65eb1 (patch)
tree68543a65d88f5afb3a0202925804103daa91bc6f /components/layout/mode-switcher.tsx
3/25 까지의 대표님 작업사항
Diffstat (limited to 'components/layout/mode-switcher.tsx')
-rw-r--r--components/layout/mode-switcher.tsx35
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>
+ )
+}