kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
150 lines (118 loc) • 18.3 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
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 _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
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");
var _templateObject, _templateObject2, _templateObject3, _templateObject4;
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
var TopRow = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n"])));
var LayerColumnConfig = exports["default"] = /*#__PURE__*/function (_Component) {
(0, _inherits2["default"])(LayerColumnConfig, _Component);
var _super = _createSuper(LayerColumnConfig);
function LayerColumnConfig() {
(0, _classCallCheck2["default"])(this, LayerColumnConfig);
return _super.apply(this, arguments);
}
(0, _createClass2["default"])(LayerColumnConfig, [{
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
});
layer.type === 'pincode' ? this.props.updateLayerConfig({
apiCallRequest: true,
apiCallLoader: true
}) : null;
}
}, {
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(
// 'inside layer-column-config layer=',
// layer,
// 'fields=',
// fields,
// 'fieldPairs=',
// fieldPairs
// );
return (/*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement("div", {
className: "layer-config__column"
}, /*#__PURE__*/_react["default"].createElement(TopRow, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, "Columns"), /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, "* Required")), Object.keys(layer.config.columns).map(function (key) {
return (/*#__PURE__*/_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 LayerColumnConfig;
}(_react.Component);
(0, _defineProperty2["default"])(LayerColumnConfig, "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 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n margin-bottom: 8px;\n align-items: center;\n"])));
var ColumnName = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n width: 30%;\n"])));
var ColumnSelect = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n width: 70%;\n"])));
var ColumnSelector = function ColumnSelector(_ref) {
var column = _ref.column,
label = _ref.label,
allFields = _ref.allFields,
onSelect = _ref.onSelect,
fieldPairs = _ref.fieldPairs;
return (/*#__PURE__*/_react["default"].createElement(ColumnRow, {
className: "layer-config__column__selector"
}, /*#__PURE__*/_react["default"].createElement(ColumnName, {
className: "layer-config__column__name"
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, label), !column.optional ? /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, " *") : null), /*#__PURE__*/_react["default"].createElement(ColumnSelect, {
className: "layer-config__column__select"
}, /*#__PURE__*/_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/layer-panel/layer-column-config.js"],"names":["TopRow","styled","div","LayerColumnConfig","key","value","layer","props","columns","pair","columnPairs","assignColumnPairs","assignColumn","updateLayerConfig","type","apiCallRequest","apiCallLoader","fields","fieldPairs","Object","keys","config","map","fp","name","defaultName","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) 2023 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 LayerColumnConfig 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    layer.type === 'pincode'\n      ? this.props.updateLayerConfig({\n          apiCallRequest: true,\n          apiCallLoader: true\n        })\n      : null;\n  }\n\n  render() {\n    const {layer, fields, fieldPairs} = this.props;\n    // console.log(\n    //   'inside layer-column-config layer=',\n    //   layer,\n    //   'fields=',\n    //   fields,\n    //   'fieldPairs=',\n    //   fieldPairs\n    // );\n    return (\n      <div>\n        <SidePanelSection>\n          <div className=\"layer-config__column\">\n            <TopRow>\n              <PanelLabel>Columns</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\nconst ColumnSelector = ({column, label, allFields, onSelect, fieldPairs}) => (\n  <ColumnRow className=\"layer-config__column__selector\">\n    <ColumnName className=\"layer-config__column__name\">\n      <PanelLabel>{label}</PanelLabel>\n      {!column.optional ? <PanelLabel>{`  *`}</PanelLabel> : null}\n    </ColumnName>\n    <ColumnSelect className=\"layer-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"]}