UNPKG

@restart/hooks

Version:

A set of utility and general-purpose React hooks.

26 lines (24 loc) 875 B
import { useEffect } from 'react'; import useEventCallback from './useEventCallback'; /** * Attaches an event handler outside directly to specified DOM element * bypassing the react synthetic event system. * * @param element The target to listen for events on * @param event The DOM event name * @param handler An event handler * @param capture Whether or not to listen during the capture event phase */ export default function useEventListener(eventTarget, event, listener, capture) { if (capture === void 0) { capture = false; } var handler = useEventCallback(listener); useEffect(function () { var target = typeof eventTarget === 'function' ? eventTarget() : eventTarget; target.addEventListener(event, handler, capture); return function () { return target.removeEventListener(event, handler, capture); }; }, [eventTarget]); }