feat(ui): theme switcher show in responsive mode

This commit is contained in:
WanQuanXie 2024-05-28 10:48:58 +08:00
parent af9862c019
commit 710b72d053
2 changed files with 16 additions and 4 deletions

View file

@ -2,10 +2,16 @@
import { useTheme } from 'next-themes';
import { SunIcon, MoonIcon, MonitorIcon } from 'lucide-react';
import { useCallback, useEffect, useState } from 'react';
import { cn } from '@/lib/utils';
type Theme = 'dark' | 'light' | 'system';
export function ThemeSwitcher() {
interface ThemeSwitcherProps {
size?: number | string;
className?: string;
}
export function ThemeSwitcher({ size, className }: ThemeSwitcherProps) {
const [mounted, setMounted] = useState(false);
const { theme, setTheme } = useTheme();
@ -46,17 +52,20 @@ export function ThemeSwitcher() {
return isTheme('dark') ? (
<SunIcon
className="cursor-pointer"
className={cn('cursor-pointer', className)}
size={size}
onClick={() => handleThemeSwitch('light')}
/>
) : isTheme('light') ? (
<MoonIcon
className="cursor-pointer"
className={cn('cursor-pointer', className)}
size={size}
onClick={() => handleThemeSwitch('dark')}
/>
) : (
<MonitorIcon
className="cursor-pointer"
className={cn('cursor-pointer', className)}
size={size}
onClick={() => handleThemeSwitch('system')}
/>
);