UNPKG

kepler.gl

Version:

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

147 lines (119 loc) 15.3 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 _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 _reactIntl = require("react-intl"); var _styledComponents = require("../../common/styled-components"); var _fieldSelector = _interopRequireDefault(require("../../common/field-selector")); var _infoHelper = _interopRequireDefault(require("../../common/info-helper")); var _dimensionScaleSelector = _interopRequireDefault(require("./dimension-scale-selector")); var _utils = require("../../../utils/utils"); // Copyright (c) 2020 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 VisConfigByFieldSelector = /*#__PURE__*/ function (_Component) { (0, _inherits2["default"])(VisConfigByFieldSelector, _Component); function VisConfigByFieldSelector() { var _getPrototypeOf2; var _this; (0, _classCallCheck2["default"])(this, VisConfigByFieldSelector); 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"])(VisConfigByFieldSelector)).call.apply(_getPrototypeOf2, [this].concat(args))); (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_updateVisByField", function (val) { _this.props.updateField(val); }); return _this; } (0, _createClass2["default"])(VisConfigByFieldSelector, [{ key: "render", value: function render() { var _this$props = this.props, property = _this$props.property, showScale = _this$props.showScale, selectedField = _this$props.selectedField, description = _this$props.description, label = _this$props.label, intl = _this$props.intl, _this$props$scaleOpti = _this$props.scaleOptions, scaleOptions = _this$props$scaleOpti === void 0 ? [] : _this$props$scaleOpti; return _react["default"].createElement(_styledComponents.SidePanelSection, null, _react["default"].createElement(_styledComponents.SidePanelSection, null, _react["default"].createElement(_styledComponents.PanelLabelWrapper, null, _react["default"].createElement(_styledComponents.PanelLabel, null, label && _react["default"].createElement(_reactIntl.FormattedMessage, { id: label }) || _react["default"].createElement(_reactIntl.FormattedMessage, { id: "layer.propertyBasedOn", values: { property: intl.formatMessage({ id: "property.".concat((0, _utils.camelize)(property)), defaultMessage: property }) } })), description && _react["default"].createElement(_infoHelper["default"], { description: description, property: property, id: "".concat(this.props.id, "-").concat(property) })), _react["default"].createElement(_fieldSelector["default"], { fields: this.props.fields, value: selectedField && selectedField.name, placeholder: this.props.placeholder, onSelect: this._updateVisByField, erasable: true })), _react["default"].createElement("div", null, showScale ? _react["default"].createElement(_dimensionScaleSelector["default"], { scaleType: this.props.scaleType, options: scaleOptions, label: "".concat(property, " scale"), onSelect: this.props.updateScale, disabled: scaleOptions.length < 2 }) : null)); } }]); return VisConfigByFieldSelector; }(_react.Component); (0, _defineProperty2["default"])(VisConfigByFieldSelector, "propTypes", { channel: _propTypes["default"].string.isRequired, fields: _propTypes["default"].arrayOf(_propTypes["default"].any).isRequired, id: _propTypes["default"].string.isRequired, property: _propTypes["default"].string.isRequired, showScale: _propTypes["default"].bool.isRequired, updateField: _propTypes["default"].func.isRequired, updateScale: _propTypes["default"].func.isRequired, // optional scaleType: _propTypes["default"].string, selectedField: _propTypes["default"].object, description: _propTypes["default"].string, label: _propTypes["default"].string, placeholder: _propTypes["default"].string }); var _default = (0, _reactIntl.injectIntl)(VisConfigByFieldSelector); exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/layer-panel/vis-config-by-field-selector.js"],"names":["VisConfigByFieldSelector","val","props","updateField","property","showScale","selectedField","description","label","intl","scaleOptions","formatMessage","id","defaultMessage","fields","name","placeholder","_updateVisByField","scaleType","updateScale","length","Component","channel","PropTypes","string","isRequired","arrayOf","any","bool","func","object"],"mappings":"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","sourcesContent":["// Copyright (c) 2020 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';\nimport {FormattedMessage, injectIntl} from 'react-intl';\n\nimport {PanelLabel, PanelLabelWrapper, SidePanelSection} from 'components/common/styled-components';\nimport FieldSelector from 'components/common/field-selector';\nimport InfoHelper from 'components/common/info-helper';\nimport DimensionScaleSelector from './dimension-scale-selector';\nimport {camelize} from 'utils/utils';\n\nclass VisConfigByFieldSelector extends Component {\n  static propTypes = {\n    channel: PropTypes.string.isRequired,\n    fields: PropTypes.arrayOf(PropTypes.any).isRequired,\n    id: PropTypes.string.isRequired,\n    property: PropTypes.string.isRequired,\n    showScale: PropTypes.bool.isRequired,\n    updateField: PropTypes.func.isRequired,\n    updateScale: PropTypes.func.isRequired,\n\n    // optional\n    scaleType: PropTypes.string,\n    selectedField: PropTypes.object,\n    description: PropTypes.string,\n    label: PropTypes.string,\n    placeholder: PropTypes.string\n  };\n\n  _updateVisByField = val => {\n    this.props.updateField(val);\n  };\n\n  render() {\n    const {\n      property,\n      showScale,\n      selectedField,\n      description,\n      label,\n      intl,\n      scaleOptions = []\n    } = this.props;\n\n    return (\n      <SidePanelSection>\n        <SidePanelSection>\n          <PanelLabelWrapper>\n            <PanelLabel>\n              {(label && <FormattedMessage id={label} />) || (\n                <FormattedMessage\n                  id=\"layer.propertyBasedOn\"\n                  values={{\n                    property: intl.formatMessage({\n                      id: `property.${camelize(property)}`,\n                      defaultMessage: property\n                    })\n                  }}\n                />\n              )}\n            </PanelLabel>\n            {description && (\n              <InfoHelper\n                description={description}\n                property={property}\n                id={`${this.props.id}-${property}`}\n              />\n            )}\n          </PanelLabelWrapper>\n          <FieldSelector\n            fields={this.props.fields}\n            value={selectedField && selectedField.name}\n            placeholder={this.props.placeholder}\n            onSelect={this._updateVisByField}\n            erasable\n          />\n        </SidePanelSection>\n        <div>\n          {showScale ? (\n            <DimensionScaleSelector\n              scaleType={this.props.scaleType}\n              options={scaleOptions}\n              label={`${property} scale`}\n              onSelect={this.props.updateScale}\n              disabled={scaleOptions.length < 2}\n            />\n          ) : null}\n        </div>\n      </SidePanelSection>\n    );\n  }\n}\n\nexport default injectIntl(VisConfigByFieldSelector);\n"]}