diff --git a/invokeai/frontend/web/src/features/gallery/components/ImageViewer/CurrentImagePreview.tsx b/invokeai/frontend/web/src/features/gallery/components/ImageViewer/CurrentImagePreview.tsx index 3f54974449..3ba3f2e372 100644 --- a/invokeai/frontend/web/src/features/gallery/components/ImageViewer/CurrentImagePreview.tsx +++ b/invokeai/frontend/web/src/features/gallery/components/ImageViewer/CurrentImagePreview.tsx @@ -24,6 +24,7 @@ const selectLastSelectedImageName = createSelector( ); const CurrentImagePreview = () => { + const { t } = useTranslation(); const shouldShowImageDetails = useAppSelector((s) => s.ui.shouldShowImageDetails); const imageName = useAppSelector(selectLastSelectedImageName); const hasDenoiseProgress = useAppSelector((s) => Boolean(s.system.denoiseProgress)); @@ -51,26 +52,18 @@ const CurrentImagePreview = () => { // Show and hide the next/prev buttons on mouse move const [shouldShowNextPrevButtons, setShouldShowNextPrevButtons] = useState(false); - const timeoutId = useRef(0); - - const { t } = useTranslation(); - - const handleMouseOver = useCallback(() => { + const onMouseMove = useCallback(() => { setShouldShowNextPrevButtons(true); window.clearTimeout(timeoutId.current); - }, []); - - const handleMouseOut = useCallback(() => { timeoutId.current = window.setTimeout(() => { setShouldShowNextPrevButtons(false); - }, 500); + }, 1000); }, []); return ( { /> )} {shouldShowImageDetails && imageDTO && ( - + )} - {!shouldShowImageDetails && imageDTO && shouldShowNextPrevButtons && ( + {shouldShowNextPrevButtons && imageDTO && ( @@ -115,11 +108,11 @@ const initial: AnimationProps['initial'] = { }; const animate: AnimationProps['animate'] = { opacity: 1, - transition: { duration: 0.1 }, + transition: { duration: 0.07 }, }; const exit: AnimationProps['exit'] = { opacity: 0, - transition: { duration: 0.1 }, + transition: { duration: 0.07 }, }; const motionStyles: CSSProperties = { position: 'absolute',