UNPKG

kepler.gl

Version:

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

190 lines (148 loc) 15.2 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = undefined; var _defineProperty2 = require('babel-runtime/helpers/defineProperty'); var _defineProperty3 = _interopRequireDefault(_defineProperty2); var _extends3 = require('babel-runtime/helpers/extends'); var _extends4 = _interopRequireDefault(_extends3); var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); var _createClass2 = require('babel-runtime/helpers/createClass'); var _createClass3 = _interopRequireDefault(_createClass2); var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); var _inherits2 = require('babel-runtime/helpers/inherits'); var _inherits3 = _interopRequireDefault(_inherits2); var _class, _temp2; // Copyright (c) 2018 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. var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _styledComponents = require('../../common/styled-components'); var _colorSelector = require('./color-selector'); var _colorSelector2 = _interopRequireDefault(_colorSelector); var _fieldSelector = require('../../common/field-selector'); var _fieldSelector2 = _interopRequireDefault(_fieldSelector); var _itemSelector = require('../../common/item-selector/item-selector'); var _itemSelector2 = _interopRequireDefault(_itemSelector); var _layerConfigGroup = require('./layer-config-group'); var _layerConfigGroup2 = _interopRequireDefault(_layerConfigGroup); var _rangeSlider = require('../../common/range-slider'); var _rangeSlider2 = _interopRequireDefault(_rangeSlider); var _layerFactory = require('../../../layers/layer-factory'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var LayerConfigurator = (_temp2 = _class = function (_Component) { (0, _inherits3.default)(LayerConfigurator, _Component); function LayerConfigurator() { var _ref; var _temp, _this, _ret; (0, _classCallCheck3.default)(this, LayerConfigurator); for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = LayerConfigurator.__proto__ || Object.getPrototypeOf(LayerConfigurator)).call.apply(_ref, [this].concat(args))), _this), _this.onAttributeChange = function (attribute) { var _this$props = _this.props, layerConfiguratorProps = _this$props.layerConfiguratorProps, textLabel = _this$props.textLabel; return function (v) { return layerConfiguratorProps.onChange({ textLabel: (0, _extends4.default)({}, textLabel, (0, _defineProperty3.default)({}, attribute, v)) }); }; }, _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: (0, _extends4.default)({}, textLabel, { anchor: anchor, offset: [anchor === 'start' ? 10 : anchor === 'end' ? -10 : 0, anchor === 'middle' ? 10 : 0] }) }); }, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); } (0, _createClass3.default)(LayerConfigurator, [{ key: 'render', value: function render() { var _this2 = this; var _props = this.props, visConfiguratorProps = _props.visConfiguratorProps, textLabel = _props.textLabel; return _react2.default.createElement( _layerConfigGroup2.default, { label: 'text' }, _react2.default.createElement( _styledComponents.PanelLabel, null, 'Show text label based on' ), _react2.default.createElement(_fieldSelector2.default, { fields: visConfiguratorProps.fields, value: textLabel.field && textLabel.field.name || 'select a field', placeholder: 'empty', onSelect: this.onAttributeChange('field'), erasable: true }), _react2.default.createElement( _styledComponents.PanelLabel, null, 'Font size' ), _react2.default.createElement(_rangeSlider2.default, (0, _extends4.default)({}, _layerFactory.LAYER_TEXT_CONFIGS.fontSize, { value1: textLabel.size, onChange: function onChange(v) { return _this2.onAttributeChange('size')(v[1]); } })), _react2.default.createElement( _styledComponents.PanelLabel, null, 'Font color' ), _react2.default.createElement(_colorSelector2.default, { colorSets: [{ selectedColor: textLabel.color, setColor: this.onAttributeChange('color') }] }), _react2.default.createElement( _styledComponents.PanelLabel, null, 'Text anchor' ), _react2.default.createElement(_itemSelector2.default, (0, _extends4.default)({}, _layerFactory.LAYER_TEXT_CONFIGS.textAnchor, { selectedItems: textLabel.anchor, onChange: this.onChangeTextAnchor })) ); } }]); return LayerConfigurator; }(_react.Component), _class.propTypes = { layerConfiguratorProps: _propTypes2.default.object.isRequired, textLabel: _propTypes2.default.object.isRequired, visConfiguratorProps: _propTypes2.default.object.isRequired }, _temp2); exports.default = LayerConfigurator; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/text-label-panel.js"],"names":["LayerConfigurator","onAttributeChange","props","layerConfiguratorProps","textLabel","onChange","attribute","v","onChangeTextAnchor","anchor","offset","visConfiguratorProps","fields","field","name","LAYER_TEXT_CONFIGS","fontSize","size","selectedColor","color","setColor","textAnchor","Component","propTypes","PropTypes","object","isRequired"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oBAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;AACA;;;;AAEA;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AAEA;;;;IAEqBA,iB;;;;;;;;;;;;;;0NAOnBC,iB,GAAoB,qBAAa;AAAA,wBACa,MAAKC,KADlB;AAAA,UACxBC,sBADwB,eACxBA,sBADwB;AAAA,UACAC,SADA,eACAA,SADA;;AAE/B,aAAO;AAAA,eAAKD,uBAAuBE,QAAvB,CAAgC;AAC1CD,gDACKA,SADL,oCAEGE,SAFH,EAEeC,CAFf;AAD0C,SAAhC,CAAL;AAAA,OAAP;AAMD,K,QAEDC,kB,GAAqB,kBAAU;AAAA,yBACe,MAAKN,KADpB;AAAA,UACtBC,sBADsB,gBACtBA,sBADsB;AAAA,UACEC,SADF,gBACEA,SADF;AAE7B;;AACAD,6BAAuBE,QAAvB,CAAgC;AAC9BD,8CACKA,SADL;AAEEK,wBAFF;AAGEC,kBAAQ,CACND,WAAW,OAAX,GAAqB,EAArB,GAA0BA,WAAW,KAAX,GAAmB,CAAC,EAApB,GAAyB,CAD7C,EAENA,WAAW,QAAX,GAAsB,EAAtB,GAA2B,CAFrB;AAHV;AAD8B,OAAhC;AAUD,K;;;;;6BAEQ;AAAA;;AAAA,mBAIH,KAAKP,KAJF;AAAA,UAELS,oBAFK,UAELA,oBAFK;AAAA,UAGLP,SAHK,UAGLA,SAHK;;AAKP,aACE;AAAC,kCAAD;AAAA,UAAkB,OAAO,MAAzB;AACE;AAAC,sCAAD;AAAA;AAAA;AAAA,SADF;AAEI,sCAAC,uBAAD;AACE,kBAAQO,qBAAqBC,MAD/B;AAEE,iBAAOR,UAAUS,KAAV,IAAmBT,UAAUS,KAAV,CAAgBC,IAAnC,IAA2C,gBAFpD;AAGE,uBAAa,OAHf;AAIE,oBAAU,KAAKb,iBAAL,CAAuB,OAAvB,CAJZ;AAKE;AALF,UAFJ;AASI;AAAC,sCAAD;AAAA;AAAA;AAAA,SATJ;AAUI,sCAAC,qBAAD,6BACMc,iCAAmBC,QADzB;AAEE,kBAAQZ,UAAUa,IAFpB;AAGE,oBAAU;AAAA,mBAAK,OAAKhB,iBAAL,CAAuB,MAAvB,EAA+BM,EAAE,CAAF,CAA/B,CAAL;AAAA;AAHZ,WAVJ;AAeI;AAAC,sCAAD;AAAA;AAAA;AAAA,SAfJ;AAgBI,sCAAC,uBAAD;AACE,qBAAW,CACT;AACEW,2BAAed,UAAUe,KAD3B;AAEEC,sBAAU,KAAKnB,iBAAL,CAAuB,OAAvB;AAFZ,WADS;AADb,UAhBJ;AAwBI;AAAC,sCAAD;AAAA;AAAA;AAAA,SAxBJ;AAyBI,sCAAC,sBAAD,6BACMc,iCAAmBM,UADzB;AAEE,yBAAejB,UAAUK,MAF3B;AAGE,oBAAU,KAAKD;AAHjB;AAzBJ,OADF;AAiCD;;;EAtE4Cc,gB,UACtCC,S,GAAY;AACjBpB,0BAAwBqB,oBAAUC,MAAV,CAAiBC,UADxB;AAEjBtB,aAAWoB,oBAAUC,MAAV,CAAiBC,UAFX;AAGjBf,wBAAsBa,oBAAUC,MAAV,CAAiBC;AAHtB,C;kBADA1B,iB","file":"text-label-panel.js","sourcesContent":["// Copyright (c) 2018 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} 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 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={'text'}>\n        <PanelLabel>{`Show text label based on`}</PanelLabel>\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          <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          <PanelLabel>{`Font color`}</PanelLabel>\n          <ColorSelector\n            colorSets={[\n              {\n                selectedColor: textLabel.color,\n                setColor: this.onAttributeChange('color')\n              }\n            ]}\n          />\n          <PanelLabel>{`Text anchor`}</PanelLabel>\n          <ItemSelector\n            {...LAYER_TEXT_CONFIGS.textAnchor}\n            selectedItems={textLabel.anchor}\n            onChange={this.onChangeTextAnchor}\n          />\n      </LayerConfigGroup>\n    );\n  }\n}\n"]}