UNPKG

kepler.gl.geoiq

Version:

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

134 lines (102 loc) 15.8 kB
"use strict"; 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 _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); 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 _colorSelector = _interopRequireDefault(require("./color-selector")); var _fieldSelector = _interopRequireDefault(require("../../common/field-selector")); var _itemSelector = _interopRequireDefault(require("../../common/item-selector/item-selector")); var _layerConfigGroup = _interopRequireWildcard(require("./layer-config-group")); var _rangeSlider = _interopRequireDefault(require("../../common/range-slider")); var _layerFactory = require("../../../layers/layer-factory"); function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } var LayerConfigurator = /*#__PURE__*/ function (_Component) { (0, _inherits2["default"])(LayerConfigurator, _Component); function LayerConfigurator() { var _getPrototypeOf2; var _this; (0, _classCallCheck2["default"])(this, LayerConfigurator); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = (0, _possibleConstructorReturn2["default"])(this, (_getPrototypeOf2 = (0, _getPrototypeOf3["default"])(LayerConfigurator)).call.apply(_getPrototypeOf2, [this].concat(args))); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onAttributeChange", function (attribute) { var _this$props = _this.props, layerConfiguratorProps = _this$props.layerConfiguratorProps, textLabel = _this$props.textLabel; return function (v) { return layerConfiguratorProps.onChange({ textLabel: _objectSpread({}, textLabel, (0, _defineProperty2["default"])({}, attribute, v)) }); }; }); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onChangeTextAnchor", function (anchor) { var _this$props2 = _this.props, layerConfiguratorProps = _this$props2.layerConfiguratorProps, textLabel = _this$props2.textLabel; // TODO: we can be smarter on determining the offset of the text layerConfiguratorProps.onChange({ textLabel: _objectSpread({}, textLabel, { anchor: anchor, offset: [anchor === 'start' ? 10 : anchor === 'end' ? -10 : 0, anchor === 'middle' ? 10 : 0] }) }); }); return _this; } (0, _createClass2["default"])(LayerConfigurator, [{ key: "render", value: function render() { var _this2 = this; var _this$props3 = this.props, visConfiguratorProps = _this$props3.visConfiguratorProps, textLabel = _this$props3.textLabel; return _react["default"].createElement(_layerConfigGroup["default"], { label: 'label', collapsible: true }, _react["default"].createElement(_styledComponents.SidePanelSection, null, _react["default"].createElement(_fieldSelector["default"], { fields: visConfiguratorProps.fields, value: textLabel.field && textLabel.field.name || 'select a field', placeholder: 'empty', onSelect: this.onAttributeChange('field'), erasable: true })), _react["default"].createElement(_layerConfigGroup.ConfigGroupCollapsibleContent, null, _react["default"].createElement(_styledComponents.SidePanelSection, null, _react["default"].createElement(_styledComponents.PanelLabel, null, "Font size"), _react["default"].createElement(_rangeSlider["default"], (0, _extends2["default"])({}, _layerFactory.LAYER_TEXT_CONFIGS.fontSize, { value1: textLabel.size, onChange: function onChange(v) { return _this2.onAttributeChange('size')(v[1]); } }))), _react["default"].createElement(_styledComponents.SidePanelSection, null, _react["default"].createElement(_styledComponents.PanelLabel, null, "Font color"), _react["default"].createElement(_colorSelector["default"], { colorSets: [{ selectedColor: textLabel.color, setColor: this.onAttributeChange('color') }] })), _react["default"].createElement(_styledComponents.SidePanelSection, null, _react["default"].createElement(_styledComponents.PanelLabel, null, "Text anchor"), _react["default"].createElement(_itemSelector["default"], (0, _extends2["default"])({}, _layerFactory.LAYER_TEXT_CONFIGS.textAnchor, { selectedItems: textLabel.anchor, onChange: this.onChangeTextAnchor }))))); } }]); return LayerConfigurator; }(_react.Component); exports["default"] = LayerConfigurator; (0, _defineProperty2["default"])(LayerConfigurator, "propTypes", { layerConfiguratorProps: _propTypes["default"].object.isRequired, textLabel: _propTypes["default"].object.isRequired, visConfiguratorProps: _propTypes["default"].object.isRequired }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/text-label-panel.js"],"names":["LayerConfigurator","attribute","props","layerConfiguratorProps","textLabel","v","onChange","anchor","offset","visConfiguratorProps","fields","field","name","onAttributeChange","LAYER_TEXT_CONFIGS","fontSize","size","selectedColor","color","setColor","textAnchor","onChangeTextAnchor","Component","PropTypes","object","isRequired"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAoBA;;AACA;;AAEA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;;;;;IAEqBA,iB;;;;;;;;;;;;;;;;;0GAOC,UAAAC,SAAS,EAAI;AAAA,wBACa,MAAKC,KADlB;AAAA,UACxBC,sBADwB,eACxBA,sBADwB;AAAA,UACAC,SADA,eACAA,SADA;AAE/B,aAAO,UAAAC,CAAC;AAAA,eAAIF,sBAAsB,CAACG,QAAvB,CAAgC;AAC1CF,UAAAA,SAAS,oBACJA,SADI,uCAENH,SAFM,EAEMI,CAFN;AADiC,SAAhC,CAAJ;AAAA,OAAR;AAMD,K;2GAEoB,UAAAE,MAAM,EAAI;AAAA,yBACe,MAAKL,KADpB;AAAA,UACtBC,sBADsB,gBACtBA,sBADsB;AAAA,UACEC,SADF,gBACEA,SADF,EAE7B;;AACAD,MAAAA,sBAAsB,CAACG,QAAvB,CAAgC;AAC9BF,QAAAA,SAAS,oBACJA,SADI;AAEPG,UAAAA,MAAM,EAANA,MAFO;AAGPC,UAAAA,MAAM,EAAE,CACND,MAAM,KAAK,OAAX,GAAqB,EAArB,GAA0BA,MAAM,KAAK,KAAX,GAAmB,CAAC,EAApB,GAAyB,CAD7C,EAENA,MAAM,KAAK,QAAX,GAAsB,EAAtB,GAA2B,CAFrB;AAHD;AADqB,OAAhC;AAUD,K;;;;;;6BAEQ;AAAA;;AAAA,yBAIH,KAAKL,KAJF;AAAA,UAELO,oBAFK,gBAELA,oBAFK;AAAA,UAGLL,SAHK,gBAGLA,SAHK;AAKP,aACE,gCAAC,4BAAD;AAAkB,QAAA,KAAK,EAAE,OAAzB;AAAkC,QAAA,WAAW;AAA7C,SACI,gCAAC,kCAAD,QACE,gCAAC,yBAAD;AACE,QAAA,MAAM,EAAEK,oBAAoB,CAACC,MAD/B;AAEE,QAAA,KAAK,EAAEN,SAAS,CAACO,KAAV,IAAmBP,SAAS,CAACO,KAAV,CAAgBC,IAAnC,IAA2C,gBAFpD;AAGE,QAAA,WAAW,EAAE,OAHf;AAIE,QAAA,QAAQ,EAAE,KAAKC,iBAAL,CAAuB,OAAvB,CAJZ;AAKE,QAAA,QAAQ;AALV,QADF,CADJ,EAUI,gCAAC,+CAAD,QACE,gCAAC,kCAAD,QACE,gCAAC,4BAAD,oBADF,EAEE,gCAAC,uBAAD,gCACMC,iCAAmBC,QADzB;AAEE,QAAA,MAAM,EAAEX,SAAS,CAACY,IAFpB;AAGE,QAAA,QAAQ,EAAE,kBAAAX,CAAC;AAAA,iBAAI,MAAI,CAACQ,iBAAL,CAAuB,MAAvB,EAA+BR,CAAC,CAAC,CAAD,CAAhC,CAAJ;AAAA;AAHb,SAFF,CADF,EASE,gCAAC,kCAAD,QACA,gCAAC,4BAAD,qBADA,EAEE,gCAAC,yBAAD;AACE,QAAA,SAAS,EAAE,CACT;AACEY,UAAAA,aAAa,EAAEb,SAAS,CAACc,KAD3B;AAEEC,UAAAA,QAAQ,EAAE,KAAKN,iBAAL,CAAuB,OAAvB;AAFZ,SADS;AADb,QAFF,CATF,EAoBE,gCAAC,kCAAD,QACE,gCAAC,4BAAD,sBADF,EAEE,gCAAC,wBAAD,gCACMC,iCAAmBM,UADzB;AAEE,QAAA,aAAa,EAAEhB,SAAS,CAACG,MAF3B;AAGE,QAAA,QAAQ,EAAE,KAAKc;AAHjB,SAFF,CApBF,CAVJ,CADF;AA0CD;;;EA/E4CC,gB;;;iCAA1BtB,iB,eACA;AACjBG,EAAAA,sBAAsB,EAAEoB,sBAAUC,MAAV,CAAiBC,UADxB;AAEjBrB,EAAAA,SAAS,EAAEmB,sBAAUC,MAAV,CAAiBC,UAFX;AAGjBhB,EAAAA,oBAAoB,EAAEc,sBAAUC,MAAV,CAAiBC;AAHtB,C","sourcesContent":["// Copyright (c) 2019 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 {PanelLabel, SidePanelSection} from 'components/common/styled-components';\nimport ColorSelector from './color-selector';\nimport FieldSelector from 'components/common/field-selector';\nimport ItemSelector from 'components/common/item-selector/item-selector';\nimport LayerConfigGroup, {ConfigGroupCollapsibleContent} from './layer-config-group';\nimport RangeSlider from 'components/common/range-slider';\n\nimport {LAYER_TEXT_CONFIGS} from 'layers/layer-factory';\n\nexport default class LayerConfigurator extends Component {\n  static propTypes = {\n    layerConfiguratorProps: PropTypes.object.isRequired,\n    textLabel: PropTypes.object.isRequired,\n    visConfiguratorProps: PropTypes.object.isRequired\n  };\n\n  onAttributeChange = attribute => {\n    const {layerConfiguratorProps, textLabel} = this.props;\n    return v => layerConfiguratorProps.onChange({\n      textLabel: {\n        ...textLabel,\n        [attribute]: v\n      }\n    });\n  };\n\n  onChangeTextAnchor = anchor => {\n    const {layerConfiguratorProps, textLabel} = this.props;\n    // TODO: we can be smarter on determining the offset of the text\n    layerConfiguratorProps.onChange({\n      textLabel: {\n        ...textLabel,\n        anchor,\n        offset: [\n          anchor === 'start' ? 10 : anchor === 'end' ? -10 : 0,\n          anchor === 'middle' ? 10 : 0\n        ]\n      }\n    });\n  };\n\n  render() {\n    const {\n      visConfiguratorProps,\n      textLabel\n    } = this.props;\n    return (\n      <LayerConfigGroup label={'label'} collapsible>\n          <SidePanelSection> \n            <FieldSelector\n              fields={visConfiguratorProps.fields}\n              value={textLabel.field && textLabel.field.name || 'select a field'}\n              placeholder={'empty'}\n              onSelect={this.onAttributeChange('field')}\n              erasable\n            />\n          </SidePanelSection>\n          <ConfigGroupCollapsibleContent>\n            <SidePanelSection>\n              <PanelLabel>{`Font size`}</PanelLabel>\n              <RangeSlider\n                {...LAYER_TEXT_CONFIGS.fontSize}\n                value1={textLabel.size}\n                onChange={v => this.onAttributeChange('size')(v[1])}\n              />\n            </SidePanelSection>\n            <SidePanelSection>\n            <PanelLabel>{`Font color`}</PanelLabel>\n              <ColorSelector\n                colorSets={[\n                  {\n                    selectedColor: textLabel.color,\n                    setColor: this.onAttributeChange('color')\n                  }\n                ]}\n              />\n            </SidePanelSection>\n            <SidePanelSection>\n              <PanelLabel>{`Text anchor`}</PanelLabel>\n              <ItemSelector\n                {...LAYER_TEXT_CONFIGS.textAnchor}\n                selectedItems={textLabel.anchor}\n                onChange={this.onChangeTextAnchor}\n              />\n            </SidePanelSection>\n          </ConfigGroupCollapsibleContent>\n      </LayerConfigGroup>\n    );\n  }\n}\n"]}