UNPKG

kepler.gl

Version:

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

137 lines (106 loc) 13.8 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.addDataToMapComposed = exports.updateVisDataComposed = undefined; var _defineProperty2 = require('babel-runtime/helpers/defineProperty'); var _defineProperty3 = _interopRequireDefault(_defineProperty2); var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); var _compostedUpdaters; // Copyright (c) 2018 Uber Technologies, Inc. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. var _actionTypes = require('../constants/action-types'); var _actionTypes2 = _interopRequireDefault(_actionTypes); var _mapStateUpdaters = require('./map-state-updaters'); var _uiStateUpdaters = require('./ui-state-updaters'); var _visStateUpdaters = require('./vis-state-updaters'); var _mapStyleUpdaters = require('./map-style-updaters'); var _dataUtils = require('../utils/data-utils'); var _schemas = require('../schemas'); var _schemas2 = _interopRequireDefault(_schemas); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } // compose action to apply result multiple reducers, with the output of one /** * Apply data and config to visState reducer * @param {object} state * @param {object} action * @param {object} action.options * @param {Boolean} action.options.centerMap * @param {Boolean} action.options.readOnly * @param {object} action.config * @returns state new reducer state */ var updateVisDataComposed = exports.updateVisDataComposed = function updateVisDataComposed(state, action) { // keep a copy of oldLayers var oldLayers = state.visState.layers; var visState = (0, _visStateUpdaters.updateVisDataUpdater)(state.visState, action); var defaultOptions = { centerMap: true }; var options = (0, _extends3.default)({}, defaultOptions, action.options); var bounds = void 0; if (options.centerMap) { // find map bounds for new layers var newLayers = visState.layers.filter(function (nl) { return !oldLayers.find(function (ol) { return ol === nl; }); }); bounds = (0, _dataUtils.findMapBounds)(newLayers); } return (0, _extends3.default)({}, state, { visState: visState, mapState: bounds ? (0, _mapStateUpdaters.fitBoundsUpdater)(state.mapState, { payload: bounds }) : state.mapState, uiState: (0, _extends3.default)({}, (0, _uiStateUpdaters.toggleModalUpdater)(state.uiState, { payload: null }), options.hasOwnProperty('readOnly') ? { readOnly: options.readOnly } : {}) }); }; /** * Combine data and full configuration update in a single action * @param state * @param action {datasets, options, config} * @returns state */ var addDataToMapComposed = exports.addDataToMapComposed = function addDataToMapComposed(state, action) { var _action$payload = action.payload, datasets = _action$payload.datasets, options = _action$payload.options, config = _action$payload.config; var parsedConfig = config; if (config && config.config && config.version) { // if passed in saved config parsedConfig = _schemas2.default.parseSavedConfig(config); } // Update visState store var mergedState = updateVisDataComposed(state, { datasets: datasets, options: options, config: parsedConfig && parsedConfig.visState }); // Update mapState store mergedState = (0, _extends3.default)({}, mergedState, { mapState: (0, _mapStateUpdaters.receiveMapConfigUpdater)(mergedState.mapState, { payload: { mapState: parsedConfig && parsedConfig.mapState } }) }); // Update mapStyle store mergedState = (0, _extends3.default)({}, mergedState, { mapStyle: (0, _mapStyleUpdaters.receiveMapConfigUpdater)(mergedState.mapStyle, { payload: { mapStyle: parsedConfig && parsedConfig.mapStyle } }) }); return mergedState; }; var compostedUpdaters = (_compostedUpdaters = {}, (0, _defineProperty3.default)(_compostedUpdaters, _actionTypes2.default.UPDATE_VIS_DATA, updateVisDataComposed), (0, _defineProperty3.default)(_compostedUpdaters, _actionTypes2.default.ADD_DATA_TO_MAP, addDataToMapComposed), _compostedUpdaters); exports.default = compostedUpdaters; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/reducers/composers.js"],"names":["updateVisDataComposed","state","action","oldLayers","visState","layers","defaultOptions","centerMap","options","bounds","newLayers","filter","find","ol","nl","mapState","payload","uiState","hasOwnProperty","readOnly","addDataToMapComposed","datasets","config","parsedConfig","version","KeplerGlSchema","parseSavedConfig","mergedState","mapStyle","compostedUpdaters","ActionTypes","UPDATE_VIS_DATA","ADD_DATA_TO_MAP"],"mappings":";;;;;;;;;;;;;;;wBAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;AACA;;AACA;;AACA;;AAEA;;AACA;;AACA;;;;;;AAEA;;AAEA;;;;;;;;;;AAUO,IAAMA,wDAAwB,SAAxBA,qBAAwB,CAACC,KAAD,EAAQC,MAAR,EAAmB;AACtD;AACA,MAAMC,YAAYF,MAAMG,QAAN,CAAeC,MAAjC;;AAEA,MAAMD,WAAW,4CAAqBH,MAAMG,QAA3B,EAAqCF,MAArC,CAAjB;;AAEA,MAAMI,iBAAiB;AACrBC,eAAW;AADU,GAAvB;;AAIA,MAAMC,qCACDF,cADC,EAEDJ,OAAOM,OAFN,CAAN;;AAKA,MAAIC,eAAJ;AACA,MAAID,QAAQD,SAAZ,EAAuB;AACrB;AACA,QAAMG,YAAYN,SAASC,MAAT,CAAgBM,MAAhB,CAAuB;AAAA,aAAM,CAACR,UAAUS,IAAV,CAAe;AAAA,eAAMC,OAAOC,EAAb;AAAA,OAAf,CAAP;AAAA,KAAvB,CAAlB;AACAL,aAAS,8BAAcC,SAAd,CAAT;AACD;;AAED,oCACKT,KADL;AAEEG,sBAFF;AAGEW,cAAUN,SACN,wCAAiBR,MAAMc,QAAvB,EAAiC;AAC/BC,eAASP;AADsB,KAAjC,CADM,GAINR,MAAMc,QAPZ;AAQEE,wCACK,yCAAmBhB,MAAMgB,OAAzB,EAAkC,EAACD,SAAS,IAAV,EAAlC,CADL,EAEMR,QAAQU,cAAR,CAAuB,UAAvB,IAAqC,EAACC,UAAUX,QAAQW,QAAnB,EAArC,GAAoE,EAF1E;AARF;AAaD,CAnCM;;AAqCP;;;;;;AAMO,IAAMC,sDAAuB,SAAvBA,oBAAuB,CAACnB,KAAD,EAAQC,MAAR,EAAmB;AAAA,wBAEjBA,OAAOc,OAFU;AAAA,MAE9CK,QAF8C,mBAE9CA,QAF8C;AAAA,MAEpCb,OAFoC,mBAEpCA,OAFoC;AAAA,MAE3Bc,MAF2B,mBAE3BA,MAF2B;;AAGrD,MAAIC,eAAeD,MAAnB;;AAEA,MAAIA,UAAUA,OAAOA,MAAjB,IAA2BA,OAAOE,OAAtC,EAA+C;AAC7C;AACAD,mBAAeE,kBAAeC,gBAAf,CAAgCJ,MAAhC,CAAf;AACD;AACD;AACA,MAAIK,cAAc3B,sBAAsBC,KAAtB,EAA6B,EAACoB,kBAAD,EAAWb,gBAAX,EAAoBc,QAAQC,gBAAgBA,aAAanB,QAAzD,EAA7B,CAAlB;;AAEA;AACAuB,2CACKA,WADL;AAEEZ,cAAU,+CAAsBY,YAAYZ,QAAlC,EAA4C,EAACC,SAAS,EAACD,UAAUQ,gBAAgBA,aAAaR,QAAxC,EAAV,EAA5C;AAFZ;;AAKA;AACAY,2CACKA,WADL;AAEEC,cAAU,+CAAsBD,YAAYC,QAAlC,EAA4C,EAACZ,SAAS,EAACY,UAAUL,gBAAgBA,aAAaK,QAAxC,EAAV,EAA5C;AAFZ;;AAKA,SAAOD,WAAP;AACD,CAzBM;;AA2BP,IAAME,gGACHC,sBAAYC,eADT,EAC2B/B,qBAD3B,qDAEH8B,sBAAYE,eAFT,EAE2BZ,oBAF3B,sBAAN;;kBAKeS,iB","file":"composers.js","sourcesContent":["// Copyright (c) 2018 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 ActionTypes from 'constants/action-types';\nimport {fitBoundsUpdater} from './map-state-updaters';\nimport {toggleModalUpdater} from './ui-state-updaters';\nimport {updateVisDataUpdater} from './vis-state-updaters';\nimport {receiveMapConfigUpdater as stateMapConfigUpdater} from './map-state-updaters';\nimport {receiveMapConfigUpdater as styleMapConfigUpdater} from './map-style-updaters';\nimport {findMapBounds} from 'utils/data-utils';\nimport KeplerGlSchema from 'schemas';\n\n// compose action to apply result multiple reducers, with the output of one\n\n/**\n * Apply data and config to visState reducer\n * @param {object} state\n * @param {object} action\n * @param {object} action.options\n * @param {Boolean} action.options.centerMap\n * @param {Boolean} action.options.readOnly\n * @param {object} action.config\n * @returns state new reducer state\n */\nexport const updateVisDataComposed = (state, action) => {\n  // keep a copy of oldLayers\n  const oldLayers = state.visState.layers;\n\n  const visState = updateVisDataUpdater(state.visState, action);\n\n  const defaultOptions = {\n    centerMap: true\n  };\n\n  const options = {\n    ...defaultOptions,\n    ...action.options\n  };\n\n  let bounds;\n  if (options.centerMap) {\n    // find map bounds for new layers\n    const newLayers = visState.layers.filter(nl => !oldLayers.find(ol => ol === nl));\n    bounds = findMapBounds(newLayers);\n  }\n\n  return {\n    ...state,\n    visState,\n    mapState: bounds\n      ? fitBoundsUpdater(state.mapState, {\n          payload: bounds\n        })\n      : state.mapState,\n    uiState: {\n      ...toggleModalUpdater(state.uiState, {payload: null}),\n      ...(options.hasOwnProperty('readOnly') ? {readOnly: options.readOnly} : {})\n    }\n  };\n};\n\n/**\n * Combine data and full configuration update in a single action\n * @param state\n * @param action {datasets, options, config}\n * @returns state\n */\nexport const addDataToMapComposed = (state, action) => {\n\n  const {datasets, options, config} = action.payload;\n  let parsedConfig = config;\n\n  if (config && config.config && config.version) {\n    // if passed in saved config\n    parsedConfig = KeplerGlSchema.parseSavedConfig(config)\n  }\n  // Update visState store\n  let mergedState = updateVisDataComposed(state, {datasets, options, config: parsedConfig && parsedConfig.visState});\n\n  // Update mapState store\n  mergedState = {\n    ...mergedState,\n    mapState: stateMapConfigUpdater(mergedState.mapState, {payload: {mapState: parsedConfig && parsedConfig.mapState}})\n  };\n\n  // Update mapStyle store\n  mergedState = {\n    ...mergedState,\n    mapStyle: styleMapConfigUpdater(mergedState.mapStyle, {payload: {mapStyle: parsedConfig && parsedConfig.mapStyle}})\n  };\n\n  return mergedState\n};\n\nconst compostedUpdaters = {\n  [ActionTypes.UPDATE_VIS_DATA]: updateVisDataComposed,\n  [ActionTypes.ADD_DATA_TO_MAP]: addDataToMapComposed\n};\n\nexport default compostedUpdaters;\n"]}