Add generic Tooltip component
This commit is contained in:
parent
0613f75c7f
commit
2172647282
2 changed files with 44 additions and 0 deletions
5
components/Tooltip/index.scss
Normal file
5
components/Tooltip/index.scss
Normal file
|
|
@ -0,0 +1,5 @@
|
||||||
|
.Tooltip {
|
||||||
|
background: var(--dialog-bg);
|
||||||
|
border-radius: $card-corner;
|
||||||
|
padding: $unit * 1.5;
|
||||||
|
}
|
||||||
39
components/Tooltip/index.tsx
Normal file
39
components/Tooltip/index.tsx
Normal file
|
|
@ -0,0 +1,39 @@
|
||||||
|
import React, { PropsWithChildren } from 'react'
|
||||||
|
import classNames from 'classnames'
|
||||||
|
|
||||||
|
import * as TooltipPrimitive from '@radix-ui/react-tooltip'
|
||||||
|
|
||||||
|
import './index.scss'
|
||||||
|
interface Props extends TooltipPrimitive.TooltipContentProps {
|
||||||
|
content: React.ReactNode
|
||||||
|
open?: boolean
|
||||||
|
onOpenChange?: (open: boolean) => void
|
||||||
|
}
|
||||||
|
|
||||||
|
export default function Tooltip({
|
||||||
|
children,
|
||||||
|
content,
|
||||||
|
open,
|
||||||
|
onOpenChange,
|
||||||
|
...props
|
||||||
|
}: PropsWithChildren<Props>) {
|
||||||
|
const classes = classNames(props.className, {
|
||||||
|
Tooltip: true,
|
||||||
|
})
|
||||||
|
|
||||||
|
return (
|
||||||
|
<TooltipPrimitive.Root open={open} onOpenChange={onOpenChange}>
|
||||||
|
<TooltipPrimitive.Trigger asChild>{children}</TooltipPrimitive.Trigger>
|
||||||
|
<TooltipPrimitive.Content
|
||||||
|
side="top"
|
||||||
|
align="center"
|
||||||
|
className={classes}
|
||||||
|
sideOffset={4}
|
||||||
|
{...props}
|
||||||
|
>
|
||||||
|
{content}
|
||||||
|
{/* <TooltipPrimitive.Arrow width={11} height={5} /> */}
|
||||||
|
</TooltipPrimitive.Content>
|
||||||
|
</TooltipPrimitive.Root>
|
||||||
|
)
|
||||||
|
}
|
||||||
Loading…
Reference in a new issue