fix: menu should remain open when showing trash alert

This commit is contained in:
Antonella Sgarlatta
2021-05-07 15:41:00 -03:00
parent 8a9dc14d81
commit 9906cd2a20
4 changed files with 28 additions and 9 deletions

View File

@@ -10,7 +10,7 @@ type Props = {
const NotesContextMenu = observer(({ appState }: Props) => {
const contextMenuRef = useRef<HTMLDivElement>();
const [closeOnBlur, setLockCloseOnBlur] = useCloseOnBlur(
const [closeOnBlur, blurLocked, setLockCloseOnBlur] = useCloseOnBlur(
contextMenuRef,
(open: boolean) => appState.notes.setContextMenuOpen(open)
);
@@ -37,6 +37,7 @@ const NotesContextMenu = observer(({ appState }: Props) => {
<NotesOptions
appState={appState}
closeOnBlur={closeOnBlur}
blurLocked={blurLocked}
setLockCloseOnBlur={setLockCloseOnBlur}
/>
</div>

View File

@@ -2,7 +2,7 @@ import { AppState } from '@/ui_models/app_state';
import { Icon, IconType } from './Icon';
import { Switch } from './Switch';
import { observer } from 'mobx-react-lite';
import { useRef, useState } from 'preact/hooks';
import { useEffect, useRef, useState } from 'preact/hooks';
import {
Disclosure,
DisclosureButton,
@@ -12,16 +12,18 @@ import {
type Props = {
appState: AppState;
closeOnBlur: (event: { relatedTarget: EventTarget | null }) => void;
blurLocked: boolean;
setLockCloseOnBlur: (lock: boolean) => void;
};
export const NotesOptions = observer(
({ appState, closeOnBlur, setLockCloseOnBlur }: Props) => {
({ appState, closeOnBlur, blurLocked, setLockCloseOnBlur }: Props) => {
const [tagsMenuOpen, setTagsMenuOpen] = useState(false);
const [tagsMenuPosition, setTagsMenuPosition] = useState({
top: 0,
right: 0,
});
const [shouldTrashNotes, setShouldTrashNotes] = useState(false);
const notes = Object.values(appState.notes.selectedNotes);
const hidePreviews = !notes.some((note) => !note.hidePreview);
@@ -39,6 +41,23 @@ export const NotesOptions = observer(
'cursor-pointer hover:bg-contrast color-text bg-transparent px-3 ' +
'text-left';
useEffect(() => {
const openTrashAlert = async () => {
if (shouldTrashNotes && blurLocked) {
await appState.notes.setTrashSelectedNotes(!trashed, trashButtonRef);
setShouldTrashNotes(false);
setLockCloseOnBlur(false);
}
};
openTrashAlert();
}, [
appState.notes,
blurLocked,
setLockCloseOnBlur,
shouldTrashNotes,
trashed,
]);
return (
<>
<Switch
@@ -167,12 +186,8 @@ export const NotesOptions = observer(
onBlur={closeOnBlur}
className={`${buttonClass} py-1.5`}
onClick={async () => {
setShouldTrashNotes(true);
setLockCloseOnBlur(true);
await appState.notes.setTrashSelectedNotes(
!trashed,
trashButtonRef
);
setLockCloseOnBlur(false);
}}
>
<Icon type={IconType.Trash} className={iconClass} />

View File

@@ -23,7 +23,7 @@ export const NotesOptionsPanel = observer(({ appState }: Props) => {
});
const buttonRef = useRef<HTMLButtonElement>();
const panelRef = useRef<HTMLDivElement>();
const [closeOnBlur, setLockCloseOnBlur] = useCloseOnBlur(panelRef, setOpen);
const [closeOnBlur, blurLocked, setLockCloseOnBlur] = useCloseOnBlur(panelRef, setOpen);
return (
<Disclosure
@@ -71,6 +71,7 @@ export const NotesOptionsPanel = observer(({ appState }: Props) => {
<NotesOptions
appState={appState}
closeOnBlur={closeOnBlur}
blurLocked={blurLocked}
setLockCloseOnBlur={setLockCloseOnBlur}
/>
)}

View File

@@ -11,6 +11,7 @@ export function useCloseOnBlur(
setOpen: (open: boolean) => void
): [
(event: { relatedTarget: EventTarget | null }) => void,
boolean,
StateUpdater<boolean>
] {
const [locked, setLocked] = useState(false);
@@ -26,6 +27,7 @@ export function useCloseOnBlur(
},
[container, setOpen, locked]
),
locked,
setLocked,
];
}