UNPKG

kepler.gl.geoiq

Version:

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

181 lines (142 loc) 16.7 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 _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _fieldSelector = _interopRequireDefault(require("../../common/field-selector")); var _styledComponents2 = require("../../common/styled-components"); function _templateObject4() { var data = (0, _taggedTemplateLiteral2["default"])(["\n width: 70%;\n"]); _templateObject4 = function _templateObject4() { return data; }; return data; } function _templateObject3() { var data = (0, _taggedTemplateLiteral2["default"])(["\n width: 30%;\n"]); _templateObject3 = function _templateObject3() { return data; }; return data; } function _templateObject2() { var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n margin-bottom: 8px;\n align-items: center;\n"]); _templateObject2 = function _templateObject2() { return data; }; return data; } function _templateObject() { var data = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n"]); _templateObject = function _templateObject() { return data; }; return data; } var TopRow = _styledComponents["default"].div(_templateObject()); var WidgetColumnConfig = /*#__PURE__*/ function (_Component) { (0, _inherits2["default"])(WidgetColumnConfig, _Component); function WidgetColumnConfig() { (0, _classCallCheck2["default"])(this, WidgetColumnConfig); return (0, _possibleConstructorReturn2["default"])(this, (0, _getPrototypeOf2["default"])(WidgetColumnConfig).apply(this, arguments)); } (0, _createClass2["default"])(WidgetColumnConfig, [{ key: "_updateColumn", value: function _updateColumn(key, value) { var layer = this.props.layer; var columns = value && value.pair && layer.columnPairs ? layer.assignColumnPairs(key, value.pair) : layer.assignColumn(key, value); this.props.updateLayerConfig({ columns: columns }); } }, { key: "render", value: function render() { var _this = this; var _this$props = this.props, layer = _this$props.layer, fields = _this$props.fields, fieldPairs = _this$props.fieldPairs; // console.log('widgetColumnConfig', layer); return _react["default"].createElement("div", null, _react["default"].createElement(_styledComponents2.SidePanelSection, null, _react["default"].createElement("div", { className: "layer-config__column" }, _react["default"].createElement(TopRow, null, _react["default"].createElement(_styledComponents2.PanelLabel, null, "Column"), _react["default"].createElement(_styledComponents2.PanelLabel, null, "* Required")), Object.keys(layer.config.columns).map(function (key) { return _react["default"].createElement(ColumnSelector, { column: layer.config.columns[key], label: key, key: key, allFields: fields, fieldPairs: layer.columnPairs ? fieldPairs.map(function (fp) { return { name: fp.defaultName, type: 'point', pair: fp.pair }; }) : null, onSelect: function onSelect(val) { return _this._updateColumn(key, val); } }); })))); } }]); return WidgetColumnConfig; }(_react.Component); exports["default"] = WidgetColumnConfig; (0, _defineProperty2["default"])(WidgetColumnConfig, "propTypes", { layer: _propTypes["default"].object.isRequired, fields: _propTypes["default"].arrayOf(_propTypes["default"].any).isRequired, updateLayerConfig: _propTypes["default"].func.isRequired, fieldPairs: _propTypes["default"].arrayOf(_propTypes["default"].any) }); var ColumnRow = _styledComponents["default"].div(_templateObject2()); var ColumnName = _styledComponents["default"].div(_templateObject3()); var ColumnSelect = _styledComponents["default"].div(_templateObject4()); // const availableFieldsSelector = createSelector( // this.fieldsSelector, // this.filterSelector, // this.nameSelector, // this.dataIdSelector, // (fields, filters, name, dataId) => // fields.filter( // f => // f.type && // f.type !== ALL_FIELD_TYPES.geojson && // (f.name === name || // !filters.find(d => d.name === f.name && d.dataId === dataId)) // ) // ); var ColumnSelector = function ColumnSelector(_ref) { var column = _ref.column, label = _ref.label, allFields = _ref.allFields, onSelect = _ref.onSelect, fieldPairs = _ref.fieldPairs; return _react["default"].createElement(ColumnRow, { className: "widget-config__column__selector" }, _react["default"].createElement(ColumnName, { className: "widget-config__column__name" }, _react["default"].createElement(_styledComponents2.PanelLabel, null, label), !column.optional ? _react["default"].createElement(_styledComponents2.PanelLabel, null, " *") : null), _react["default"].createElement(ColumnSelect, { className: "widget-config__column__select" }, _react["default"].createElement(_fieldSelector["default"], { suggested: fieldPairs, error: !column.optional && !column.value, fields: allFields, value: column.value, erasable: Boolean(column.optional), onSelect: onSelect }))); }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/widget-panel/widget-column-config.js"],"names":["TopRow","styled","div","WidgetColumnConfig","key","value","layer","props","columns","pair","columnPairs","assignColumnPairs","assignColumn","updateLayerConfig","fields","fieldPairs","Object","keys","config","map","fp","name","defaultName","type","val","_updateColumn","Component","PropTypes","object","isRequired","arrayOf","any","func","ColumnRow","ColumnName","ColumnSelect","ColumnSelector","column","label","allFields","onSelect","optional","Boolean"],"mappings":"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","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';\nimport styled from 'styled-components';\nimport FieldSelector from 'components/common/field-selector';\n\nimport {\n  PanelLabel,\n  SidePanelSection\n} from 'components/common/styled-components';\n\nconst TopRow = styled.div`\n  display: flex;\n  justify-content: space-between;\n`;\n\nexport default class WidgetColumnConfig extends Component {\n  static propTypes = {\n    layer: PropTypes.object.isRequired,\n    fields: PropTypes.arrayOf(PropTypes.any).isRequired,\n    updateLayerConfig: PropTypes.func.isRequired,\n    fieldPairs: PropTypes.arrayOf(PropTypes.any)\n  };\n\n  _updateColumn(key, value) {\n    const {layer} = this.props;\n\n    const columns =\n      value && value.pair && layer.columnPairs\n        ? layer.assignColumnPairs(key, value.pair)\n        : layer.assignColumn(key, value);\n\n    this.props.updateLayerConfig({columns});\n  }\n\n  render() {\n    const {layer, fields, fieldPairs} = this.props;\n    // console.log('widgetColumnConfig', layer);\n    return (\n      <div>\n        <SidePanelSection>\n          <div className=\"layer-config__column\">\n            <TopRow>\n              <PanelLabel>Column</PanelLabel>\n              <PanelLabel>* Required</PanelLabel>\n            </TopRow>\n            {Object.keys(layer.config.columns).map(key => (\n              <ColumnSelector\n                column={layer.config.columns[key]}\n                label={key}\n                key={key}\n                allFields={fields}\n                fieldPairs={\n                  layer.columnPairs\n                    ? fieldPairs.map(fp => ({\n                        name: fp.defaultName,\n                        type: 'point',\n                        pair: fp.pair\n                      }))\n                    : null\n                }\n                onSelect={val => this._updateColumn(key, val)}\n              />\n            ))}\n          </div>\n        </SidePanelSection>\n      </div>\n    );\n  }\n}\n\nconst ColumnRow = styled.div`\n  display: flex;\n  margin-bottom: 8px;\n  align-items: center;\n`;\n\nconst ColumnName = styled.div`\n  width: 30%;\n`;\nconst ColumnSelect = styled.div`\n  width: 70%;\n`;\n\n// const availableFieldsSelector = createSelector(\n//   this.fieldsSelector,\n//   this.filterSelector,\n//   this.nameSelector,\n//   this.dataIdSelector,\n//   (fields, filters, name, dataId) =>\n//     fields.filter(\n//       f =>\n//         f.type &&\n//         f.type !== ALL_FIELD_TYPES.geojson &&\n//         (f.name === name ||\n//           !filters.find(d => d.name === f.name && d.dataId === dataId))\n//     )\n// );\n\nconst ColumnSelector = ({column, label, allFields, onSelect, fieldPairs}) => (\n  <ColumnRow className=\"widget-config__column__selector\">\n    <ColumnName className=\"widget-config__column__name\">\n      <PanelLabel>{label}</PanelLabel>\n      {!column.optional ? <PanelLabel>{`  *`}</PanelLabel> : null}\n    </ColumnName>\n    <ColumnSelect className=\"widget-config__column__select\">\n      <FieldSelector\n        suggested={fieldPairs}\n        error={!column.optional && !column.value}\n        fields={allFields}\n        value={column.value}\n        erasable={Boolean(column.optional)}\n        onSelect={onSelect}\n      />\n    </ColumnSelect>\n  </ColumnRow>\n);\n"]}