bigbuffet-rw/app/soapbox/components/hoverable.tsx

64 lines
1.3 KiB
TypeScript
Raw Normal View History

import classNames from 'classnames';
2022-04-01 11:31:08 -07:00
import React, { useState, useRef } from 'react';
import { usePopper } from 'react-popper';
2022-04-01 11:31:08 -07:00
interface IHoverable {
2022-04-02 16:43:34 -07:00
component: JSX.Element,
2022-04-01 11:31:08 -07:00
}
/** Wrapper to render a given component when hovered */
const Hoverable: React.FC<IHoverable> = ({
component,
children,
}): JSX.Element => {
const [portalActive, setPortalActive] = useState(false);
2022-04-01 11:31:08 -07:00
const ref = useRef<HTMLDivElement>(null);
const popperRef = useRef<HTMLDivElement>(null);
2022-04-01 11:31:08 -07:00
const handleMouseEnter = () => {
setPortalActive(true);
};
const handleMouseLeave = () => {
setPortalActive(false);
};
const { styles, attributes } = usePopper(ref.current, popperRef.current, {
placement: 'top-start',
strategy: 'fixed',
modifiers: [
{
name: 'offset',
options: {
offset: [-10, 0],
},
},
],
});
2022-04-01 11:31:08 -07:00
return (
<div
onMouseEnter={handleMouseEnter}
onMouseLeave={handleMouseLeave}
ref={ref}
>
{children}
<div
className={classNames('fixed z-50 transition-opacity duration-100', {
'opacity-0 pointer-events-none': !portalActive,
})}
ref={popperRef}
style={styles.popper}
{...attributes.popper}
>
{component}
</div>
2022-04-01 11:31:08 -07:00
</div>
);
};
export default Hoverable;