kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
156 lines (117 loc) • 18.5 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
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 _defaultSettings = require("../../constants/default-settings");
var _colorSelector = _interopRequireDefault(require("./layer-panel/color-selector"));
var _reselect = require("reselect");
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
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; }
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 _class, _temp;
return _temp = _class = /*#__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.set3dBuildingColor;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "colorSetSelector", (0, _reselect.createSelector)(_this.buildingColorSelector, _this.setColorSelector, function (selectedColor, setColor) {
return [{
selectedColor: selectedColor,
setColor: setColor,
isRange: false,
label: '3D Building Color'
}];
}));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_updateConfig", function (newProp) {
var newConfig = _objectSpread(_objectSpread({}, _this.props.mapStyle), newProp);
_this.props.onConfigChange(newConfig);
});
(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) {
_this.props.onStyleChange(val);
_this._toggleSelecting();
});
return _this;
}
(0, _createClass2["default"])(MapManager, [{
key: "render",
value: function render() {
var mapStyle = this.props.mapStyle;
var editableLayers = _defaultSettings.DEFAULT_LAYER_GROUPS.map(function (lg) {
return lg.slug;
});
var hasBuildingLayer = mapStyle.visibleLayerGroups['3d building'];
var colorSets = this.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: this._updateConfig
}) : null, /*#__PURE__*/_react["default"].createElement(_styledComponents.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(_colorSelector["default"], {
colorSets: colorSets,
disabled: !hasBuildingLayer
})), /*#__PURE__*/_react["default"].createElement(_styledComponents.Button, {
onClick: this.props.showAddMapStyleModal,
secondary: true
}, /*#__PURE__*/_react["default"].createElement(_icons.Add, {
height: "12px"
}), "Add Map Style")))
);
}
}]);
return MapManager;
}(_react.Component), (0, _defineProperty2["default"])(_class, "propTypes", {
mapStyle: _propTypes["default"].object.isRequired,
onConfigChange: _propTypes["default"].func.isRequired,
onStyleChange: _propTypes["default"].func.isRequired,
showAddMapStyleModal: _propTypes["default"].func.isRequired
}), _temp;
}
var _default = exports["default"] = MapManagerFactory;
//# 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","isSelecting","props","mapStyle","threeDBuildingColor","set3dBuildingColor","buildingColorSelector","setColorSelector","selectedColor","setColor","isRange","label","newProp","newConfig","onConfigChange","setState","state","val","onStyleChange","_toggleSelecting","editableLayers","DEFAULT_LAYER_GROUPS","map","lg","slug","hasBuildingLayer","visibleLayerGroups","colorSets","colorSetSelector","_selectStyle","length","topLayerGroups","_updateConfig","showAddMapStyleModal","Component","PropTypes","object","isRequired","func"],"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 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 {DEFAULT_LAYER_GROUPS} from 'constants/default-settings';\nimport ColorSelector from './layer-panel/color-selector';\nimport {createSelector} from 'reselect';\n\nMapManagerFactory.deps = [MapStyleSelectorFactory, LayerGroupSelectorFactory];\n\nfunction MapManagerFactory(MapStyleSelector, LayerGroupSelector) {\n  return class MapManager extends Component {\n    static propTypes = {\n      mapStyle: PropTypes.object.isRequired,\n      onConfigChange: PropTypes.func.isRequired,\n      onStyleChange: PropTypes.func.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.set3dBuildingColor;\n    colorSetSelector = createSelector(\n      this.buildingColorSelector,\n      this.setColorSelector,\n      (selectedColor, setColor) => ([{\n        selectedColor,\n        setColor,\n        isRange: false,\n        label: '3D Building Color'\n      }])\n    );\n\n    _updateConfig = newProp => {\n      const newConfig = {...this.props.mapStyle, ...newProp};\n      this.props.onConfigChange(newConfig);\n    };\n\n    _toggleSelecting = () => {\n      this.setState({isSelecting: !this.state.isSelecting});\n    };\n\n    _selectStyle = val => {\n      this.props.onStyleChange(val);\n      this._toggleSelecting();\n    };\n\n    render() {\n      const {mapStyle} = this.props;\n      const editableLayers = DEFAULT_LAYER_GROUPS.map(lg => lg.slug);\n      const hasBuildingLayer = mapStyle.visibleLayerGroups['3d building'];\n      const colorSets = this.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={this._updateConfig}\n              />\n            ) : null}\n            <SidePanelSection>\n              <ColorSelector\n                colorSets={colorSets}\n                disabled={!hasBuildingLayer}\n              />\n            </SidePanelSection>\n            <Button onClick={this.props.showAddMapStyleModal} secondary>\n              <Add height=\"12px\" />\n              Add Map Style\n            </Button>\n          </div>\n        </div>\n      );\n    }\n  };\n}\n\nexport default MapManagerFactory;\n"]}