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