Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[EuiToolTip] Add programmatic way to close tooltips #6430

Closed
1Copenut opened this issue Nov 22, 2022 · 1 comment · Fixed by #6522
Closed

[EuiToolTip] Add programmatic way to close tooltips #6430

1Copenut opened this issue Nov 22, 2022 · 1 comment · Fixed by #6522

Comments

@1Copenut
Copy link
Contributor

We've received a request to add a programmatic way to close EUI tooltips: #5883

I've opted to close the previous issue and open this new one as a feature request. There was a fair bit of conversation about use cases including programmatic closures and removing focus from buttons with tooltips. My last comment to the original post was that the EUI team would explore a programmatic means to close tooltips, but that removing focus from elements (buttons primarily) that fire tooltip events was not recommended.

@cee-chen
Copy link
Contributor

cee-chen commented Jan 12, 2023

As noted in #6522:

As it turns out, controlling internal EuiToolTip visibility state is already currently achievable (due to it being a class component) via ref, e.g.

const toolTipRef = useRef<EuiToolTip>(null);

const hideToolTip = () => toolTipRef.current?.hideToolTip();

return (
  <EuiToolTip ref={toolTipRef} content="Tooltip content">
    <EuiButton onClick={hideToolTip}>
      Hides tooltip on click
    </EuiButton>
  </EuiToolTip>
);

After speaking to @1Copenut, we've decided against publicly documenting this functionality - this control has a lot of accessibility implications, and as a team, EUI only wants to recommend it to consumers for very very specific use cases.

The below CodeSandbox example (a button that toggles a flyout/modal/focus trap and consumers not wanting the tooltip to be re-shown on when the focus trap closes) is one such use case, primarily for when the tooltip occludes another UI element:

https://codesandbox.io/s/morning-sky-64vyoh?file=/demo.tsx:518-552

If this comes up again in future issues, and is a valid use case, we should direct consumers to the above CodeSandbox example.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants