kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
155 lines (122 loc) • 17.6 kB
JavaScript
;
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _styledComponents = require("../common/styled-components");
var _mapStyleSelector = _interopRequireDefault(require("./map-style-panel/map-style-selector"));
var _mapLayerSelector = _interopRequireDefault(require("./map-style-panel/map-layer-selector"));
var _icons = require("../common/icons");
var _colorSelector = _interopRequireDefault(require("./layer-panel/color-selector"));
var _reselect = require("reselect");
var _reactIntl = require("react-intl");
var _localization = require("../../localization");
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
MapManagerFactory.deps = [_mapStyleSelector["default"], _mapLayerSelector["default"]];
function MapManagerFactory(MapStyleSelector, LayerGroupSelector) {
var MapManager = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(MapManager, _Component);
var _super = _createSuper(MapManager);
function MapManager() {
var _this;
(0, _classCallCheck2["default"])(this, MapManager);
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
_this = _super.call.apply(_super, [this].concat(args));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "state", {
isSelecting: false
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "buildingColorSelector", function (props) {
return props.mapStyle.threeDBuildingColor;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "setColorSelector", function (props) {
return props.mapStyleActions.set3dBuildingColor;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_toggleSelecting", function () {
_this.setState({
isSelecting: !_this.state.isSelecting
});
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_selectStyle", function (val) {
var mapStyleActions = _this.props.mapStyleActions;
var mapStyleChange = mapStyleActions.mapStyleChange;
mapStyleChange(val);
_this._toggleSelecting();
});
return _this;
}
(0, _createClass2["default"])(MapManager, [{
key: "render",
value: function render() {
var _this$props = this.props,
mapStyle = _this$props.mapStyle,
intl = _this$props.intl,
mapStyleActions = _this$props.mapStyleActions,
showAddMapStyleModal = _this$props.showAddMapStyleModal;
var currentStyle = mapStyle.mapStyles[mapStyle.styleType] || {};
var editableLayers = (currentStyle.layerGroups || []).map(function (lg) {
return lg.slug;
});
var hasBuildingLayer = mapStyle.visibleLayerGroups['3d building'];
var colorSetSelector = (0, _reselect.createSelector)(this.buildingColorSelector, this.setColorSelector, function (selectedColor, setColor) {
return [{
selectedColor: selectedColor,
setColor: setColor,
isRange: false,
label: intl.formatMessage({
id: 'mapManager.3dBuildingColor'
})
}];
});
var colorSets = colorSetSelector(this.props);
return /*#__PURE__*/_react["default"].createElement("div", {
className: "map-style-panel"
}, /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(MapStyleSelector, {
mapStyle: mapStyle,
isSelecting: this.state.isSelecting,
onChange: this._selectStyle,
toggleActive: this._toggleSelecting
}), editableLayers.length ? /*#__PURE__*/_react["default"].createElement(LayerGroupSelector, {
layers: mapStyle.visibleLayerGroups,
editableLayers: editableLayers,
topLayers: mapStyle.topLayerGroups,
onChange: mapStyleActions.mapConfigChange
}) : null, /*#__PURE__*/_react["default"].createElement(_styledComponents.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(_colorSelector["default"], {
colorSets: colorSets,
disabled: !hasBuildingLayer
})), /*#__PURE__*/_react["default"].createElement(_styledComponents.Button, {
className: "add-map-style-button",
onClick: showAddMapStyleModal,
secondary: true
}, /*#__PURE__*/_react["default"].createElement(_icons.Add, {
height: "12px"
}), /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: 'mapManager.addMapStyle'
}))));
}
}]);
return MapManager;
}(_react.Component);
(0, _defineProperty2["default"])(MapManager, "propTypes", {
mapStyle: _propTypes["default"].object.isRequired,
mapStyleActions: _propTypes["default"].object.isRequired,
showAddMapStyleModal: _propTypes["default"].func.isRequired
});
return (0, _reactIntl.injectIntl)(MapManager);
}
var _default = MapManagerFactory;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/side-panel/map-manager.js"],"names":["MapManagerFactory","deps","MapStyleSelectorFactory","LayerGroupSelectorFactory","MapStyleSelector","LayerGroupSelector","MapManager","isSelecting","props","mapStyle","threeDBuildingColor","mapStyleActions","set3dBuildingColor","setState","state","val","mapStyleChange","_toggleSelecting","intl","showAddMapStyleModal","currentStyle","mapStyles","styleType","editableLayers","layerGroups","map","lg","slug","hasBuildingLayer","visibleLayerGroups","colorSetSelector","buildingColorSelector","setColorSelector","selectedColor","setColor","isRange","label","formatMessage","id","colorSets","_selectStyle","length","topLayerGroups","mapConfigChange","Component","PropTypes","object","isRequired","func"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 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 React, {Component} from 'react';\nimport PropTypes from 'prop-types';\n\nimport {Button, SidePanelSection} from 'components/common/styled-components';\nimport MapStyleSelectorFactory from 'components/side-panel/map-style-panel/map-style-selector';\nimport LayerGroupSelectorFactory from 'components/side-panel/map-style-panel/map-layer-selector';\n\nimport {Add} from 'components/common/icons';\nimport ColorSelector from './layer-panel/color-selector';\nimport {createSelector} from 'reselect';\nimport {injectIntl} from 'react-intl';\nimport {FormattedMessage} from 'localization';\n\nMapManagerFactory.deps = [MapStyleSelectorFactory, LayerGroupSelectorFactory];\n\nfunction MapManagerFactory(MapStyleSelector, LayerGroupSelector) {\n  class MapManager extends Component {\n    static propTypes = {\n      mapStyle: PropTypes.object.isRequired,\n      mapStyleActions: PropTypes.object.isRequired,\n      showAddMapStyleModal: PropTypes.func.isRequired\n    };\n\n    state = {\n      isSelecting: false\n    };\n\n    buildingColorSelector = props => props.mapStyle.threeDBuildingColor;\n    setColorSelector = props => props.mapStyleActions.set3dBuildingColor;\n\n    _toggleSelecting = () => {\n      this.setState({isSelecting: !this.state.isSelecting});\n    };\n\n    _selectStyle = val => {\n      const {mapStyleActions} = this.props;\n      const {mapStyleChange} = mapStyleActions;\n      mapStyleChange(val);\n      this._toggleSelecting();\n    };\n\n    render() {\n      const {mapStyle, intl, mapStyleActions, showAddMapStyleModal} = this.props;\n      const currentStyle = mapStyle.mapStyles[mapStyle.styleType] || {};\n      const editableLayers = (currentStyle.layerGroups || []).map(lg => lg.slug);\n      const hasBuildingLayer = mapStyle.visibleLayerGroups['3d building'];\n      const colorSetSelector = createSelector(\n        this.buildingColorSelector,\n        this.setColorSelector,\n        (selectedColor, setColor) => [\n          {\n            selectedColor,\n            setColor,\n            isRange: false,\n            label: intl.formatMessage({id: 'mapManager.3dBuildingColor'})\n          }\n        ]\n      );\n\n      const colorSets = colorSetSelector(this.props);\n\n      return (\n        <div className=\"map-style-panel\">\n          <div>\n            <MapStyleSelector\n              mapStyle={mapStyle}\n              isSelecting={this.state.isSelecting}\n              onChange={this._selectStyle}\n              toggleActive={this._toggleSelecting}\n            />\n            {editableLayers.length ? (\n              <LayerGroupSelector\n                layers={mapStyle.visibleLayerGroups}\n                editableLayers={editableLayers}\n                topLayers={mapStyle.topLayerGroups}\n                onChange={mapStyleActions.mapConfigChange}\n              />\n            ) : null}\n            <SidePanelSection>\n              <ColorSelector colorSets={colorSets} disabled={!hasBuildingLayer} />\n            </SidePanelSection>\n            <Button className=\"add-map-style-button\" onClick={showAddMapStyleModal} secondary>\n              <Add height=\"12px\" />\n              <FormattedMessage id={'mapManager.addMapStyle'} />\n            </Button>\n          </div>\n        </div>\n      );\n    }\n  }\n  return injectIntl(MapManager);\n}\n\nexport default MapManagerFactory;\n"]}