UNPKG

kepler.gl

Version:

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

158 lines (141 loc) 14.7 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.set3dBuildingColor = exports.loadCustomMapStyle = exports.mapStyleChange = exports.loadMapStyleErr = exports.loadMapStyles = exports.requestMapStyles = exports.mapConfigChange = exports.inputMapStyle = exports.addCustomMapStyle = void 0; var _reduxActions = require("redux-actions"); var _actionTypes = _interopRequireDefault(require("../constants/action-types")); // Copyright (c) 2020 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. /** * Add map style from user input to reducer and set it to current style * This action is called when user click confirm after putting in a valid style url in the custom map style dialog. * It should not be called from outside kepler.gl without a valid `inputStyle` in the `mapStyle` reducer. * param {void} * @memberof mapStyleActions * @public */ var addCustomMapStyle = (0, _reduxActions.createAction)(_actionTypes["default"].ADD_CUSTOM_MAP_STYLE); /** * Input a custom map style object * @memberof mapStyleActions * @param {Object} inputStyle * @param {string} inputStyle.url - style url e.g. `'mapbox://styles/heshan/xxxxxyyyyzzz'` * @param {string} inputStyle.id - style url e.g. `'custom_style_1'` * @param {Object} inputStyle.style - actual mapbox style json * @param {string} inputStyle.name - style name * @param {Object} inputStyle.layerGroups - layer groups that can be used to set map layer visibility * @param {Object} inputStyle.icon - icon image data url * @param {Object} mapState - mapState is optional * @public */ exports.addCustomMapStyle = addCustomMapStyle; var inputMapStyle = (0, _reduxActions.createAction)(_actionTypes["default"].INPUT_MAP_STYLE, function (inputStyle, mapState) { return { inputStyle: inputStyle, mapState: mapState }; }); /** * Update `visibleLayerGroups`to change layer group visibility * @memberof mapStyleActions * @param {Object} mapStyle new config `{visibleLayerGroups: {label: false, road: true, background: true}}` * @public */ exports.inputMapStyle = inputMapStyle; var mapConfigChange = (0, _reduxActions.createAction)(_actionTypes["default"].MAP_CONFIG_CHANGE, function (mapStyle) { return mapStyle; }); /** * Request map style style object based on style.url. * @memberof mapStyleActions * @param {Array<Object>} mapStyles * @public */ exports.mapConfigChange = mapConfigChange; var requestMapStyles = (0, _reduxActions.createAction)(_actionTypes["default"].REQUEST_MAP_STYLES, function (mapStyles) { return mapStyles; }); /** * Callback when load map style success * @memberof mapStyleActions * @param {Object} newStyles a `{[id]: style}` mapping * @public */ exports.requestMapStyles = requestMapStyles; var loadMapStyles = (0, _reduxActions.createAction)(_actionTypes["default"].LOAD_MAP_STYLES, function (newStyles) { return newStyles; }); /** * Callback when load map style error * @memberof mapStyleActions * @param {*} error * @public */ exports.loadMapStyles = loadMapStyles; var loadMapStyleErr = (0, _reduxActions.createAction)(_actionTypes["default"].LOAD_MAP_STYLE_ERR, function (error) { return error; }); /** * Change to another map style. The selected style should already been loaded into `mapStyle.mapStyles` * @memberof mapStyleActions * @param {string} styleType the style to change to * @public */ exports.loadMapStyleErr = loadMapStyleErr; var mapStyleChange = (0, _reduxActions.createAction)(_actionTypes["default"].MAP_STYLE_CHANGE, function (styleType) { return styleType; }); /** * Callback when a custom map style object is received * @memberof mapStyleActions * @param {Object} customMapStyle * @param {string} customMapStyle.icon * @param {Object} customMapStyle.style * @param {*} customMapStyle.error * @public */ exports.mapStyleChange = mapStyleChange; var loadCustomMapStyle = (0, _reduxActions.createAction)(_actionTypes["default"].LOAD_CUSTOM_MAP_STYLE, function (customMapStyle) { return customMapStyle; }); // SET_3D_BUILDING_COLOR /** * Set 3d building layer group color * @memberof mapStyleActions * @param {Array} color - [r, g, b] * @public */ exports.loadCustomMapStyle = loadCustomMapStyle; var set3dBuildingColor = (0, _reduxActions.createAction)(_actionTypes["default"].SET_3D_BUILDING_COLOR, function (color) { return color; }); /** * Actions handled mostly by `mapStyle` reducer. * They manage the display of base map, such as loading and receiving base map styles, * hiding and showing map layers, user input of custom map style url. * * @public */ /* eslint-disable no-unused-vars */ exports.set3dBuildingColor = set3dBuildingColor; var mapStyleActions = null; /* eslint-enable no-unused-vars */ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/actions/map-style-actions.js"],"names":["addCustomMapStyle","ActionTypes","ADD_CUSTOM_MAP_STYLE","inputMapStyle","INPUT_MAP_STYLE","inputStyle","mapState","mapConfigChange","MAP_CONFIG_CHANGE","mapStyle","requestMapStyles","REQUEST_MAP_STYLES","mapStyles","loadMapStyles","LOAD_MAP_STYLES","newStyles","loadMapStyleErr","LOAD_MAP_STYLE_ERR","error","mapStyleChange","MAP_STYLE_CHANGE","styleType","loadCustomMapStyle","LOAD_CUSTOM_MAP_STYLE","customMapStyle","set3dBuildingColor","SET_3D_BUILDING_COLOR","color","mapStyleActions"],"mappings":";;;;;;;;;AAoBA;;AACA;;AArBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAKA;;;;;;;;AAQO,IAAMA,iBAAiB,GAAG,gCAAaC,wBAAYC,oBAAzB,CAA1B;AAEP;;;;;;;;;;;;;;;AAaO,IAAMC,aAAa,GAAG,gCAAaF,wBAAYG,eAAzB,EAA0C,UAACC,UAAD,EAAaC,QAAb;AAAA,SAA2B;AAChGD,IAAAA,UAAU,EAAVA,UADgG;AAEhGC,IAAAA,QAAQ,EAARA;AAFgG,GAA3B;AAAA,CAA1C,CAAtB;AAKP;;;;;;;;AAMO,IAAMC,eAAe,GAAG,gCAAaN,wBAAYO,iBAAzB,EAA4C,UAAAC,QAAQ;AAAA,SAAIA,QAAJ;AAAA,CAApD,CAAxB;AAEP;;;;;;;;AAMO,IAAMC,gBAAgB,GAAG,gCAC9BT,wBAAYU,kBADkB,EAE9B,UAAAC,SAAS;AAAA,SAAIA,SAAJ;AAAA,CAFqB,CAAzB;AAIP;;;;;;;;AAMO,IAAMC,aAAa,GAAG,gCAAaZ,wBAAYa,eAAzB,EAA0C,UAAAC,SAAS;AAAA,SAAIA,SAAJ;AAAA,CAAnD,CAAtB;AAEP;;;;;;;;AAMO,IAAMC,eAAe,GAAG,gCAAaf,wBAAYgB,kBAAzB,EAA6C,UAAAC,KAAK;AAAA,SAAIA,KAAJ;AAAA,CAAlD,CAAxB;AAEP;;;;;;;;AAMO,IAAMC,cAAc,GAAG,gCAAalB,wBAAYmB,gBAAzB,EAA2C,UAAAC,SAAS;AAAA,SAAIA,SAAJ;AAAA,CAApD,CAAvB;AAEP;;;;;;;;;;;AASO,IAAMC,kBAAkB,GAAG,gCAChCrB,wBAAYsB,qBADoB,EAEhC,UAAAC,cAAc;AAAA,SAAIA,cAAJ;AAAA,CAFkB,CAA3B,C,CAKP;;AACA;;;;;;;;AAMO,IAAMC,kBAAkB,GAAG,gCAAaxB,wBAAYyB,qBAAzB,EAAgD,UAAAC,KAAK;AAAA,SAAIA,KAAJ;AAAA,CAArD,CAA3B;AAEP;;;;;;;;AAOA;;;AACA,IAAMC,eAAe,GAAG,IAAxB;AACA","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 {createAction} from 'redux-actions';\nimport ActionTypes from 'constants/action-types';\n\n/**\n * Add map style from user input to reducer and set it to current style\n * This action is called when user click confirm after putting in a valid style url in the custom map style dialog.\n * It should not be called from outside kepler.gl without a valid `inputStyle` in the `mapStyle` reducer.\n * param {void}\n * @memberof mapStyleActions\n * @public\n */\nexport const addCustomMapStyle = createAction(ActionTypes.ADD_CUSTOM_MAP_STYLE);\n\n/**\n * Input a custom map style object\n * @memberof mapStyleActions\n * @param {Object} inputStyle\n * @param {string} inputStyle.url - style url e.g. `'mapbox://styles/heshan/xxxxxyyyyzzz'`\n * @param {string} inputStyle.id - style url e.g. `'custom_style_1'`\n * @param {Object} inputStyle.style - actual mapbox style json\n * @param {string} inputStyle.name - style name\n * @param {Object} inputStyle.layerGroups - layer groups that can be used to set map layer visibility\n * @param {Object} inputStyle.icon - icon image data url\n * @param {Object} mapState - mapState is optional\n * @public\n */\nexport const inputMapStyle = createAction(ActionTypes.INPUT_MAP_STYLE, (inputStyle, mapState) => ({\n  inputStyle,\n  mapState\n}));\n\n/**\n * Update `visibleLayerGroups`to change layer group visibility\n * @memberof mapStyleActions\n * @param {Object} mapStyle new config `{visibleLayerGroups: {label: false, road: true, background: true}}`\n * @public\n */\nexport const mapConfigChange = createAction(ActionTypes.MAP_CONFIG_CHANGE, mapStyle => mapStyle);\n\n/**\n * Request map style style object based on style.url.\n * @memberof mapStyleActions\n * @param {Array<Object>} mapStyles\n * @public\n */\nexport const requestMapStyles = createAction(\n  ActionTypes.REQUEST_MAP_STYLES,\n  mapStyles => mapStyles\n);\n/**\n * Callback when load map style success\n * @memberof mapStyleActions\n * @param {Object} newStyles a `{[id]: style}` mapping\n * @public\n */\nexport const loadMapStyles = createAction(ActionTypes.LOAD_MAP_STYLES, newStyles => newStyles);\n\n/**\n * Callback when load map style error\n * @memberof mapStyleActions\n * @param {*} error\n * @public\n */\nexport const loadMapStyleErr = createAction(ActionTypes.LOAD_MAP_STYLE_ERR, error => error);\n\n/**\n * Change to another map style. The selected style should already been loaded into `mapStyle.mapStyles`\n * @memberof mapStyleActions\n * @param {string} styleType the style to change to\n * @public\n */\nexport const mapStyleChange = createAction(ActionTypes.MAP_STYLE_CHANGE, styleType => styleType);\n\n/**\n * Callback when a custom map style object is received\n * @memberof mapStyleActions\n * @param {Object} customMapStyle\n * @param {string} customMapStyle.icon\n * @param {Object} customMapStyle.style\n * @param {*} customMapStyle.error\n * @public\n */\nexport const loadCustomMapStyle = createAction(\n  ActionTypes.LOAD_CUSTOM_MAP_STYLE,\n  customMapStyle => customMapStyle\n);\n\n// SET_3D_BUILDING_COLOR\n/**\n * Set 3d building layer group color\n * @memberof mapStyleActions\n * @param {Array} color - [r, g, b]\n * @public\n */\nexport const set3dBuildingColor = createAction(ActionTypes.SET_3D_BUILDING_COLOR, color => color);\n\n/**\n * Actions handled mostly by  `mapStyle` reducer.\n * They manage the display of base map, such as loading and receiving base map styles,\n * hiding and showing map layers, user input of custom map style url.\n *\n * @public\n */\n/* eslint-disable no-unused-vars */\nconst mapStyleActions = null;\n/* eslint-enable no-unused-vars */\n"]}