import classNames from 'clsx'; import debounce from 'lodash/debounce'; import React, { useRef } from 'react'; import { fetchAccount } from 'soapbox/actions/accounts'; import { openProfileHoverCard, closeProfileHoverCard, } from 'soapbox/actions/profile-hover-card'; import { useAppDispatch } from 'soapbox/hooks'; import { isMobile } from 'soapbox/is-mobile'; const showProfileHoverCard = debounce((dispatch, ref, accountId) => { dispatch(openProfileHoverCard(ref, accountId)); }, 600); interface IHoverRefWrapper { accountId: string, inline?: boolean, className?: string, } /** Makes a profile hover card appear when the wrapped element is hovered. */ export const HoverRefWrapper: React.FC = ({ accountId, children, inline = false, className }) => { const dispatch = useAppDispatch(); const ref = useRef(null); const Elem: keyof JSX.IntrinsicElements = inline ? 'span' : 'div'; const handleMouseEnter = () => { if (!isMobile(window.innerWidth)) { dispatch(fetchAccount(accountId)); showProfileHoverCard(dispatch, ref, accountId); } }; const handleMouseLeave = () => { showProfileHoverCard.cancel(); setTimeout(() => dispatch(closeProfileHoverCard()), 300); }; const handleClick = () => { showProfileHoverCard.cancel(); dispatch(closeProfileHoverCard(true)); }; return ( {children} ); }; export { HoverRefWrapper as default, showProfileHoverCard };