tooltip.tsx 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. "use client"
  2. import * as React from "react"
  3. import * as TooltipPrimitive from "@radix-ui/react-tooltip"
  4. import { cn } from "@/lib/utils"
  5. function TooltipProvider({
  6. delayDuration = 0,
  7. ...props
  8. }: React.ComponentProps<typeof TooltipPrimitive.Provider>) {
  9. return (
  10. <TooltipPrimitive.Provider
  11. data-slot="tooltip-provider"
  12. delayDuration={delayDuration}
  13. {...props}
  14. />
  15. )
  16. }
  17. function Tooltip({
  18. ...props
  19. }: React.ComponentProps<typeof TooltipPrimitive.Root>) {
  20. return (
  21. <TooltipProvider>
  22. <TooltipPrimitive.Root data-slot="tooltip" {...props} />
  23. </TooltipProvider>
  24. )
  25. }
  26. function TooltipTrigger({
  27. ...props
  28. }: React.ComponentProps<typeof TooltipPrimitive.Trigger>) {
  29. return <TooltipPrimitive.Trigger data-slot="tooltip-trigger" {...props} />
  30. }
  31. function TooltipContent({
  32. className,
  33. sideOffset = 0,
  34. children,
  35. ...props
  36. }: React.ComponentProps<typeof TooltipPrimitive.Content>) {
  37. return (
  38. <TooltipPrimitive.Portal>
  39. <TooltipPrimitive.Content
  40. data-slot="tooltip-content"
  41. sideOffset={sideOffset}
  42. className={cn(
  43. "bg-primary text-primary-foreground animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 w-fit origin-(--radix-tooltip-content-transform-origin) rounded-md px-3 py-1.5 text-xs text-balance",
  44. className
  45. )}
  46. {...props}
  47. >
  48. {children}
  49. <TooltipPrimitive.Arrow className="bg-primary fill-primary z-50 size-2.5 translate-y-[calc(-50%_-_2px)] rotate-45 rounded-[2px]" />
  50. </TooltipPrimitive.Content>
  51. </TooltipPrimitive.Portal>
  52. )
  53. }
  54. export { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider }