Path: blob/master/gate-controller/components/ui/sonner.tsx
1082 views
"use client"12import {3CircleCheckIcon,4InfoIcon,5Loader2Icon,6OctagonXIcon,7TriangleAlertIcon,8} from "lucide-react"9import { useTheme } from "next-themes"10import { Toaster as Sonner, type ToasterProps } from "sonner"1112const Toaster = ({ ...props }: ToasterProps) => {13const { theme = "system" } = useTheme()1415return (16<Sonner17theme={theme as ToasterProps["theme"]}18className="toaster group"19icons={{20success: <CircleCheckIcon className="size-4" />,21info: <InfoIcon className="size-4" />,22warning: <TriangleAlertIcon className="size-4" />,23error: <OctagonXIcon className="size-4" />,24loading: <Loader2Icon className="size-4 animate-spin" />,25}}26style={27{28"--normal-bg": "var(--popover)",29"--normal-text": "var(--popover-foreground)",30"--normal-border": "var(--border)",31"--border-radius": "var(--radius)",32} as React.CSSProperties33}34{...props}35/>36)37}3839export { Toaster }404142