Files
SatsFaucet/frontend/src/contexts/ToastContext.tsx
Michaël 3734365463 first commit
Made-with: Cursor
2026-02-26 18:33:00 -03:00

38 lines
1.0 KiB
TypeScript

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>
);
}