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
JavaScript
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"]}
;