UNPKG

kepler.gl.geoiq

Version:

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

214 lines (178 loc) 25.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; exports.provideInitialState = provideInitialState; var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _reduxActions = require("redux-actions"); var _actionWrapper = require("../actions/action-wrapper"); var _actions = require("../actions/actions"); var _core = require("./core"); var _actionTypes = _interopRequireDefault(require("../constants/action-types")); function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } // INITIAL_STATE var initialCoreState = {}; function provideInitialState(initialState) { var coreReducer = (0, _core.coreReducerFactory)(initialState); var handleRegisterEntry = function handleRegisterEntry(state, _ref) { var _ref$payload = _ref.payload, id = _ref$payload.id, mint = _ref$payload.mint, mapboxApiAccessToken = _ref$payload.mapboxApiAccessToken, mapboxApiUrl = _ref$payload.mapboxApiUrl, mapStylesReplaceDefault = _ref$payload.mapStylesReplaceDefault; // by default, always create a mint state even if the same id already exist // if state.id exist and mint=false, keep the existing state var previousState = state[id] && mint === false ? state[id] : undefined; return _objectSpread(_objectSpread({}, state), {}, (0, _defineProperty2["default"])({}, id, coreReducer(previousState, (0, _actions.keplerGlInit)({ mapboxApiAccessToken: mapboxApiAccessToken, mapboxApiUrl: mapboxApiUrl, mapStylesReplaceDefault: mapStylesReplaceDefault })))); }; var handleDeleteEntry = function handleDeleteEntry(state, _ref2) { var id = _ref2.payload; return Object.keys(state).reduce(function (accu, curr) { return _objectSpread(_objectSpread({}, accu), curr === id ? {} : (0, _defineProperty2["default"])({}, curr, state[curr])); }, {}); }; var handleRenameEntry = function handleRenameEntry(state, _ref4) { var _ref4$payload = _ref4.payload, oldId = _ref4$payload.oldId, newId = _ref4$payload.newId; return Object.keys(state).reduce(function (accu, curr) { return _objectSpread(_objectSpread({}, accu), (0, _defineProperty2["default"])({}, curr === oldId ? newId : curr, state[curr])); }, {}); }; return function () { var _handleActions; var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialCoreState; var action = arguments.length > 1 ? arguments[1] : undefined; // update child states Object.keys(state).forEach(function (id) { var updateItemState = coreReducer(state[id], (0, _actionWrapper._actionFor)(id, action)); state = (0, _actionWrapper._updateProperty)(state, id, updateItemState); }); // perform additional state reducing (e.g. switch action.type etc...) return (0, _reduxActions.handleActions)((_handleActions = {}, (0, _defineProperty2["default"])(_handleActions, _actionTypes["default"].REGISTER_ENTRY, handleRegisterEntry), (0, _defineProperty2["default"])(_handleActions, _actionTypes["default"].DELETE_ENTRY, handleDeleteEntry), (0, _defineProperty2["default"])(_handleActions, _actionTypes["default"].RENAME_ENTRY, handleRenameEntry), _handleActions), initialCoreState)(state, action); }; } var _keplerGlReducer = provideInitialState(); function mergeInitialState() { var saved = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var provided = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; var keys = ['mapState', 'mapStyle', 'visState', 'uiState']; // shallow merge each reducer return keys.reduce(function (accu, key) { return _objectSpread(_objectSpread({}, accu), saved[key] && provided[key] ? (0, _defineProperty2["default"])({}, key, _objectSpread(_objectSpread({}, saved[key]), provided[key])) : (0, _defineProperty2["default"])({}, key, saved[key] || provided[key] || {})); }, {}); } function decorate(target) { var savedInitialState = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; var targetInitialState = savedInitialState; /** * Returns a kepler.gl reducer that will also pass each action through additional reducers spiecified. * The parameter should be either a reducer map or a reducer function. * The state passed into the additional action handler is the instance state. * It will include all the subreducers `visState`, `uiState`, `mapState` and `mapStyle`. * `.plugin` is only meant to be called once when mounting the keplerGlReducer to the store. * **Note** This is an advanced option to give you more freedom to modify the internal state of the kepler.gl instance. * You should only use this to adding additional actions instead of replacing default actions. * * @mixin keplerGlReducer.plugin * @memberof keplerGlReducer * @param {Object|Function} customReducer - A reducer map or a reducer * @public * @example * const myKeplerGlReducer = keplerGlReducer * .plugin({ * // 1. as reducer map * HIDE_AND_SHOW_SIDE_PANEL: (state, action) => ({ * ...state, * uiState: { * ...state.uiState, * readOnly: !state.uiState.readOnly * } * }) * }) * .plugin(handleActions({ * // 2. as reducer * 'HIDE_MAP_CONTROLS': (state, action) => ({ * ...state, * uiState: { * ...state.uiState, * mapControls: hiddenMapControl * } * }) * }, {})); */ target.plugin = function plugin(customReducer) { var _this = this; if ((0, _typeof2["default"])(customReducer) === 'object') { // if only provided a reducerMap, wrap it in a reducer customReducer = (0, _reduxActions.handleActions)(customReducer, {}); } // use 'function' keyword to enable 'this' return decorate(function () { var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var action = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; var nextState = _this(state, action); // for each entry in the staten Object.keys(nextState).forEach(function (id) { // update child states nextState = (0, _actionWrapper._updateProperty)(nextState, id, customReducer(nextState[id], (0, _actionWrapper._actionFor)(id, action))); }); return nextState; }); }; /** * Return a reducer that initiated with custom initial state. * The parameter should be an object mapping from `subreducer` name to custom subreducer state, * which will be shallow **merged** with default initial state. * * Default subreducer state: * - [`visState`](./vis-state.md#INITIAL_VIS_STATE) * - [`mapState`](./map-state.md#INITIAL_MAP_STATE) * - [`mapStyle`](./map-style.md#INITIAL_MAP_STYLE) * - [`uiState`](./ui-state.md#INITIAL_UI_STATE) * @mixin keplerGlReducer.initialState * @memberof keplerGlReducer * @param {Object} iniSt - custom state to be merged with default initial state * @public * @example * const myKeplerGlReducer = keplerGlReducer * .initialState({ * uiState: {readOnly: true} * }); */ target.initialState = function initialState(iniSt) { var merged = mergeInitialState(targetInitialState, iniSt); var targetReducer = provideInitialState(merged); return decorate(targetReducer, merged); }; return target; } /** * Kepler.gl reducer to be mounted to your store. You can mount `keplerGlReducer` at property `keplerGl`, if you choose * to mount it at another address e.g. `foo` you will need to specify it when you mount `KeplerGl` component in your app with `getState: state => state.foo` * @public * @example * import keplerGlReducer from 'kepler.gl/reducers'; * import {createStore, combineReducers, applyMiddleware, compose} from 'redux'; * import {taskMiddleware} from 'react-palm/tasks'; * * const initialState = {}; * const reducers = combineReducers({ * // <-- mount kepler.gl reducer in your app * keplerGl: keplerGlReducer, * * // Your other reducers here * app: appReducer * }); * * // using createStore * export default createStore(reducer, initialState, applyMiddleware(taskMiddleware)); */ var keplerGlReducer = decorate(_keplerGlReducer); var _default = exports["default"] = keplerGlReducer; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/reducers/root.js"],"names":["initialCoreState","provideInitialState","initialState","coreReducer","handleRegisterEntry","state","payload","id","mint","mapboxApiAccessToken","mapboxApiUrl","mapStylesReplaceDefault","previousState","undefined","handleDeleteEntry","Object","keys","reduce","accu","curr","handleRenameEntry","oldId","newId","action","forEach","updateItemState","ActionTypes","REGISTER_ENTRY","DELETE_ENTRY","RENAME_ENTRY","_keplerGlReducer","mergeInitialState","saved","provided","key","decorate","target","savedInitialState","targetInitialState","plugin","customReducer","nextState","iniSt","merged","targetReducer","keplerGlReducer"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 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 {handleActions} from 'redux-actions';\n\nimport {_actionFor, _updateProperty} from '../actions/action-wrapper';\nimport {keplerGlInit} from '../actions/actions';\nimport {coreReducerFactory} from './core';\nimport ActionTypes from 'constants/action-types';\n\n// INITIAL_STATE\nconst initialCoreState = {};\n\nexport function provideInitialState(initialState) {\n  const coreReducer = coreReducerFactory(initialState);\n\n  const handleRegisterEntry = (state, {payload: {id, mint, mapboxApiAccessToken, mapboxApiUrl, mapStylesReplaceDefault}}) => {\n\n    // by default, always create a mint state even if the same id already exist\n    // if state.id exist and mint=false, keep the existing state\n    const previousState = state[id] && mint === false ? state[id] : undefined;\n\n    return {\n      // register entry to kepler.gl passing in mapbox config to mapStyle\n      ...state,\n      [id]: coreReducer(previousState, keplerGlInit({mapboxApiAccessToken, mapboxApiUrl, mapStylesReplaceDefault}))\n    }\n  };\n\n  const handleDeleteEntry = (state, {payload: id}) =>\n    Object.keys(state).reduce(\n      (accu, curr) => ({\n        ...accu,\n        ...(curr === id ? {} : {[curr]: state[curr]})\n      }),\n      {}\n    );\n\n  const handleRenameEntry = (state, {payload: {oldId, newId}}) =>\n    Object.keys(state).reduce(\n      (accu, curr) => ({\n        ...accu,\n        ...{[curr === oldId ? newId : curr]: state[curr]}\n      }),\n      {}\n    );\n\n  return (state = initialCoreState, action) => {\n    // update child states\n    Object.keys(state).forEach(id => {\n      const updateItemState = coreReducer(state[id], _actionFor(id, action));\n      state = _updateProperty(state, id, updateItemState);\n    });\n\n    // perform additional state reducing (e.g. switch action.type etc...)\n    return handleActions(\n      {\n        [ActionTypes.REGISTER_ENTRY]: handleRegisterEntry,\n        [ActionTypes.DELETE_ENTRY]: handleDeleteEntry,\n        [ActionTypes.RENAME_ENTRY]: handleRenameEntry\n      },\n      initialCoreState\n    )(state, action);\n  };\n}\n\nconst _keplerGlReducer = provideInitialState();\n\nfunction mergeInitialState(saved = {}, provided = {}) {\n  const keys = ['mapState', 'mapStyle', 'visState', 'uiState'];\n\n  // shallow merge each reducer\n  return keys.reduce((accu, key) => ({\n    ...accu,\n    ...(saved[key] && provided[key] ?\n        {[key]: {...saved[key], ...provided[key]}} :\n        {[key]: saved[key] || provided[key] || {}})\n  }), {});\n}\n\nfunction decorate(target, savedInitialState = {}) {\n  const targetInitialState = savedInitialState;\n\n  /**\n   * Returns a kepler.gl reducer that will also pass each action through additional reducers spiecified.\n   * The parameter should be either a reducer map or a reducer function.\n   * The state passed into the additional action handler is the instance state.\n   * It will include all the subreducers `visState`, `uiState`, `mapState` and `mapStyle`.\n   * `.plugin` is only meant to be called once when mounting the keplerGlReducer to the store.\n   * **Note** This is an advanced option to give you more freedom to modify the internal state of the kepler.gl instance.\n   * You should only use this to adding additional actions instead of replacing default actions.\n   *\n   * @mixin keplerGlReducer.plugin\n   * @memberof keplerGlReducer\n   * @param {Object|Function} customReducer - A reducer map or a reducer\n   * @public\n   * @example\n   * const myKeplerGlReducer = keplerGlReducer\n   *  .plugin({\n   *    // 1. as reducer map\n   *    HIDE_AND_SHOW_SIDE_PANEL: (state, action) => ({\n   *      ...state,\n   *      uiState: {\n   *        ...state.uiState,\n   *        readOnly: !state.uiState.readOnly\n   *      }\n   *    })\n   *  })\n   * .plugin(handleActions({\n   *   // 2. as reducer\n   *   'HIDE_MAP_CONTROLS': (state, action) => ({\n   *     ...state,\n   *     uiState: {\n   *       ...state.uiState,\n   *       mapControls: hiddenMapControl\n   *     }\n   *   })\n   * }, {}));\n   */\n  target.plugin = function plugin(customReducer) {\n    if (typeof customReducer === 'object') {\n      // if only provided a reducerMap, wrap it in a reducer\n      customReducer = handleActions(customReducer, {});\n    }\n\n    // use 'function' keyword to enable 'this'\n    return decorate((state = {}, action = {}) => {\n      let nextState = this(state, action);\n\n      // for each entry in the staten\n      Object.keys(nextState).forEach(id => {\n        // update child states\n        nextState = _updateProperty(\n          nextState,\n          id,\n          customReducer(nextState[id], _actionFor(id, action))\n        );\n      });\n\n      return nextState;\n    });\n  };\n\n  /**\n   * Return a reducer that initiated with custom initial state.\n   * The parameter should be an object mapping from `subreducer` name to custom subreducer state,\n   * which will be shallow **merged** with default initial state.\n   *\n   * Default subreducer state:\n   *  - [`visState`](./vis-state.md#INITIAL_VIS_STATE)\n   *  - [`mapState`](./map-state.md#INITIAL_MAP_STATE)\n   *  - [`mapStyle`](./map-style.md#INITIAL_MAP_STYLE)\n   *  - [`uiState`](./ui-state.md#INITIAL_UI_STATE)\n   * @mixin keplerGlReducer.initialState\n   * @memberof keplerGlReducer\n   * @param {Object} iniSt - custom state to be merged with default initial state\n   * @public\n   * @example\n   * const myKeplerGlReducer = keplerGlReducer\n   *  .initialState({\n   *    uiState: {readOnly: true}\n   *  });\n   */\n  target.initialState = function initialState(iniSt) {\n    const merged = mergeInitialState(targetInitialState, iniSt);\n    const targetReducer = provideInitialState(merged);\n\n    return decorate(targetReducer, merged);\n  };\n\n  return target;\n}\n\n/**\n * Kepler.gl reducer to be mounted to your store. You can mount `keplerGlReducer` at property `keplerGl`, if you choose\n * to mount it at another address e.g. `foo` you will need to specify it when you mount `KeplerGl` component in your app with `getState: state => state.foo`\n * @public\n * @example\n * import keplerGlReducer from 'kepler.gl/reducers';\n * import {createStore, combineReducers, applyMiddleware, compose} from 'redux';\n * import {taskMiddleware} from 'react-palm/tasks';\n *\n * const initialState = {};\n * const reducers = combineReducers({\n *   // <-- mount kepler.gl reducer in your app\n *   keplerGl: keplerGlReducer,\n *\n *   // Your other reducers here\n *   app: appReducer\n * });\n *\n * // using createStore\n * export default createStore(reducer, initialState, applyMiddleware(taskMiddleware));\n */\nconst keplerGlReducer = decorate(_keplerGlReducer);\nexport default keplerGlReducer;\n"]}