From 7c6ea86797a8d9144a2178220b19b58fff35a91d Mon Sep 17 00:00:00 2001 From: ANTONA09 Date: Tue, 21 May 2024 18:06:57 +0530 Subject: [PATCH] fix: #6644, Galleria: Galleria image in fullscreen mode not closing on escape button click --- components/lib/galleria/Galleria.js | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/components/lib/galleria/Galleria.js b/components/lib/galleria/Galleria.js index ddaeb59847..f59be5ce63 100644 --- a/components/lib/galleria/Galleria.js +++ b/components/lib/galleria/Galleria.js @@ -2,7 +2,7 @@ import * as React from 'react'; import PrimeReact, { PrimeReactContext, localeOption } from '../api/Api'; import { useHandleStyle } from '../componentbase/ComponentBase'; import { CSSTransition } from '../csstransition/CSSTransition'; -import { useInterval, useMergeProps, useUnmountEffect } from '../hooks/Hooks'; +import { useInterval, useMergeProps, useUnmountEffect, ESC_KEY_HANDLING_PRIORITIES, useGlobalOnEscapeKey } from '../hooks/Hooks'; import { TimesIcon } from '../icons/times'; import { Portal } from '../portal/Portal'; import { Ripple } from '../ripple/Ripple'; @@ -40,6 +40,14 @@ export const Galleria = React.memo( useHandleStyle(GalleriaBase.css.styles, isUnstyled, { name: 'galleria' }); + useGlobalOnEscapeKey({ + callback: () => { + hide(); + }, + when: props.closeOnEscape && props.fullScreen, + priority: [ESC_KEY_HANDLING_PRIORITIES.IMAGE, 0] + }); + useInterval( () => { onActiveItemChange({ index: props.circular && props.value.length - 1 === activeItemIndex ? 0 : activeItemIndex + 1 });