UNPKG

kepler.gl

Version:

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

242 lines (201 loc) 20 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.getMapDimForSplitMap = getMapDimForSplitMap; exports.toggleSplitMapUpdater = exports.receiveMapConfigUpdater = exports.resetMapConfigUpdater = exports.togglePerspectiveUpdater = exports.fitBoundsUpdater = exports.updateMapUpdater = exports.INITIAL_MAP_STATE = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _geoViewport = _interopRequireDefault(require("@mapbox/geo-viewport")); function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } /** * Updaters for `mapState` reducer. Can be used in your root reducer to directly modify kepler.gl's state. * Read more about [Using updaters](../advanced-usage/using-updaters.md) * @public * @example * * import keplerGlReducer, {mapStateUpdaters} from 'kepler.gl/reducers'; * // Root Reducer * const reducers = combineReducers({ * keplerGl: keplerGlReducer, * app: appReducer * }); * * const composedReducer = (state, action) => { * switch (action.type) { * // click button to close side panel * case 'CLICK_BUTTON': * return { * ...state, * keplerGl: { * ...state.keplerGl, * foo: { * ...state.keplerGl.foo, * mapState: mapStateUpdaters.fitBoundsUpdater( * mapState, {payload: [127.34, 31.09, 127.56, 31.59]]} * ) * } * } * }; * } * return reducers(state, action); * }; * * export default composedReducer; */ /* eslint-disable no-unused-vars */ var mapStateUpdaters = null; /* eslint-enable no-unused-vars */ /** * Default initial `mapState` * @memberof mapStateUpdaters * @constant * @property {number} pitch Default: `0` * @property {number} bearing Default: `0` * @property {number} latitude Default: `37.75043` * @property {number} longitude Default: `-122.34679` * @property {number} zoom Default: `9` * @property {boolean} dragRotate Default: `false` * @property {number} width Default: `800` * @property {number} height Default: `800` * @property {boolean} isSplit Default: `false` * @public */ var INITIAL_MAP_STATE = { pitch: 0, bearing: 0, latitude: 37.75043, longitude: -122.34679, zoom: 9, dragRotate: false, width: 800, height: 800, isSplit: false }; /* Updaters */ /** * Update map viewport * @memberof mapStateUpdaters * @param {Object} state * @param {Object} action * @param {Object} action.payload - viewport * @returns {Object} nextState * @public */ exports.INITIAL_MAP_STATE = INITIAL_MAP_STATE; var updateMapUpdater = function updateMapUpdater(state, action) { return _objectSpread({}, state, {}, action.payload || {}); }; /** * Fit map viewport to bounds * @memberof mapStateUpdaters * @param {Object} state * @param {Object} action * @param {number[]} action.payload - bounds as `[lngMin, latMin, lngMax, latMax]` * @returns {Object} nextState * @public */ exports.updateMapUpdater = updateMapUpdater; var fitBoundsUpdater = function fitBoundsUpdater(state, action) { var bounds = action.payload; var _geoViewport$viewport = _geoViewport["default"].viewport(bounds, [state.width, state.height]), center = _geoViewport$viewport.center, zoom = _geoViewport$viewport.zoom; return _objectSpread({}, state, { latitude: center[1], longitude: center[0], zoom: zoom }); }; /** * Toggle between 3d and 2d map. * @memberof mapStateUpdaters * @param {Object} state * @returns {Object} nextState * @public */ exports.fitBoundsUpdater = fitBoundsUpdater; var togglePerspectiveUpdater = function togglePerspectiveUpdater(state) { return _objectSpread({}, state, {}, { pitch: state.dragRotate ? 0 : 50, bearing: state.dragRotate ? 0 : 24 }, { dragRotate: !state.dragRotate }); }; /** * reset mapState to initial State * @memberof mapStateUpdaters * @param {Object} state `mapState` * @returns {Object} nextState * @public */ exports.togglePerspectiveUpdater = togglePerspectiveUpdater; var resetMapConfigUpdater = function resetMapConfigUpdater(state) { return _objectSpread({}, INITIAL_MAP_STATE, {}, state.initialState, { initialState: state.initialState }); }; // consider case where you have a split map and user wants to reset /** * Update `mapState` to propagate a new config * @memberof mapStateUpdaters * @param {Object} state * @param {Object} action * @param {Object} action.payload - saved map config * @returns {Object} nextState * @public */ exports.resetMapConfigUpdater = resetMapConfigUpdater; var receiveMapConfigUpdater = function receiveMapConfigUpdater(state, _ref) { var _ref$payload = _ref.payload, _ref$payload$config = _ref$payload.config, config = _ref$payload$config === void 0 ? {} : _ref$payload$config, _ref$payload$options = _ref$payload.options, options = _ref$payload$options === void 0 ? {} : _ref$payload$options, _ref$payload$bounds = _ref$payload.bounds, bounds = _ref$payload$bounds === void 0 ? null : _ref$payload$bounds; var _ref2 = config || {}, mapState = _ref2.mapState; // merged received mapstate with previous state var mergedState = _objectSpread({}, state, {}, mapState); // if center map // center map will override mapState config if (options.centerMap && bounds) { mergedState = fitBoundsUpdater(mergedState, { payload: bounds }); } return _objectSpread({}, mergedState, {}, getMapDimForSplitMap(mergedState.isSplit, state)); }; /** * Toggle between one or split maps * @memberof mapStateUpdaters * @param {Object} state * @returns {Object} nextState * @public */ exports.receiveMapConfigUpdater = receiveMapConfigUpdater; var toggleSplitMapUpdater = function toggleSplitMapUpdater(state) { return _objectSpread({}, state, { isSplit: !state.isSplit }, getMapDimForSplitMap(!state.isSplit, state)); }; // Helpers exports.toggleSplitMapUpdater = toggleSplitMapUpdater; function getMapDimForSplitMap(isSplit, state) { // cases: // 1. state split: true - isSplit: true // do nothing // 2. state split: false - isSplit: false // do nothing if (state.isSplit === isSplit) { return {}; } var width = state.isSplit && !isSplit ? // 3. state split: true - isSplit: false // double width state.width * 2 : // 4. state split: false - isSplit: true // split width state.width / 2; return { width: width }; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/reducers/map-state-updaters.js"],"names":["mapStateUpdaters","INITIAL_MAP_STATE","pitch","bearing","latitude","longitude","zoom","dragRotate","width","height","isSplit","updateMapUpdater","state","action","payload","fitBoundsUpdater","bounds","geoViewport","viewport","center","togglePerspectiveUpdater","resetMapConfigUpdater","initialState","receiveMapConfigUpdater","config","options","mapState","mergedState","centerMap","getMapDimForSplitMap","toggleSplitMapUpdater"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport geoViewport from '@mapbox/geo-viewport';\n\n/**\n * Updaters for `mapState` reducer. Can be used in your root reducer to directly modify kepler.gl's state.\n * Read more about [Using updaters](../advanced-usage/using-updaters.md)\n * @public\n * @example\n *\n * import keplerGlReducer, {mapStateUpdaters} from 'kepler.gl/reducers';\n * // Root Reducer\n * const reducers = combineReducers({\n *  keplerGl: keplerGlReducer,\n *  app: appReducer\n * });\n *\n * const composedReducer = (state, action) => {\n *  switch (action.type) {\n *    // click button to close side panel\n *    case 'CLICK_BUTTON':\n *      return {\n *        ...state,\n *        keplerGl: {\n *          ...state.keplerGl,\n *          foo: {\n *             ...state.keplerGl.foo,\n *             mapState: mapStateUpdaters.fitBoundsUpdater(\n *               mapState, {payload: [127.34, 31.09, 127.56, 31.59]]}\n *             )\n *          }\n *        }\n *      };\n *  }\n *  return reducers(state, action);\n * };\n *\n * export default composedReducer;\n */\n/* eslint-disable no-unused-vars */\nconst mapStateUpdaters = null;\n/* eslint-enable no-unused-vars */\n\n/**\n * Default initial `mapState`\n * @memberof mapStateUpdaters\n * @constant\n * @property {number} pitch Default: `0`\n * @property {number} bearing Default: `0`\n * @property {number} latitude Default: `37.75043`\n * @property {number} longitude Default: `-122.34679`\n * @property {number} zoom Default: `9`\n * @property {boolean} dragRotate Default: `false`\n * @property {number} width Default: `800`\n * @property {number} height Default: `800`\n * @property {boolean} isSplit Default: `false`\n * @public\n */\nexport const INITIAL_MAP_STATE = {\n  pitch: 0,\n  bearing: 0,\n  latitude: 37.75043,\n  longitude: -122.34679,\n  zoom: 9,\n  dragRotate: false,\n  width: 800,\n  height: 800,\n  isSplit: false\n};\n\n/* Updaters */\n/**\n * Update map viewport\n * @memberof mapStateUpdaters\n * @param {Object} state\n * @param {Object} action\n * @param {Object} action.payload - viewport\n * @returns {Object} nextState\n * @public\n */\nexport const updateMapUpdater = (state, action) => ({\n  ...state,\n  ...(action.payload || {})\n});\n\n/**\n * Fit map viewport to bounds\n * @memberof mapStateUpdaters\n * @param {Object} state\n * @param {Object} action\n * @param {number[]} action.payload - bounds as `[lngMin, latMin, lngMax, latMax]`\n * @returns {Object} nextState\n * @public\n */\nexport const fitBoundsUpdater = (state, action) => {\n  const bounds = action.payload;\n  const {center, zoom} = geoViewport.viewport(bounds, [state.width, state.height]);\n\n  return {\n    ...state,\n    latitude: center[1],\n    longitude: center[0],\n    zoom\n  };\n};\n\n/**\n * Toggle between 3d and 2d map.\n * @memberof mapStateUpdaters\n * @param {Object} state\n * @returns {Object} nextState\n * @public\n */\nexport const togglePerspectiveUpdater = state => ({\n  ...state,\n  ...{\n    pitch: state.dragRotate ? 0 : 50,\n    bearing: state.dragRotate ? 0 : 24\n  },\n  dragRotate: !state.dragRotate\n});\n\n/**\n * reset mapState to initial State\n * @memberof mapStateUpdaters\n * @param {Object} state `mapState`\n * @returns {Object} nextState\n * @public\n */\nexport const resetMapConfigUpdater = state => ({\n  ...INITIAL_MAP_STATE,\n  ...state.initialState,\n  initialState: state.initialState\n});\n\n// consider case where you have a split map and user wants to reset\n/**\n * Update `mapState` to propagate a new config\n * @memberof mapStateUpdaters\n * @param {Object} state\n * @param {Object} action\n * @param {Object} action.payload - saved map config\n * @returns {Object} nextState\n * @public\n */\nexport const receiveMapConfigUpdater = (\n  state,\n  {payload: {config = {}, options = {}, bounds = null}}\n) => {\n  const {mapState} = config || {};\n\n  // merged received mapstate with previous state\n  let mergedState = {...state, ...mapState};\n\n  // if center map\n  // center map will override mapState config\n  if (options.centerMap && bounds) {\n    mergedState = fitBoundsUpdater(mergedState, {\n      payload: bounds\n    });\n  }\n\n  return {\n    ...mergedState,\n    // update width if `isSplit` has changed\n    ...getMapDimForSplitMap(mergedState.isSplit, state)\n  };\n};\n\n/**\n * Toggle between one or split maps\n * @memberof mapStateUpdaters\n * @param {Object} state\n * @returns {Object} nextState\n * @public\n */\nexport const toggleSplitMapUpdater = state => ({\n  ...state,\n  isSplit: !state.isSplit,\n  ...getMapDimForSplitMap(!state.isSplit, state)\n});\n\n// Helpers\nexport function getMapDimForSplitMap(isSplit, state) {\n  // cases:\n  // 1. state split: true - isSplit: true\n  // do nothing\n  // 2. state split: false - isSplit: false\n  // do nothing\n  if (state.isSplit === isSplit) {\n    return {};\n  }\n\n  const width =\n    state.isSplit && !isSplit\n      ? // 3. state split: true - isSplit: false\n        // double width\n        state.width * 2\n      : // 4. state split: false - isSplit: true\n        // split width\n        state.width / 2;\n\n  return {\n    width\n  };\n}\n"]}