The react component to use as the trigger for the tooltip
Tooltip
A tooltip is a brief, informative message that appears when a user interacts with an element. Tooltips are usually initiated in one of two ways: through a mouse-hover gesture or through a keyboard-hover gesture.
The Tooltip
component follows the
WAI-ARIA Tooltip Pattern.
Import#
import { Tooltip } from "@chakra-ui/react"
Usage#
If the children
of Tooltip is a string
, we wrap with in a span
with
tabIndex
set to 0
, to ensure it meets the accessibility requirements.
Note 🚨: If the
Tooltip
is wrapping a functional component, ensure that the functional component accepts aref
usingforwardRef
.
With an icon#
Note 🚨: If you're wrapping an icon from
react-icons
, you need to also wrap the icon in aspan
element asreact-icons
icons do not useforwardRef
.
With arrow#
Tooltip with focusable content#
If the children of the tooltip is a focusable element, the tooltip will show when you focus or hover on the element, and will hide when you blur or move cursor out of the element.
Disabled Tooltip#
Placement#
Using the placement
prop you can adjust where your tooltip will be displayed.
More examples#
Props#
children
required
children
required
ReactNode
aria-label
aria-label
The accessible, human friendly label to use for
screen readers.
If passed, tooltip will show the content label
but expose only `aria-label` to assistive technologies
string
arrowPadding
arrowPadding
The padding required to prevent the arrow from reaching the very edge of the popper.
number
8
arrowShadowColor
arrowShadowColor
string
arrowSize
arrowSize
number
closeDelay
closeDelay
Delay (in ms) before hiding the tooltip
number
0ms
closeOnClick
closeOnClick
If true
, the tooltip will hide on click
boolean
closeOnMouseDown
closeOnMouseDown
If true
, the tooltip will hide while the mouse
is down
boolean
colorScheme
colorScheme
Color Schemes for Tooltip
are not implemented in the default theme. You can extend the theme to implement them.
"whiteAlpha" | "blackAlpha" | "gray" | "red" | "orange" | "yellow" | "green" | "teal" | "blue" | "cyan" | "purple" | "pink" | "linkedin" | "facebook" | "messenger" | "whatsapp" | "twitter" | "telegram"
defaultIsOpen
defaultIsOpen
If true
, the tooltip will be initially shown
boolean
gutter
gutter
The distance or margin between the reference and popper.
It is used internally to create an offset
modifier.
NB: If you define offset
prop, it'll override the gutter.
number
8
hasArrow
hasArrow
If true
, the tooltip will show an arrow tip
boolean
isDisabled
isDisabled
boolean
isOpen
isOpen
If true
, the tooltip will be shown (in controlled mode)
boolean
label
label
The label of the tooltip
ReactNode
modifiers
modifiers
Array of popper.js modifiers. Check the docs to see the list of possible modifiers you can pass. @see Docs https://popper.js.org/docs/v2/modifiers/
Partial<Modifier<string, any>>[]
offset
offset
The main and cross-axis offset to displace popper element from its reference element.
[crossAxis: number, mainAxis: number]
onClose
onClose
Callback to run when the tooltip hides
(() => void)
onOpen
onOpen
Callback to run when the tooltip shows
(() => void)
openDelay
openDelay
Delay (in ms) before showing the tooltip
number
0ms
placement
placement
The Popper.js placement of the tooltip
"bottom" | "left" | "right" | "top" | "auto" | "auto-start" | "auto-end" | "top-start" | "top-end" | "bottom-start" | "bottom-end" | "right-start" | "right-end" | "left-start" | "left-end"
portalProps
portalProps
Props to be forwarded to the portal component
Pick<PortalProps, "appendToParentPortal" | "containerRef">
shouldWrapChildren
shouldWrapChildren
If true
, the tooltip will wrap its children
in a `<span/>` with `tabIndex=0`
boolean
size
size
Sizes for Tooltip
are not implemented in the default theme. You can extend the theme to implement them.
string
variant
variant
Variants for Tooltip
are not implemented in the default theme. You can extend the theme to implement them.
string