UNPKG

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
'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"]}