first commit
Made-with: Cursor
This commit is contained in:
37
frontend/src/contexts/ToastContext.tsx
Normal file
37
frontend/src/contexts/ToastContext.tsx
Normal file
@@ -0,0 +1,37 @@
|
||||
import { createContext, useContext, useState, useCallback, type ReactNode } from "react";
|
||||
import { Toast } from "../components/Toast";
|
||||
|
||||
interface ToastContextValue {
|
||||
showToast: (message: string) => void;
|
||||
}
|
||||
|
||||
const ToastContext = createContext<ToastContextValue | null>(null);
|
||||
|
||||
export function useToast(): ToastContextValue {
|
||||
const ctx = useContext(ToastContext);
|
||||
if (!ctx) throw new Error("useToast must be used within ToastProvider");
|
||||
return ctx;
|
||||
}
|
||||
|
||||
interface ToastProviderProps {
|
||||
children: ReactNode;
|
||||
}
|
||||
|
||||
export function ToastProvider({ children }: ToastProviderProps) {
|
||||
const [message, setMessage] = useState("");
|
||||
const [visible, setVisible] = useState(false);
|
||||
|
||||
const showToast = useCallback((msg: string) => {
|
||||
setMessage(msg);
|
||||
setVisible(true);
|
||||
}, []);
|
||||
|
||||
const onDismiss = useCallback(() => setVisible(false), []);
|
||||
|
||||
return (
|
||||
<ToastContext.Provider value={{ showToast }}>
|
||||
{children}
|
||||
<Toast message={message} visible={visible} onDismiss={onDismiss} />
|
||||
</ToastContext.Provider>
|
||||
);
|
||||
}
|
||||
Reference in New Issue
Block a user