From 78bd97ec514ad213540b3c72153945faa902e78e Mon Sep 17 00:00:00 2001 From: Ivan <8611739+IRBorisov@users.noreply.github.com> Date: Wed, 2 Apr 2025 17:44:37 +0300 Subject: [PATCH] B: Prevent default behavior when ESC is intercepted --- rsconcept/frontend/src/hooks/use-escape-key.ts | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/rsconcept/frontend/src/hooks/use-escape-key.ts b/rsconcept/frontend/src/hooks/use-escape-key.ts index d86f525b..f8fbea0a 100644 --- a/rsconcept/frontend/src/hooks/use-escape-key.ts +++ b/rsconcept/frontend/src/hooks/use-escape-key.ts @@ -6,6 +6,8 @@ export function useEscapeKey(handleClose: () => void, isEnabled: boolean = true) const handleEscKey = useCallback( (event: KeyboardEvent) => { if (event.key === 'Escape') { + event.preventDefault(); + event.stopPropagation(); handleClose(); } }, @@ -14,9 +16,9 @@ export function useEscapeKey(handleClose: () => void, isEnabled: boolean = true) useEffect(() => { if (isEnabled) { - document.addEventListener('keyup', handleEscKey, false); + document.addEventListener('keydown', handleEscKey, false); return () => { - document.removeEventListener('keyup', handleEscKey, false); + document.removeEventListener('keydown', handleEscKey, false); }; } }, [handleEscKey, isEnabled]);