qol-hooks
Version:
A collection of React hooks to improve the quality of life of developers.
31 lines (30 loc) • 1.16 kB
JavaScript
import { useEffect } from "react";
/**
* @description A hook to call a function when a click event occurs outside a specified element
* @param {React.RefObject<HTMLElement>} ref The reference to the element to check if the click event occurred outside
* @param {(event: MouseEvent | TouchEvent) => void} handler The function to call when the click event occurs outside the element
*
* @example```tsx
* const ref = useRef(null);
* useOnClickOutside(ref, () => console.log("Clicked outside!"));
*
* return <div ref={ref}>Click outside me!</div>;
* ```
*/
function useOnClickOutside(ref, handler) {
useEffect(() => {
const listener = (event) => {
if (!ref.current || ref.current.contains(event.target)) {
return;
}
handler(event);
};
document.addEventListener("mousedown", listener);
document.addEventListener("touchstart", listener);
return () => {
document.removeEventListener("mousedown", listener);
document.removeEventListener("touchstart", listener);
};
}, [ref, handler]);
}
export default useOnClickOutside;