kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
350 lines (285 loc) • 35.7 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _extends2 = require('babel-runtime/helpers/extends');
var _extends3 = _interopRequireDefault(_extends2);
var _toConsumableArray2 = require('babel-runtime/helpers/toConsumableArray');
var _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2);
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, _temp2;
var _templateObject = (0, _taggedTemplateLiteral3.default)(['\n ', ';\n\n .list__item__anchor {\n ', ';\n }\n'], ['\n ', ';\n\n .list__item__anchor {\n ', ';\n }\n']),
_templateObject2 = (0, _taggedTemplateLiteral3.default)(['\n color: ', ';\n overflow: hidden;\n'], ['\n color: ', ';\n overflow: hidden;\n']),
_templateObject3 = (0, _taggedTemplateLiteral3.default)(['\n margin-left: 6px;\n display: flex;\n'], ['\n margin-left: 6px;\n display: flex;\n']),
_templateObject4 = (0, _taggedTemplateLiteral3.default)(['\n background: ', ';\n border: 0;\n width: 100%;\n left: 0;\n z-index: 100;\n position: absolute;\n bottom: ', ';\n margin-top: ', ';\n margin-bottom: ', ';\n'], ['\n background: ', ';\n border: 0;\n width: 100%;\n left: 0;\n z-index: 100;\n position: absolute;\n bottom: ', ';\n margin-top: ', ';\n margin-bottom: ', ';\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 _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
var _lodash = require('lodash.uniq');
var _lodash2 = _interopRequireDefault(_lodash);
var _reactOnclickoutside = require('react-onclickoutside');
var _reactOnclickoutside2 = _interopRequireDefault(_reactOnclickoutside);
var _styledComponents = require('styled-components');
var _styledComponents2 = _interopRequireDefault(_styledComponents);
var _accessor = require('./accessor');
var _accessor2 = _interopRequireDefault(_accessor);
var _chickletedInput = require('./chickleted-input');
var _chickletedInput2 = _interopRequireDefault(_chickletedInput);
var _typeahead = require('./typeahead');
var _typeahead2 = _interopRequireDefault(_typeahead);
var _icons = require('../icons');
var _dropdownList = require('./dropdown-list');
var _dropdownList2 = _interopRequireDefault(_dropdownList);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/**
* Converts non-arrays to arrays. Leaves arrays alone. Converts
* undefined values to empty arrays ([] instead of [undefined]).
* Otherwise, just returns [item] for non-array items.
*
* @param {*} item
* @returns {array} boom! much array. very indexed. so useful.
*/
function _toArray(item) {
if (Array.isArray(item)) {
return item;
}
if (typeof item === 'undefined' || item === null) {
return [];
}
return [item];
}
var StyledDropdownSelect = _styledComponents2.default.div(_templateObject, function (props) {
return props.inputTheme === 'secondary' ? props.theme.secondaryInput : props.theme.input;
}, function (props) {
return props.theme.dropdownListAnchor;
});
var DropdownSelectValue = _styledComponents2.default.span(_templateObject2, function (props) {
return props.placeholder ? props.theme.selectColorPlaceHolder : props.theme.selectColor;
});
var DropdownSelectErase = _styledComponents2.default.div(_templateObject3);
var DropdownWrapper = _styledComponents2.default.div(_templateObject4, function (props) {
return props.theme.dropdownBgd;
}, function (props) {
return props.placement === 'top' ? props.theme.inputBoxHeight : 'auto';
}, function (props) {
return props.placement === 'bottom' ? '4px' : 'auto';
}, function (props) {
return props.placement === 'top' ? '4px' : 'auto';
});
var ItemSelector = (_temp2 = _class = function (_Component) {
(0, _inherits3.default)(ItemSelector, _Component);
function ItemSelector() {
var _ref;
var _temp, _this, _ret;
(0, _classCallCheck3.default)(this, ItemSelector);
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, (_ref = ItemSelector.__proto__ || Object.getPrototypeOf(ItemSelector)).call.apply(_ref, [this].concat(args))), _this), _this.state = {
showTypeahead: false
}, _this.handleClickOutside = function () {
_this._hideTypeahead();
}, _this._onBlur = function () {
// note: chickleted input is not a real form element so we call onBlur()
// when we feel the events are appropriate
if (_this.props.onBlur) {
_this.props.onBlur();
}
}, _this._removeItem = function (item, e) {
// only used when multiSelect = true
e.preventDefault();
e.stopPropagation();
var selectedItems = _this.props.selectedItems;
var index = selectedItems.findIndex(function (t) {
return t === item;
});
if (index < 0) {
return;
}
var items = [].concat((0, _toConsumableArray3.default)(selectedItems.slice(0, index)), (0, _toConsumableArray3.default)(selectedItems.slice(index + 1, selectedItems.length)));
_this.props.onChange(items);
if (_this.props.closeOnSelect) {
_this.setState({ showTypeahead: false });
_this._onBlur();
}
}, _this._selectItem = function (item) {
var getValue = _accessor2.default.generateOptionToStringFor(_this.props.getOptionValue || _this.props.displayOption);
var previousSelected = _toArray(_this.props.selectedItems);
if (_this.props.multiSelect) {
var items = (0, _lodash2.default)(previousSelected.concat(_toArray(item).map(getValue)));
_this.props.onChange(items);
} else {
_this.props.onChange(getValue(item));
}
if (_this.props.closeOnSelect) {
_this.setState({ showTypeahead: false });
_this._onBlur();
}
}, _this._onErase = function (e) {
e.stopPropagation();
_this.props.onChange(null);
}, _this._showTypeahead = function () {
if (!_this.props.disabled) {
_this.setState({
showTypeahead: true
});
}
}, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret);
}
(0, _createClass3.default)(ItemSelector, [{
key: '_hideTypeahead',
value: function _hideTypeahead() {
this.setState({ showTypeahead: false });
this._onBlur();
}
}, {
key: '_renderDropdown',
value: function _renderDropdown() {
return _react2.default.createElement(
DropdownWrapper,
{ placement: this.props.placement },
_react2.default.createElement(_typeahead2.default, {
customClasses: {
results: 'list-selector',
input: 'typeahead__input',
listItem: 'list__item',
listAnchor: 'list__item__anchor'
},
options: this.props.options,
filterOption: this.props.filterOption,
fixedOptions: this.props.fixedOptions,
placeholder: 'Search',
onOptionSelected: this._selectItem,
customListComponent: this.props.DropDownRenderComponent,
customListHeaderComponent: this.props.DropdownHeaderComponent,
customListItemComponent: this.props.DropDownLineItemRenderComponent,
displayOption: _accessor2.default.generateOptionToStringFor(this.props.displayOption),
searchable: this.props.searchable,
showOptionsWhenEmpty: true,
selectedItems: _toArray(this.props.selectedItems)
})
);
}
}, {
key: 'render',
value: function render() {
var selected = _toArray(this.props.selectedItems);
var hasValue = selected.length;
var displayOption = _accessor2.default.generateOptionToStringFor(this.props.displayOption);
var dropdownSelectProps = {
className: (0, _classnames2.default)('item-selector__dropdown', {
active: this.state.showTypeahead
}),
disabled: this.props.disabled,
onClick: this._showTypeahead,
onFocus: this._showPopover,
error: this.props.isError,
inputTheme: this.props.inputTheme
};
return _react2.default.createElement(
'div',
{ className: 'item-selector' },
_react2.default.createElement(
'div',
{ style: { position: 'relative' } },
this.props.multiSelect ? _react2.default.createElement(_chickletedInput2.default, (0, _extends3.default)({}, dropdownSelectProps, {
selectedItems: _toArray(this.props.selectedItems),
placeholder: this.props.placeholder,
displayOption: displayOption,
removeItem: this._removeItem
})) : _react2.default.createElement(
StyledDropdownSelect,
dropdownSelectProps,
_react2.default.createElement(
DropdownSelectValue,
{ placeholder: !hasValue },
hasValue ? _react2.default.createElement(this.props.DropDownLineItemRenderComponent, {
displayOption: displayOption,
value: selected[0]
}) : this.props.placeholder
),
this.props.erasable && hasValue ? _react2.default.createElement(
DropdownSelectErase,
null,
_react2.default.createElement(_icons.Delete, { height: '12px', onClick: this._onErase })
) : null
),
this.state.showTypeahead && this._renderDropdown()
)
);
}
}]);
return ItemSelector;
}(_react.Component), _class.propTypes = {
// required properties
selectedItems: _propTypes2.default.oneOfType([_propTypes2.default.array, _propTypes2.default.string, _propTypes2.default.number, _propTypes2.default.bool, _propTypes2.default.object]),
onChange: _propTypes2.default.func.isRequired,
options: _propTypes2.default.arrayOf(_propTypes2.default.any).isRequired,
// optional properties
fixedOptions: _propTypes2.default.arrayOf(_propTypes2.default.any),
erasable: _propTypes2.default.bool,
displayOption: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
getOptionValue: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
filterOption: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
placement: _propTypes2.default.string,
disabled: _propTypes2.default.bool,
isError: _propTypes2.default.bool,
multiSelect: _propTypes2.default.bool,
inputTheme: _propTypes2.default.string,
onBlur: _propTypes2.default.func,
placeholder: _propTypes2.default.string,
closeOnSelect: _propTypes2.default.bool,
DropdownHeaderComponent: _propTypes2.default.func,
DropDownRenderComponent: _propTypes2.default.func,
DropDownLineItemRenderComponent: _propTypes2.default.func
}, _class.defaultProps = {
erasable: false,
placement: 'bottom',
selectedItems: [],
displayOption: null,
getOptionValue: null,
filterOption: null,
fixedOptions: null,
inputTheme: 'primary',
multiSelect: true,
placeholder: 'Enter a value',
closeOnSelect: true,
searchable: true,
dropdownHeader: null,
DropdownHeaderComponent: null,
DropDownRenderComponent: _dropdownList2.default,
DropDownLineItemRenderComponent: _dropdownList.ListItem
}, _temp2);
;
exports.default = (0, _reactOnclickoutside2.default)(ItemSelector);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/common/item-selector/item-selector.js"],"names":["_toArray","item","Array","isArray","StyledDropdownSelect","styled","div","props","inputTheme","theme","secondaryInput","input","dropdownListAnchor","DropdownSelectValue","span","placeholder","selectColorPlaceHolder","selectColor","DropdownSelectErase","DropdownWrapper","dropdownBgd","placement","inputBoxHeight","ItemSelector","state","showTypeahead","handleClickOutside","_hideTypeahead","_onBlur","onBlur","_removeItem","e","preventDefault","stopPropagation","selectedItems","index","findIndex","t","items","slice","length","onChange","closeOnSelect","setState","_selectItem","getValue","Accessor","generateOptionToStringFor","getOptionValue","displayOption","previousSelected","multiSelect","concat","map","_onErase","_showTypeahead","disabled","results","listItem","listAnchor","options","filterOption","fixedOptions","DropDownRenderComponent","DropdownHeaderComponent","DropDownLineItemRenderComponent","searchable","selected","hasValue","dropdownSelectProps","className","active","onClick","onFocus","_showPopover","error","isError","position","erasable","_renderDropdown","Component","propTypes","PropTypes","oneOfType","array","string","number","bool","object","func","isRequired","arrayOf","any","defaultProps","dropdownHeader","DropdownList","ListItem"],"mappings":"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","file":"item-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 classnames from 'classnames';\nimport uniq from 'lodash.uniq';\nimport listensToClickOutside from 'react-onclickoutside';\nimport styled from 'styled-components';\n\nimport Accessor from './accessor';\nimport ChickletedInput from './chickleted-input';\nimport Typeahead from './typeahead';\nimport {Delete} from 'components/common/icons';\nimport DropdownList, {ListItem} from './dropdown-list';\n\n/**\n * Converts non-arrays to arrays.  Leaves arrays alone.  Converts\n * undefined values to empty arrays ([] instead of [undefined]).\n * Otherwise, just returns [item] for non-array items.\n *\n * @param {*} item\n * @returns {array} boom! much array. very indexed. so useful.\n */\nfunction _toArray(item) {\n  if (Array.isArray(item)) {\n    return item;\n  }\n\n  if (typeof item === 'undefined' || item === null) {\n    return [];\n  }\n\n  return [item];\n}\n\nconst StyledDropdownSelect = styled.div`\n  ${props =>\n    props.inputTheme === 'secondary'\n      ? props.theme.secondaryInput\n      : props.theme.input};\n\n  .list__item__anchor {\n    ${props => props.theme.dropdownListAnchor};\n  }\n`;\n\nconst DropdownSelectValue = styled.span`\n  color: ${props =>\n    props.placeholder\n      ? props.theme.selectColorPlaceHolder\n      : props.theme.selectColor};\n  overflow: hidden;\n`;\n\nconst DropdownSelectErase = styled.div`\n  margin-left: 6px;\n  display: flex;\n`;\n\nconst DropdownWrapper = styled.div`\n  background: ${props => props.theme.dropdownBgd};\n  border: 0;\n  width: 100%;\n  left: 0;\n  z-index: 100;\n  position: absolute;\n  bottom: ${props =>\n    props.placement === 'top' ? props.theme.inputBoxHeight : 'auto'};\n  margin-top: ${props => (props.placement === 'bottom' ? '4px' : 'auto')};\n  margin-bottom: ${props => (props.placement === 'top' ? '4px' : 'auto')};\n`;\n\nclass ItemSelector extends Component {\n  static propTypes = {\n    // required properties\n    selectedItems: PropTypes.oneOfType([\n      PropTypes.array,\n      PropTypes.string,\n      PropTypes.number,\n      PropTypes.bool,\n      PropTypes.object\n    ]),\n    onChange: PropTypes.func.isRequired,\n    options: PropTypes.arrayOf(PropTypes.any).isRequired,\n\n    // optional properties\n    fixedOptions: PropTypes.arrayOf(PropTypes.any),\n    erasable: PropTypes.bool,\n    displayOption: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    getOptionValue: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    filterOption: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    placement: PropTypes.string,\n    disabled: PropTypes.bool,\n    isError: PropTypes.bool,\n    multiSelect: PropTypes.bool,\n    inputTheme: PropTypes.string,\n    onBlur: PropTypes.func,\n    placeholder: PropTypes.string,\n    closeOnSelect: PropTypes.bool,\n    DropdownHeaderComponent: PropTypes.func,\n    DropDownRenderComponent: PropTypes.func,\n    DropDownLineItemRenderComponent: PropTypes.func\n  };\n\n  static defaultProps = {\n    erasable: false,\n    placement: 'bottom',\n    selectedItems: [],\n    displayOption: null,\n    getOptionValue: null,\n    filterOption: null,\n    fixedOptions: null,\n    inputTheme: 'primary',\n    multiSelect: true,\n    placeholder: 'Enter a value',\n    closeOnSelect: true,\n    searchable: true,\n    dropdownHeader: null,\n    DropdownHeaderComponent: null,\n    DropDownRenderComponent: DropdownList,\n    DropDownLineItemRenderComponent: ListItem\n  };\n\n  state = {\n    showTypeahead: false\n  };\n\n  handleClickOutside = () => {\n    this._hideTypeahead();\n  };\n\n  _hideTypeahead() {\n    this.setState({showTypeahead: false});\n    this._onBlur();\n  }\n\n  _onBlur = () => {\n    // note: chickleted input is not a real form element so we call onBlur()\n    // when we feel the events are appropriate\n    if (this.props.onBlur) {\n      this.props.onBlur();\n    }\n  };\n\n  _removeItem = (item, e) => {\n    // only used when multiSelect = true\n    e.preventDefault();\n    e.stopPropagation();\n    const {selectedItems} = this.props;\n    const index = selectedItems.findIndex(t => t === item);\n\n    if (index < 0) {\n      return;\n    }\n\n    const items = [\n      ...selectedItems.slice(0, index),\n      ...selectedItems.slice(index + 1, selectedItems.length)\n    ];\n\n    this.props.onChange(items);\n\n    if (this.props.closeOnSelect) {\n      this.setState({showTypeahead: false});\n      this._onBlur();\n    }\n  };\n\n  _selectItem = item => {\n    const getValue = Accessor.generateOptionToStringFor(\n      this.props.getOptionValue || this.props.displayOption\n    );\n\n    const previousSelected = _toArray(this.props.selectedItems);\n\n    if (this.props.multiSelect) {\n      const items = uniq(previousSelected.concat(_toArray(item).map(getValue)));\n      this.props.onChange(items);\n    } else {\n      this.props.onChange(getValue(item));\n    }\n\n    if (this.props.closeOnSelect) {\n      this.setState({showTypeahead: false});\n      this._onBlur();\n    }\n  };\n\n  _onErase = e => {\n    e.stopPropagation();\n    this.props.onChange(null);\n  };\n\n  _showTypeahead = () => {\n    if (!this.props.disabled) {\n      this.setState({\n        showTypeahead: true\n      });\n    }\n  };\n\n  _renderDropdown() {\n    return (\n      <DropdownWrapper placement={this.props.placement}>\n        <Typeahead\n          customClasses={{\n            results: 'list-selector',\n            input: 'typeahead__input',\n            listItem: 'list__item',\n            listAnchor: 'list__item__anchor'\n          }}\n          options={this.props.options}\n          filterOption={this.props.filterOption}\n          fixedOptions={this.props.fixedOptions}\n          placeholder=\"Search\"\n          onOptionSelected={this._selectItem}\n          customListComponent={this.props.DropDownRenderComponent}\n          customListHeaderComponent={this.props.DropdownHeaderComponent}\n          customListItemComponent={this.props.DropDownLineItemRenderComponent}\n          displayOption={Accessor.generateOptionToStringFor(\n            this.props.displayOption\n          )}\n          searchable={this.props.searchable}\n          showOptionsWhenEmpty\n          selectedItems={_toArray(this.props.selectedItems)}\n        />\n      </DropdownWrapper>\n    );\n  }\n\n  render() {\n    const selected = _toArray(this.props.selectedItems);\n    const hasValue = selected.length;\n    const displayOption = Accessor.generateOptionToStringFor(\n      this.props.displayOption\n    );\n\n    const dropdownSelectProps = {\n      className: classnames(`item-selector__dropdown`, {\n        active: this.state.showTypeahead\n      }),\n      disabled: this.props.disabled,\n      onClick: this._showTypeahead,\n      onFocus: this._showPopover,\n      error: this.props.isError,\n      inputTheme: this.props.inputTheme\n    };\n\n    return (\n      <div className=\"item-selector\">\n        <div style={{position: 'relative'}}>\n          {/* this part is used to display the label */}\n          {this.props.multiSelect ? (\n            <ChickletedInput\n              {...dropdownSelectProps}\n              selectedItems={_toArray(this.props.selectedItems)}\n              placeholder={this.props.placeholder}\n              displayOption={displayOption}\n              removeItem={this._removeItem}\n            />\n          ) : (\n            <StyledDropdownSelect {...dropdownSelectProps}>\n              <DropdownSelectValue placeholder={!hasValue}>\n                {hasValue ? (\n                  <this.props.DropDownLineItemRenderComponent\n                    displayOption={displayOption}\n                    value={selected[0]}\n                  />\n                ) : (\n                  this.props.placeholder\n                )}\n              </DropdownSelectValue>\n              {this.props.erasable && hasValue ? (\n                <DropdownSelectErase>\n                  <Delete height=\"12px\" onClick={this._onErase} />\n                </DropdownSelectErase>\n              ) : null}\n            </StyledDropdownSelect>\n          )}\n          {/* this part is used to built the list */}\n          {this.state.showTypeahead && this._renderDropdown()}\n        </div>\n      </div>\n    );\n  }\n};\n\nexport default listensToClickOutside(ItemSelector);\n"]}