"use client"; import { Ref, useState } from "react"; import { usePopper } from "react-popper"; import { Popover } from "@headlessui/react"; // popper // helper import { getButtonStyling } from "@plane/ui"; type Props = { label: string; icon?: any; title: string | undefined; description: string | undefined; onClick?: () => void; disabled?: boolean; }; export const ComicBoxButton: React.FC<Props> = (props) => { const { label, icon, title, description, onClick, disabled = false } = props; const [isHovered, setIsHovered] = useState(false); const handleMouseEnter = () => { setIsHovered(true); }; const handleMouseLeave = () => { setIsHovered(false); }; const [referenceElement, setReferenceElement] = useState<HTMLButtonElement | null>(null); const [popperElement, setPopperElement] = useState<HTMLDivElement | null>(); const { styles, attributes } = usePopper(referenceElement, popperElement, { placement: "right-end", modifiers: [ { name: "offset", options: { offset: [0, 10], }, }, ], }); return ( <Popover> <Popover.Button ref={setReferenceElement} onClick={onClick} disabled={disabled}> <div className={`flex items-center gap-2.5 ${getButtonStyling("primary", "lg", disabled)}`}> {icon} <span className="leading-4">{label}</span> <span className="relative h-2 w-2"> <div onMouseEnter={handleMouseEnter} onMouseLeave={handleMouseLeave} className={`absolute bg-blue-300 right-0 z-10 h-2.5 w-2.5 animate-ping rounded-full`} /> <div className={`absolute bg-blue-400/40 right-0 h-1.5 w-1.5 mt-0.5 mr-0.5 rounded-full`} /> </span> </div> </Popover.Button> {isHovered && ( <Popover.Panel as="div" className="flex flex-col rounded border border-custom-border-200 bg-custom-background-100 p-5 relative min-w-80" ref={setPopperElement as Ref<HTMLDivElement>} style={styles.popper} {...attributes.popper} static > <div className="absolute w-2 h-2 bg-custom-background-100 border rounded-lb-sm border-custom-border-200 border-r-0 border-t-0 transform rotate-45 bottom-2 -left-[5px]" /> <h3 className="text-lg font-semibold w-full">{title}</h3> <h4 className="mt-1 text-sm">{description}</h4> </Popover.Panel> )} </Popover> ); };