UNPKG

@vis.gl/react-google-maps

Version:

React components and hooks for the Google Maps JavaScript API

27 lines (21 loc) 727 B
/* eslint-disable @typescript-eslint/no-explicit-any */ import {useEffect} from 'react'; import {useEffectEvent} from './use-effect-event'; const noop = () => {}; /** * Internally used to bind events to Maps JavaScript API objects. * @internal */ export function useMapsEventListener<T extends (...args: any[]) => void>( target?: object | null, name?: string, callback?: T | null ) { const eventFn = useEffectEvent(callback ?? noop); const isCallbackDefined = Boolean(callback); useEffect(() => { if (!target || !name || !isCallbackDefined) return; const listener = google.maps.event.addListener(target, name, eventFn); return () => listener.remove(); }, [target, name, isCallbackDefined]); }