UNPKG

@globalfishingwatch/react-map-gl

Version:

A React wrapper for MapboxGL-js and overlay API.

105 lines (95 loc) 2.45 kB
import { useContext, useRef, useEffect } from 'react'; import PropTypes from 'prop-types'; import MapContext from './map-context'; export const mapControlDefaultProps = { captureScroll: false, captureDrag: true, captureClick: true, captureDoubleClick: true, capturePointerMove: false }; export const mapControlPropTypes = { captureScroll: PropTypes.bool, captureDrag: PropTypes.bool, captureClick: PropTypes.bool, captureDoubleClick: PropTypes.bool, capturePointerMove: PropTypes.bool }; function onMount(thisRef, callbacks = {}) { const ref = thisRef.containerRef.current; const { eventManager } = thisRef.context; if (!ref || !eventManager) { return undefined; } const events = { wheel: evt => { if (thisRef.props.captureScroll) { evt.stopPropagation(); } if (callbacks.onScroll) { callbacks.onScroll(evt, thisRef); } }, panstart: evt => { if (thisRef.props.captureDrag) { evt.stopPropagation(); } if (callbacks.onDragStart) { callbacks.onDragStart(evt, thisRef); } }, anyclick: evt => { if (thisRef.props.captureClick) { evt.stopPropagation(); } if (callbacks.onClick) { callbacks.onClick(evt, thisRef); } }, click: evt => { if (thisRef.props.captureClick) { evt.stopPropagation(); } if (callbacks.onClick) { callbacks.onClick(evt, thisRef); } }, dblclick: evt => { if (thisRef.props.captureDoubleClick) { evt.stopPropagation(); } if (callbacks.onDoubleClick) { callbacks.onDoubleClick(evt, thisRef); } }, pointermove: evt => { if (thisRef.props.capturePointerMove) { evt.stopPropagation(); } if (callbacks.onPointerMove) { callbacks.onPointerMove(evt, thisRef); } } }; eventManager.watch(events, ref); return () => { eventManager.off(events); }; } export default function useMapControl(props, callbacks) { const context = useContext(MapContext); const containerRef = useRef(null); const thisRef = useRef({ props, state: {}, context, containerRef }); thisRef.current.props = props; thisRef.current.context = context; useEffect(() => onMount(thisRef.current, callbacks), [context.eventManager]); return thisRef.current; } //# sourceMappingURL=use-map-control.js.map