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