mirror of
https://github.com/usememos/memos.git
synced 2025-10-25 05:46:03 +08:00
32 lines
816 B
TypeScript
32 lines
816 B
TypeScript
import * as TooltipUI from "@radix-ui/react-tooltip";
|
|
|
|
type Side = "top" | "right" | "bottom" | "left";
|
|
|
|
interface Props {
|
|
title: string;
|
|
side: Side;
|
|
children: React.ReactNode;
|
|
}
|
|
|
|
const Tooltip = (props: Props) => {
|
|
const { title, side, children } = props;
|
|
|
|
return (
|
|
<TooltipUI.Provider delayDuration={0} skipDelayDuration={0}>
|
|
<TooltipUI.Root>
|
|
<TooltipUI.Trigger asChild>{children}</TooltipUI.Trigger>
|
|
<TooltipUI.Portal>
|
|
<TooltipUI.Content
|
|
className="bg-zinc-800 text-gray-300 dark:bg-black shadow text-sm p-1 rounded-md z-[99999]"
|
|
side={side}
|
|
sideOffset={6}
|
|
>
|
|
{title}
|
|
</TooltipUI.Content>
|
|
</TooltipUI.Portal>
|
|
</TooltipUI.Root>
|
|
</TooltipUI.Provider>
|
|
);
|
|
};
|
|
|
|
export default Tooltip;
|