@mantine/hooks
Version:
A collection of 50+ hooks for state and UI management
28 lines (24 loc) • 798 B
JavaScript
'use client';
;
var React = require('react');
function useHover() {
const [hovered, setHovered] = React.useState(false);
const ref = React.useRef(null);
const onMouseEnter = React.useCallback(() => setHovered(true), []);
const onMouseLeave = React.useCallback(() => setHovered(false), []);
React.useEffect(() => {
const node = ref.current;
if (node) {
node.addEventListener("mouseenter", onMouseEnter);
node.addEventListener("mouseleave", onMouseLeave);
return () => {
node?.removeEventListener("mouseenter", onMouseEnter);
node?.removeEventListener("mouseleave", onMouseLeave);
};
}
return void 0;
}, [ref.current]);
return { ref, hovered };
}
exports.useHover = useHover;
//# sourceMappingURL=use-hover.cjs.map