( ref: RefObject<T>, handler: (event: MouseEvent | TouchEvent) => void )
| 1 | import { RefObject, useEffect } from 'react'; |
| 2 | |
| 3 | function useClickOutside<T extends HTMLElement>( |
| 4 | ref: RefObject<T>, |
| 5 | handler: (event: MouseEvent | TouchEvent) => void |
| 6 | ): void { |
| 7 | useEffect(() => { |
| 8 | const handleClickOutside = (event: MouseEvent | TouchEvent) => { |
| 9 | if (!ref || !ref.current || ref.current.contains(event.target as Node)) { |
| 10 | return; |
| 11 | } |
| 12 | |
| 13 | handler(event); |
| 14 | }; |
| 15 | |
| 16 | document.addEventListener('mousedown', handleClickOutside); |
| 17 | document.addEventListener('touchstart', handleClickOutside); |
| 18 | |
| 19 | return () => { |
| 20 | document.removeEventListener('mousedown', handleClickOutside); |
| 21 | document.removeEventListener('touchstart', handleClickOutside); |
| 22 | }; |
| 23 | }, [ref, handler]); |
| 24 | } |
| 25 | |
| 26 | export default useClickOutside; |
no outgoing calls
no test coverage detected