Files
pinkudex/components/trash/TrashPanelProvider.tsx
T
2026-05-26 22:46:00 +02:00

20 lines
764 B
TypeScript

"use client";
import { createContext, useCallback, useContext, useMemo, useState } from "react";
type Ctx = { open: boolean; toggle: () => void; close: () => void };
const C = createContext<Ctx | null>(null);
export function TrashPanelProvider({ children }: { children: React.ReactNode }) {
const [open, setOpen] = useState(false);
const toggle = useCallback(() => setOpen((o) => !o), []);
const close = useCallback(() => setOpen(false), []);
const value = useMemo<Ctx>(() => ({ open, toggle, close }), [open, toggle, close]);
return <C.Provider value={value}>{children}</C.Provider>;
}
export function useTrashPanel() {
const ctx = useContext(C);
if (!ctx) throw new Error("useTrashPanel must be used within TrashPanelProvider");
return ctx;
}