kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
99 lines (93 loc) • 14.7 kB
JavaScript
;
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';\ntype MapViewState = {\n  latitude: number;\n  longitude: number;\n  zoom: number;\n  bearing?: number;\n  pitch?: number;\n};\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":[]}