UNPKG

kepler.gl

Version:

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

101 lines (94 loc) 15.2 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("/Users/ihordykhta/Desktop/unfolded/kepler.gl/node_modules/react")); var _isEqual = _interopRequireDefault(require("lodash/isEqual")); var _pick = _interopRequireDefault(require("lodash/pick")); var _src = require("/Users/ihordykhta/Desktop/unfolded/kepler.gl/src/reducers/src"); 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 = (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; // Define viewport properties that should be compared for changes var viewportProps = ['latitude', 'longitude', 'zoom', 'pitch', 'bearing', 'width', 'height']; var hasChanged = function hasChanged(a, b) { return !(0, _isEqual["default"])((0, _pick["default"])(a, viewportProps), (0, _pick["default"])(b, viewportProps)); }; 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)) { // Update internal view state when mapState viewport properties change // This ensures synchronization when viewport is updated via fitBoundsUpdater setViewStates([(0, _src.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","_src","_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","viewportProps","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/components/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\n    // Define viewport properties that should be compared for changes\n    const viewportProps = ['latitude', 'longitude', 'zoom', 'pitch', 'bearing', 'width', 'height'];\n    const hasChanged = (a, b) => !isEqual(pick(a, viewportProps), pick(b, viewportProps));\n\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      // Update internal view state when mapState viewport properties change\n      // This ensures synchronization when viewport is updated via fitBoundsUpdater\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":[]}