import { AppState } from '@/ui_models/app_state'; import { toDirective, useCloseOnBlur } from './utils'; import { observer } from 'mobx-react-lite'; import { NotesOptions } from './NotesOptions'; import { useEffect, useRef, useState } from 'preact/hooks'; type Props = { appState: AppState; }; const NotesContextMenu = observer(({ appState }: Props) => { const contextMenuRef = useRef(); const [closeOnBlur, setLockCloseOnBlur] = useCloseOnBlur( contextMenuRef, (open: boolean) => null ); const [submenuOpen, setSubmenuOpen] = useState(false); const closeOnClickOutside = (event: MouseEvent) => { if (!contextMenuRef.current?.contains(event.target as Node)) { if (submenuOpen) { setSubmenuOpen(false); } else { console.log('here'); appState.notes.setContextMenuOpen(false); } } }; useEffect(() => { document.addEventListener('click', closeOnClickOutside); return () => { document.removeEventListener('click', closeOnClickOutside); }; }); return appState.notes.contextMenuOpen ? (
) : null; }); export const NotesContextMenuDirective = toDirective(NotesContextMenu);