diff --git a/packages/compass-sidebar/src/components/connections-filter-popover.tsx b/packages/compass-sidebar/src/components/connections-filter-popover.tsx index 404c6815041..4cf936dadf3 100644 --- a/packages/compass-sidebar/src/components/connections-filter-popover.tsx +++ b/packages/compass-sidebar/src/components/connections-filter-popover.tsx @@ -1,4 +1,4 @@ -import React, { useCallback, type PropsWithChildren } from 'react'; +import React, { useCallback, useState, type PropsWithChildren } from 'react'; import { css, @@ -67,58 +67,75 @@ export default function ConnectionsFilterPopover({ // Add future filters to the boolean below const isActivated = filter.excludeInactive; + // Manually handling the tooltip state instead of supplying a trigger + // we do this to avoid the tooltip from rendering when the popover is open + // and when the IconButton regains focus as the + const [isTooltipOpen, setTooltipOpen] = useState(false); + const handleButtonMouseEnter = useCallback( + () => setTooltipOpen(true), + [setTooltipOpen] + ); + const handleButtonMouseLeave = useCallback( + () => setTooltipOpen(false), + [setTooltipOpen] + ); + return ( - ( - <> - } - > - - {isActivated && ( - - - - )} - - } - > - Filter connections - - {children} - > - )} - > - Filter Options - - - - Show only active connections - - - + <> + + Filter connections + + ( + <> + } + > + + {isActivated && ( + + + + )} + + {children} + > + )} + > + Filter Options + + + + Show only active connections + + + + > ); }