Use a tooltip component to add context to elements on the page.
Tooltips should be our last resort for conveying information, because they are hidden by default and usually provide zero or very little visual indicator of its existence.
Before adding a tooltip, consider the following: Is the information essential and necessary? Can the UI be made clearer? Can the information be shown on the page by default?
If you are unsure which alternative to use, consult a designer or the Design Systems team at Appfire for advice.
Tooltips are popups that display information related to an element when the element receives keyboard focus, or when somone mouse hovers over the element. Fuegokit React provides an ecosystem-agnostic, accessible tooltip that can be styled as needed.
- Labeling support for screen readers and exposed as a tooltip to assistive technology via ARIA
- Native tooltip focus behavior
- Closes when the trigger is activated or when pressing escape
- Supports custom timings
- Handles collisions
- Matches native tooltip behavior with delay on hover of first tooltip and no delay on subsequent tooltips
Import
import {Tooltip} from '@fuegokit/react'
Usage
Accessibility
Tooltips are rarely the appropriate choice.
Misusing a tooltip can result in many accessibility issues.
Always consider not using a tooltip for an improved user experience.
Here are a few quick alternatives to tooltips to consider:
- Persist the content in a way that it's always available on the page or in the interface.
- Avoid duplicating content. If the tooltip duplicates content that is already available, remove it.
- Use a modal instead. Modals are accessible for mobile users, and they allow structured content to be presented accessibly that might otherwise be crammed into a tooltip.
- Use a disclosure that allows both mobile and desktop device users the ability to show or hide content.
If you must use a tooltip, ensure that:
- The tooltip is discoverable and readable with a mouse, touchscreens, eye-tracking devices, and other pointer devices, keyboard, screen readers, zoom software, and any other assistive technology.
- The tooltip provides relevant information that may be helpful to learn the UI, but is not required to operate it.
- The tooltip doesn't block a user from performing any other task on the screen.
- The tooltip is not accidentally dismissed by magnification software.
Anatomy
Tooltip
Keyboard accessibility
Key | Description |
---|---|
Tab | Opens/closes the tooltip without delay. |
Space | If open, closes the tooltip without delay. |
Enter | If open, closes the tooltip without delay. |
Escape | If open, closes the tooltip without delay. |