Tooltip

Accessible, ecosystem-agnostic tooltip primitive
Access to Fuegokit npm packages, source code repositories, and some content is limited to Appfire staff. Log in with Slack to continue.

Use a tooltip component to add context to elements on the page. Tooltips are popups that display information related to an element when the element receives keyboard focus, or when somone mouse hovers over the element.

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. If you are unsure which alternative to use, consult a designer or the Design Systems team at Appfire for advice.

Import

import {Tooltip} from '@fuegokit/react'

Additional styling guides and examples are coming soon. For now, explore the examples at Storybook.

Usage

<Tooltip.Provider>
<Tooltip>
<Tooltip.Trigger asChild>
<AtlasButton>Hover or Focus me</AtlasButton>
</Tooltip.Trigger>
<Tooltip.Portal>
<StyledRadixTooltipContent sideOffset={5}>
Nicely done!
<StyledRadixTooltipArrow offset={10} />

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

Tooltip

Keyboard accessibility

KeyDescription
TabOpens/closes the tooltip without delay.
SpaceIf open, closes the tooltip without delay.
EnterIf open, closes the tooltip without delay.
EscapeIf open, closes the tooltip without delay.

Features

  • 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

See also