2
0

tooltip.tsx 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. import * as React from "react"
  2. import * as TooltipPrimitive from "@radix-ui/react-tooltip"
  3. import { cn } from "@/client/lib/utils"
  4. function TooltipProvider({
  5. delayDuration = 0,
  6. ...props
  7. }: React.ComponentProps<typeof TooltipPrimitive.Provider>) {
  8. return (
  9. <TooltipPrimitive.Provider
  10. data-slot="tooltip-provider"
  11. delayDuration={delayDuration}
  12. {...props}
  13. />
  14. )
  15. }
  16. function Tooltip({
  17. ...props
  18. }: React.ComponentProps<typeof TooltipPrimitive.Root>) {
  19. return (
  20. <TooltipProvider>
  21. <TooltipPrimitive.Root data-slot="tooltip" {...props} />
  22. </TooltipProvider>
  23. )
  24. }
  25. function TooltipTrigger({
  26. ...props
  27. }: React.ComponentProps<typeof TooltipPrimitive.Trigger>) {
  28. return <TooltipPrimitive.Trigger data-slot="tooltip-trigger" {...props} />
  29. }
  30. function TooltipContent({
  31. className,
  32. sideOffset = 0,
  33. children,
  34. ...props
  35. }: React.ComponentProps<typeof TooltipPrimitive.Content>) {
  36. return (
  37. <TooltipPrimitive.Portal>
  38. <TooltipPrimitive.Content
  39. data-slot="tooltip-content"
  40. sideOffset={sideOffset}
  41. className={cn(
  42. "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",
  43. className
  44. )}
  45. {...props}
  46. >
  47. {children}
  48. <TooltipPrimitive.Arrow className="bg-primary fill-primary z-50 size-2.5 translate-y-[calc(-50%_-_2px)] rotate-45 rounded-[2px]" />
  49. </TooltipPrimitive.Content>
  50. </TooltipPrimitive.Portal>
  51. )
  52. }
  53. export { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider }