import { createContext, useContext, useEffect, useId, useMemo, useRef, } from 'react' import {useDialogStateContext} from '#/state/dialogs' import { type DialogContextProps, type DialogControlRefProps, type DialogOuterProps, } from '#/components/Dialog/types' import {BottomSheetSnapPoint} from '../../../modules/bottom-sheet/src/BottomSheet.types' export const Context = createContext({ close: () => {}, isNativeDialog: false, nativeSnapPoint: BottomSheetSnapPoint.Hidden, disableDrag: false, setDisableDrag: () => {}, isWithinDialog: false, }) Context.displayName = 'DialogContext' export function useDialogContext() { return useContext(Context) } export function useDialogControl(): DialogOuterProps['control'] { const id = useId() const control = useRef({ open: () => {}, close: () => {}, }) const {activeDialogs} = useDialogStateContext() useEffect(() => { activeDialogs.current.set(id, control) return () => { // eslint-disable-next-line react-hooks/exhaustive-deps activeDialogs.current.delete(id) } }, [id, activeDialogs]) return useMemo( () => ({ id, ref: control, open: () => { control.current.open() }, close: cb => { control.current.close(cb) }, }), [id, control], ) }