From 375d83e98832ef0fece8f040378599904d289bc5 Mon Sep 17 00:00:00 2001 From: Cody Olsen <81981+stipsan@users.noreply.github.com> Date: Thu, 18 Jul 2024 11:45:42 +0200 Subject: [PATCH] fix(dialog): refactor to `useClickOutsideEvent` (#1396) --- src/core/components/dialog/dialog.tsx | 32 ++++++++++++--------------- 1 file changed, 14 insertions(+), 18 deletions(-) diff --git a/src/core/components/dialog/dialog.tsx b/src/core/components/dialog/dialog.tsx index b60fe70f7..e0218f169 100644 --- a/src/core/components/dialog/dialog.tsx +++ b/src/core/components/dialog/dialog.tsx @@ -1,6 +1,6 @@ import {CloseIcon} from '@sanity/icons' import {ThemeColorSchemeKey} from '@sanity/ui/theme' -import {forwardRef, useCallback, useEffect, useImperativeHandle, useRef, useState} from 'react' +import {forwardRef, useCallback, useEffect, useImperativeHandle, useRef} from 'react' import {styled} from 'styled-components' import { containsOrEqualsElement, @@ -8,7 +8,12 @@ import { focusLastDescendant, isHTMLElement, } from '../../helpers' -import {useArrayProp, useClickOutside, useGlobalKeyDown, usePrefersReducedMotion} from '../../hooks' +import { + useArrayProp, + useClickOutsideEvent, + useGlobalKeyDown, + usePrefersReducedMotion, +} from '../../hooks' import {Box, Button, Card, Container, Flex, Text} from '../../primitives' import {ResponsivePaddingProps, ResponsiveWidthProps} from '../../primitives/types' import {responsivePaddingStyle, ResponsivePaddingStyleProps} from '../../styles/internal' @@ -170,7 +175,6 @@ const DialogCard = forwardRef(function DialogCard( const shadow = useArrayProp(shadowProp) const width = useArrayProp(widthProp) const ref = useRef(null) - const [rootElement, setRootElement] = useState(null) const contentRef = useRef(null) const layer = useLayer() const {isTopLayer} = layer @@ -215,11 +219,10 @@ const DialogCard = forwardRef(function DialogCard( ), ) - useClickOutside( - useCallback( - (event) => { - if (!isTopLayer || !onClickOutside) return - + useClickOutsideEvent( + isTopLayer && + onClickOutside && + ((event) => { const target = event.target as Node | null if (target && !isTargetWithinScope(boundaryElement, portalElement, target)) { @@ -228,20 +231,13 @@ const DialogCard = forwardRef(function DialogCard( } onClickOutside() - }, - [boundaryElement, isTopLayer, onClickOutside, portalElement], - ), - [rootElement], + }), + () => [ref.current], ) - const setRef = useCallback((el: HTMLDivElement | null) => { - setRootElement(el) - ref.current = el - }, []) - return ( - + {showHeader && (