Files
dify-batch-tester/components/ui/sonner.tsx
Xin Wang 721b186051 Improve toasts and font loading
Made-with: Cursor
2026-04-18 13:29:39 +08:00

53 lines
1.3 KiB
TypeScript

"use client"
import * as React from "react"
import { Toaster as Sonner, type ToasterProps } from "sonner"
import { CircleCheckIcon, InfoIcon, TriangleAlertIcon, OctagonXIcon, Loader2Icon, XIcon } from "lucide-react"
const Toaster = ({ ...props }: ToasterProps) => {
const theme = "light"
return (
<Sonner
theme={theme as ToasterProps["theme"]}
className="toaster group toast-close-tr"
closeButton
closeButtonAriaLabel="关闭通知"
icons={{
success: (
<CircleCheckIcon className="size-4" />
),
info: (
<InfoIcon className="size-4" />
),
warning: (
<TriangleAlertIcon className="size-4" />
),
error: (
<OctagonXIcon className="size-4" />
),
loading: (
<Loader2Icon className="size-4 animate-spin" />
),
close: <XIcon className="size-3.5" aria-hidden />,
}}
style={
{
"--normal-bg": "var(--popover)",
"--normal-text": "var(--popover-foreground)",
"--normal-border": "var(--border)",
"--border-radius": "var(--radius)",
} as React.CSSProperties
}
toastOptions={{
classNames: {
toast: "cn-toast",
},
}}
{...props}
/>
)
}
export { Toaster }