UNPKG

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
'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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uZAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AAEA;;;;AACA;;;;AACA;;;;AACA;;AACA;;;;;;AAEA;;;;;;;;AAQA,SAASA,QAAT,CAAkBC,IAAlB,EAAwB;AACtB,MAAIC,MAAMC,OAAN,CAAcF,IAAd,CAAJ,EAAyB;AACvB,WAAOA,IAAP;AACD;;AAED,MAAI,OAAOA,IAAP,KAAgB,WAAhB,IAA+BA,SAAS,IAA5C,EAAkD;AAChD,WAAO,EAAP;AACD;;AAED,SAAO,CAACA,IAAD,CAAP;AACD;;AAED,IAAMG,uBAAuBC,2BAAOC,GAA9B,kBACF;AAAA,SACAC,MAAMC,UAAN,KAAqB,WAArB,GACID,MAAME,KAAN,CAAYC,cADhB,GAEIH,MAAME,KAAN,CAAYE,KAHhB;AAAA,CADE,EAOA;AAAA,SAASJ,MAAME,KAAN,CAAYG,kBAArB;AAAA,CAPA,CAAN;;AAWA,IAAMC,sBAAsBR,2BAAOS,IAA7B,mBACK;AAAA,SACPP,MAAMQ,WAAN,GACIR,MAAME,KAAN,CAAYO,sBADhB,GAEIT,MAAME,KAAN,CAAYQ,WAHT;AAAA,CADL,CAAN;;AAQA,IAAMC,sBAAsBb,2BAAOC,GAA7B,kBAAN;;AAKA,IAAMa,kBAAkBd,2BAAOC,GAAzB,mBACU;AAAA,SAASC,MAAME,KAAN,CAAYW,WAArB;AAAA,CADV,EAOM;AAAA,SACRb,MAAMc,SAAN,KAAoB,KAApB,GAA4Bd,MAAME,KAAN,CAAYa,cAAxC,GAAyD,MADjD;AAAA,CAPN,EASU;AAAA,SAAUf,MAAMc,SAAN,KAAoB,QAApB,GAA+B,KAA/B,GAAuC,MAAjD;AAAA,CATV,EAUa;AAAA,SAAUd,MAAMc,SAAN,KAAoB,KAApB,GAA4B,KAA5B,GAAoC,MAA9C;AAAA,CAVb,CAAN;;IAaME,Y;;;;;;;;;;;;;;gNAmDJC,K,GAAQ;AACNC,qBAAe;AADT,K,QAIRC,kB,GAAqB,YAAM;AACzB,YAAKC,cAAL;AACD,K,QAODC,O,GAAU,YAAM;AACd;AACA;AACA,UAAI,MAAKrB,KAAL,CAAWsB,MAAf,EAAuB;AACrB,cAAKtB,KAAL,CAAWsB,MAAX;AACD;AACF,K,QAEDC,W,GAAc,UAAC7B,IAAD,EAAO8B,CAAP,EAAa;AACzB;AACAA,QAAEC,cAAF;AACAD,QAAEE,eAAF;AAHyB,UAIlBC,aAJkB,GAID,MAAK3B,KAJJ,CAIlB2B,aAJkB;;AAKzB,UAAMC,QAAQD,cAAcE,SAAd,CAAwB;AAAA,eAAKC,MAAMpC,IAAX;AAAA,OAAxB,CAAd;;AAEA,UAAIkC,QAAQ,CAAZ,EAAe;AACb;AACD;;AAED,UAAMG,mDACDJ,cAAcK,KAAd,CAAoB,CAApB,EAAuBJ,KAAvB,CADC,oCAEDD,cAAcK,KAAd,CAAoBJ,QAAQ,CAA5B,EAA+BD,cAAcM,MAA7C,CAFC,EAAN;;AAKA,YAAKjC,KAAL,CAAWkC,QAAX,CAAoBH,KAApB;;AAEA,UAAI,MAAK/B,KAAL,CAAWmC,aAAf,EAA8B;AAC5B,cAAKC,QAAL,CAAc,EAAClB,eAAe,KAAhB,EAAd;AACA,cAAKG,OAAL;AACD;AACF,K,QAEDgB,W,GAAc,gBAAQ;AACpB,UAAMC,WAAWC,mBAASC,yBAAT,CACf,MAAKxC,KAAL,CAAWyC,cAAX,IAA6B,MAAKzC,KAAL,CAAW0C,aADzB,CAAjB;;AAIA,UAAMC,mBAAmBlD,SAAS,MAAKO,KAAL,CAAW2B,aAApB,CAAzB;;AAEA,UAAI,MAAK3B,KAAL,CAAW4C,WAAf,EAA4B;AAC1B,YAAMb,QAAQ,sBAAKY,iBAAiBE,MAAjB,CAAwBpD,SAASC,IAAT,EAAeoD,GAAf,CAAmBR,QAAnB,CAAxB,CAAL,CAAd;AACA,cAAKtC,KAAL,CAAWkC,QAAX,CAAoBH,KAApB;AACD,OAHD,MAGO;AACL,cAAK/B,KAAL,CAAWkC,QAAX,CAAoBI,SAAS5C,IAAT,CAApB;AACD;;AAED,UAAI,MAAKM,KAAL,CAAWmC,aAAf,EAA8B;AAC5B,cAAKC,QAAL,CAAc,EAAClB,eAAe,KAAhB,EAAd;AACA,cAAKG,OAAL;AACD;AACF,K,QAED0B,Q,GAAW,aAAK;AACdvB,QAAEE,eAAF;AACA,YAAK1B,KAAL,CAAWkC,QAAX,CAAoB,IAApB;AACD,K,QAEDc,c,GAAiB,YAAM;AACrB,UAAI,CAAC,MAAKhD,KAAL,CAAWiD,QAAhB,EAA0B;AACxB,cAAKb,QAAL,CAAc;AACZlB,yBAAe;AADH,SAAd;AAGD;AACF,K;;;;;qCApEgB;AACf,WAAKkB,QAAL,CAAc,EAAClB,eAAe,KAAhB,EAAd;AACA,WAAKG,OAAL;AACD;;;sCAmEiB;AAChB,aACE;AAAC,uBAAD;AAAA,UAAiB,WAAW,KAAKrB,KAAL,CAAWc,SAAvC;AACE,sCAAC,mBAAD;AACE,yBAAe;AACboC,qBAAS,eADI;AAEb9C,mBAAO,kBAFM;AAGb+C,sBAAU,YAHG;AAIbC,wBAAY;AAJC,WADjB;AAOE,mBAAS,KAAKpD,KAAL,CAAWqD,OAPtB;AAQE,wBAAc,KAAKrD,KAAL,CAAWsD,YAR3B;AASE,wBAAc,KAAKtD,KAAL,CAAWuD,YAT3B;AAUE,uBAAY,QAVd;AAWE,4BAAkB,KAAKlB,WAXzB;AAYE,+BAAqB,KAAKrC,KAAL,CAAWwD,uBAZlC;AAaE,qCAA2B,KAAKxD,KAAL,CAAWyD,uBAbxC;AAcE,mCAAyB,KAAKzD,KAAL,CAAW0D,+BAdtC;AAeE,yBAAenB,mBAASC,yBAAT,CACb,KAAKxC,KAAL,CAAW0C,aADE,CAfjB;AAkBE,sBAAY,KAAK1C,KAAL,CAAW2D,UAlBzB;AAmBE,oCAnBF;AAoBE,yBAAelE,SAAS,KAAKO,KAAL,CAAW2B,aAApB;AApBjB;AADF,OADF;AA0BD;;;6BAEQ;AACP,UAAMiC,WAAWnE,SAAS,KAAKO,KAAL,CAAW2B,aAApB,CAAjB;AACA,UAAMkC,WAAWD,SAAS3B,MAA1B;AACA,UAAMS,gBAAgBH,mBAASC,yBAAT,CACpB,KAAKxC,KAAL,CAAW0C,aADS,CAAtB;;AAIA,UAAMoB,sBAAsB;AAC1BC,mBAAW,qDAAsC;AAC/CC,kBAAQ,KAAK/C,KAAL,CAAWC;AAD4B,SAAtC,CADe;AAI1B+B,kBAAU,KAAKjD,KAAL,CAAWiD,QAJK;AAK1BgB,iBAAS,KAAKjB,cALY;AAM1BkB,iBAAS,KAAKC,YANY;AAO1BC,eAAO,KAAKpE,KAAL,CAAWqE,OAPQ;AAQ1BpE,oBAAY,KAAKD,KAAL,CAAWC;AARG,OAA5B;;AAWA,aACE;AAAA;AAAA,UAAK,WAAU,eAAf;AACE;AAAA;AAAA,YAAK,OAAO,EAACqE,UAAU,UAAX,EAAZ;AAEG,eAAKtE,KAAL,CAAW4C,WAAX,GACC,8BAAC,yBAAD,6BACMkB,mBADN;AAEE,2BAAerE,SAAS,KAAKO,KAAL,CAAW2B,aAApB,CAFjB;AAGE,yBAAa,KAAK3B,KAAL,CAAWQ,WAH1B;AAIE,2BAAekC,aAJjB;AAKE,wBAAY,KAAKnB;AALnB,aADD,GASC;AAAC,gCAAD;AAA0BuC,+BAA1B;AACE;AAAC,iCAAD;AAAA,gBAAqB,aAAa,CAACD,QAAnC;AACGA,yBACC,mCAAM,KAAN,CAAY,+BAAZ;AACE,+BAAenB,aADjB;AAEE,uBAAOkB,SAAS,CAAT;AAFT,gBADD,GAMC,KAAK5D,KAAL,CAAWQ;AAPf,aADF;AAWG,iBAAKR,KAAL,CAAWuE,QAAX,IAAuBV,QAAvB,GACC;AAAC,iCAAD;AAAA;AACE,4CAAC,aAAD,IAAQ,QAAO,MAAf,EAAsB,SAAS,KAAKd,QAApC;AADF,aADD,GAIG;AAfN,WAXJ;AA8BG,eAAK9B,KAAL,CAAWC,aAAX,IAA4B,KAAKsD,eAAL;AA9B/B;AADF,OADF;AAoCD;;;EApNwBC,gB,UAClBC,S,GAAY;AACjB;AACA/C,iBAAegD,oBAAUC,SAAV,CAAoB,CACjCD,oBAAUE,KADuB,EAEjCF,oBAAUG,MAFuB,EAGjCH,oBAAUI,MAHuB,EAIjCJ,oBAAUK,IAJuB,EAKjCL,oBAAUM,MALuB,CAApB,CAFE;AASjB/C,YAAUyC,oBAAUO,IAAV,CAAeC,UATR;AAUjB9B,WAASsB,oBAAUS,OAAV,CAAkBT,oBAAUU,GAA5B,EAAiCF,UAVzB;;AAYjB;AACA5B,gBAAcoB,oBAAUS,OAAV,CAAkBT,oBAAUU,GAA5B,CAbG;AAcjBd,YAAUI,oBAAUK,IAdH;AAejBtC,iBAAeiC,oBAAUC,SAAV,CAAoB,CAACD,oBAAUG,MAAX,EAAmBH,oBAAUO,IAA7B,CAApB,CAfE;AAgBjBzC,kBAAgBkC,oBAAUC,SAAV,CAAoB,CAACD,oBAAUG,MAAX,EAAmBH,oBAAUO,IAA7B,CAApB,CAhBC;AAiBjB5B,gBAAcqB,oBAAUC,SAAV,CAAoB,CAACD,oBAAUG,MAAX,EAAmBH,oBAAUO,IAA7B,CAApB,CAjBG;AAkBjBpE,aAAW6D,oBAAUG,MAlBJ;AAmBjB7B,YAAU0B,oBAAUK,IAnBH;AAoBjBX,WAASM,oBAAUK,IApBF;AAqBjBpC,eAAa+B,oBAAUK,IArBN;AAsBjB/E,cAAY0E,oBAAUG,MAtBL;AAuBjBxD,UAAQqD,oBAAUO,IAvBD;AAwBjB1E,eAAamE,oBAAUG,MAxBN;AAyBjB3C,iBAAewC,oBAAUK,IAzBR;AA0BjBvB,2BAAyBkB,oBAAUO,IA1BlB;AA2BjB1B,2BAAyBmB,oBAAUO,IA3BlB;AA4BjBxB,mCAAiCiB,oBAAUO;AA5B1B,C,SA+BZI,Y,GAAe;AACpBf,YAAU,KADU;AAEpBzD,aAAW,QAFS;AAGpBa,iBAAe,EAHK;AAIpBe,iBAAe,IAJK;AAKpBD,kBAAgB,IALI;AAMpBa,gBAAc,IANM;AAOpBC,gBAAc,IAPM;AAQpBtD,cAAY,SARQ;AASpB2C,eAAa,IATO;AAUpBpC,eAAa,eAVO;AAWpB2B,iBAAe,IAXK;AAYpBwB,cAAY,IAZQ;AAapB4B,kBAAgB,IAbI;AAcpB9B,2BAAyB,IAdL;AAepBD,2BAAyBgC,sBAfL;AAgBpB9B,mCAAiC+B;AAhBb,C;AAqLvB;;kBAEc,mCAAsBzE,YAAtB,C","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"]}