Skip to content

Tooltip Primitive

A pop-up presenting relevant information pertaining to an element whenever the element gains keyboard focus or when the mouse hovers over it.

Install the component via your command line.

Terminal window
npx expo install @rn-primitives/tooltip
import * as TooltipPrimitive from '@rn-primitives/tooltip';
import { Platform, Text } from 'react-native';
function Example() {
return (
<TooltipPrimitive.Root>
<TooltipPrimitive.Trigger>
<Text>{Platform.OS === 'web' ? "Hover me" : "Press me"}</Text>
</TooltipPrimitive.Trigger>
<TooltipPrimitive.Portal>
<TooltipPrimitive.Content>
<Text>Tooltip Content</Text>
</TooltipPrimitive.Content>
</TooltipPrimitive.Portal>
</TooltipPrimitive.Root>
);
}

Extends View props

PropTypeNote
asChildboolean(optional)
onOpenChange(value: boolean) => void(optional)
delayDurationnumberWeb Only - defaults to 700 (optional)
skipDelayDurationnumberWeb Only - defaults to 300 (optional)
disableHoverableContentboolean(optional)

Extends Pressable props

PropTypeNote
asChildboolean(optional)
MethodsargsNote
openopens the tooltip
closecloses the tooltip

Extends Pressable props

PropTypeNote
asChildboolean(optional)
forceMounttrue | undefined;(optional)
closeOnPressboolean(optional)
PropTypeNote
children*React.ReactNode
forceMounttrue | undefined(optional)
hostNamestringWeb Only (optional)
containerHTMLElement | null | undefinedWeb Only (optional)

Extends View props

PropTypeNote
asChildboolean(optional)
forceMounttrue | undefined(optional)
alignOffsetnumber(optional)
insetsInsets(optional)
avoidCollisionsboolean(optional)
alignstart | center | end(optional)
sidetop | bottom | left | rightleft and right are web only (optional)
sideOffsetnumber(optional)
disablePositioningStylebooleanNative Only (optional)
collisionBoundaryElement | null | Array<Element | null>Web Only (optional)
stickypartial | alwaysWeb Only (optional)
hideWhenDetachedbooleanWeb Only (optional)
onEscapeKeyDown(ev: Event) => voidWeb Only (optional)
onPointerDownOutside(ev: Event) => voidWeb Only (optional)