From 1828e1c4c964d2c1bc793a89acd0149a9f08aea3 Mon Sep 17 00:00:00 2001 From: momodaadaa99 Date: Wed, 20 Nov 2024 14:32:24 +0100 Subject: [PATCH] Refactor tooltip - use floating-ui/react library instead floating-uiu/dom --- .../components/tooltip/Tooltip.component.tsx | 78 ++++++++----------- 1 file changed, 33 insertions(+), 45 deletions(-) diff --git a/src/lib/components/tooltip/Tooltip.component.tsx b/src/lib/components/tooltip/Tooltip.component.tsx index 8c9c149470..f85cccfe16 100644 --- a/src/lib/components/tooltip/Tooltip.component.tsx +++ b/src/lib/components/tooltip/Tooltip.component.tsx @@ -1,9 +1,9 @@ -import { computePosition, flip, offset, shift } from '@floating-ui/dom'; -import { CSSProperties, useEffect, useRef, useState } from 'react'; +import { CSSProperties, useState } from 'react'; import styled from 'styled-components'; import { spacing } from '../../spacing'; import { fontSize, zIndex } from '../../style/theme'; import { getThemePropSelector } from '../../utils'; +import { useFloating, useHover, useInteractions } from '@floating-ui/react'; export const TOP = 'top'; export const BOTTOM = 'bottom'; export const LEFT = 'left'; @@ -40,11 +40,9 @@ const TooltipContainer = styled.div` display: inline-block; `; const TooltipOverLayContainer = styled.div<{ - placement: Position; style?: CSSProperties; }>` display: inline-block; - opacity: 0; position: fixed; width: max-content; border: 1px solid ${getThemePropSelector('border')}; @@ -85,51 +83,41 @@ function Tooltip({ overlay, ...rest }: Props) { - const childrenRef = useRef(null); - const tooltipRef = useRef(null); - const [isTooltipVisible, setIsTooltipVisible] = useState(false); - useEffect(() => { - if (childrenRef.current && tooltipRef.current) { - computePosition(childrenRef.current, tooltipRef.current, { - placement, - middleware: [offset(5), shift(), flip()], - }).then(({ x, y }) => { - if (tooltipRef.current) { - Object.assign(tooltipRef.current.style, { - opacity: '1', - // we set opacity to 1 to make sure the tooltip is not displayed before the position is computed - left: `${x}px`, - top: `${y}px`, - }); - } - }); - } - }, [tooltipRef.current, childrenRef.current, isTooltipVisible]); + + const { refs, floatingStyles, context } = useFloating({ + open: isTooltipVisible, + onOpenChange: setIsTooltipVisible, + placement: placement, + }); + + const hover = useHover(context); + + const { getReferenceProps, getFloatingProps } = useInteractions([hover]); return ( - { - setIsTooltipVisible(true); - }} - onPointerLeave={() => { - setIsTooltipVisible(false); - }} - > - {isTooltipVisible && overlay ? ( - + + {isTooltipVisible && overlay ? ( + + + {overlay} + + + ) : null} +
- - {overlay} - - - ) : null} -
{children}
- + {children} +
+
+ ); }