From 9ee7f2150a3078bd46c202c5df829e73772b5a43 Mon Sep 17 00:00:00 2001 From: ben Date: Thu, 18 Apr 2024 13:46:51 +0100 Subject: [PATCH] fix(tooltip): dynamically set domelement --- .../molecules/OakTooltip/OakTooltip.tsx | 67 +++++++++++-------- 1 file changed, 39 insertions(+), 28 deletions(-) diff --git a/src/components/molecules/OakTooltip/OakTooltip.tsx b/src/components/molecules/OakTooltip/OakTooltip.tsx index 802a4f41..334cd4ff 100644 --- a/src/components/molecules/OakTooltip/OakTooltip.tsx +++ b/src/components/molecules/OakTooltip/OakTooltip.tsx @@ -42,11 +42,14 @@ export const OakTooltip = ({ children, tooltip, isOpen, - domContainer = document.body, + domContainer, ...props }: OakTooltipProps) => { const [targetElement, setTargetElement] = useState(null); const [isIntersecting, setIsIntersecting] = useState(true); + const [domContainerState, setDomContainerState] = useState< + Element | undefined + >(domContainer); const isVisible = isOpen && isIntersecting; /** @@ -123,39 +126,47 @@ export const OakTooltip = ({ }; }, [targetElement]); + useLayoutEffect(() => { + if (domContainerState) { + return; + } + setDomContainerState(document.body); + }, [domContainerState]); + return ( <> - {createPortal( - isVisible && ( - + {domContainerState && + createPortal( + isVisible && ( - - {tooltip} - + + {tooltip} + + - - ), - domContainer, - )} + ), + domContainerState, + )}
{ setTargetElement(domElement?.firstElementChild ?? null);