feat: add dark mode toggle functionality using next-themes.

This commit is contained in:
2025-12-23 02:38:11 +01:00
parent 6c68d922dc
commit 4e410433ff
3 changed files with 50 additions and 8 deletions

View File

@@ -4,6 +4,7 @@ import { Outlet } from "react-router-dom"
import { Button } from "@/components/ui/button";
import { LogOut } from "lucide-react";
import { useLogout, useUser } from "@/hooks/use-auth";
import { ModeToggle } from "@/components/mode-toggle";
export default function Layout() {
const { mutate: logout } = useLogout();
@@ -23,6 +24,7 @@ export default function Layout() {
<div className="text-sm text-muted-foreground hidden sm:block">
{user?.email}
</div>
<ModeToggle />
<Button variant="ghost" size="icon" onClick={() => logout()} title="Logout">
<LogOut className="h-4 w-4" />
</Button>

View File

@@ -0,0 +1,37 @@
import { Moon, Sun } from "lucide-react"
import { useTheme } from "next-themes"
import { Button } from "@/components/ui/button"
import {
DropdownMenu,
DropdownMenuContent,
DropdownMenuItem,
DropdownMenuTrigger,
} from "@/components/ui/dropdown-menu"
export function ModeToggle() {
const { setTheme } = useTheme()
return (
<DropdownMenu>
<DropdownMenuTrigger asChild>
<Button variant="outline" size="icon">
<Sun className="h-[1.2rem] w-[1.2rem] rotate-0 scale-100 transition-all dark:-rotate-90 dark:scale-0" />
<Moon className="absolute h-[1.2rem] w-[1.2rem] rotate-90 scale-0 transition-all dark:rotate-0 dark:scale-100" />
<span className="sr-only">Toggle theme</span>
</Button>
</DropdownMenuTrigger>
<DropdownMenuContent align="end">
<DropdownMenuItem onClick={() => setTheme("light")}>
Light
</DropdownMenuItem>
<DropdownMenuItem onClick={() => setTheme("dark")}>
Dark
</DropdownMenuItem>
<DropdownMenuItem onClick={() => setTheme("system")}>
System
</DropdownMenuItem>
</DropdownMenuContent>
</DropdownMenu>
)
}

View File

@@ -1,6 +1,7 @@
import { QueryClient, QueryClientProvider } from "@tanstack/react-query";
import { BrowserRouter } from "react-router-dom";
import { type ReactNode } from "react";
import { ThemeProvider } from "next-themes";
const queryClient = new QueryClient({
defaultOptions: {
@@ -14,7 +15,9 @@ const queryClient = new QueryClient({
export function Providers({ children }: { children: ReactNode }) {
return (
<QueryClientProvider client={queryClient}>
<ThemeProvider attribute="class" defaultTheme="system" enableSystem>
<BrowserRouter>{children}</BrowserRouter>
</ThemeProvider>
</QueryClientProvider>
);
}