import { atom } from "jotai"; import type { DialogInstance } from "../components/Dialogs"; import { jotaiStore } from "./jotai"; export const dialogsAtom = atom([]); export function toggleDialog({ id, ...props }: DialogInstance) { const dialogs = jotaiStore.get(dialogsAtom); if (dialogs.some((d) => d.id === id)) { hideDialog(id); } else { showDialog({ id, ...props }); } } export function showDialog({ id, ...props }: DialogInstance) { jotaiStore.set(dialogsAtom, (a) => [...a.filter((d) => d.id !== id), { id, ...props }]); } export function hideDialog(id: string) { jotaiStore.set(dialogsAtom, (a) => a.filter((d) => d.id !== id)); }