kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
205 lines (161 loc) • 18.8 kB
JavaScript
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 _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 _reactIntl = require("react-intl");
var _fieldSelector = _interopRequireDefault(require("../../common/field-selector"));
var _reselect = require("reselect");
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 LayerColumnConfig =
/*#__PURE__*/
function (_Component) {
(0, _inherits2["default"])(LayerColumnConfig, _Component);
function LayerColumnConfig() {
var _getPrototypeOf2;
var _this;
(0, _classCallCheck2["default"])(this, LayerColumnConfig);
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"])(LayerColumnConfig)).call.apply(_getPrototypeOf2, [this].concat(args)));
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "columnPairs", function (props) {
return props.columnPairs;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "fieldPairs", function (props) {
return props.fieldPairs;
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "fieldPairsSelector", (0, _reselect.createSelector)(_this.columnPairs, _this.fieldPairs, function (columnPairs, fieldPairs) {
return columnPairs ? fieldPairs.map(function (fp) {
return {
name: fp.defaultName,
type: 'point',
pair: fp.pair
};
}) : null;
}));
return _this;
}
(0, _createClass2["default"])(LayerColumnConfig, [{
key: "_updateColumn",
value: function _updateColumn(key, value) {
var _this$props = this.props,
columnPairs = _this$props.columnPairs,
assignColumnPairs = _this$props.assignColumnPairs,
assignColumn = _this$props.assignColumn;
var columns = value && value.pair && columnPairs ? assignColumnPairs(key, value.pair) : assignColumn(key, value);
this.props.updateLayerConfig({
columns: columns
});
}
}, {
key: "render",
value: function render() {
var _this2 = this;
var _this$props2 = this.props,
columns = _this$props2.columns,
columnLabels = _this$props2.columnLabels,
fields = _this$props2.fields;
var fieldPairs = this.fieldPairsSelector(this.props);
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, _react["default"].createElement(_reactIntl.FormattedMessage, {
id: 'columns.title'
})), _react["default"].createElement(_styledComponents2.PanelLabel, null, _react["default"].createElement(_reactIntl.FormattedMessage, {
id: "layer.required"
}))), Object.keys(columns).map(function (key) {
return _react["default"].createElement(ColumnSelector, {
column: columns[key],
label: columnLabels && columnLabels[key] || key,
key: key,
allFields: fields,
fieldPairs: fieldPairs,
onSelect: function onSelect(val) {
return _this2._updateColumn(key, val);
}
});
}))));
}
}]);
return LayerColumnConfig;
}(_react.Component);
exports["default"] = LayerColumnConfig;
(0, _defineProperty2["default"])(LayerColumnConfig, "propTypes", {
columns: _propTypes["default"].object.isRequired,
fields: _propTypes["default"].arrayOf(_propTypes["default"].any).isRequired,
assignColumnPairs: _propTypes["default"].func.isRequired,
assignColumn: _propTypes["default"].func.isRequired,
updateLayerConfig: _propTypes["default"].func.isRequired,
columnPairs: _propTypes["default"].object,
fieldPairs: _propTypes["default"].arrayOf(_propTypes["default"].any),
columnLabels: _propTypes["default"].object
});
var ColumnRow = _styledComponents["default"].div(_templateObject2());
var ColumnName = _styledComponents["default"].div(_templateObject3());
var ColumnSelect = _styledComponents["default"].div(_templateObject4());
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: "layer-config__column__selector"
}, _react["default"].createElement(ColumnName, {
className: "layer-config__column__name"
}, _react["default"].createElement(_styledComponents2.PanelLabel, null, _react["default"].createElement(_reactIntl.FormattedMessage, {
id: "columns.".concat(label)
})), !column.optional ? _react["default"].createElement(_styledComponents2.PanelLabel, null, " *") : null), _react["default"].createElement(ColumnSelect, {
className: "layer-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/layer-panel/layer-column-config.js"],"names":["TopRow","styled","div","LayerColumnConfig","props","columnPairs","fieldPairs","map","fp","name","defaultName","type","pair","key","value","assignColumnPairs","assignColumn","columns","updateLayerConfig","columnLabels","fields","fieldPairsSelector","Object","keys","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) 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 styled from 'styled-components';\nimport {FormattedMessage} from 'react-intl';\nimport FieldSelector from 'components/common/field-selector';\nimport {createSelector} from 'reselect';\n\nimport {PanelLabel, SidePanelSection} 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    columns: PropTypes.object.isRequired,\n    fields: PropTypes.arrayOf(PropTypes.any).isRequired,\n    assignColumnPairs: PropTypes.func.isRequired,\n    assignColumn: PropTypes.func.isRequired,\n    updateLayerConfig: PropTypes.func.isRequired,\n    columnPairs: PropTypes.object,\n    fieldPairs: PropTypes.arrayOf(PropTypes.any),\n    columnLabels: PropTypes.object\n  };\n\n  columnPairs = props => props.columnPairs;\n  fieldPairs = props => props.fieldPairs;\n  fieldPairsSelector = createSelector(\n    this.columnPairs,\n    this.fieldPairs,\n    (columnPairs, fieldPairs) =>\n      columnPairs\n        ? fieldPairs.map(fp => ({\n            name: fp.defaultName,\n            type: 'point',\n            pair: fp.pair\n          }))\n        : null\n  );\n\n  _updateColumn(key, value) {\n    const {columnPairs, assignColumnPairs, assignColumn} = this.props;\n\n    const columns =\n      value && value.pair && columnPairs\n        ? assignColumnPairs(key, value.pair)\n        : assignColumn(key, value);\n\n    this.props.updateLayerConfig({columns});\n  }\n\n  render() {\n    const {columns, columnLabels, fields} = this.props;\n\n    const fieldPairs = this.fieldPairsSelector(this.props);\n\n    return (\n      <div>\n        <SidePanelSection>\n          <div className=\"layer-config__column\">\n            <TopRow>\n              <PanelLabel><FormattedMessage id={'columns.title'} /></PanelLabel>\n              <PanelLabel>\n                <FormattedMessage id=\"layer.required\" />\n              </PanelLabel>\n            </TopRow>\n            {Object.keys(columns).map(key => (\n              <ColumnSelector\n                column={columns[key]}\n                label={(columnLabels && columnLabels[key]) || key}\n                key={key}\n                allFields={fields}\n                fieldPairs={fieldPairs}\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>\n        <FormattedMessage id={`columns.${label}`} />\n      </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"]}
;