2022-11-24 18:12:11 +00:00
|
|
|
import React from "react";
|
2022-11-19 14:21:26 +00:00
|
|
|
|
2022-11-24 18:12:11 +00:00
|
|
|
type Props = {
|
|
|
|
children: React.ReactNode;
|
|
|
|
content: React.ReactNode;
|
|
|
|
position?: "top" | "bottom" | "left" | "right";
|
2022-11-19 14:21:26 +00:00
|
|
|
};
|
|
|
|
|
2022-11-24 18:12:11 +00:00
|
|
|
const Tooltip: React.FC<Props> = ({ children, content, position = "top" }) => {
|
2022-11-19 14:21:26 +00:00
|
|
|
return (
|
2022-11-24 18:12:11 +00:00
|
|
|
<div className="relative group">
|
|
|
|
<div
|
|
|
|
className={`fixed pointer-events-none transition-opacity opacity-0 group-hover:opacity-100 bg-black text-white px-3 py-1 rounded ${
|
|
|
|
position === "right"
|
|
|
|
? "left-14"
|
|
|
|
: position === "left"
|
|
|
|
? "right-14"
|
|
|
|
: position === "top"
|
|
|
|
? "bottom-14"
|
|
|
|
: "top-14"
|
|
|
|
}`}
|
|
|
|
>
|
|
|
|
<p className="truncate text-sx">{content}</p>
|
2022-11-19 14:21:26 +00:00
|
|
|
<span
|
2022-11-24 18:12:11 +00:00
|
|
|
className={`absolute w-2 h-2 bg-black ${
|
|
|
|
position === "top"
|
|
|
|
? "top-full left-1/2 transform -translate-y-1/2 -translate-x-1/2 rotate-45"
|
|
|
|
: position === "bottom"
|
|
|
|
? "bottom-full left-1/2 transform translate-y-1/2 -translate-x-1/2 rotate-45"
|
|
|
|
: position === "left"
|
|
|
|
? "left-full top-1/2 transform translate-x-1/2 -translate-y-1/2 rotate-45"
|
|
|
|
: "right-full top-1/2 transform translate-x-1/2 -translate-y-1/2 rotate-45"
|
|
|
|
}`}
|
|
|
|
></span>
|
2022-11-19 14:21:26 +00:00
|
|
|
</div>
|
2022-11-24 18:12:11 +00:00
|
|
|
{children}
|
|
|
|
</div>
|
2022-11-19 14:21:26 +00:00
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default Tooltip;
|