UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

99 lines (93 loc) 14.6 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.MapViewStateContextProvider = exports.MapViewStateContext = void 0; var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _react = _interopRequireWildcard(require("react")); var _isEqual = _interopRequireDefault(require("lodash/isEqual")); var _pick = _interopRequireDefault(require("lodash/pick")); var _reducers = require("@kepler.gl/reducers"); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; } // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project var MapViewStateContext = exports.MapViewStateContext = /*#__PURE__*/(0, _react.createContext)({ getInternalViewState: function getInternalViewState() { return { latitude: 0, longitude: 0, zoom: 0 }; }, setInternalViewState: function setInternalViewState() { return; } }); /** * This context provider is used to localize the map view state so * that changes to the map view state do not affect the rest of the app, * mainly to prevent issues we experienced with basemap/deck viewport syncing. */ var MapViewStateContextProvider = exports.MapViewStateContextProvider = function MapViewStateContextProvider(_ref) { var mapState = _ref.mapState, children = _ref.children; var _ref2 = mapState || {}, isSplit = _ref2.isSplit, isViewportSynced = _ref2.isViewportSynced; // Store locally map view states by mapIndex var _useState = (0, _react.useState)([mapState]), _useState2 = (0, _slicedToArray2["default"])(_useState, 2), viewStates = _useState2[0], setViewStates = _useState2[1]; // Detect and apply outside viewport changes // (e.g. from geocoder or when switching to 3d mode) (0, _react.useEffect)(function () { if (!mapState) return; var primaryState = viewStates[0]; if (primaryState === mapState) return; var props = Object.keys(primaryState).filter(function (key) { return !key.startsWith('transition'); }); var hasChanged = function hasChanged(a, b) { return !(0, _isEqual["default"])((0, _pick["default"])(a, props), (0, _pick["default"])(b, props)); }; if (isSplit && !isViewportSynced) { var _mapState$splitMapVie; if ((_mapState$splitMapVie = mapState.splitMapViewports) !== null && _mapState$splitMapVie !== void 0 && _mapState$splitMapVie.some(function (s, i) { return hasChanged(s, viewStates[i]); })) { setViewStates(mapState.splitMapViewports); } } else if (hasChanged(primaryState, mapState)) { setViewStates([(0, _reducers.pickViewportPropsFromMapState)(mapState)]); } // Only update internalViewState when viewState changes // eslint-disable-next-line react-hooks/exhaustive-deps }, [mapState]); var value = { getInternalViewState: function getInternalViewState() { var _viewStates$index; var index = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; return (_viewStates$index = viewStates[index]) !== null && _viewStates$index !== void 0 ? _viewStates$index : viewStates[0]; }, setInternalViewState: function setInternalViewState(newViewState) { var index = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; setViewStates(function (prevViewStates) { if (isSplit && !isViewportSynced) { var nextViewStates = (0, _toConsumableArray2["default"])(prevViewStates); nextViewStates[index] = newViewState; return nextViewStates; } return [newViewState]; }); } }; return /*#__PURE__*/_react["default"].createElement(MapViewStateContext.Provider, { value: value }, children); }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_isEqual","_interopRequireDefault","_pick","_reducers","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","MapViewStateContext","exports","createContext","getInternalViewState","latitude","longitude","zoom","setInternalViewState","MapViewStateContextProvider","_ref","mapState","children","_ref2","isSplit","isViewportSynced","_useState","useState","_useState2","_slicedToArray2","viewStates","setViewStates","useEffect","primaryState","props","keys","filter","key","startsWith","hasChanged","b","isEqual","pick","_mapState$splitMapVie","splitMapViewports","some","s","pickViewportPropsFromMapState","value","_viewStates$index","index","arguments","length","undefined","newViewState","prevViewStates","nextViewStates","_toConsumableArray2","createElement","Provider"],"sources":["../src/map-view-state-context.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useState, useEffect, createContext} from 'react';\nimport isEqual from 'lodash/isEqual';\nimport pick from 'lodash/pick';\nimport {MapViewState} from '@deck.gl/core/typed';\nimport {pickViewportPropsFromMapState} from '@kepler.gl/reducers';\n\nimport {MapState} from '@kepler.gl/types';\n\nexport type MapViewStateContextType = {\n  getInternalViewState: (index?: number) => MapViewState;\n  setInternalViewState: (viewState?: MapViewState, index?: number) => void;\n};\n\nexport const MapViewStateContext: React.Context<MapViewStateContextType> = createContext({\n  getInternalViewState: () => ({latitude: 0, longitude: 0, zoom: 0}),\n  setInternalViewState: () => {\n    return;\n  }\n});\n\n/**\n * This context provider is used to localize the map view state so\n * that changes to the map view state do not affect the rest of the app,\n * mainly to prevent issues we experienced with basemap/deck viewport syncing.\n */\n\nexport const MapViewStateContextProvider = ({\n  mapState,\n  children\n}: {\n  mapState: MapState;\n  children: React.ReactNode;\n}) => {\n  const {isSplit, isViewportSynced} = mapState || {};\n\n  // Store locally map view states by mapIndex\n  const [viewStates, setViewStates] = useState([mapState]);\n\n  // Detect and apply outside viewport changes\n  // (e.g. from geocoder or when switching to 3d mode)\n  useEffect(() => {\n    if (!mapState) return;\n    const primaryState = viewStates[0];\n    if (primaryState === mapState) return;\n    const props = Object.keys(primaryState).filter(key => !key.startsWith('transition'));\n    const hasChanged = (a, b) => !isEqual(pick(a, props), pick(b, props));\n    if (isSplit && !isViewportSynced) {\n      if (mapState.splitMapViewports?.some((s, i) => hasChanged(s, viewStates[i]))) {\n        setViewStates(mapState.splitMapViewports as MapState[]);\n      }\n    } else if (hasChanged(primaryState, mapState)) {\n      setViewStates([pickViewportPropsFromMapState(mapState)] as MapState[]);\n    }\n    // Only update internalViewState when viewState changes\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [mapState]);\n\n  const value = {\n    getInternalViewState: (index = 0) => viewStates[index] ?? viewStates[0],\n    setInternalViewState: (newViewState, index = 0) => {\n      setViewStates(prevViewStates => {\n        if (isSplit && !isViewportSynced) {\n          const nextViewStates = [...prevViewStates];\n          nextViewStates[index] = newViewState as MapState;\n          return nextViewStates;\n        }\n        return [newViewState] as MapState[];\n      });\n    }\n  } as MapViewStateContextType;\n  return <MapViewStateContext.Provider value={value}>{children}</MapViewStateContext.Provider>;\n};\n"],"mappings":"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","ignoreList":[]}