A popup that displays information related to an element when the element receives keyboard focus or the mouse hovers over it.
Installation
Install bits-ui:
Copy and paste the component source files linked at the top of this page into your project.
Usage
The Tooltip.Provider component should be placed once in your root layout, wrapping all content that will contain tooltips. This ensures that only one tooltip within the provider can be open at a time.
<script lang="ts">
import * as Tooltip from "$lib/components/ui/tooltip/index.js";
let { children } = $props();
</script>
<Tooltip.Provider>
{@render children()}
</Tooltip.Provider> Then use tooltips anywhere in your app:
<script lang="ts">
import * as Tooltip from "$lib/components/ui/tooltip/index.js";
</script>
<Tooltip.Root>
<Tooltip.Trigger>Hover</Tooltip.Trigger>
<Tooltip.Content>
<p>Add to library</p>
</Tooltip.Content>
</Tooltip.Root> Nested Providers
You can nest providers to create groups with different settings. Tooltips use the closest ancestor provider. This is useful when you want instant tooltips in specific areas:
<Tooltip.Provider delayDuration={0}>
<!-- Tooltips here will open instantly -->
</Tooltip.Provider>