import React from 'react' import {useDialogStateContext} from '#/state/dialogs' import { DialogContextProps, DialogControlRefProps, DialogOuterProps, } from '#/components/Dialog/types' export const Context = React.createContext({ close: () => {}, }) export function useDialogContext() { return React.useContext(Context) } export function useDialogControl(): DialogOuterProps['control'] { const id = React.useId() const control = React.useRef({ open: () => {}, close: () => {}, }) const {activeDialogs} = useDialogStateContext() React.useEffect(() => { activeDialogs.current.set(id, control) return () => { // eslint-disable-next-line react-hooks/exhaustive-deps activeDialogs.current.delete(id) } }, [id, activeDialogs]) return { id, ref: control, open: () => { control.current.open() }, close: cb => { control.current.close(cb) }, } }