2024-03-19 01:41:21 +00:00
|
|
|
import {
|
|
|
|
Toast,
|
2024-03-19 15:38:42 +00:00
|
|
|
ToastAction,
|
2024-03-19 01:41:21 +00:00
|
|
|
ToastClose,
|
|
|
|
ToastDescription,
|
|
|
|
ToastProvider,
|
|
|
|
ToastTitle,
|
|
|
|
ToastViewport,
|
2024-03-25 07:34:22 +00:00
|
|
|
} from "~/components/ui/toast";
|
|
|
|
import { useToast } from "~/components/ui/use-toast";
|
2024-03-19 01:41:21 +00:00
|
|
|
|
|
|
|
export function Toaster() {
|
2024-03-25 07:34:22 +00:00
|
|
|
const { toasts } = useToast();
|
2024-03-19 01:41:21 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<ToastProvider>
|
2024-03-25 07:34:22 +00:00
|
|
|
{toasts.map(
|
|
|
|
({ id, title, description, action, cancelMutation, ...props }) => {
|
|
|
|
const undoButton = cancelMutation ? (
|
|
|
|
<ToastAction altText="Undo" onClick={cancelMutation}>
|
|
|
|
Undo
|
|
|
|
</ToastAction>
|
|
|
|
) : undefined;
|
|
|
|
return (
|
|
|
|
<Toast key={id} {...props} variant={"default"}>
|
|
|
|
<div className="grid gap-1">
|
|
|
|
{title && <ToastTitle>{title}</ToastTitle>}
|
|
|
|
{description && (
|
|
|
|
<ToastDescription>{description}</ToastDescription>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
{action}
|
|
|
|
{undoButton}
|
|
|
|
<ToastClose />
|
|
|
|
</Toast>
|
|
|
|
);
|
|
|
|
},
|
|
|
|
)}
|
2024-03-19 01:41:21 +00:00
|
|
|
<ToastViewport />
|
|
|
|
</ToastProvider>
|
2024-03-25 07:34:22 +00:00
|
|
|
);
|
2024-03-19 01:41:21 +00:00
|
|
|
}
|