Spaces:
Paused
Paused
File size: 633 Bytes
3c3f089 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 |
import { useEffect, useState } from "react";
const UseOutsideRef = (ref: any) => {
const [isOutsideRef, setIsOutsideRef] = useState(false);
useEffect(() => {
function handleClickOutside(event: any) {
if (ref.current && !ref.current.contains(event.target)) {
setIsOutsideRef(true);
setTimeout(() => {
setIsOutsideRef(false);
}, 200);
}
}
document.addEventListener("mousedown", handleClickOutside);
return () => {
document.removeEventListener("mousedown", handleClickOutside);
};
}, [ref]);
return { isOutsideRef };
};
export default UseOutsideRef;
|