kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
201 lines (166 loc) • 16.5 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = undefined;
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _taggedTemplateLiteral2 = require('babel-runtime/helpers/taggedTemplateLiteral');
var _taggedTemplateLiteral3 = _interopRequireDefault(_taggedTemplateLiteral2);
var _class, _temp;
var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n display: flex;\n justify-content: space-between;\n'], ['\n display: flex;\n justify-content: space-between;\n']),
_templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n display: flex;\n margin-bottom: 8px;\n align-items: center;\n'], ['\n display: flex;\n margin-bottom: 8px;\n align-items: center;\n']),
_templateObject3 = (0, _taggedTemplateLiteral3.default)(['\n width: 30%;\n'], ['\n width: 30%;\n']),
_templateObject4 = (0, _taggedTemplateLiteral3.default)(['\n width: 70%;\n'], ['\n width: 70%;\n']); // Copyright (c) 2018 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 _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _styledComponents = require('styled-components');
var _styledComponents2 = _interopRequireDefault(_styledComponents);
var _fieldSelector = require('../../common/field-selector');
var _fieldSelector2 = _interopRequireDefault(_fieldSelector);
var _styledComponents3 = require('../../common/styled-components');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var TopRow = _styledComponents2.default.div(_templateObject);
var LayerColumnConfig = (_temp = _class = function (_Component) {
(0, _inherits3.default)(LayerColumnConfig, _Component);
function LayerColumnConfig() {
(0, _classCallCheck3.default)(this, LayerColumnConfig);
return (0, _possibleConstructorReturn3.default)(this, (LayerColumnConfig.__proto__ || Object.getPrototypeOf(LayerColumnConfig)).apply(this, arguments));
}
(0, _createClass3.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 });
}
}, {
key: 'render',
value: function render() {
var _this2 = this;
var _props = this.props,
layer = _props.layer,
fields = _props.fields,
fieldPairs = _props.fieldPairs;
return _react2.default.createElement(
'div',
null,
_react2.default.createElement(
_styledComponents3.SidePanelSection,
null,
_react2.default.createElement(
'div',
{ className: 'layer-config__column' },
_react2.default.createElement(
TopRow,
null,
_react2.default.createElement(
_styledComponents3.PanelLabel,
null,
'Columns'
),
_react2.default.createElement(
_styledComponents3.PanelLabel,
null,
'* Required'
)
),
Object.keys(layer.config.columns).map(function (key) {
return _react2.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 _this2._updateColumn(key, val);
}
});
})
)
)
);
}
}]);
return LayerColumnConfig;
}(_react.Component), _class.propTypes = {
layer: _propTypes2.default.object.isRequired,
fields: _propTypes2.default.arrayOf(_propTypes2.default.any).isRequired,
updateLayerConfig: _propTypes2.default.func.isRequired,
fieldPairs: _propTypes2.default.arrayOf(_propTypes2.default.any)
}, _temp);
exports.default = LayerColumnConfig;
;
var ColumnRow = _styledComponents2.default.div(_templateObject2);
var ColumnName = _styledComponents2.default.div(_templateObject3);
var ColumnSelect = _styledComponents2.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 _react2.default.createElement(
ColumnRow,
{ className: 'layer-config__column__selector' },
_react2.default.createElement(
ColumnName,
{ className: 'layer-config__column__name' },
_react2.default.createElement(
_styledComponents3.PanelLabel,
null,
label
),
!column.optional ? _react2.default.createElement(
_styledComponents3.PanelLabel,
null,
' *'
) : null
),
_react2.default.createElement(
ColumnSelect,
{ className: 'layer-config__column__select' },
_react2.default.createElement(_fieldSelector2.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","fields","fieldPairs","Object","keys","config","map","name","fp","defaultName","type","_updateColumn","val","Component","propTypes","PropTypes","object","isRequired","arrayOf","any","func","ColumnRow","ColumnName","ColumnSelect","ColumnSelector","column","label","allFields","onSelect","optional","Boolean"],"mappings":"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","file":"layer-column-config.js","sourcesContent":["// Copyright (c) 2018 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  }\n\n  render() {\n    const {layer, fields, fieldPairs} = this.props;\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"]}
;