mirror of
https://github.com/supabase/supabase.git
synced 2026-06-20 21:16:00 +08:00
29 lines
885 B
TypeScript
29 lines
885 B
TypeScript
import { ComponentProps, ComponentPropsWithoutRef, ElementRef, ReactNode, forwardRef } from 'react'
|
|
import { Button, Tooltip, TooltipContent, TooltipTrigger, cn } from 'ui'
|
|
|
|
export const ButtonTooltip = forwardRef<
|
|
ElementRef<typeof Button>,
|
|
ComponentPropsWithoutRef<typeof Button> & {
|
|
tooltip: {
|
|
content: ComponentProps<typeof TooltipContent> & {
|
|
text?: string | ReactNode
|
|
}
|
|
}
|
|
}
|
|
>(({ ...props }, ref) => {
|
|
return (
|
|
<Tooltip>
|
|
<TooltipTrigger asChild>
|
|
<Button ref={ref} {...props} className={cn(props.className, 'pointer-events-auto')}>
|
|
{props.children}
|
|
</Button>
|
|
</TooltipTrigger>
|
|
{props.tooltip.content.text !== undefined && (
|
|
<TooltipContent {...props.tooltip.content}>{props.tooltip.content.text}</TooltipContent>
|
|
)}
|
|
</Tooltip>
|
|
)
|
|
})
|
|
|
|
ButtonTooltip.displayName = 'ButtonTooltip'
|