From 1919787c1108529c7b8583411cd40d0a35aef105 Mon Sep 17 00:00:00 2001 From: Walidoux Date: Sun, 23 Apr 2023 20:16:56 +0100 Subject: [PATCH] feat(hooks): implement useOutsideClickEventHandler --- src/hooks/useOutsideClickEventHandler.ts | 30 ++++++++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 src/hooks/useOutsideClickEventHandler.ts diff --git a/src/hooks/useOutsideClickEventHandler.ts b/src/hooks/useOutsideClickEventHandler.ts new file mode 100644 index 0000000..0ac43e9 --- /dev/null +++ b/src/hooks/useOutsideClickEventHandler.ts @@ -0,0 +1,30 @@ +import type { RefObject } from 'react' +import { useEffect, useRef } from 'react' + +export const useOutSideClickEventHandler = (callback: () => void): RefObject => { + const wrapper = useRef(null) + + useEffect(() => { + const handleClickOutside = (event: KeyboardEvent): void => { + if (Boolean(wrapper.current?.contains(event.target as Node))) return + if (event.key !== 'Escape') return + return callback() + } + + window.addEventListener('click', (event: any) => { + return handleClickOutside(event) + }) + + window.addEventListener('keydown', (event: any) => { + return handleClickOutside(event) + }) + + return () => { + return window.removeEventListener('click', (event: any) => { + return handleClickOutside(event) + }) + } + }, []) + + return wrapper +}