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