A floating label for additional information.
import { Tooltip as TooltipPrimitives, TooltipRootProps } from "@ark-ui/react";
import { forwardRef } from "react";
const Tooltip = (props: TooltipRootProps) => {
return (
<TooltipPrimitives.Root
positioning={{
placement: "bottom",
gutter: 2,
}}
openDelay={600}
{...props}
/>
);
};
Tooltip.displayName = "Tooltip";
const TooltipTrigger = TooltipPrimitives.Trigger;
const TooltipContent = forwardRef<
React.ElementRef<typeof TooltipPrimitives.Content>,
React.ComponentPropsWithoutRef<typeof TooltipPrimitives.Content>
>((props, ref) => (
<TooltipPrimitives.Positioner>
<TooltipPrimitives.Content
ref={ref}
className="border-base-900 bg-base-900 text-base-0 z-50 block max-w-52 overflow-hidden rounded border px-3 py-1.5 text-sm font-medium shadow-md transition-all duration-200 data-[state=closed]:opacity-0 data-[state=open]:opacity-100"
{...props}
/>
</TooltipPrimitives.Positioner>
));
TooltipContent.displayName = "TooltipContent";
export { Tooltip, TooltipContent, TooltipTrigger };
import { Button } from "../core/button";
import { Tooltip, TooltipContent, TooltipTrigger } from "../core/tooltip";
export const TooltipExample = () => {
return (
<Tooltip>
<TooltipTrigger asChild>
<Button variant="outline">Hover to see</Button>
</TooltipTrigger>
<TooltipContent>Lorem ipsum</TooltipContent>
</Tooltip>
);
};