kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
206 lines (173 loc) • 20.3 kB
JavaScript
'use strict';
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 _class, _temp2; // 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 _reselect = require('reselect');
var _itemSelector = require('./item-selector/item-selector');
var _itemSelector2 = _interopRequireDefault(_itemSelector);
var _fieldToken = require('../common/field-token');
var _fieldToken2 = _interopRequireDefault(_fieldToken);
var _dropdownList = require('./item-selector/dropdown-list');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var defaultDisplayOption = function defaultDisplayOption(d) {
return d.name;
};
// custom list Item
var FieldListItemFactory = function FieldListItemFactory(showToken) {
var FieldListItem = function FieldListItem(_ref) {
var value = _ref.value,
_ref$displayOption = _ref.displayOption,
displayOption = _ref$displayOption === undefined ? defaultDisplayOption : _ref$displayOption;
return _react2.default.createElement(
'div',
null,
showToken ? _react2.default.createElement(
'div',
{ style: { display: 'inline-block', margin: '0 4px 0 0' } },
_react2.default.createElement(_fieldToken2.default, { type: value.type })
) : null,
_react2.default.createElement(
'span',
{ className: _dropdownList.classList.listItemAnchor },
displayOption(value)
)
);
};
return FieldListItem;
};
var SuggestedFieldHeader = function SuggestedFieldHeader() {
return _react2.default.createElement(
'div',
null,
'Suggested Field'
);
};
var FieldType = _propTypes2.default.oneOfType([_propTypes2.default.arrayOf(_propTypes2.default.string), _propTypes2.default.string, _propTypes2.default.shape({
format: _propTypes2.default.string,
id: _propTypes2.default.string,
name: _propTypes2.default.string,
tableFieldIndex: _propTypes2.default.number,
type: _propTypes2.default.number
})]);
var FieldSelector = (_temp2 = _class = function (_Component) {
(0, _inherits3.default)(FieldSelector, _Component);
function FieldSelector() {
var _ref2;
var _temp, _this, _ret;
(0, _classCallCheck3.default)(this, FieldSelector);
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
args[_key] = arguments[_key];
}
return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref2 = FieldSelector.__proto__ || Object.getPrototypeOf(FieldSelector)).call.apply(_ref2, [this].concat(args))), _this), _this.fieldsSelector = function (props) {
return props.fields;
}, _this.valueSelector = function (props) {
return props.value;
}, _this.filterFieldTypesSelector = function (props) {
return props.filterFieldTypes;
}, _this.showTokenSelector = function (props) {
return props.showToken;
}, _this.selectedItemsSelector = (0, _reselect.createSelector)(_this.fieldsSelector, _this.valueSelector, function (fields, value) {
return fields.filter(function (f) {
return (Array.isArray(value) ? value : [value]).includes(defaultDisplayOption(f));
});
}), _this.fieldOptionsSelector = (0, _reselect.createSelector)(_this.fieldsSelector, _this.filterFieldTypesSelector, function (fields, filterFieldTypes) {
if (!filterFieldTypes) {
return fields;
}
var filters = Array.isArray(filterFieldTypes) ? filterFieldTypes : [filterFieldTypes];
return fields.filter(function (f) {
return filters.includes(f.type);
});
}), _this.fieldListItemSelector = (0, _reselect.createSelector)(_this.showTokenSelector, FieldListItemFactory), _temp), (0, _possibleConstructorReturn3.default)(_this, _ret);
}
(0, _createClass3.default)(FieldSelector, [{
key: 'render',
value: function render() {
return _react2.default.createElement(
'div',
null,
_react2.default.createElement(_itemSelector2.default, {
getOptionValue: function getOptionValue(d) {
return d;
},
closeOnSelect: this.props.closeOnSelect,
displayOption: defaultDisplayOption,
filterOption: 'id',
fixedOptions: this.props.suggested,
inputTheme: this.props.inputTheme,
isError: this.props.error,
selectedItems: this.selectedItemsSelector(this.props),
erasable: this.props.erasable,
options: this.fieldOptionsSelector(this.props),
multiSelect: this.props.multiSelect,
placeholder: this.props.placeholder,
placement: this.props.placement,
onChange: this.props.onSelect,
DropDownLineItemRenderComponent: this.fieldListItemSelector(this.props),
DropdownHeaderComponent: this.props.suggested ? SuggestedFieldHeader : null
})
);
}
}]);
return FieldSelector;
}(_react.Component), _class.propTypes = {
fields: _propTypes2.default.oneOfType([_propTypes2.default.array, _propTypes2.default.arrayOf(FieldType)]),
onSelect: _propTypes2.default.func.isRequired,
placement: _propTypes2.default.string,
value: FieldType,
filterFieldTypes: _propTypes2.default.oneOfType([FieldType, _propTypes2.default.arrayOf(FieldType)]),
inputTheme: _propTypes2.default.string,
placeholder: _propTypes2.default.string,
erasable: _propTypes2.default.bool,
error: _propTypes2.default.bool,
multiSelect: _propTypes2.default.bool,
closeOnSelect: _propTypes2.default.bool,
showToken: _propTypes2.default.bool,
suggested: _propTypes2.default.arrayOf(_propTypes2.default.any)
}, _class.defaultProps = {
erasable: true,
error: false,
fields: [],
onSelect: function onSelect() {},
placement: 'bottom',
value: null,
multiSelect: false,
closeOnSelect: true,
showToken: true,
placeholder: 'Select a field'
}, _temp2);
exports.default = FieldSelector;
;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/common/field-selector.js"],"names":["defaultDisplayOption","d","name","FieldListItemFactory","FieldListItem","value","displayOption","showToken","display","margin","type","classList","listItemAnchor","SuggestedFieldHeader","FieldType","PropTypes","oneOfType","arrayOf","string","shape","format","id","tableFieldIndex","number","FieldSelector","fieldsSelector","props","fields","valueSelector","filterFieldTypesSelector","filterFieldTypes","showTokenSelector","selectedItemsSelector","filter","Array","isArray","includes","f","fieldOptionsSelector","filters","fieldListItemSelector","closeOnSelect","suggested","inputTheme","error","erasable","multiSelect","placeholder","placement","onSelect","Component","propTypes","array","func","isRequired","bool","any","defaultProps"],"mappings":"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","file":"field-selector.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 {createSelector} from 'reselect';\n\nimport ItemSelector from './item-selector/item-selector';\nimport FieldToken from '../common/field-token';\nimport {classList} from './item-selector/dropdown-list';\n\nconst defaultDisplayOption = d => d.name;\n\n// custom list Item\nconst FieldListItemFactory = showToken => {\n  const FieldListItem = ({value, displayOption = defaultDisplayOption}) => (\n    <div>\n      {showToken ? (\n        <div style={{display: 'inline-block', margin: '0 4px 0 0'}}>\n          <FieldToken type={value.type} />\n        </div>\n      ) : null}\n      <span className={classList.listItemAnchor}>{displayOption(value)}</span>\n    </div>\n  );\n\n  return FieldListItem;\n};\n\nconst SuggestedFieldHeader = () => <div>Suggested Field</div>;\n\nconst FieldType = PropTypes.oneOfType([\n  PropTypes.arrayOf(PropTypes.string),\n  PropTypes.string,\n  PropTypes.shape({\n    format: PropTypes.string,\n    id: PropTypes.string,\n    name: PropTypes.string,\n    tableFieldIndex: PropTypes.number,\n    type: PropTypes.number\n  })\n]);\n\nexport default class FieldSelector extends Component {\n  static propTypes = {\n    fields: PropTypes.oneOfType([\n      PropTypes.array,\n      PropTypes.arrayOf(FieldType)\n    ]),\n    onSelect: PropTypes.func.isRequired,\n    placement: PropTypes.string,\n    value: FieldType,\n    filterFieldTypes: PropTypes.oneOfType([FieldType, PropTypes.arrayOf(FieldType)]),\n    inputTheme: PropTypes.string,\n    placeholder: PropTypes.string,\n    erasable: PropTypes.bool,\n    error: PropTypes.bool,\n    multiSelect: PropTypes.bool,\n    closeOnSelect: PropTypes.bool,\n    showToken: PropTypes.bool,\n    suggested: PropTypes.arrayOf(PropTypes.any)\n  };\n\n  static defaultProps = {\n    erasable: true,\n    error: false,\n    fields: [],\n    onSelect: () => {},\n    placement: 'bottom',\n    value: null,\n    multiSelect: false,\n    closeOnSelect: true,\n    showToken: true,\n    placeholder: 'Select a field'\n  };\n\n  fieldsSelector = props => props.fields;\n  valueSelector = props => props.value;\n  filterFieldTypesSelector = props => props.filterFieldTypes;\n  showTokenSelector = props => props.showToken;\n\n  selectedItemsSelector = createSelector(\n    this.fieldsSelector,\n    this.valueSelector,\n    (fields, value) =>\n      fields.filter(f =>\n        (Array.isArray(value) ? value : [value]).includes(\n          defaultDisplayOption(f)\n        )\n      )\n  );\n\n  fieldOptionsSelector = createSelector(\n    this.fieldsSelector,\n    this.filterFieldTypesSelector,\n    (fields, filterFieldTypes) => {\n      if (!filterFieldTypes) {\n        return fields;\n      }\n      const filters = Array.isArray(filterFieldTypes)\n        ? filterFieldTypes\n        : [filterFieldTypes];\n      return fields.filter(f => filters.includes(f.type));\n    }\n  );\n\n  fieldListItemSelector = createSelector(\n    this.showTokenSelector,\n    FieldListItemFactory\n  );\n\n  render() {\n    return (\n      <div>\n        <ItemSelector\n          getOptionValue={d => d}\n          closeOnSelect={this.props.closeOnSelect}\n          displayOption={defaultDisplayOption}\n          filterOption={'id'}\n          fixedOptions={this.props.suggested}\n          inputTheme={this.props.inputTheme}\n          isError={this.props.error}\n          selectedItems={this.selectedItemsSelector(this.props)}\n          erasable={this.props.erasable}\n          options={this.fieldOptionsSelector(this.props)}\n          multiSelect={this.props.multiSelect}\n          placeholder={this.props.placeholder}\n          placement={this.props.placement}\n          onChange={this.props.onSelect}\n          DropDownLineItemRenderComponent={this.fieldListItemSelector(\n            this.props\n          )}\n          DropdownHeaderComponent={\n            this.props.suggested ? SuggestedFieldHeader : null\n          }\n        />\n      </div>\n    );\n  }\n};\n"]}