magicui

Форк
0
/
mode-toggle.tsx 
39 строк · 1.2 Кб
1
"use client";
2

3
import { MoonIcon, SunIcon } from "@radix-ui/react-icons";
4
import { useTheme } from "next-themes";
5

6
import { Button } from "@/components/ui/button";
7
import {
8
  DropdownMenu,
9
  DropdownMenuContent,
10
  DropdownMenuItem,
11
  DropdownMenuTrigger,
12
} from "@/components/ui/dropdown-menu";
13

14
export function ModeToggle() {
15
  const { setTheme } = useTheme();
16

17
  return (
18
    <DropdownMenu>
19
      <DropdownMenuTrigger asChild>
20
        <Button variant="ghost" size="icon" className="min-w-[2.25rem]">
21
          <SunIcon className="h-[1.2rem] w-[1.2rem] rotate-0 scale-100 transition-all dark:-rotate-90 dark:scale-0" />
22
          <MoonIcon className="absolute h-[1.2rem] w-[1.2rem] rotate-90 scale-0 transition-all dark:rotate-0 dark:scale-100" />
23
          <span className="sr-only">Toggle theme</span>
24
        </Button>
25
      </DropdownMenuTrigger>
26
      <DropdownMenuContent align="end">
27
        <DropdownMenuItem onClick={() => setTheme("light")}>
28
          Light
29
        </DropdownMenuItem>
30
        <DropdownMenuItem onClick={() => setTheme("dark")}>
31
          Dark
32
        </DropdownMenuItem>
33
        <DropdownMenuItem onClick={() => setTheme("system")}>
34
          System
35
        </DropdownMenuItem>
36
      </DropdownMenuContent>
37
    </DropdownMenu>
38
  );
39
}
40

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.