nav-next/components/ui/use-toast.tsx
mei 6440d171b9 feat: 添加新的工具类别和工具项
- 新增了三个新的工具项:仓库管理器、仓库管理器(特供版)和检查单
- 添加 README.md
2025-01-27 08:34:05 +08:00

39 lines
944 B
TypeScript

import { useState } from 'react';
import type {
ToastActionElement,
ToastProps,
ToasterToast,
} from '@/components/ui/toast';
const useToast = () => {
const [toasts, setToasts] = useState<ToasterToast[]>([]);
const showToast = (props: ToastProps) => {
const id = Math.random().toString(36).substr(2, 9);
const newToast: ToasterToast = {
...props,
id,
onOpenChange: (open) => {
if (!open) dismiss(id);
},
};
setToasts((prevToasts) => [...prevToasts, newToast]);
};
const removeToast = (id: string) => {
setToasts((prevToasts) => prevToasts.filter((toast) => toast.id !== id));
};
const dismiss = (id: string) => {
setToasts((prevToasts) =>
prevToasts.map((toast) =>
toast.id === id ? { ...toast, onOpenChange: undefined } : toast
)
);
};
return { toasts, showToast, removeToast };
};
export { useToast, ToastProps, ToastActionElement };