From 98222112f20771d351f13ba9d2687bd44faae868 Mon Sep 17 00:00:00 2001 From: Vitaly Solovyov Date: Thu, 1 Dec 2016 15:58:55 +0300 Subject: [PATCH] build for 28208c2 commit --- dist/react-select.css | 1 + dist/react-select.js | 272 +- dist/react-select.min.css | 2 +- dist/react-select.min.js | 4 +- examples/dist/app.js | 203 +- examples/dist/bundle.js | 152 +- examples/dist/common.js | 25258 +++++++++++++++++----------------- examples/dist/standalone.js | 150 +- lib/Async.js | 83 +- lib/AsyncCreatable.js | 16 +- lib/Creatable.js | 45 +- lib/Select.js | 128 +- 12 files changed, 13249 insertions(+), 13065 deletions(-) diff --git a/dist/react-select.css b/dist/react-select.css index 9fdf382c87..26f87313cc 100644 --- a/dist/react-select.css +++ b/dist/react-select.css @@ -210,6 +210,7 @@ margin: -1px; clip: rect(0, 0, 0, 0); overflow: hidden; + float: left; } @-webkit-keyframes Select-animation-fadeIn { from { diff --git a/dist/react-select.js b/dist/react-select.js index c4a59600e4..6bbd0b27b1 100644 --- a/dist/react-select.js +++ b/dist/react-select.js @@ -38,18 +38,26 @@ var propTypes = { children: _react2['default'].PropTypes.func.isRequired, // Child function responsible for creating the inner Select component; (props: Object): PropTypes.element ignoreAccents: _react2['default'].PropTypes.bool, // strip diacritics when filtering; defaults to true ignoreCase: _react2['default'].PropTypes.bool, // perform case-insensitive filtering; defaults to true - loadingPlaceholder: _react.PropTypes.string.isRequired, // replaces the placeholder while options are loading + loadingPlaceholder: _react2['default'].PropTypes.oneOfType([// replaces the placeholder while options are loading + _react2['default'].PropTypes.string, _react2['default'].PropTypes.node]), loadOptions: _react2['default'].PropTypes.func.isRequired, // callback to load options asynchronously; (inputValue: string, callback: Function): ?Promise options: _react.PropTypes.array.isRequired, // array of options placeholder: _react2['default'].PropTypes.oneOfType([// field placeholder, displayed when there's no value (shared with Select) _react2['default'].PropTypes.string, _react2['default'].PropTypes.node]), + noResultsText: _react2['default'].PropTypes.oneOfType([// field noResultsText, displayed when no options come back from the server + _react2['default'].PropTypes.string, _react2['default'].PropTypes.node]), + onChange: _react2['default'].PropTypes.func, // onChange handler: function (newValue) {} searchPromptText: _react2['default'].PropTypes.oneOfType([// label to prompt for search input - _react2['default'].PropTypes.string, _react2['default'].PropTypes.node]) -}; + _react2['default'].PropTypes.string, _react2['default'].PropTypes.node]), + onInputChange: _react2['default'].PropTypes.func, // optional for keeping track of what is being typed + value: _react2['default'].PropTypes.any }; + +// initial field value +var defaultCache = {}; var defaultProps = { autoload: true, - cache: {}, + cache: defaultCache, children: defaultChildren, ignoreAccents: true, ignoreCase: true, @@ -66,6 +74,8 @@ var Async = (function (_Component) { _get(Object.getPrototypeOf(Async.prototype), 'constructor', this).call(this, props, context); + this._cache = props.cache === defaultCache ? {} : props.cache; + this.state = { isLoading: false, options: props.options @@ -95,14 +105,19 @@ var Async = (function (_Component) { } }); } + }, { + key: 'clearOptions', + value: function clearOptions() { + this.setState({ options: [] }); + } }, { key: 'loadOptions', value: function loadOptions(inputValue) { var _this2 = this; - var _props = this.props; - var cache = _props.cache; - var loadOptions = _props.loadOptions; + var loadOptions = this.props.loadOptions; + + var cache = this._cache; if (cache && cache.hasOwnProperty(inputValue)) { this.setState({ @@ -152,9 +167,10 @@ var Async = (function (_Component) { }, { key: '_onInputChange', value: function _onInputChange(inputValue) { - var _props2 = this.props; - var ignoreAccents = _props2.ignoreAccents; - var ignoreCase = _props2.ignoreCase; + var _props = this.props; + var ignoreAccents = _props.ignoreAccents; + var ignoreCase = _props.ignoreCase; + var onInputChange = _props.onInputChange; if (ignoreAccents) { inputValue = (0, _utilsStripDiacritics2['default'])(inputValue); @@ -164,24 +180,65 @@ var Async = (function (_Component) { inputValue = inputValue.toLowerCase(); } + if (onInputChange) { + onInputChange(inputValue); + } + return this.loadOptions(inputValue); } + }, { + key: 'inputValue', + value: function inputValue() { + if (this.select) { + return this.select.state.inputValue; + } + return ''; + } + }, { + key: 'noResultsText', + value: function noResultsText() { + var _props2 = this.props; + var loadingPlaceholder = _props2.loadingPlaceholder; + var noResultsText = _props2.noResultsText; + var searchPromptText = _props2.searchPromptText; + var isLoading = this.state.isLoading; + + var inputValue = this.inputValue(); + + if (isLoading) { + return loadingPlaceholder; + } + if (inputValue && noResultsText) { + return noResultsText; + } + return searchPromptText; + } }, { key: 'render', value: function render() { + var _this3 = this; + var _props3 = this.props; var children = _props3.children; var loadingPlaceholder = _props3.loadingPlaceholder; var placeholder = _props3.placeholder; - var searchPromptText = _props3.searchPromptText; var _state = this.state; var isLoading = _state.isLoading; var options = _state.options; var props = { - noResultsText: isLoading ? loadingPlaceholder : searchPromptText, + noResultsText: this.noResultsText(), placeholder: isLoading ? loadingPlaceholder : placeholder, - options: isLoading ? [] : options + options: isLoading && loadingPlaceholder ? [] : options, + ref: function ref(_ref) { + return _this3.select = _ref; + }, + onChange: function onChange(newValues) { + if (_this3.props.value && newValues.length > _this3.props.value.length) { + _this3.clearOptions(); + } + _this3.props.onChange(newValues); + } }; return children(_extends({}, this.props, props, { @@ -221,6 +278,16 @@ var _Select = require('./Select'); var _Select2 = _interopRequireDefault(_Select); +function reduce(obj) { + var props = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + + return Object.keys(obj).reduce(function (props, key) { + var value = obj[key]; + if (value !== undefined) props[key] = value; + return props; + }, props); +} + var AsyncCreatable = _react2['default'].createClass({ displayName: 'AsyncCreatableSelect', @@ -235,10 +302,14 @@ var AsyncCreatable = _react2['default'].createClass({ _Select2['default'].Creatable, _this.props, function (creatableProps) { - return _react2['default'].createElement(_Select2['default'], _extends({}, asyncProps, creatableProps, { + return _react2['default'].createElement(_Select2['default'], _extends({}, reduce(asyncProps, reduce(creatableProps, {})), { onInputChange: function (input) { creatableProps.onInputChange(input); return asyncProps.onInputChange(input); + }, + ref: function (ref) { + creatableProps.ref(ref); + asyncProps.ref(ref); } })); } @@ -305,6 +376,15 @@ var Creatable = _react2['default'].createClass({ // ({ label: string, labelKey: string, valueKey: string }): Object newOptionCreator: _react2['default'].PropTypes.func, + // input change handler: function (inputValue) {} + onInputChange: _react2['default'].PropTypes.func, + + // input keyDown handler: function (event) {} + onInputKeyDown: _react2['default'].PropTypes.func, + + // new option click handler: function (option) {} + onNewOptionClick: _react2['default'].PropTypes.func, + // See Select.propTypes.options options: _react2['default'].PropTypes.array, @@ -341,6 +421,7 @@ var Creatable = _react2['default'].createClass({ var _props = this.props; var isValidNewOption = _props.isValidNewOption; var newOptionCreator = _props.newOptionCreator; + var onNewOptionClick = _props.onNewOptionClick; var _props$options = _props.options; var options = _props$options === undefined ? [] : _props$options; var shouldKeyDownEventCreateNewOption = _props.shouldKeyDownEventCreateNewOption; @@ -351,9 +432,13 @@ var Creatable = _react2['default'].createClass({ // Don't add the same option twice. if (_isOptionUnique) { - options.unshift(option); + if (onNewOptionClick) { + onNewOptionClick(option); + } else { + options.unshift(option); - this.select.selectValue(option); + this.select.selectValue(option); + } } } }, @@ -423,17 +508,26 @@ var Creatable = _react2['default'].createClass({ var menuRenderer = this.props.menuRenderer; return menuRenderer(_extends({}, params, { - onSelect: this.onOptionSelect + onSelect: this.onOptionSelect, + selectValue: this.onOptionSelect })); }, onInputChange: function onInputChange(input) { + var onInputChange = this.props.onInputChange; + + if (onInputChange) { + onInputChange(input); + } + // This value may be needed in between Select mounts (when this.select is null) this.inputValue = input; }, onInputKeyDown: function onInputKeyDown(event) { - var shouldKeyDownEventCreateNewOption = this.props.shouldKeyDownEventCreateNewOption; + var _props3 = this.props; + var shouldKeyDownEventCreateNewOption = _props3.shouldKeyDownEventCreateNewOption; + var onInputKeyDown = _props3.onInputKeyDown; var focusedOption = this.select.getFocusedOption(); @@ -442,6 +536,8 @@ var Creatable = _react2['default'].createClass({ // Prevent decorated Select from doing anything additional with this keyDown event event.preventDefault(); + } else if (onInputKeyDown) { + onInputKeyDown(event); } }, @@ -456,13 +552,13 @@ var Creatable = _react2['default'].createClass({ render: function render() { var _this = this; - var _props3 = this.props; - var _props3$children = _props3.children; - var children = _props3$children === undefined ? defaultChildren : _props3$children; - var newOptionCreator = _props3.newOptionCreator; - var shouldKeyDownEventCreateNewOption = _props3.shouldKeyDownEventCreateNewOption; + var _props4 = this.props; + var _props4$children = _props4.children; + var children = _props4$children === undefined ? defaultChildren : _props4$children; + var newOptionCreator = _props4.newOptionCreator; + var shouldKeyDownEventCreateNewOption = _props4.shouldKeyDownEventCreateNewOption; - var restProps = _objectWithoutProperties(_props3, ['children', 'newOptionCreator', 'shouldKeyDownEventCreateNewOption']); + var restProps = _objectWithoutProperties(_props4, ['children', 'newOptionCreator', 'shouldKeyDownEventCreateNewOption']); var props = _extends({}, restProps, { allowCreate: true, @@ -759,6 +855,7 @@ var Select = _react2['default'].createClass({ clearAllText: stringOrNode, // title for the "clear" control when multi: true clearValueText: stringOrNode, // title for the "clear" control clearable: _react2['default'].PropTypes.bool, // should it be possible to reset value + deleteRemoves: _react2['default'].PropTypes.bool, // whether backspace removes an item if there is no text input delimiter: _react2['default'].PropTypes.string, // delimiter to use to join multiple values for the hidden field value disabled: _react2['default'].PropTypes.bool, // whether the Select is disabled or not escapeClearsValue: _react2['default'].PropTypes.bool, // whether escape clears the value when the menu is closed @@ -827,6 +924,7 @@ var Select = _react2['default'].createClass({ clearable: true, clearAllText: 'Clear all', clearValueText: 'Clear value', + deleteRemoves: true, delimiter: ',', disabled: false, escapeClearsValue: true, @@ -938,14 +1036,26 @@ var Select = _react2['default'].createClass({ }, componentWillUnmount: function componentWillUnmount() { - document.removeEventListener('touchstart', this.handleTouchOutside); + if (!document.removeEventListener && document.detachEvent) { + document.detachEvent('ontouchstart', this.handleTouchOutside); + } else { + document.removeEventListener('touchstart', this.handleTouchOutside); + } }, toggleTouchOutsideEvent: function toggleTouchOutsideEvent(enabled) { if (enabled) { - document.addEventListener('touchstart', this.handleTouchOutside); + if (!document.addEventListener && document.attachEvent) { + document.attachEvent('ontouchstart', this.handleTouchOutside); + } else { + document.addEventListener('touchstart', this.handleTouchOutside); + } } else { - document.removeEventListener('touchstart', this.handleTouchOutside); + if (!document.removeEventListener && document.detachEvent) { + document.detachEvent('ontouchstart', this.handleTouchOutside); + } else { + document.removeEventListener('touchstart', this.handleTouchOutside); + } } }, @@ -1220,6 +1330,13 @@ var Select = _react2['default'].createClass({ } this.focusStartOption(); break; + case 46: + // backspace + if (!this.state.inputValue && this.props.deleteRemoves) { + event.preventDefault(); + this.popValue(); + } + return; default: return; } @@ -1545,70 +1662,69 @@ var Select = _react2['default'].createClass({ }, renderInput: function renderInput(valueArray, focusedOptionIndex) { - var _this5 = this; + var _classNames, + _this5 = this; + + var className = (0, _classnames2['default'])('Select-input', this.props.inputProps.className); + var isOpen = !!this.state.isOpen; + + var ariaOwns = (0, _classnames2['default'])((_classNames = {}, _defineProperty(_classNames, this._instancePrefix + '-list', isOpen), _defineProperty(_classNames, this._instancePrefix + '-backspace-remove-message', this.props.multi && !this.props.disabled && this.state.isFocused && !this.state.inputValue), _classNames)); + + // TODO: Check how this project includes Object.assign() + var inputProps = _extends({}, this.props.inputProps, { + role: 'combobox', + 'aria-expanded': '' + isOpen, + 'aria-owns': ariaOwns, + 'aria-haspopup': '' + isOpen, + 'aria-activedescendant': isOpen ? this._instancePrefix + '-option-' + focusedOptionIndex : this._instancePrefix + '-value', + 'aria-labelledby': this.props['aria-labelledby'], + 'aria-label': this.props['aria-label'], + className: className, + tabIndex: this.props.tabIndex, + onBlur: this.handleInputBlur, + onChange: this.handleInputChange, + onFocus: this.handleInputFocus, + ref: function ref(_ref) { + return _this5.input = _ref; + }, + required: this.state.required, + value: this.state.inputValue + }); if (this.props.inputRenderer) { - return this.props.inputRenderer(); - } else { - var _classNames; + return this.props.inputRenderer(inputProps); + } - var className = (0, _classnames2['default'])('Select-input', this.props.inputProps.className); - var isOpen = !!this.state.isOpen; + if (this.props.disabled || !this.props.searchable) { + var _props$inputProps = this.props.inputProps; + var inputClassName = _props$inputProps.inputClassName; - var ariaOwns = (0, _classnames2['default'])((_classNames = {}, _defineProperty(_classNames, this._instancePrefix + '-list', isOpen), _defineProperty(_classNames, this._instancePrefix + '-backspace-remove-message', this.props.multi && !this.props.disabled && this.state.isFocused && !this.state.inputValue), _classNames)); + var divProps = _objectWithoutProperties(_props$inputProps, ['inputClassName']); - // TODO: Check how this project includes Object.assign() - var inputProps = _extends({}, this.props.inputProps, { + return _react2['default'].createElement('div', _extends({}, divProps, { role: 'combobox', - 'aria-expanded': '' + isOpen, - 'aria-owns': ariaOwns, - 'aria-haspopup': '' + isOpen, + 'aria-expanded': isOpen, + 'aria-owns': isOpen ? this._instancePrefix + '-list' : this._instancePrefix + '-value', 'aria-activedescendant': isOpen ? this._instancePrefix + '-option-' + focusedOptionIndex : this._instancePrefix + '-value', - 'aria-labelledby': this.props['aria-labelledby'], - 'aria-label': this.props['aria-label'], className: className, - tabIndex: this.props.tabIndex, + tabIndex: this.props.tabIndex || 0, onBlur: this.handleInputBlur, - onChange: this.handleInputChange, onFocus: this.handleInputFocus, - ref: function ref(_ref) { - return _this5.input = _ref; + ref: function (ref) { + return _this5.input = ref; }, - required: this.state.required, - value: this.state.inputValue - }); - - if (this.props.disabled || !this.props.searchable) { - var _props$inputProps = this.props.inputProps; - var inputClassName = _props$inputProps.inputClassName; - - var divProps = _objectWithoutProperties(_props$inputProps, ['inputClassName']); - - return _react2['default'].createElement('div', _extends({}, divProps, { - role: 'combobox', - 'aria-expanded': isOpen, - 'aria-owns': isOpen ? this._instancePrefix + '-list' : this._instancePrefix + '-value', - 'aria-activedescendant': isOpen ? this._instancePrefix + '-option-' + focusedOptionIndex : this._instancePrefix + '-value', - className: className, - tabIndex: this.props.tabIndex || 0, - onBlur: this.handleInputBlur, - onFocus: this.handleInputFocus, - ref: function (ref) { - return _this5.input = ref; - }, - 'aria-readonly': '' + !!this.props.disabled, - style: { border: 0, width: 1, display: 'inline-block' } })); - } + 'aria-readonly': '' + !!this.props.disabled, + style: { border: 0, width: 1, display: 'inline-block' } })); + } - if (this.props.autosize) { - return _react2['default'].createElement(_reactInputAutosize2['default'], _extends({}, inputProps, { minWidth: '5px' })); - } - return _react2['default'].createElement( - 'div', - { className: className }, - _react2['default'].createElement('input', inputProps) - ); + if (this.props.autosize) { + return _react2['default'].createElement(_reactInputAutosize2['default'], _extends({}, inputProps, { minWidth: '5' })); } + return _react2['default'].createElement( + 'div', + { className: className }, + _react2['default'].createElement('input', inputProps) + ); }, renderClear: function renderClear() { diff --git a/dist/react-select.min.css b/dist/react-select.min.css index b20611f70f..a406797613 100644 --- a/dist/react-select.min.css +++ b/dist/react-select.min.css @@ -1 +1 @@ -.Select,.Select-control{position:relative}.Select,.Select div,.Select input,.Select span{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.Select.is-disabled>.Select-control{background-color:#f9f9f9}.Select.is-disabled>.Select-control:hover{box-shadow:none}.Select.is-disabled .Select-arrow-zone{cursor:default;pointer-events:none;opacity:.35}.Select-control{background-color:#fff;border-radius:4px;border:1px solid #ccc;color:#333;cursor:default;display:table;border-spacing:0;border-collapse:separate;height:36px;outline:0;overflow:hidden;width:100%}.is-searchable.is-focused:not(.is-open)>.Select-control,.is-searchable.is-open>.Select-control{cursor:text}.Select-control:hover{box-shadow:0 1px 0 rgba(0,0,0,.06)}.Select-control .Select-input:focus{outline:0}.is-open>.Select-control{border-bottom-right-radius:0;border-bottom-left-radius:0;background:#fff;border-color:#b3b3b3 #ccc #d9d9d9}.is-open>.Select-control>.Select-arrow{border-color:transparent transparent #999;border-width:0 5px 5px}.is-focused:not(.is-open)>.Select-control{border-color:#007eff;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 0 3px rgba(0,126,255,.1)}.Select--single>.Select-control .Select-value,.Select-placeholder{bottom:0;color:#aaa;left:0;line-height:34px;padding-left:10px;padding-right:10px;position:absolute;right:0;top:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.has-value.Select--single>.Select-control .Select-value .Select-value-label,.has-value.is-pseudo-focused.Select--single>.Select-control .Select-value .Select-value-label{color:#333}.has-value.Select--single>.Select-control .Select-value a.Select-value-label,.has-value.is-pseudo-focused.Select--single>.Select-control .Select-value a.Select-value-label{cursor:pointer;text-decoration:none}.has-value.Select--single>.Select-control .Select-value a.Select-value-label:focus,.has-value.Select--single>.Select-control .Select-value a.Select-value-label:hover,.has-value.is-pseudo-focused.Select--single>.Select-control .Select-value a.Select-value-label:focus,.has-value.is-pseudo-focused.Select--single>.Select-control .Select-value a.Select-value-label:hover{color:#007eff;outline:0;text-decoration:underline}.Select-input{height:34px;padding-left:10px;padding-right:10px;vertical-align:middle}.Select-input>input{width:100%;background:none;border:0;box-shadow:none;cursor:default;display:inline-block;font-family:inherit;font-size:inherit;margin:0;outline:0;line-height:14px;padding:8px 0 12px;-webkit-appearance:none}.Select-loading,.Select-loading-zone{width:16px;position:relative;vertical-align:middle}.is-focused .Select-input>input{cursor:text}.has-value.is-pseudo-focused .Select-input{opacity:0}.Select-control:not(.is-searchable)>.Select-input{outline:0}.Select-loading-zone{cursor:pointer;display:table-cell;text-align:center}.Select-loading{-webkit-animation:Select-animation-spin .4s infinite linear;-o-animation:Select-animation-spin .4s infinite linear;animation:Select-animation-spin .4s infinite linear;height:16px;box-sizing:border-box;border-radius:50%;border:2px solid #ccc;border-right-color:#333;display:inline-block}.Select-clear-zone{-webkit-animation:Select-animation-fadeIn .2s;-o-animation:Select-animation-fadeIn .2s;animation:Select-animation-fadeIn .2s;color:#999;cursor:pointer;display:table-cell;position:relative;text-align:center;vertical-align:middle;width:17px}.Select-clear-zone:hover{color:#D0021B}.Select-clear{display:inline-block;font-size:18px;line-height:1}.Select--multi .Select-clear-zone{width:17px}.Select-arrow-zone{cursor:pointer;display:table-cell;position:relative;text-align:center;vertical-align:middle;width:25px;padding-right:5px}.Select--multi .Select-multi-value-wrapper,.Select-arrow{display:inline-block}.Select-arrow{border-color:#999 transparent transparent;border-style:solid;border-width:5px 5px 2.5px;height:0;width:0}.Select-arrow-zone:hover>.Select-arrow,.is-open .Select-arrow{border-top-color:#666}.Select .Select-aria-only{display:inline-block;height:1px;width:1px;margin:-1px;clip:rect(0,0,0,0);overflow:hidden}.Select-noresults,.Select-option{box-sizing:border-box;display:block;padding:8px 10px}@-webkit-keyframes Select-animation-fadeIn{from{opacity:0}to{opacity:1}}@keyframes Select-animation-fadeIn{from{opacity:0}to{opacity:1}}.Select-menu-outer{border-bottom-right-radius:4px;border-bottom-left-radius:4px;background-color:#fff;border:1px solid #ccc;border-top-color:#e6e6e6;box-shadow:0 1px 0 rgba(0,0,0,.06);box-sizing:border-box;margin-top:-1px;max-height:200px;position:absolute;top:100%;width:100%;z-index:1;-webkit-overflow-scrolling:touch}.Select-menu{max-height:198px;overflow-y:auto}.Select-option{background-color:#fff;color:#666;cursor:pointer}.Select-option:last-child{border-bottom-right-radius:4px;border-bottom-left-radius:4px}.Select-option.is-selected{background-color:#f5faff;background-color:rgba(0,126,255,.04);color:#333}.Select-option.is-focused{background-color:#ebf5ff;background-color:rgba(0,126,255,.08);color:#333}.Select-option.is-disabled{color:#ccc;cursor:default}.Select-noresults{color:#999;cursor:default}.Select--multi .Select-input{vertical-align:middle;margin-left:10px;padding:0}.Select--multi.has-value .Select-input{margin-left:5px}.Select--multi .Select-value{background-color:#ebf5ff;background-color:rgba(0,126,255,.08);border-radius:2px;border:1px solid #c2e0ff;border:1px solid rgba(0,126,255,.24);color:#007eff;display:inline-block;font-size:.9em;line-height:1.4;margin-left:5px;margin-top:5px;vertical-align:top}.Select--multi .Select-value-icon,.Select--multi .Select-value-label{display:inline-block;vertical-align:middle}.Select--multi .Select-value-label{border-bottom-right-radius:2px;border-top-right-radius:2px;cursor:default;padding:2px 5px}.Select--multi a.Select-value-label{color:#007eff;cursor:pointer;text-decoration:none}.Select--multi a.Select-value-label:hover{text-decoration:underline}.Select--multi .Select-value-icon{cursor:pointer;border-bottom-left-radius:2px;border-top-left-radius:2px;border-right:1px solid #c2e0ff;border-right:1px solid rgba(0,126,255,.24);padding:1px 5px 3px}.Select--multi .Select-value-icon:focus,.Select--multi .Select-value-icon:hover{background-color:#d8eafd;background-color:rgba(0,113,230,.08);color:#0071e6}.Select--multi .Select-value-icon:active{background-color:#c2e0ff;background-color:rgba(0,126,255,.24)}.Select--multi.is-disabled .Select-value{background-color:#fcfcfc;border:1px solid #e3e3e3;color:#333}.Select--multi.is-disabled .Select-value-icon{cursor:not-allowed;border-right:1px solid #e3e3e3}.Select--multi.is-disabled .Select-value-icon:active,.Select--multi.is-disabled .Select-value-icon:focus,.Select--multi.is-disabled .Select-value-icon:hover{background-color:#fcfcfc}@keyframes Select-animation-spin{to{transform:rotate(1turn)}}@-webkit-keyframes Select-animation-spin{to{-webkit-transform:rotate(1turn)}} \ No newline at end of file +.Select,.Select-control{position:relative}.Select,.Select div,.Select input,.Select span{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.Select.is-disabled>.Select-control{background-color:#f9f9f9}.Select.is-disabled>.Select-control:hover{box-shadow:none}.Select.is-disabled .Select-arrow-zone{cursor:default;pointer-events:none;opacity:.35}.Select-control{background-color:#fff;border-radius:4px;border:1px solid #ccc;color:#333;cursor:default;display:table;border-spacing:0;border-collapse:separate;height:36px;outline:0;overflow:hidden;width:100%}.is-searchable.is-focused:not(.is-open)>.Select-control,.is-searchable.is-open>.Select-control{cursor:text}.Select-control:hover{box-shadow:0 1px 0 rgba(0,0,0,.06)}.Select-control .Select-input:focus{outline:0}.is-open>.Select-control{border-bottom-right-radius:0;border-bottom-left-radius:0;background:#fff;border-color:#b3b3b3 #ccc #d9d9d9}.is-open>.Select-control>.Select-arrow{border-color:transparent transparent #999;border-width:0 5px 5px}.is-focused:not(.is-open)>.Select-control{border-color:#007eff;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 0 3px rgba(0,126,255,.1)}.Select--single>.Select-control .Select-value,.Select-placeholder{bottom:0;color:#aaa;left:0;line-height:34px;padding-left:10px;padding-right:10px;position:absolute;right:0;top:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.has-value.Select--single>.Select-control .Select-value .Select-value-label,.has-value.is-pseudo-focused.Select--single>.Select-control .Select-value .Select-value-label{color:#333}.has-value.Select--single>.Select-control .Select-value a.Select-value-label,.has-value.is-pseudo-focused.Select--single>.Select-control .Select-value a.Select-value-label{cursor:pointer;text-decoration:none}.has-value.Select--single>.Select-control .Select-value a.Select-value-label:focus,.has-value.Select--single>.Select-control .Select-value a.Select-value-label:hover,.has-value.is-pseudo-focused.Select--single>.Select-control .Select-value a.Select-value-label:focus,.has-value.is-pseudo-focused.Select--single>.Select-control .Select-value a.Select-value-label:hover{color:#007eff;outline:0;text-decoration:underline}.Select-input{height:34px;padding-left:10px;padding-right:10px;vertical-align:middle}.Select-input>input{width:100%;background:none;border:0;box-shadow:none;cursor:default;display:inline-block;font-family:inherit;font-size:inherit;margin:0;outline:0;line-height:14px;padding:8px 0 12px;-webkit-appearance:none}.Select-loading,.Select-loading-zone{width:16px;position:relative;vertical-align:middle}.is-focused .Select-input>input{cursor:text}.has-value.is-pseudo-focused .Select-input{opacity:0}.Select-control:not(.is-searchable)>.Select-input{outline:0}.Select-loading-zone{cursor:pointer;display:table-cell;text-align:center}.Select-loading{-webkit-animation:Select-animation-spin .4s infinite linear;-o-animation:Select-animation-spin .4s infinite linear;animation:Select-animation-spin .4s infinite linear;height:16px;box-sizing:border-box;border-radius:50%;border:2px solid #ccc;border-right-color:#333;display:inline-block}.Select-clear-zone{-webkit-animation:Select-animation-fadeIn .2s;-o-animation:Select-animation-fadeIn .2s;animation:Select-animation-fadeIn .2s;color:#999;cursor:pointer;display:table-cell;position:relative;text-align:center;vertical-align:middle;width:17px}.Select-clear-zone:hover{color:#D0021B}.Select-clear{display:inline-block;font-size:18px;line-height:1}.Select--multi .Select-clear-zone{width:17px}.Select-arrow-zone{cursor:pointer;display:table-cell;position:relative;text-align:center;vertical-align:middle;width:25px;padding-right:5px}.Select--multi .Select-multi-value-wrapper,.Select-arrow{display:inline-block}.Select-arrow{border-color:#999 transparent transparent;border-style:solid;border-width:5px 5px 2.5px;height:0;width:0}.Select-arrow-zone:hover>.Select-arrow,.is-open .Select-arrow{border-top-color:#666}.Select .Select-aria-only{display:inline-block;height:1px;width:1px;margin:-1px;clip:rect(0,0,0,0);overflow:hidden;float:left}.Select-noresults,.Select-option{box-sizing:border-box;display:block;padding:8px 10px}@-webkit-keyframes Select-animation-fadeIn{from{opacity:0}to{opacity:1}}@keyframes Select-animation-fadeIn{from{opacity:0}to{opacity:1}}.Select-menu-outer{border-bottom-right-radius:4px;border-bottom-left-radius:4px;background-color:#fff;border:1px solid #ccc;border-top-color:#e6e6e6;box-shadow:0 1px 0 rgba(0,0,0,.06);box-sizing:border-box;margin-top:-1px;max-height:200px;position:absolute;top:100%;width:100%;z-index:1;-webkit-overflow-scrolling:touch}.Select-menu{max-height:198px;overflow-y:auto}.Select-option{background-color:#fff;color:#666;cursor:pointer}.Select-option:last-child{border-bottom-right-radius:4px;border-bottom-left-radius:4px}.Select-option.is-selected{background-color:#f5faff;background-color:rgba(0,126,255,.04);color:#333}.Select-option.is-focused{background-color:#ebf5ff;background-color:rgba(0,126,255,.08);color:#333}.Select-option.is-disabled{color:#ccc;cursor:default}.Select-noresults{color:#999;cursor:default}.Select--multi .Select-input{vertical-align:middle;margin-left:10px;padding:0}.Select--multi.has-value .Select-input{margin-left:5px}.Select--multi .Select-value{background-color:#ebf5ff;background-color:rgba(0,126,255,.08);border-radius:2px;border:1px solid #c2e0ff;border:1px solid rgba(0,126,255,.24);color:#007eff;display:inline-block;font-size:.9em;line-height:1.4;margin-left:5px;margin-top:5px;vertical-align:top}.Select--multi .Select-value-icon,.Select--multi .Select-value-label{display:inline-block;vertical-align:middle}.Select--multi .Select-value-label{border-bottom-right-radius:2px;border-top-right-radius:2px;cursor:default;padding:2px 5px}.Select--multi a.Select-value-label{color:#007eff;cursor:pointer;text-decoration:none}.Select--multi a.Select-value-label:hover{text-decoration:underline}.Select--multi .Select-value-icon{cursor:pointer;border-bottom-left-radius:2px;border-top-left-radius:2px;border-right:1px solid #c2e0ff;border-right:1px solid rgba(0,126,255,.24);padding:1px 5px 3px}.Select--multi .Select-value-icon:focus,.Select--multi .Select-value-icon:hover{background-color:#d8eafd;background-color:rgba(0,113,230,.08);color:#0071e6}.Select--multi .Select-value-icon:active{background-color:#c2e0ff;background-color:rgba(0,126,255,.24)}.Select--multi.is-disabled .Select-value{background-color:#fcfcfc;border:1px solid #e3e3e3;color:#333}.Select--multi.is-disabled .Select-value-icon{cursor:not-allowed;border-right:1px solid #e3e3e3}.Select--multi.is-disabled .Select-value-icon:active,.Select--multi.is-disabled .Select-value-icon:focus,.Select--multi.is-disabled .Select-value-icon:hover{background-color:#fcfcfc}@keyframes Select-animation-spin{to{transform:rotate(1turn)}}@-webkit-keyframes Select-animation-spin{to{-webkit-transform:rotate(1turn)}} \ No newline at end of file diff --git a/dist/react-select.min.js b/dist/react-select.min.js index 6e7e8ee34e..9068799320 100644 --- a/dist/react-select.min.js +++ b/dist/react-select.min.js @@ -1,2 +1,2 @@ -!function(e){if("object"==typeof exports&&"undefined"!=typeof module)module.exports=e();else if("function"==typeof define&&define.amd)define([],e);else{var t;t="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:this,t.Select=e()}}(function(){return function e(t,u,n){function s(i,a){if(!u[i]){if(!t[i]){var r="function"==typeof require&&require;if(!a&&r)return r(i,!0);if(o)return o(i,!0);var l=new Error("Cannot find module '"+i+"'");throw l.code="MODULE_NOT_FOUND",l}var p=u[i]={exports:{}};t[i][0].call(p.exports,function(e){var u=t[i][1][e];return s(u?u:e)},p,p.exports,e,t,u,n)}return u[i].exports}for(var o="function"==typeof require&&require,i=0;i=0||Object.prototype.hasOwnProperty.call(e,n)&&(u[n]=e[n]);return u}function o(e){return f["default"].createElement(E["default"],e)}function i(e){var t=e.option,u=e.options,n=e.labelKey,s=e.valueKey;return 0===u.filter(function(e){return e[n]===t[n]||e[s]===t[s]}).length}function a(e){var t=e.label;return!!t}function r(e){var t=e.label,u=e.labelKey,n=e.valueKey,s={};return s[n]=t,s[u]=t,s.className="Select-create-option-placeholder",s}function l(e){return'Create option "'+e+'"'}function p(e){var t=e.keyCode;switch(t){case 9:case 13:case 188:return!0}return!1}var d=Object.assign||function(e){for(var t=1;t=0||Object.prototype.hasOwnProperty.call(e,n)&&(u[n]=e[n]);return u}function i(e,t,u){return t in e?Object.defineProperty(e,t,{value:u,enumerable:!0,configurable:!0,writable:!0}):e[t]=u,e}function a(e){var t=typeof e;return"string"===t?e:"object"===t?JSON.stringify(e):"number"===t||"boolean"===t?String(e):""}Object.defineProperty(u,"__esModule",{value:!0});var r=Object.assign||function(e){for(var t=1;ta.bottom||i.topt.offsetHeight&&!(t.scrollHeight-t.offsetHeight-t.scrollTop)&&this.props.onMenuScrollToBottom()}},handleRequired:function(e,t){return!e||(t?0===e.length:0===Object.keys(e).length)},getOptionLabel:function(e){return e[this.props.labelKey]},getValueArray:function(e,t){var u=this,n="object"==typeof t?t:this.props;if(n.multi){if("string"==typeof e&&(e=e.split(n.delimiter)),!Array.isArray(e)){if(null===e||void 0===e)return[];e=[e]}return e.map(function(e){return u.expandValue(e,n)}).filter(function(e){return e})}var s=this.expandValue(e,n);return s?[s]:[]},expandValue:function(e,t){var u=typeof e;if("string"!==u&&"number"!==u&&"boolean"!==u)return e;var n=t.options,s=t.valueKey;if(n)for(var o=0;o0?u-=1:u=t.length-1;else if("start"===e)u=0;else if("end"===e)u=t.length-1;else if("page_up"===e){var s=u-this.props.pageSize;u=s<0?0:s}else if("page_down"===e){var s=u+this.props.pageSize;u=s>t.length-1?t.length-1:s}u===-1&&(u=0),this.setState({focusedIndex:t[u].index,focusedOption:t[u].option})}},getFocusedOption:function(){return this._focusedOption},getInputValue:function(){return this.state.inputValue},selectFocusedOption:function(){if(this._focusedOption)return this.selectValue(this._focusedOption)},renderLoading:function(){if(this.props.isLoading)return p["default"].createElement("span",{className:"Select-loading-zone","aria-hidden":"true"},p["default"].createElement("span",{className:"Select-loading"}))},renderValue:function(e,t){var u=this,n=this.props.valueRenderer||this.getOptionLabel,s=this.props.valueComponent;if(!e.length)return this.state.inputValue?null:p["default"].createElement("div",{className:"Select-placeholder"},this.props.placeholder);var o=this.props.onValueClick?this.handleValueClick:null;return this.props.multi?e.map(function(e,t){return p["default"].createElement(s,{id:u._instancePrefix+"-value-"+t,instancePrefix:u._instancePrefix,disabled:u.props.disabled||e.clearableValue===!1,key:"value-"+t+"-"+e[u.props.valueKey],onClick:o,onRemove:u.removeValue,value:e},n(e,t),p["default"].createElement("span",{className:"Select-aria-only"}," "))}):this.state.inputValue?void 0:(t&&(o=null),p["default"].createElement(s,{id:this._instancePrefix+"-value-item",disabled:this.props.disabled,instancePrefix:this._instancePrefix,onClick:o,value:e[0]},n(e[0])))},renderInput:function(e,t){var u=this;if(this.props.inputRenderer)return this.props.inputRenderer();var n,s=(0,y["default"])("Select-input",this.props.inputProps.className),a=!!this.state.isOpen,l=(0,y["default"])((n={},i(n,this._instancePrefix+"-list",a),i(n,this._instancePrefix+"-backspace-remove-message",this.props.multi&&!this.props.disabled&&this.state.isFocused&&!this.state.inputValue),n)),d=r({},this.props.inputProps,{role:"combobox","aria-expanded":""+a,"aria-owns":l,"aria-haspopup":""+a,"aria-activedescendant":a?this._instancePrefix+"-option-"+t:this._instancePrefix+"-value","aria-labelledby":this.props["aria-labelledby"],"aria-label":this.props["aria-label"],className:s,tabIndex:this.props.tabIndex,onBlur:this.handleInputBlur,onChange:this.handleInputChange,onFocus:this.handleInputFocus,ref:function(e){return u.input=e},required:this.state.required,value:this.state.inputValue});if(this.props.disabled||!this.props.searchable){var c=this.props.inputProps,f=(c.inputClassName,o(c,["inputClassName"]));return p["default"].createElement("div",r({},f,{role:"combobox","aria-expanded":a,"aria-owns":a?this._instancePrefix+"-list":this._instancePrefix+"-value","aria-activedescendant":a?this._instancePrefix+"-option-"+t:this._instancePrefix+"-value",className:s,tabIndex:this.props.tabIndex||0,onBlur:this.handleInputBlur,onFocus:this.handleInputFocus,ref:function(e){return u.input=e},"aria-readonly":""+!!this.props.disabled,style:{border:0,width:1,display:"inline-block"}}))}return this.props.autosize?p["default"].createElement(h["default"],r({},d,{minWidth:"5px"})):p["default"].createElement("div",{className:s},p["default"].createElement("input",d))},renderClear:function(){if(this.props.clearable&&this.props.value&&0!==this.props.value&&(!this.props.multi||this.props.value.length)&&!this.props.disabled&&!this.props.isLoading)return p["default"].createElement("span",{className:"Select-clear-zone",title:this.props.multi?this.props.clearAllText:this.props.clearValueText,"aria-label":this.props.multi?this.props.clearAllText:this.props.clearValueText,onMouseDown:this.clearValue,onTouchStart:this.handleTouchStart,onTouchMove:this.handleTouchMove,onTouchEnd:this.handleTouchEndClearValue},p["default"].createElement("span",{className:"Select-clear",dangerouslySetInnerHTML:{__html:"×"}}))},renderArrow:function(){var e=this.handleMouseDownOnArrow,t=this.props.arrowRenderer({onMouseDown:e});return p["default"].createElement("span",{className:"Select-arrow-zone",onMouseDown:e},t)},filterOptions:function _(e){var t=this.state.inputValue,u=this.props.options||[];if(this.props.filterOptions){var _="function"==typeof this.props.filterOptions?this.props.filterOptions:m["default"];return _(u,t,e,{filterOption:this.props.filterOption,ignoreAccents:this.props.ignoreAccents,ignoreCase:this.props.ignoreCase,labelKey:this.props.labelKey,matchPos:this.props.matchPos,matchProp:this.props.matchProp,valueKey:this.props.valueKey})}return u},onOptionRef:function(e,t){t&&(this.focused=e)},renderMenu:function(e,t,u){return e&&e.length?this.props.menuRenderer({focusedOption:u,focusOption:this.focusOption,instancePrefix:this._instancePrefix,labelKey:this.props.labelKey,onFocus:this.focusOption,onSelect:this.selectValue,optionClassName:this.props.optionClassName,optionComponent:this.props.optionComponent,optionRenderer:this.props.optionRenderer||this.getOptionLabel,options:e,selectValue:this.selectValue,valueArray:t,valueKey:this.props.valueKey,onOptionRef:this.onOptionRef}):this.props.noResultsText?p["default"].createElement("div",{className:"Select-noresults"},this.props.noResultsText):null},renderHiddenField:function(e){var t=this;if(this.props.name){if(this.props.joinValues){var u=e.map(function(e){return a(e[t.props.valueKey])}).join(this.props.delimiter);return p["default"].createElement("input",{type:"hidden",ref:function(e){return t.value=e},name:this.props.name,value:u,disabled:this.props.disabled})}return e.map(function(e,u){return p["default"].createElement("input",{key:"hidden."+u,type:"hidden",ref:"value"+u,name:t.props.name,value:a(e[t.props.valueKey]),disabled:t.props.disabled})})}},getFocusableOptionIndex:function(e){var t=this._visibleOptions;if(!t.length)return null;var u=this.state.focusedOption||e;if(u&&!u.disabled){var n=t.indexOf(u);if(n!==-1)return n}for(var s=0;s-1)return!1;if(n.filterOption)return n.filterOption.call(s,e,t);if(!t)return!0;var o=String(e[n.valueKey]),a=String(e[n.labelKey]);return n.ignoreAccents&&("label"!==n.matchProp&&(o=(0,i["default"])(o)),"value"!==n.matchProp&&(a=(0,i["default"])(a))),n.ignoreCase&&("label"!==n.matchProp&&(o=o.toLowerCase()),"value"!==n.matchProp&&(a=a.toLowerCase())),"start"===n.matchPos?"label"!==n.matchProp&&o.substr(0,t.length)===t||"value"!==n.matchProp&&a.substr(0,t.length)===t:"label"!==n.matchProp&&o.indexOf(t)>=0||"value"!==n.matchProp&&a.indexOf(t)>=0})}var o=e("./stripDiacritics"),i=n(o);t.exports=s},{"./stripDiacritics":10}],9:[function(e,t,u){(function(e){"use strict";function u(e){return e&&e.__esModule?e:{"default":e}}function n(e){var t=e.focusedOption,u=e.instancePrefix,n=(e.labelKey,e.onFocus),s=e.onSelect,i=e.optionClassName,r=e.optionComponent,l=e.optionRenderer,p=e.options,d=e.valueArray,c=e.valueKey,f=e.onOptionRef,h=r;return p.map(function(e,r){var p=d&&d.indexOf(e)>-1,E=e===t,y=(0,o["default"])(i,{"Select-option":!0,"is-selected":p,"is-focused":E,"is-disabled":e.disabled});return a["default"].createElement(h,{className:y,instancePrefix:u,isDisabled:e.disabled,isFocused:E,isSelected:p,key:"option-"+r+"-"+e[c],onFocus:n,onSelect:s,option:e,optionIndex:r,ref:function(e){f(e,E)}},l(e,r))})}var s="undefined"!=typeof window?window.classNames:"undefined"!=typeof e?e.classNames:null,o=u(s),i="undefined"!=typeof window?window.React:"undefined"!=typeof e?e.React:null,a=u(i);t.exports=n}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{}],10:[function(e,t,u){"use strict";var n=[{base:"A",letters:/[\u0041\u24B6\uFF21\u00C0\u00C1\u00C2\u1EA6\u1EA4\u1EAA\u1EA8\u00C3\u0100\u0102\u1EB0\u1EAE\u1EB4\u1EB2\u0226\u01E0\u00C4\u01DE\u1EA2\u00C5\u01FA\u01CD\u0200\u0202\u1EA0\u1EAC\u1EB6\u1E00\u0104\u023A\u2C6F]/g},{base:"AA",letters:/[\uA732]/g},{base:"AE",letters:/[\u00C6\u01FC\u01E2]/g},{base:"AO",letters:/[\uA734]/g},{base:"AU",letters:/[\uA736]/g},{base:"AV",letters:/[\uA738\uA73A]/g},{base:"AY",letters:/[\uA73C]/g},{base:"B",letters:/[\u0042\u24B7\uFF22\u1E02\u1E04\u1E06\u0243\u0182\u0181]/g},{base:"C",letters:/[\u0043\u24B8\uFF23\u0106\u0108\u010A\u010C\u00C7\u1E08\u0187\u023B\uA73E]/g},{base:"D",letters:/[\u0044\u24B9\uFF24\u1E0A\u010E\u1E0C\u1E10\u1E12\u1E0E\u0110\u018B\u018A\u0189\uA779]/g},{base:"DZ",letters:/[\u01F1\u01C4]/g},{base:"Dz",letters:/[\u01F2\u01C5]/g},{base:"E",letters:/[\u0045\u24BA\uFF25\u00C8\u00C9\u00CA\u1EC0\u1EBE\u1EC4\u1EC2\u1EBC\u0112\u1E14\u1E16\u0114\u0116\u00CB\u1EBA\u011A\u0204\u0206\u1EB8\u1EC6\u0228\u1E1C\u0118\u1E18\u1E1A\u0190\u018E]/g},{base:"F",letters:/[\u0046\u24BB\uFF26\u1E1E\u0191\uA77B]/g},{base:"G",letters:/[\u0047\u24BC\uFF27\u01F4\u011C\u1E20\u011E\u0120\u01E6\u0122\u01E4\u0193\uA7A0\uA77D\uA77E]/g},{base:"H",letters:/[\u0048\u24BD\uFF28\u0124\u1E22\u1E26\u021E\u1E24\u1E28\u1E2A\u0126\u2C67\u2C75\uA78D]/g},{base:"I",letters:/[\u0049\u24BE\uFF29\u00CC\u00CD\u00CE\u0128\u012A\u012C\u0130\u00CF\u1E2E\u1EC8\u01CF\u0208\u020A\u1ECA\u012E\u1E2C\u0197]/g},{base:"J",letters:/[\u004A\u24BF\uFF2A\u0134\u0248]/g},{base:"K",letters:/[\u004B\u24C0\uFF2B\u1E30\u01E8\u1E32\u0136\u1E34\u0198\u2C69\uA740\uA742\uA744\uA7A2]/g},{base:"L",letters:/[\u004C\u24C1\uFF2C\u013F\u0139\u013D\u1E36\u1E38\u013B\u1E3C\u1E3A\u0141\u023D\u2C62\u2C60\uA748\uA746\uA780]/g},{base:"LJ",letters:/[\u01C7]/g},{base:"Lj",letters:/[\u01C8]/g},{base:"M",letters:/[\u004D\u24C2\uFF2D\u1E3E\u1E40\u1E42\u2C6E\u019C]/g},{base:"N",letters:/[\u004E\u24C3\uFF2E\u01F8\u0143\u00D1\u1E44\u0147\u1E46\u0145\u1E4A\u1E48\u0220\u019D\uA790\uA7A4]/g},{base:"NJ",letters:/[\u01CA]/g},{base:"Nj",letters:/[\u01CB]/g},{base:"O",letters:/[\u004F\u24C4\uFF2F\u00D2\u00D3\u00D4\u1ED2\u1ED0\u1ED6\u1ED4\u00D5\u1E4C\u022C\u1E4E\u014C\u1E50\u1E52\u014E\u022E\u0230\u00D6\u022A\u1ECE\u0150\u01D1\u020C\u020E\u01A0\u1EDC\u1EDA\u1EE0\u1EDE\u1EE2\u1ECC\u1ED8\u01EA\u01EC\u00D8\u01FE\u0186\u019F\uA74A\uA74C]/g},{base:"OI",letters:/[\u01A2]/g},{base:"OO",letters:/[\uA74E]/g},{base:"OU",letters:/[\u0222]/g},{base:"P",letters:/[\u0050\u24C5\uFF30\u1E54\u1E56\u01A4\u2C63\uA750\uA752\uA754]/g},{base:"Q",letters:/[\u0051\u24C6\uFF31\uA756\uA758\u024A]/g},{base:"R",letters:/[\u0052\u24C7\uFF32\u0154\u1E58\u0158\u0210\u0212\u1E5A\u1E5C\u0156\u1E5E\u024C\u2C64\uA75A\uA7A6\uA782]/g},{base:"S",letters:/[\u0053\u24C8\uFF33\u1E9E\u015A\u1E64\u015C\u1E60\u0160\u1E66\u1E62\u1E68\u0218\u015E\u2C7E\uA7A8\uA784]/g},{base:"T",letters:/[\u0054\u24C9\uFF34\u1E6A\u0164\u1E6C\u021A\u0162\u1E70\u1E6E\u0166\u01AC\u01AE\u023E\uA786]/g},{base:"TZ",letters:/[\uA728]/g},{base:"U",letters:/[\u0055\u24CA\uFF35\u00D9\u00DA\u00DB\u0168\u1E78\u016A\u1E7A\u016C\u00DC\u01DB\u01D7\u01D5\u01D9\u1EE6\u016E\u0170\u01D3\u0214\u0216\u01AF\u1EEA\u1EE8\u1EEE\u1EEC\u1EF0\u1EE4\u1E72\u0172\u1E76\u1E74\u0244]/g},{base:"V",letters:/[\u0056\u24CB\uFF36\u1E7C\u1E7E\u01B2\uA75E\u0245]/g},{base:"VY",letters:/[\uA760]/g},{base:"W",letters:/[\u0057\u24CC\uFF37\u1E80\u1E82\u0174\u1E86\u1E84\u1E88\u2C72]/g},{base:"X",letters:/[\u0058\u24CD\uFF38\u1E8A\u1E8C]/g},{base:"Y",letters:/[\u0059\u24CE\uFF39\u1EF2\u00DD\u0176\u1EF8\u0232\u1E8E\u0178\u1EF6\u1EF4\u01B3\u024E\u1EFE]/g},{base:"Z",letters:/[\u005A\u24CF\uFF3A\u0179\u1E90\u017B\u017D\u1E92\u1E94\u01B5\u0224\u2C7F\u2C6B\uA762]/g},{base:"a",letters:/[\u0061\u24D0\uFF41\u1E9A\u00E0\u00E1\u00E2\u1EA7\u1EA5\u1EAB\u1EA9\u00E3\u0101\u0103\u1EB1\u1EAF\u1EB5\u1EB3\u0227\u01E1\u00E4\u01DF\u1EA3\u00E5\u01FB\u01CE\u0201\u0203\u1EA1\u1EAD\u1EB7\u1E01\u0105\u2C65\u0250]/g},{base:"aa",letters:/[\uA733]/g},{base:"ae",letters:/[\u00E6\u01FD\u01E3]/g},{base:"ao",letters:/[\uA735]/g},{base:"au",letters:/[\uA737]/g},{base:"av",letters:/[\uA739\uA73B]/g},{base:"ay",letters:/[\uA73D]/g},{base:"b",letters:/[\u0062\u24D1\uFF42\u1E03\u1E05\u1E07\u0180\u0183\u0253]/g},{base:"c",letters:/[\u0063\u24D2\uFF43\u0107\u0109\u010B\u010D\u00E7\u1E09\u0188\u023C\uA73F\u2184]/g},{base:"d",letters:/[\u0064\u24D3\uFF44\u1E0B\u010F\u1E0D\u1E11\u1E13\u1E0F\u0111\u018C\u0256\u0257\uA77A]/g},{base:"dz",letters:/[\u01F3\u01C6]/g},{base:"e",letters:/[\u0065\u24D4\uFF45\u00E8\u00E9\u00EA\u1EC1\u1EBF\u1EC5\u1EC3\u1EBD\u0113\u1E15\u1E17\u0115\u0117\u00EB\u1EBB\u011B\u0205\u0207\u1EB9\u1EC7\u0229\u1E1D\u0119\u1E19\u1E1B\u0247\u025B\u01DD]/g},{base:"f",letters:/[\u0066\u24D5\uFF46\u1E1F\u0192\uA77C]/g},{base:"g",letters:/[\u0067\u24D6\uFF47\u01F5\u011D\u1E21\u011F\u0121\u01E7\u0123\u01E5\u0260\uA7A1\u1D79\uA77F]/g},{base:"h",letters:/[\u0068\u24D7\uFF48\u0125\u1E23\u1E27\u021F\u1E25\u1E29\u1E2B\u1E96\u0127\u2C68\u2C76\u0265]/g},{base:"hv",letters:/[\u0195]/g},{base:"i",letters:/[\u0069\u24D8\uFF49\u00EC\u00ED\u00EE\u0129\u012B\u012D\u00EF\u1E2F\u1EC9\u01D0\u0209\u020B\u1ECB\u012F\u1E2D\u0268\u0131]/g},{base:"j",letters:/[\u006A\u24D9\uFF4A\u0135\u01F0\u0249]/g},{base:"k",letters:/[\u006B\u24DA\uFF4B\u1E31\u01E9\u1E33\u0137\u1E35\u0199\u2C6A\uA741\uA743\uA745\uA7A3]/g},{base:"l",letters:/[\u006C\u24DB\uFF4C\u0140\u013A\u013E\u1E37\u1E39\u013C\u1E3D\u1E3B\u017F\u0142\u019A\u026B\u2C61\uA749\uA781\uA747]/g},{base:"lj",letters:/[\u01C9]/g},{base:"m",letters:/[\u006D\u24DC\uFF4D\u1E3F\u1E41\u1E43\u0271\u026F]/g},{base:"n",letters:/[\u006E\u24DD\uFF4E\u01F9\u0144\u00F1\u1E45\u0148\u1E47\u0146\u1E4B\u1E49\u019E\u0272\u0149\uA791\uA7A5]/g},{base:"nj",letters:/[\u01CC]/g},{base:"o",letters:/[\u006F\u24DE\uFF4F\u00F2\u00F3\u00F4\u1ED3\u1ED1\u1ED7\u1ED5\u00F5\u1E4D\u022D\u1E4F\u014D\u1E51\u1E53\u014F\u022F\u0231\u00F6\u022B\u1ECF\u0151\u01D2\u020D\u020F\u01A1\u1EDD\u1EDB\u1EE1\u1EDF\u1EE3\u1ECD\u1ED9\u01EB\u01ED\u00F8\u01FF\u0254\uA74B\uA74D\u0275]/g},{base:"oi",letters:/[\u01A3]/g},{base:"ou",letters:/[\u0223]/g},{base:"oo",letters:/[\uA74F]/g},{base:"p",letters:/[\u0070\u24DF\uFF50\u1E55\u1E57\u01A5\u1D7D\uA751\uA753\uA755]/g},{base:"q",letters:/[\u0071\u24E0\uFF51\u024B\uA757\uA759]/g},{base:"r",letters:/[\u0072\u24E1\uFF52\u0155\u1E59\u0159\u0211\u0213\u1E5B\u1E5D\u0157\u1E5F\u024D\u027D\uA75B\uA7A7\uA783]/g},{base:"s",letters:/[\u0073\u24E2\uFF53\u00DF\u015B\u1E65\u015D\u1E61\u0161\u1E67\u1E63\u1E69\u0219\u015F\u023F\uA7A9\uA785\u1E9B]/g},{base:"t",letters:/[\u0074\u24E3\uFF54\u1E6B\u1E97\u0165\u1E6D\u021B\u0163\u1E71\u1E6F\u0167\u01AD\u0288\u2C66\uA787]/g},{base:"tz",letters:/[\uA729]/g},{base:"u",letters:/[\u0075\u24E4\uFF55\u00F9\u00FA\u00FB\u0169\u1E79\u016B\u1E7B\u016D\u00FC\u01DC\u01D8\u01D6\u01DA\u1EE7\u016F\u0171\u01D4\u0215\u0217\u01B0\u1EEB\u1EE9\u1EEF\u1EED\u1EF1\u1EE5\u1E73\u0173\u1E77\u1E75\u0289]/g},{base:"v",letters:/[\u0076\u24E5\uFF56\u1E7D\u1E7F\u028B\uA75F\u028C]/g},{base:"vy",letters:/[\uA761]/g},{base:"w",letters:/[\u0077\u24E6\uFF57\u1E81\u1E83\u0175\u1E87\u1E85\u1E98\u1E89\u2C73]/g},{base:"x",letters:/[\u0078\u24E7\uFF58\u1E8B\u1E8D]/g},{base:"y",letters:/[\u0079\u24E8\uFF59\u1EF3\u00FD\u0177\u1EF9\u0233\u1E8F\u00FF\u1EF7\u1E99\u1EF5\u01B4\u024F\u1EFF]/g},{base:"z",letters:/[\u007A\u24E9\uFF5A\u017A\u1E91\u017C\u017E\u1E93\u1E95\u01B6\u0225\u0240\u2C6C\uA763]/g}];t.exports=function(e){for(var t=0;te.props.value.length&&e.clearOptions(),e.props.onChange(t)}};return u(l({},this.props,r,{isLoading:i,onInputChange:this._onInputChange}))}}]),t}(c.Component);u["default"]=C,C.propTypes=b,C.defaultProps=m,t.exports=u["default"]}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{"./Select":5,"./utils/stripDiacritics":10}],2:[function(e,t,u){(function(u){"use strict";function n(e){return e&&e.__esModule?e:{"default":e}}function s(e){var t=arguments.length<=1||void 0===arguments[1]?{}:arguments[1];return Object.keys(e).reduce(function(t,u){var n=e[u];return void 0!==n&&(t[u]=n),t},t)}var o=Object.assign||function(e){for(var t=1;t=0||Object.prototype.hasOwnProperty.call(e,n)&&(u[n]=e[n]);return u}function o(e){return f["default"].createElement(E["default"],e)}function i(e){var t=e.option,u=e.options,n=e.labelKey,s=e.valueKey;return 0===u.filter(function(e){return e[n]===t[n]||e[s]===t[s]}).length}function a(e){var t=e.label;return!!t}function r(e){var t=e.label,u=e.labelKey,n=e.valueKey,s={};return s[n]=t,s[u]=t,s.className="Select-create-option-placeholder",s}function l(e){return'Create option "'+e+'"'}function p(e){var t=e.keyCode;switch(t){case 9:case 13:case 188:return!0}return!1}var d=Object.assign||function(e){for(var t=1;t=0||Object.prototype.hasOwnProperty.call(e,n)&&(u[n]=e[n]);return u}function i(e,t,u){return t in e?Object.defineProperty(e,t,{value:u,enumerable:!0,configurable:!0,writable:!0}):e[t]=u,e}function a(e){var t=typeof e;return"string"===t?e:"object"===t?JSON.stringify(e):"number"===t||"boolean"===t?String(e):""}Object.defineProperty(u,"__esModule",{value:!0});var r=Object.assign||function(e){for(var t=1;ta.bottom||i.topt.offsetHeight&&!(t.scrollHeight-t.offsetHeight-t.scrollTop)&&this.props.onMenuScrollToBottom()}},handleRequired:function(e,t){return!e||(t?0===e.length:0===Object.keys(e).length)},getOptionLabel:function(e){return e[this.props.labelKey]},getValueArray:function(e,t){var u=this,n="object"==typeof t?t:this.props;if(n.multi){if("string"==typeof e&&(e=e.split(n.delimiter)),!Array.isArray(e)){if(null===e||void 0===e)return[];e=[e]}return e.map(function(e){return u.expandValue(e,n)}).filter(function(e){return e})}var s=this.expandValue(e,n);return s?[s]:[]},expandValue:function(e,t){var u=typeof e;if("string"!==u&&"number"!==u&&"boolean"!==u)return e;var n=t.options,s=t.valueKey;if(n)for(var o=0;o0?u-=1:u=t.length-1;else if("start"===e)u=0;else if("end"===e)u=t.length-1;else if("page_up"===e){var s=u-this.props.pageSize;u=s<0?0:s}else if("page_down"===e){var s=u+this.props.pageSize;u=s>t.length-1?t.length-1:s}u===-1&&(u=0),this.setState({focusedIndex:t[u].index,focusedOption:t[u].option})}},getFocusedOption:function(){return this._focusedOption},getInputValue:function(){return this.state.inputValue},selectFocusedOption:function(){if(this._focusedOption)return this.selectValue(this._focusedOption)},renderLoading:function(){if(this.props.isLoading)return p["default"].createElement("span",{className:"Select-loading-zone","aria-hidden":"true"},p["default"].createElement("span",{className:"Select-loading"}))},renderValue:function(e,t){var u=this,n=this.props.valueRenderer||this.getOptionLabel,s=this.props.valueComponent;if(!e.length)return this.state.inputValue?null:p["default"].createElement("div",{className:"Select-placeholder"},this.props.placeholder);var o=this.props.onValueClick?this.handleValueClick:null;return this.props.multi?e.map(function(e,t){return p["default"].createElement(s,{id:u._instancePrefix+"-value-"+t,instancePrefix:u._instancePrefix,disabled:u.props.disabled||e.clearableValue===!1,key:"value-"+t+"-"+e[u.props.valueKey],onClick:o,onRemove:u.removeValue,value:e},n(e,t),p["default"].createElement("span",{className:"Select-aria-only"}," "))}):this.state.inputValue?void 0:(t&&(o=null),p["default"].createElement(s,{id:this._instancePrefix+"-value-item",disabled:this.props.disabled,instancePrefix:this._instancePrefix,onClick:o,value:e[0]},n(e[0])))},renderInput:function(e,t){var u,n=this,s=(0,y["default"])("Select-input",this.props.inputProps.className),a=!!this.state.isOpen,l=(0,y["default"])((u={},i(u,this._instancePrefix+"-list",a),i(u,this._instancePrefix+"-backspace-remove-message",this.props.multi&&!this.props.disabled&&this.state.isFocused&&!this.state.inputValue),u)),d=r({},this.props.inputProps,{role:"combobox","aria-expanded":""+a,"aria-owns":l,"aria-haspopup":""+a,"aria-activedescendant":a?this._instancePrefix+"-option-"+t:this._instancePrefix+"-value","aria-labelledby":this.props["aria-labelledby"],"aria-label":this.props["aria-label"],className:s,tabIndex:this.props.tabIndex,onBlur:this.handleInputBlur,onChange:this.handleInputChange,onFocus:this.handleInputFocus,ref:function(e){return n.input=e},required:this.state.required,value:this.state.inputValue});if(this.props.inputRenderer)return this.props.inputRenderer(d);if(this.props.disabled||!this.props.searchable){var c=this.props.inputProps,f=(c.inputClassName,o(c,["inputClassName"]));return p["default"].createElement("div",r({},f,{role:"combobox","aria-expanded":a,"aria-owns":a?this._instancePrefix+"-list":this._instancePrefix+"-value","aria-activedescendant":a?this._instancePrefix+"-option-"+t:this._instancePrefix+"-value",className:s,tabIndex:this.props.tabIndex||0,onBlur:this.handleInputBlur,onFocus:this.handleInputFocus,ref:function(e){return n.input=e},"aria-readonly":""+!!this.props.disabled,style:{border:0,width:1,display:"inline-block"}}))}return this.props.autosize?p["default"].createElement(h["default"],r({},d,{minWidth:"5"})):p["default"].createElement("div",{className:s},p["default"].createElement("input",d))},renderClear:function(){if(this.props.clearable&&this.props.value&&0!==this.props.value&&(!this.props.multi||this.props.value.length)&&!this.props.disabled&&!this.props.isLoading)return p["default"].createElement("span",{className:"Select-clear-zone",title:this.props.multi?this.props.clearAllText:this.props.clearValueText,"aria-label":this.props.multi?this.props.clearAllText:this.props.clearValueText,onMouseDown:this.clearValue,onTouchStart:this.handleTouchStart,onTouchMove:this.handleTouchMove,onTouchEnd:this.handleTouchEndClearValue},p["default"].createElement("span",{className:"Select-clear",dangerouslySetInnerHTML:{__html:"×"}}))},renderArrow:function(){var e=this.handleMouseDownOnArrow,t=this.props.arrowRenderer({onMouseDown:e});return p["default"].createElement("span",{className:"Select-arrow-zone",onMouseDown:e},t)},filterOptions:function _(e){var t=this.state.inputValue,u=this.props.options||[];if(this.props.filterOptions){var _="function"==typeof this.props.filterOptions?this.props.filterOptions:m["default"];return _(u,t,e,{filterOption:this.props.filterOption,ignoreAccents:this.props.ignoreAccents,ignoreCase:this.props.ignoreCase,labelKey:this.props.labelKey,matchPos:this.props.matchPos,matchProp:this.props.matchProp,valueKey:this.props.valueKey})}return u},onOptionRef:function(e,t){t&&(this.focused=e)},renderMenu:function(e,t,u){return e&&e.length?this.props.menuRenderer({focusedOption:u,focusOption:this.focusOption,instancePrefix:this._instancePrefix,labelKey:this.props.labelKey,onFocus:this.focusOption,onSelect:this.selectValue,optionClassName:this.props.optionClassName,optionComponent:this.props.optionComponent,optionRenderer:this.props.optionRenderer||this.getOptionLabel,options:e,selectValue:this.selectValue, +valueArray:t,valueKey:this.props.valueKey,onOptionRef:this.onOptionRef}):this.props.noResultsText?p["default"].createElement("div",{className:"Select-noresults"},this.props.noResultsText):null},renderHiddenField:function(e){var t=this;if(this.props.name){if(this.props.joinValues){var u=e.map(function(e){return a(e[t.props.valueKey])}).join(this.props.delimiter);return p["default"].createElement("input",{type:"hidden",ref:function(e){return t.value=e},name:this.props.name,value:u,disabled:this.props.disabled})}return e.map(function(e,u){return p["default"].createElement("input",{key:"hidden."+u,type:"hidden",ref:"value"+u,name:t.props.name,value:a(e[t.props.valueKey]),disabled:t.props.disabled})})}},getFocusableOptionIndex:function(e){var t=this._visibleOptions;if(!t.length)return null;var u=this.state.focusedOption||e;if(u&&!u.disabled){var n=t.indexOf(u);if(n!==-1)return n}for(var s=0;s-1)return!1;if(n.filterOption)return n.filterOption.call(s,e,t);if(!t)return!0;var o=String(e[n.valueKey]),a=String(e[n.labelKey]);return n.ignoreAccents&&("label"!==n.matchProp&&(o=(0,i["default"])(o)),"value"!==n.matchProp&&(a=(0,i["default"])(a))),n.ignoreCase&&("label"!==n.matchProp&&(o=o.toLowerCase()),"value"!==n.matchProp&&(a=a.toLowerCase())),"start"===n.matchPos?"label"!==n.matchProp&&o.substr(0,t.length)===t||"value"!==n.matchProp&&a.substr(0,t.length)===t:"label"!==n.matchProp&&o.indexOf(t)>=0||"value"!==n.matchProp&&a.indexOf(t)>=0})}var o=e("./stripDiacritics"),i=n(o);t.exports=s},{"./stripDiacritics":10}],9:[function(e,t,u){(function(e){"use strict";function u(e){return e&&e.__esModule?e:{"default":e}}function n(e){var t=e.focusedOption,u=e.instancePrefix,n=(e.labelKey,e.onFocus),s=e.onSelect,i=e.optionClassName,r=e.optionComponent,l=e.optionRenderer,p=e.options,d=e.valueArray,c=e.valueKey,f=e.onOptionRef,h=r;return p.map(function(e,r){var p=d&&d.indexOf(e)>-1,E=e===t,y=(0,o["default"])(i,{"Select-option":!0,"is-selected":p,"is-focused":E,"is-disabled":e.disabled});return a["default"].createElement(h,{className:y,instancePrefix:u,isDisabled:e.disabled,isFocused:E,isSelected:p,key:"option-"+r+"-"+e[c],onFocus:n,onSelect:s,option:e,optionIndex:r,ref:function(e){f(e,E)}},l(e,r))})}var s="undefined"!=typeof window?window.classNames:"undefined"!=typeof e?e.classNames:null,o=u(s),i="undefined"!=typeof window?window.React:"undefined"!=typeof e?e.React:null,a=u(i);t.exports=n}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{}],10:[function(e,t,u){"use strict";var n=[{base:"A",letters:/[\u0041\u24B6\uFF21\u00C0\u00C1\u00C2\u1EA6\u1EA4\u1EAA\u1EA8\u00C3\u0100\u0102\u1EB0\u1EAE\u1EB4\u1EB2\u0226\u01E0\u00C4\u01DE\u1EA2\u00C5\u01FA\u01CD\u0200\u0202\u1EA0\u1EAC\u1EB6\u1E00\u0104\u023A\u2C6F]/g},{base:"AA",letters:/[\uA732]/g},{base:"AE",letters:/[\u00C6\u01FC\u01E2]/g},{base:"AO",letters:/[\uA734]/g},{base:"AU",letters:/[\uA736]/g},{base:"AV",letters:/[\uA738\uA73A]/g},{base:"AY",letters:/[\uA73C]/g},{base:"B",letters:/[\u0042\u24B7\uFF22\u1E02\u1E04\u1E06\u0243\u0182\u0181]/g},{base:"C",letters:/[\u0043\u24B8\uFF23\u0106\u0108\u010A\u010C\u00C7\u1E08\u0187\u023B\uA73E]/g},{base:"D",letters:/[\u0044\u24B9\uFF24\u1E0A\u010E\u1E0C\u1E10\u1E12\u1E0E\u0110\u018B\u018A\u0189\uA779]/g},{base:"DZ",letters:/[\u01F1\u01C4]/g},{base:"Dz",letters:/[\u01F2\u01C5]/g},{base:"E",letters:/[\u0045\u24BA\uFF25\u00C8\u00C9\u00CA\u1EC0\u1EBE\u1EC4\u1EC2\u1EBC\u0112\u1E14\u1E16\u0114\u0116\u00CB\u1EBA\u011A\u0204\u0206\u1EB8\u1EC6\u0228\u1E1C\u0118\u1E18\u1E1A\u0190\u018E]/g},{base:"F",letters:/[\u0046\u24BB\uFF26\u1E1E\u0191\uA77B]/g},{base:"G",letters:/[\u0047\u24BC\uFF27\u01F4\u011C\u1E20\u011E\u0120\u01E6\u0122\u01E4\u0193\uA7A0\uA77D\uA77E]/g},{base:"H",letters:/[\u0048\u24BD\uFF28\u0124\u1E22\u1E26\u021E\u1E24\u1E28\u1E2A\u0126\u2C67\u2C75\uA78D]/g},{base:"I",letters:/[\u0049\u24BE\uFF29\u00CC\u00CD\u00CE\u0128\u012A\u012C\u0130\u00CF\u1E2E\u1EC8\u01CF\u0208\u020A\u1ECA\u012E\u1E2C\u0197]/g},{base:"J",letters:/[\u004A\u24BF\uFF2A\u0134\u0248]/g},{base:"K",letters:/[\u004B\u24C0\uFF2B\u1E30\u01E8\u1E32\u0136\u1E34\u0198\u2C69\uA740\uA742\uA744\uA7A2]/g},{base:"L",letters:/[\u004C\u24C1\uFF2C\u013F\u0139\u013D\u1E36\u1E38\u013B\u1E3C\u1E3A\u0141\u023D\u2C62\u2C60\uA748\uA746\uA780]/g},{base:"LJ",letters:/[\u01C7]/g},{base:"Lj",letters:/[\u01C8]/g},{base:"M",letters:/[\u004D\u24C2\uFF2D\u1E3E\u1E40\u1E42\u2C6E\u019C]/g},{base:"N",letters:/[\u004E\u24C3\uFF2E\u01F8\u0143\u00D1\u1E44\u0147\u1E46\u0145\u1E4A\u1E48\u0220\u019D\uA790\uA7A4]/g},{base:"NJ",letters:/[\u01CA]/g},{base:"Nj",letters:/[\u01CB]/g},{base:"O",letters:/[\u004F\u24C4\uFF2F\u00D2\u00D3\u00D4\u1ED2\u1ED0\u1ED6\u1ED4\u00D5\u1E4C\u022C\u1E4E\u014C\u1E50\u1E52\u014E\u022E\u0230\u00D6\u022A\u1ECE\u0150\u01D1\u020C\u020E\u01A0\u1EDC\u1EDA\u1EE0\u1EDE\u1EE2\u1ECC\u1ED8\u01EA\u01EC\u00D8\u01FE\u0186\u019F\uA74A\uA74C]/g},{base:"OI",letters:/[\u01A2]/g},{base:"OO",letters:/[\uA74E]/g},{base:"OU",letters:/[\u0222]/g},{base:"P",letters:/[\u0050\u24C5\uFF30\u1E54\u1E56\u01A4\u2C63\uA750\uA752\uA754]/g},{base:"Q",letters:/[\u0051\u24C6\uFF31\uA756\uA758\u024A]/g},{base:"R",letters:/[\u0052\u24C7\uFF32\u0154\u1E58\u0158\u0210\u0212\u1E5A\u1E5C\u0156\u1E5E\u024C\u2C64\uA75A\uA7A6\uA782]/g},{base:"S",letters:/[\u0053\u24C8\uFF33\u1E9E\u015A\u1E64\u015C\u1E60\u0160\u1E66\u1E62\u1E68\u0218\u015E\u2C7E\uA7A8\uA784]/g},{base:"T",letters:/[\u0054\u24C9\uFF34\u1E6A\u0164\u1E6C\u021A\u0162\u1E70\u1E6E\u0166\u01AC\u01AE\u023E\uA786]/g},{base:"TZ",letters:/[\uA728]/g},{base:"U",letters:/[\u0055\u24CA\uFF35\u00D9\u00DA\u00DB\u0168\u1E78\u016A\u1E7A\u016C\u00DC\u01DB\u01D7\u01D5\u01D9\u1EE6\u016E\u0170\u01D3\u0214\u0216\u01AF\u1EEA\u1EE8\u1EEE\u1EEC\u1EF0\u1EE4\u1E72\u0172\u1E76\u1E74\u0244]/g},{base:"V",letters:/[\u0056\u24CB\uFF36\u1E7C\u1E7E\u01B2\uA75E\u0245]/g},{base:"VY",letters:/[\uA760]/g},{base:"W",letters:/[\u0057\u24CC\uFF37\u1E80\u1E82\u0174\u1E86\u1E84\u1E88\u2C72]/g},{base:"X",letters:/[\u0058\u24CD\uFF38\u1E8A\u1E8C]/g},{base:"Y",letters:/[\u0059\u24CE\uFF39\u1EF2\u00DD\u0176\u1EF8\u0232\u1E8E\u0178\u1EF6\u1EF4\u01B3\u024E\u1EFE]/g},{base:"Z",letters:/[\u005A\u24CF\uFF3A\u0179\u1E90\u017B\u017D\u1E92\u1E94\u01B5\u0224\u2C7F\u2C6B\uA762]/g},{base:"a",letters:/[\u0061\u24D0\uFF41\u1E9A\u00E0\u00E1\u00E2\u1EA7\u1EA5\u1EAB\u1EA9\u00E3\u0101\u0103\u1EB1\u1EAF\u1EB5\u1EB3\u0227\u01E1\u00E4\u01DF\u1EA3\u00E5\u01FB\u01CE\u0201\u0203\u1EA1\u1EAD\u1EB7\u1E01\u0105\u2C65\u0250]/g},{base:"aa",letters:/[\uA733]/g},{base:"ae",letters:/[\u00E6\u01FD\u01E3]/g},{base:"ao",letters:/[\uA735]/g},{base:"au",letters:/[\uA737]/g},{base:"av",letters:/[\uA739\uA73B]/g},{base:"ay",letters:/[\uA73D]/g},{base:"b",letters:/[\u0062\u24D1\uFF42\u1E03\u1E05\u1E07\u0180\u0183\u0253]/g},{base:"c",letters:/[\u0063\u24D2\uFF43\u0107\u0109\u010B\u010D\u00E7\u1E09\u0188\u023C\uA73F\u2184]/g},{base:"d",letters:/[\u0064\u24D3\uFF44\u1E0B\u010F\u1E0D\u1E11\u1E13\u1E0F\u0111\u018C\u0256\u0257\uA77A]/g},{base:"dz",letters:/[\u01F3\u01C6]/g},{base:"e",letters:/[\u0065\u24D4\uFF45\u00E8\u00E9\u00EA\u1EC1\u1EBF\u1EC5\u1EC3\u1EBD\u0113\u1E15\u1E17\u0115\u0117\u00EB\u1EBB\u011B\u0205\u0207\u1EB9\u1EC7\u0229\u1E1D\u0119\u1E19\u1E1B\u0247\u025B\u01DD]/g},{base:"f",letters:/[\u0066\u24D5\uFF46\u1E1F\u0192\uA77C]/g},{base:"g",letters:/[\u0067\u24D6\uFF47\u01F5\u011D\u1E21\u011F\u0121\u01E7\u0123\u01E5\u0260\uA7A1\u1D79\uA77F]/g},{base:"h",letters:/[\u0068\u24D7\uFF48\u0125\u1E23\u1E27\u021F\u1E25\u1E29\u1E2B\u1E96\u0127\u2C68\u2C76\u0265]/g},{base:"hv",letters:/[\u0195]/g},{base:"i",letters:/[\u0069\u24D8\uFF49\u00EC\u00ED\u00EE\u0129\u012B\u012D\u00EF\u1E2F\u1EC9\u01D0\u0209\u020B\u1ECB\u012F\u1E2D\u0268\u0131]/g},{base:"j",letters:/[\u006A\u24D9\uFF4A\u0135\u01F0\u0249]/g},{base:"k",letters:/[\u006B\u24DA\uFF4B\u1E31\u01E9\u1E33\u0137\u1E35\u0199\u2C6A\uA741\uA743\uA745\uA7A3]/g},{base:"l",letters:/[\u006C\u24DB\uFF4C\u0140\u013A\u013E\u1E37\u1E39\u013C\u1E3D\u1E3B\u017F\u0142\u019A\u026B\u2C61\uA749\uA781\uA747]/g},{base:"lj",letters:/[\u01C9]/g},{base:"m",letters:/[\u006D\u24DC\uFF4D\u1E3F\u1E41\u1E43\u0271\u026F]/g},{base:"n",letters:/[\u006E\u24DD\uFF4E\u01F9\u0144\u00F1\u1E45\u0148\u1E47\u0146\u1E4B\u1E49\u019E\u0272\u0149\uA791\uA7A5]/g},{base:"nj",letters:/[\u01CC]/g},{base:"o",letters:/[\u006F\u24DE\uFF4F\u00F2\u00F3\u00F4\u1ED3\u1ED1\u1ED7\u1ED5\u00F5\u1E4D\u022D\u1E4F\u014D\u1E51\u1E53\u014F\u022F\u0231\u00F6\u022B\u1ECF\u0151\u01D2\u020D\u020F\u01A1\u1EDD\u1EDB\u1EE1\u1EDF\u1EE3\u1ECD\u1ED9\u01EB\u01ED\u00F8\u01FF\u0254\uA74B\uA74D\u0275]/g},{base:"oi",letters:/[\u01A3]/g},{base:"ou",letters:/[\u0223]/g},{base:"oo",letters:/[\uA74F]/g},{base:"p",letters:/[\u0070\u24DF\uFF50\u1E55\u1E57\u01A5\u1D7D\uA751\uA753\uA755]/g},{base:"q",letters:/[\u0071\u24E0\uFF51\u024B\uA757\uA759]/g},{base:"r",letters:/[\u0072\u24E1\uFF52\u0155\u1E59\u0159\u0211\u0213\u1E5B\u1E5D\u0157\u1E5F\u024D\u027D\uA75B\uA7A7\uA783]/g},{base:"s",letters:/[\u0073\u24E2\uFF53\u00DF\u015B\u1E65\u015D\u1E61\u0161\u1E67\u1E63\u1E69\u0219\u015F\u023F\uA7A9\uA785\u1E9B]/g},{base:"t",letters:/[\u0074\u24E3\uFF54\u1E6B\u1E97\u0165\u1E6D\u021B\u0163\u1E71\u1E6F\u0167\u01AD\u0288\u2C66\uA787]/g},{base:"tz",letters:/[\uA729]/g},{base:"u",letters:/[\u0075\u24E4\uFF55\u00F9\u00FA\u00FB\u0169\u1E79\u016B\u1E7B\u016D\u00FC\u01DC\u01D8\u01D6\u01DA\u1EE7\u016F\u0171\u01D4\u0215\u0217\u01B0\u1EEB\u1EE9\u1EEF\u1EED\u1EF1\u1EE5\u1E73\u0173\u1E77\u1E75\u0289]/g},{base:"v",letters:/[\u0076\u24E5\uFF56\u1E7D\u1E7F\u028B\uA75F\u028C]/g},{base:"vy",letters:/[\uA761]/g},{base:"w",letters:/[\u0077\u24E6\uFF57\u1E81\u1E83\u0175\u1E87\u1E85\u1E98\u1E89\u2C73]/g},{base:"x",letters:/[\u0078\u24E7\uFF58\u1E8B\u1E8D]/g},{base:"y",letters:/[\u0079\u24E8\uFF59\u1EF3\u00FD\u0177\u1EF9\u0233\u1E8F\u00FF\u1EF7\u1E99\u1EF5\u01B4\u024F\u1EFF]/g},{base:"z",letters:/[\u007A\u24E9\uFF5A\u017A\u1E91\u017C\u017E\u1E93\u1E95\u01B6\u0225\u0240\u2C6C\uA763]/g}];t.exports=function(e){for(var t=0;t -1 + } + } + function normalizeName(name) { if (typeof name !== 'string') { name = String(name) @@ -9479,12 +9503,8 @@ module.exports = function (str) { Headers.prototype.append = function(name, value) { name = normalizeName(name) value = normalizeValue(value) - var list = this.map[name] - if (!list) { - list = [] - this.map[name] = list - } - list.push(value) + var oldValue = this.map[name] + this.map[name] = oldValue ? oldValue+','+value : value } Headers.prototype['delete'] = function(name) { @@ -9492,12 +9512,8 @@ module.exports = function (str) { } Headers.prototype.get = function(name) { - var values = this.map[normalizeName(name)] - return values ? values[0] : null - } - - Headers.prototype.getAll = function(name) { - return this.map[normalizeName(name)] || [] + name = normalizeName(name) + return this.has(name) ? this.map[name] : null } Headers.prototype.has = function(name) { @@ -9505,15 +9521,15 @@ module.exports = function (str) { } Headers.prototype.set = function(name, value) { - this.map[normalizeName(name)] = [normalizeValue(value)] + this.map[normalizeName(name)] = normalizeValue(value) } Headers.prototype.forEach = function(callback, thisArg) { - Object.getOwnPropertyNames(this.map).forEach(function(name) { - this.map[name].forEach(function(value) { - callback.call(thisArg, value, name, this) - }, this) - }, this) + for (var name in this.map) { + if (this.map.hasOwnProperty(name)) { + callback.call(thisArg, this.map[name], name, this) + } + } } Headers.prototype.keys = function() { @@ -9558,14 +9574,36 @@ module.exports = function (str) { function readBlobAsArrayBuffer(blob) { var reader = new FileReader() + var promise = fileReaderReady(reader) reader.readAsArrayBuffer(blob) - return fileReaderReady(reader) + return promise } function readBlobAsText(blob) { var reader = new FileReader() + var promise = fileReaderReady(reader) reader.readAsText(blob) - return fileReaderReady(reader) + return promise + } + + function readArrayBufferAsText(buf) { + var view = new Uint8Array(buf) + var chars = new Array(view.length) + + for (var i = 0; i < view.length; i++) { + chars[i] = String.fromCharCode(view[i]) + } + return chars.join('') + } + + function bufferClone(buf) { + if (buf.slice) { + return buf.slice(0) + } else { + var view = new Uint8Array(buf.byteLength) + view.set(new Uint8Array(buf)) + return view.buffer + } } function Body() { @@ -9573,7 +9611,9 @@ module.exports = function (str) { this._initBody = function(body) { this._bodyInit = body - if (typeof body === 'string') { + if (!body) { + this._bodyText = '' + } else if (typeof body === 'string') { this._bodyText = body } else if (support.blob && Blob.prototype.isPrototypeOf(body)) { this._bodyBlob = body @@ -9581,11 +9621,12 @@ module.exports = function (str) { this._bodyFormData = body } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) { this._bodyText = body.toString() - } else if (!body) { - this._bodyText = '' - } else if (support.arrayBuffer && ArrayBuffer.prototype.isPrototypeOf(body)) { - // Only support ArrayBuffers for POST method. - // Receiving ArrayBuffers happens via Blobs, instead. + } else if (support.arrayBuffer && support.blob && isDataView(body)) { + this._bodyArrayBuffer = bufferClone(body.buffer) + // IE 10-11 can't handle a DataView body. + this._bodyInit = new Blob([this._bodyArrayBuffer]) + } else if (support.arrayBuffer && (ArrayBuffer.prototype.isPrototypeOf(body) || isArrayBufferView(body))) { + this._bodyArrayBuffer = bufferClone(body) } else { throw new Error('unsupported BodyInit type') } @@ -9610,6 +9651,8 @@ module.exports = function (str) { if (this._bodyBlob) { return Promise.resolve(this._bodyBlob) + } else if (this._bodyArrayBuffer) { + return Promise.resolve(new Blob([this._bodyArrayBuffer])) } else if (this._bodyFormData) { throw new Error('could not read FormData body as blob') } else { @@ -9618,27 +9661,28 @@ module.exports = function (str) { } this.arrayBuffer = function() { - return this.blob().then(readBlobAsArrayBuffer) - } - - this.text = function() { - var rejected = consumed(this) - if (rejected) { - return rejected - } - - if (this._bodyBlob) { - return readBlobAsText(this._bodyBlob) - } else if (this._bodyFormData) { - throw new Error('could not read FormData body as text') + if (this._bodyArrayBuffer) { + return consumed(this) || Promise.resolve(this._bodyArrayBuffer) } else { - return Promise.resolve(this._bodyText) + return this.blob().then(readBlobAsArrayBuffer) } } - } else { - this.text = function() { - var rejected = consumed(this) - return rejected ? rejected : Promise.resolve(this._bodyText) + } + + this.text = function() { + var rejected = consumed(this) + if (rejected) { + return rejected + } + + if (this._bodyBlob) { + return readBlobAsText(this._bodyBlob) + } else if (this._bodyArrayBuffer) { + return Promise.resolve(readArrayBufferAsText(this._bodyArrayBuffer)) + } else if (this._bodyFormData) { + throw new Error('could not read FormData body as text') + } else { + return Promise.resolve(this._bodyText) } } @@ -9666,7 +9710,10 @@ module.exports = function (str) { function Request(input, options) { options = options || {} var body = options.body - if (Request.prototype.isPrototypeOf(input)) { + + if (typeof input === 'string') { + this.url = input + } else { if (input.bodyUsed) { throw new TypeError('Already read') } @@ -9677,12 +9724,10 @@ module.exports = function (str) { } this.method = input.method this.mode = input.mode - if (!body) { + if (!body && input._bodyInit != null) { body = input._bodyInit input.bodyUsed = true } - } else { - this.url = input } this.credentials = options.credentials || this.credentials || 'omit' @@ -9700,7 +9745,7 @@ module.exports = function (str) { } Request.prototype.clone = function() { - return new Request(this) + return new Request(this, { body: this._bodyInit }) } function decode(body) { @@ -9716,16 +9761,17 @@ module.exports = function (str) { return form } - function headers(xhr) { - var head = new Headers() - var pairs = (xhr.getAllResponseHeaders() || '').trim().split('\n') - pairs.forEach(function(header) { - var split = header.trim().split(':') - var key = split.shift().trim() - var value = split.join(':').trim() - head.append(key, value) + function parseHeaders(rawHeaders) { + var headers = new Headers() + rawHeaders.split('\r\n').forEach(function(line) { + var parts = line.split(':') + var key = parts.shift().trim() + if (key) { + var value = parts.join(':').trim() + headers.append(key, value) + } }) - return head + return headers } Body.call(Request.prototype) @@ -9736,10 +9782,10 @@ module.exports = function (str) { } this.type = 'default' - this.status = options.status + this.status = 'status' in options ? options.status : 200 this.ok = this.status >= 200 && this.status < 300 - this.statusText = options.statusText - this.headers = options.headers instanceof Headers ? options.headers : new Headers(options.headers) + this.statusText = 'statusText' in options ? options.statusText : 'OK' + this.headers = new Headers(options.headers) this.url = options.url || '' this._initBody(bodyInit) } @@ -9777,35 +9823,16 @@ module.exports = function (str) { self.fetch = function(input, init) { return new Promise(function(resolve, reject) { - var request - if (Request.prototype.isPrototypeOf(input) && !init) { - request = input - } else { - request = new Request(input, init) - } - + var request = new Request(input, init) var xhr = new XMLHttpRequest() - function responseURL() { - if ('responseURL' in xhr) { - return xhr.responseURL - } - - // Avoid security warnings on getResponseHeader when not allowed by CORS - if (/^X-Request-URL:/m.test(xhr.getAllResponseHeaders())) { - return xhr.getResponseHeader('X-Request-URL') - } - - return - } - xhr.onload = function() { var options = { status: xhr.status, statusText: xhr.statusText, - headers: headers(xhr), - url: responseURL() + headers: parseHeaders(xhr.getAllResponseHeaders() || '') } + options.url = 'responseURL' in xhr ? xhr.responseURL : options.headers.get('X-Request-URL') var body = 'response' in xhr ? xhr.response : xhr.responseText resolve(new Response(body, options)) } @@ -9839,4 +9866,4 @@ module.exports = function (str) { })(typeof self !== 'undefined' ? self : this); },{}]},{},[1]) -//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","/Users/bvaughn/Documents/git/react-select/examples/src/app.js","/Users/bvaughn/Documents/git/react-select/examples/src/components/BooleanSelect.js","/Users/bvaughn/Documents/git/react-select/examples/src/components/Contributors.js","/Users/bvaughn/Documents/git/react-select/examples/src/components/Creatable.js","/Users/bvaughn/Documents/git/react-select/examples/src/components/CustomComponents.js","/Users/bvaughn/Documents/git/react-select/examples/src/components/CustomRender.js","/Users/bvaughn/Documents/git/react-select/examples/src/components/GithubUsers.js","/Users/bvaughn/Documents/git/react-select/examples/src/components/Multiselect.js","/Users/bvaughn/Documents/git/react-select/examples/src/components/NumericSelect.js","/Users/bvaughn/Documents/git/react-select/examples/src/components/States.js","/Users/bvaughn/Documents/git/react-select/examples/src/components/Virtualized.js","/Users/bvaughn/Documents/git/react-select/examples/src/data/cities.js","/Users/bvaughn/Documents/git/react-select/examples/src/data/contributors.js","/Users/bvaughn/Documents/git/react-select/examples/src/data/states.js","/Users/bvaughn/Documents/git/react-select/examples/src/data/users.js","node_modules/charenc/charenc.js","node_modules/crypt/crypt.js","node_modules/dom-helpers/util/inDOM.js","node_modules/dom-helpers/util/scrollbarSize.js","node_modules/fbjs/lib/shallowEqual.js","node_modules/is-buffer/index.js","node_modules/is-retina/index.js","node_modules/isomorphic-fetch/fetch-npm-browserify.js","node_modules/md5/md5.js","node_modules/object-assign/index.js","node_modules/performance-now/lib/performance-now.js","node_modules/process/browser.js","node_modules/query-string/index.js","node_modules/raf/index.js","node_modules/react-addons-shallow-compare/index.js","node_modules/react-gravatar/dist/index.js","node_modules/react-highlight-words/dist/main.js","node_modules/react-virtualized-select/dist/commonjs/VirtualizedSelect/VirtualizedSelect.js","node_modules/react-virtualized-select/dist/commonjs/VirtualizedSelect/index.js","node_modules/react-virtualized/dist/commonjs/ArrowKeyStepper/ArrowKeyStepper.js","node_modules/react-virtualized/dist/commonjs/ArrowKeyStepper/index.js","node_modules/react-virtualized/dist/commonjs/AutoSizer/AutoSizer.js","node_modules/react-virtualized/dist/commonjs/AutoSizer/index.js","node_modules/react-virtualized/dist/commonjs/CellMeasurer/CellMeasurer.js","node_modules/react-virtualized/dist/commonjs/CellMeasurer/defaultCellSizeCache.js","node_modules/react-virtualized/dist/commonjs/CellMeasurer/index.js","node_modules/react-virtualized/dist/commonjs/Collection/Collection.js","node_modules/react-virtualized/dist/commonjs/Collection/CollectionView.js","node_modules/react-virtualized/dist/commonjs/Collection/Section.js","node_modules/react-virtualized/dist/commonjs/Collection/SectionManager.js","node_modules/react-virtualized/dist/commonjs/Collection/index.js","node_modules/react-virtualized/dist/commonjs/Collection/utils/calculateSizeAndPositionData.js","node_modules/react-virtualized/dist/commonjs/ColumnSizer/ColumnSizer.js","node_modules/react-virtualized/dist/commonjs/ColumnSizer/index.js","node_modules/react-virtualized/dist/commonjs/FlexTable/FlexColumn.js","node_modules/react-virtualized/dist/commonjs/FlexTable/FlexTable.js","node_modules/react-virtualized/dist/commonjs/FlexTable/SortDirection.js","node_modules/react-virtualized/dist/commonjs/FlexTable/SortIndicator.js","node_modules/react-virtualized/dist/commonjs/FlexTable/defaultCellDataGetter.js","node_modules/react-virtualized/dist/commonjs/FlexTable/defaultCellRenderer.js","node_modules/react-virtualized/dist/commonjs/FlexTable/defaultHeaderRenderer.js","node_modules/react-virtualized/dist/commonjs/FlexTable/defaultRowRenderer.js","node_modules/react-virtualized/dist/commonjs/FlexTable/index.js","node_modules/react-virtualized/dist/commonjs/Grid/Grid.js","node_modules/react-virtualized/dist/commonjs/Grid/defaultCellRangeRenderer.js","node_modules/react-virtualized/dist/commonjs/Grid/index.js","node_modules/react-virtualized/dist/commonjs/Grid/utils/CellSizeAndPositionManager.js","node_modules/react-virtualized/dist/commonjs/Grid/utils/ScalingCellSizeAndPositionManager.js","node_modules/react-virtualized/dist/commonjs/Grid/utils/calculateSizeAndPositionDataAndUpdateScrollOffset.js","node_modules/react-virtualized/dist/commonjs/Grid/utils/getOverscanIndices.js","node_modules/react-virtualized/dist/commonjs/Grid/utils/updateScrollIndexHelper.js","node_modules/react-virtualized/dist/commonjs/InfiniteLoader/InfiniteLoader.js","node_modules/react-virtualized/dist/commonjs/InfiniteLoader/index.js","node_modules/react-virtualized/dist/commonjs/ScrollSync/ScrollSync.js","node_modules/react-virtualized/dist/commonjs/ScrollSync/index.js","node_modules/react-virtualized/dist/commonjs/VirtualScroll/VirtualScroll.js","node_modules/react-virtualized/dist/commonjs/VirtualScroll/index.js","node_modules/react-virtualized/dist/commonjs/WindowScroller/WindowScroller.js","node_modules/react-virtualized/dist/commonjs/WindowScroller/index.js","node_modules/react-virtualized/dist/commonjs/WindowScroller/utils/onScroll.js","node_modules/react-virtualized/dist/commonjs/index.js","node_modules/react-virtualized/dist/commonjs/utils/createCallbackMemoizer.js","node_modules/react-virtualized/dist/commonjs/utils/getUpdatedOffsetForIndex.js","node_modules/react-virtualized/dist/commonjs/vendor/detectElementResize.js","node_modules/react/lib/shallowCompare.js","node_modules/strict-uri-encode/index.js","node_modules/whatwg-fetch/fetch.js"],"names":[],"mappings":"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C,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,eAAe,EAAE,EACvC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,WAAW,EAAE,EACnC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,CACpC,CAAC;;;;;ACvEF,MAAM,CAAC,OAAO,GAAG,CAChB,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,gBAAgB,EAAE,EACrE,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,gBAAgB,EAAE,EACrE,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,gBAAgB,EAAE,CACrE,CAAC;;;ACJF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChGA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AClGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACxEA;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/QA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClqBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChhCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7RA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/* eslint react/prop-types: 0 */\n\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport Select from 'react-select';\n\nimport Creatable from './components/Creatable';\nimport Contributors from './components/Contributors';\nimport GithubUsers from './components/GithubUsers';\nimport CustomComponents from './components/CustomComponents';\nimport CustomRender from './components/CustomRender';\nimport Multiselect from './components/Multiselect';\nimport NumericSelect from './components/NumericSelect';\nimport BooleanSelect from './components/BooleanSelect';\nimport Virtualized from './components/Virtualized';\nimport States from './components/States';\n\nReactDOM.render(\n\t<div>\n\t\t<States label=\"States\" searchable />\n\t\t<Multiselect label=\"Multiselect\" />\n\t\t<Virtualized label=\"Virtualized\" />\n\t\t<Contributors label=\"Contributors (Async)\" />\n\t\t<GithubUsers label=\"Github users (Async with fetch.js)\" />\n\t\t<NumericSelect label=\"Numeric Values\" />\n\t\t<BooleanSelect label=\"Boolean Values\" />\n\t\t<CustomRender label=\"Custom Render Methods\"/>\n\t\t<CustomComponents label=\"Custom Placeholder, Option, Value, and Arrow Components\" />\n\t\t<Creatable\n\t\t\thint=\"Enter a value that's NOT in the list, then hit return\"\n\t\t\tlabel=\"Custom tag creation\"\n\t\t/>\n\t</div>,\n\tdocument.getElementById('example')\n);\n","import React from 'react';\nimport Select from 'react-select';\n\nvar ValuesAsBooleansField = React.createClass({\n\tdisplayName: 'ValuesAsBooleansField',\n\tpropTypes: {\n\t\tlabel: React.PropTypes.string\n\t},\n\tgetInitialState () {\n\t\treturn {\n\t\t\toptions: [\n\t\t\t\t{ value: true, label: 'Yes' },\n\t\t\t\t{ value: false, label: 'No' }\n\t\t\t],\n\t\t\tmatchPos: 'any',\n\t\t\tmatchValue: true,\n\t\t\tmatchLabel: true,\n\t\t\tvalue: null,\n\t\t\tmulti: false\n\t\t};\n\t},\n\tonChangeMatchStart(event) {\n\t\tthis.setState({\n\t\t\tmatchPos: event.target.checked ? 'start' : 'any'\n\t\t});\n\t},\n\tonChangeMatchValue(event) {\n\t\tthis.setState({\n\t\t\tmatchValue: event.target.checked\n\t\t});\n\t},\n\tonChangeMatchLabel(event) {\n\t\tthis.setState({\n\t\t\tmatchLabel: event.target.checked\n\t\t});\n\t},\n\tonChange(value) {\n\t\tthis.setState({ value });\n\t\tconsole.log('Boolean Select value changed to', value);\n\t},\n\tonChangeMulti(event) {\n\t\tthis.setState({\n\t\t\tmulti: event.target.checked\n\t\t});\n\t},\n\trender () {\n\t\tvar matchProp = 'any';\n\t\tif (this.state.matchLabel && !this.state.matchValue) {\n\t\t\tmatchProp = 'label';\n\t\t}\n\t\tif (!this.state.matchLabel && this.state.matchValue) {\n\t\t\tmatchProp = 'value';\n\t\t}\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select\n\t\t\t\t\tmatchPos={this.state.matchPos}\n\t\t\t\t\tmatchProp={matchProp}\n\t\t\t\t\tmulti={this.state.multi}\n\t\t\t\t\tonChange={this.onChange}\n\t\t\t\t\toptions={this.state.options}\n\t\t\t\t\tsimpleValue\n\t\t\t\t\tvalue={this.state.value}\n\t\t\t\t\t/>\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.multi} onChange={this.onChangeMulti} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Multi-Select</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.matchValue} onChange={this.onChangeMatchValue} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Match value</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.matchLabel} onChange={this.onChangeMatchLabel} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Match label</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.matchPos === 'start'} onChange={this.onChangeMatchStart} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Only include matches from the start of the string</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"hint\">This example uses simple boolean values</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nmodule.exports = ValuesAsBooleansField;\n","import React from 'react';\nimport Select from 'react-select';\n\nconst CONTRIBUTORS = require('../data/contributors');\nconst MAX_CONTRIBUTORS = 6;\nconst ASYNC_DELAY = 500;\n\nconst Contributors = React.createClass({\n\tdisplayName: 'Contributors',\n\tpropTypes: {\n\t\tlabel: React.PropTypes.string,\n\t},\n\tgetInitialState () {\n\t\treturn {\n\t\t\tmulti: true,\n\t\t\tvalue: [CONTRIBUTORS[0]],\n\t\t};\n\t},\n\tonChange (value) {\n\t\tthis.setState({\n\t\t\tvalue: value,\n\t\t});\n\t},\n\tswitchToMulti () {\n\t\tthis.setState({\n\t\t\tmulti: true,\n\t\t\tvalue: [this.state.value],\n\t\t});\n\t},\n\tswitchToSingle () {\n\t\tthis.setState({\n\t\t\tmulti: false,\n\t\t\tvalue: this.state.value[0],\n\t\t});\n\t},\n\tgetContributors (input, callback) {\n\t\tinput = input.toLowerCase();\n\t\tvar options = CONTRIBUTORS.filter(i => {\n\t\t\treturn i.github.substr(0, input.length) === input;\n\t\t});\n\t\tvar data = {\n\t\t\toptions: options.slice(0, MAX_CONTRIBUTORS),\n\t\t\tcomplete: options.length <= MAX_CONTRIBUTORS,\n\t\t};\n\t\tsetTimeout(function() {\n\t\t\tcallback(null, data);\n\t\t}, ASYNC_DELAY);\n\t},\n\tgotoContributor (value, event) {\n\t\twindow.open('https://github.com/' + value.github);\n\t},\n\trender () {\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select.Async multi={this.state.multi} value={this.state.value} onChange={this.onChange} onValueClick={this.gotoContributor} valueKey=\"github\" labelKey=\"name\" loadOptions={this.getContributors} />\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"radio\" className=\"checkbox-control\" checked={this.state.multi} onChange={this.switchToMulti}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Multiselect</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"radio\" className=\"checkbox-control\" checked={!this.state.multi} onChange={this.switchToSingle}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Single Value</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"hint\">This example implements custom label and value properties, async options and opens the github profiles in a new window when values are clicked</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nmodule.exports = Contributors;\n","import React from 'react';\nimport Select from 'react-select';\n\nvar CreatableDemo = React.createClass({\n\tdisplayName: 'CreatableDemo',\n\tpropTypes: {\n\t\thint: React.PropTypes.string,\n\t\tlabel: React.PropTypes.string\n\t},\n\tgetInitialState () {\n\t\treturn {\n\t\t\tmulti: true,\n\t\t\tmultiValue: [],\n\t\t\toptions: [\n\t\t\t\t{ value: 'R', label: 'Red' },\n\t\t\t\t{ value: 'G', label: 'Green' },\n\t\t\t\t{ value: 'B', label: 'Blue' }\n\t\t\t],\n\t\t\tvalue: undefined\n\t\t};\n\t},\n\thandleOnChange (value) {\n\t\tconst { multi } = this.state;\n\t\tif (multi) {\n\t\t\tthis.setState({ multiValue: value });\n\t\t} else {\n\t\t\tthis.setState({ value });\n\t\t}\n\t},\n\trender () {\n\t\tconst { multi, multiValue, options, value } = this.state;\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select.Creatable\n\t\t\t\t\tmulti={multi}\n\t\t\t\t\toptions={options}\n\t\t\t\t\tonChange={this.handleOnChange}\n\t\t\t\t\tvalue={multi ? multiValue : value}\n\t\t\t\t/>\n\t\t\t\t<div className=\"hint\">{this.props.hint}</div>\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input\n\t\t\t\t\t\t\ttype=\"radio\"\n\t\t\t\t\t\t\tclassName=\"checkbox-control\"\n\t\t\t\t\t\t\tchecked={multi}\n\t\t\t\t\t\t\tonChange={() => this.setState({ multi: true })}\n\t\t\t\t\t\t/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Multiselect</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input\n\t\t\t\t\t\t\ttype=\"radio\"\n\t\t\t\t\t\t\tclassName=\"checkbox-control\"\n\t\t\t\t\t\t\tchecked={!multi}\n\t\t\t\t\t\t\tonChange={() => this.setState({ multi: false })}\n\t\t\t\t\t\t/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Single Value</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nmodule.exports = CreatableDemo;\n","import React from 'react';\nimport Select from 'react-select';\nimport Gravatar from 'react-gravatar';\n\nconst USERS = require('../data/users');\nconst GRAVATAR_SIZE = 15;\n\nconst GravatarOption = React.createClass({\n\tpropTypes: {\n\t\tchildren: React.PropTypes.node,\n\t\tclassName: React.PropTypes.string,\n\t\tisDisabled: React.PropTypes.bool,\n\t\tisFocused: React.PropTypes.bool,\n\t\tisSelected: React.PropTypes.bool,\n\t\tonFocus: React.PropTypes.func,\n\t\tonSelect: React.PropTypes.func,\n\t\toption: React.PropTypes.object.isRequired,\n\t},\n\thandleMouseDown (event) {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\tthis.props.onSelect(this.props.option, event);\n\t},\n\thandleMouseEnter (event) {\n\t\tthis.props.onFocus(this.props.option, event);\n\t},\n\thandleMouseMove (event) {\n\t\tif (this.props.isFocused) return;\n\t\tthis.props.onFocus(this.props.option, event);\n\t},\n\trender () {\n\t\tlet gravatarStyle = {\n\t\t\tborderRadius: 3,\n\t\t\tdisplay: 'inline-block',\n\t\t\tmarginRight: 10,\n\t\t\tposition: 'relative',\n\t\t\ttop: -2,\n\t\t\tverticalAlign: 'middle',\n\t\t};\n\t\treturn (\n\t\t\t<div className={this.props.className}\n\t\t\t\tonMouseDown={this.handleMouseDown}\n\t\t\t\tonMouseEnter={this.handleMouseEnter}\n\t\t\t\tonMouseMove={this.handleMouseMove}\n\t\t\t\ttitle={this.props.option.title}>\n\t\t\t\t<Gravatar email={this.props.option.email} size={GRAVATAR_SIZE} style={gravatarStyle} />\n\t\t\t\t{this.props.children}\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nconst GravatarValue = React.createClass({\n\tpropTypes: {\n\t\tchildren: React.PropTypes.node,\n\t\tplaceholder: React.PropTypes.string,\n\t\tvalue: React.PropTypes.object\n\t},\n\trender () {\n\t\tvar gravatarStyle = {\n\t\t\tborderRadius: 3,\n\t\t\tdisplay: 'inline-block',\n\t\t\tmarginRight: 10,\n\t\t\tposition: 'relative',\n\t\t\ttop: -2,\n\t\t\tverticalAlign: 'middle',\n\t\t};\n\t\treturn (\n\t\t\t<div className=\"Select-value\" title={this.props.value.title}>\n\t\t\t\t<span className=\"Select-value-label\">\n\t\t\t\t\t<Gravatar email={this.props.value.email} size={GRAVATAR_SIZE} style={gravatarStyle} />\n\t\t\t\t\t{this.props.children}\n\t\t\t\t</span>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nconst UsersField = React.createClass({\n\tpropTypes: {\n\t\thint: React.PropTypes.string,\n\t\tlabel: React.PropTypes.string,\n\t},\n\tgetInitialState () {\n\t\treturn {};\n\t},\n\tsetValue (value) {\n\t\tthis.setState({ value });\n\t},\n\trender () {\n\t\tvar placeholder = <span>&#9786; Select User</span>;\n\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select\n\t\t\t\t\tarrowRenderer={arrowRenderer}\n\t\t\t\t\tonChange={this.setValue}\n\t\t\t\t\toptionComponent={GravatarOption}\n\t\t\t\t\toptions={USERS}\n\t\t\t\t\tplaceholder={placeholder}\n\t\t\t\t\tvalue={this.state.value}\n\t\t\t\t\tvalueComponent={GravatarValue}\n\t\t\t\t\t/>\n\t\t\t\t<div className=\"hint\">\n\t\t\t\t\tThis example implements custom Option and Value components to render a Gravatar image for each user based on their email.\n\t\t\t\t\tIt also demonstrates rendering HTML elements as the placeholder.\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nfunction arrowRenderer () {\n\treturn (\n\t\t<span>+</span>\n\t);\n}\n\nmodule.exports = UsersField;\n","import React from 'react';\nimport Select from 'react-select';\nimport Highlighter from 'react-highlight-words';\n\nvar DisabledUpsellOptions = React.createClass({\n\tdisplayName: 'DisabledUpsellOptions',\n\tpropTypes: {\n\t\tlabel: React.PropTypes.string,\n\t},\n\tgetInitialState () {\n\t\treturn {};\n\t},\n\tsetValue (value) {\n\t\tthis.setState({ value });\n\t\tconsole.log('Support level selected:', value.label);\n\t},\n\trenderLink: function() {\n\t\treturn <a style={{ marginLeft: 5 }} href=\"/upgrade\" target=\"_blank\">Upgrade here!</a>;\n\t},\n\trenderOption: function(option) {\n\t\treturn (\n\t\t\t<Highlighter\n\t\t\t  searchWords={[this._inputValue]}\n\t\t\t  textToHighlight={option.label}\n\t\t\t/>\n\t\t);\n\t},\n\trenderValue: function(option) {\n\t\treturn <strong style={{ color: option.color }}>{option.label}</strong>;\n\t},\n\trender: function() {\n\t\tvar options = [\n\t\t\t{ label: 'Basic customer support', value: 'basic', color: '#E31864' },\n\t\t\t{ label: 'Premium customer support', value: 'premium', color: '#6216A3' },\n\t\t\t{ label: 'Pro customer support', value: 'pro', disabled: true, link: this.renderLink() },\n\t\t];\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select\n\t\t\t\t\tonInputChange={(inputValue) => this._inputValue = inputValue}\n\t\t\t\t\toptions={options}\n\t\t\t\t\toptionRenderer={this.renderOption}\n\t\t\t\t\tonChange={this.setValue}\n\t\t\t\t\tvalue={this.state.value}\n\t\t\t\t\tvalueRenderer={this.renderValue}\n\t\t\t\t\t/>\n\t\t\t\t<div className=\"hint\">This demonstates custom render methods and links in disabled options</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\nmodule.exports = DisabledUpsellOptions;\n","import React from 'react';\nimport Select from 'react-select';\nimport fetch from 'isomorphic-fetch';\n\n\nconst GithubUsers = React.createClass({\n\tdisplayName: 'GithubUsers',\n\tpropTypes: {\n\t\tlabel: React.PropTypes.string,\n\t},\n\tgetInitialState () {\n\t\treturn {\n\t\t\tbackspaceRemoves: true,\n\t\t\tmulti: true\n\t\t};\n\t},\n\tonChange (value) {\n\t\tthis.setState({\n\t\t\tvalue: value,\n\t\t});\n\t},\n\tswitchToMulti () {\n\t\tthis.setState({\n\t\t\tmulti: true,\n\t\t\tvalue: [this.state.value],\n\t\t});\n\t},\n\tswitchToSingle () {\n\t\tthis.setState({\n\t\t\tmulti: false,\n\t\t\tvalue: this.state.value ? this.state.value[0] : null\n\t\t});\n\t},\n\tgetUsers (input) {\n\t\tif (!input) {\n\t\t\treturn Promise.resolve({ options: [] });\n\t\t}\n\n\t\treturn fetch(`https://api.github.com/search/users?q=${input}`)\n      .then((response) => response.json())\n      .then((json) => {\n        return { options: json.items };\n      });\n\t},\n\tgotoUser (value, event) {\n\t\twindow.open(value.html_url);\n\t},\n\ttoggleBackspaceRemoves () {\n\t\tthis.setState({\n\t\t\tbackspaceRemoves: !this.state.backspaceRemoves\n\t\t});\n\t},\n\ttoggleCreatable () {\n\t\tthis.setState({\n\t\t\tcreatable: !this.state.creatable\n\t\t});\n\t},\n\trender () {\n\t\tconst AsyncComponent = this.state.creatable\n\t\t\t? Select.AsyncCreatable\n\t\t\t: Select.Async;\n\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<AsyncComponent multi={this.state.multi} value={this.state.value} onChange={this.onChange} onValueClick={this.gotoUser} valueKey=\"id\" labelKey=\"login\" loadOptions={this.getUsers} backspaceRemoves={this.state.backspaceRemoves} />\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"radio\" className=\"checkbox-control\" checked={this.state.multi} onChange={this.switchToMulti}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Multiselect</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"radio\" className=\"checkbox-control\" checked={!this.state.multi} onChange={this.switchToSingle}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Single Value</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t   <input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.creatable} onChange={this.toggleCreatable} />\n\t\t\t\t\t   <span className=\"checkbox-label\">Creatable?</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t   <input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.backspaceRemoves} onChange={this.toggleBackspaceRemoves} />\n\t\t\t\t\t   <span className=\"checkbox-label\">Backspace Removes?</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"hint\">This example uses fetch.js for showing Async options with Promises</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nmodule.exports = GithubUsers;\n","import React from 'react';\nimport Select from 'react-select';\n\nconst FLAVOURS = [\n\t{ label: 'Chocolate', value: 'chocolate' },\n\t{ label: 'Vanilla', value: 'vanilla' },\n\t{ label: 'Strawberry', value: 'strawberry' },\n\t{ label: 'Caramel', value: 'caramel' },\n\t{ label: 'Cookies and Cream', value: 'cookiescream' },\n\t{ label: 'Peppermint', value: 'peppermint' },\n];\n\nconst WHY_WOULD_YOU = [\n\t{ label: 'Chocolate (are you crazy?)', value: 'chocolate', disabled: true },\n].concat(FLAVOURS.slice(1));\n\nvar MultiSelectField = React.createClass({\n\tdisplayName: 'MultiSelectField',\n\tpropTypes: {\n\t\tlabel: React.PropTypes.string,\n\t},\n\tgetInitialState () {\n\t\treturn {\n\t\t\tdisabled: false,\n\t\t\tcrazy: false,\n\t\t\toptions: FLAVOURS,\n\t\t\tvalue: [],\n\t\t};\n\t},\n\thandleSelectChange (value) {\n\t\tconsole.log('You\\'ve selected:', value);\n\t\tthis.setState({ value });\n\t},\n\ttoggleDisabled (e) {\n\t\tthis.setState({ disabled: e.target.checked });\n\t},\n\ttoggleChocolate (e) {\n\t\tlet crazy = e.target.checked;\n\t\tthis.setState({\n\t\t\tcrazy: crazy,\n\t\t\toptions: crazy ? WHY_WOULD_YOU : FLAVOURS,\n\t\t});\n\t},\n\trender () {\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select multi simpleValue disabled={this.state.disabled} value={this.state.value} placeholder=\"Select your favourite(s)\" options={this.state.options} onChange={this.handleSelectChange} />\n\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.disabled} onChange={this.toggleDisabled} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Disable the control</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.crazy} onChange={this.toggleChocolate} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">I don't like Chocolate (disabled the option)</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nmodule.exports = MultiSelectField;\n","import React from 'react';\nimport Select from 'react-select';\n\nvar ValuesAsNumbersField = React.createClass({\n\tdisplayName: 'ValuesAsNumbersField',\n\tpropTypes: {\n\t\tlabel: React.PropTypes.string\n\t},\n\tgetInitialState () {\n\t\treturn {\n\t\t\toptions: [\n\t\t\t\t{ value: 10, label: 'Ten' },\n\t\t\t\t{ value: 11, label: 'Eleven' },\n\t\t\t\t{ value: 12, label: 'Twelve' },\n\t\t\t\t{ value: 23, label: 'Twenty-three' },\n\t\t\t\t{ value: 24, label: 'Twenty-four' }\n\t\t\t],\n\t\t\tmatchPos: 'any',\n\t\t\tmatchValue: true,\n\t\t\tmatchLabel: true,\n\t\t\tvalue: null,\n\t\t\tmulti: false\n\t\t};\n\t},\n\tonChangeMatchStart(event) {\n\t\tthis.setState({\n\t\t\tmatchPos: event.target.checked ? 'start' : 'any'\n\t\t});\n\t},\n\tonChangeMatchValue(event) {\n\t\tthis.setState({\n\t\t\tmatchValue: event.target.checked\n\t\t});\n\t},\n\tonChangeMatchLabel(event) {\n\t\tthis.setState({\n\t\t\tmatchLabel: event.target.checked\n\t\t});\n\t},\n\tonChange(value) {\n\t\tthis.setState({ value });\n\t\tconsole.log('Numeric Select value changed to', value);\n\t},\n\tonChangeMulti(event) {\n\t\tthis.setState({\n\t\t\tmulti: event.target.checked\n\t\t});\n\t},\n\trender () {\n\t\tvar matchProp = 'any';\n\t\tif (this.state.matchLabel && !this.state.matchValue) {\n\t\t\tmatchProp = 'label';\n\t\t}\n\t\tif (!this.state.matchLabel && this.state.matchValue) {\n\t\t\tmatchProp = 'value';\n\t\t}\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select\n\t\t\t\t\tmatchPos={this.state.matchPos}\n\t\t\t\t\tmatchProp={matchProp}\n\t\t\t\t\tmulti={this.state.multi}\n\t\t\t\t\tonChange={this.onChange}\n\t\t\t\t\toptions={this.state.options}\n\t\t\t\t\tsimpleValue\n\t\t\t\t\tvalue={this.state.value}\n\t\t\t\t\t/>\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.multi} onChange={this.onChangeMulti} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Multi-Select</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.matchValue} onChange={this.onChangeMatchValue} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Match value</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.matchLabel} onChange={this.onChangeMatchLabel} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Match label</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.matchPos === 'start'} onChange={this.onChangeMatchStart} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Only include matches from the start of the string</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"hint\">This example uses simple numeric values</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nmodule.exports = ValuesAsNumbersField;\n","import React from 'react';\nimport Select from 'react-select';\n\nconst STATES = require('../data/states');\n\nvar StatesField = React.createClass({\n\tdisplayName: 'StatesField',\n\tpropTypes: {\n\t\tlabel: React.PropTypes.string,\n\t\tsearchable: React.PropTypes.bool,\n\t},\n\tgetDefaultProps () {\n\t\treturn {\n\t\t\tlabel: 'States:',\n\t\t\tsearchable: true,\n\t\t};\n\t},\n\tgetInitialState () {\n\t\treturn {\n\t\t\tcountry: 'AU',\n\t\t\tdisabled: false,\n\t\t\tsearchable: this.props.searchable,\n\t\t\tselectValue: 'new-south-wales',\n\t\t\tclearable: true,\n\t\t};\n\t},\n\tswitchCountry (e) {\n\t\tvar newCountry = e.target.value;\n\t\tconsole.log('Country changed to ' + newCountry);\n\t\tthis.setState({\n\t\t\tcountry: newCountry,\n\t\t\tselectValue: null\n\t\t});\n\t},\n\tupdateValue (newValue) {\n\t\tconsole.log('State changed to ' + newValue);\n\t\tthis.setState({\n\t\t\tselectValue: newValue\n\t\t});\n\t},\n\tfocusStateSelect () {\n\t\tthis.refs.stateSelect.focus();\n\t},\n\ttoggleCheckbox (e) {\n\t\tlet newState = {};\n\t\tnewState[e.target.name] = e.target.checked;\n\t\tthis.setState(newState);\n\t},\n\trender () {\n\t\tvar options = STATES[this.state.country];\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select ref=\"stateSelect\" autofocus options={options} simpleValue clearable={this.state.clearable} name=\"selected-state\" disabled={this.state.disabled} value={this.state.selectValue} onChange={this.updateValue} searchable={this.state.searchable} />\n\n\t\t\t\t<div style={{ marginTop: 14 }}>\n\t\t\t\t\t<button type=\"button\" onClick={this.focusStateSelect}>Focus Select</button>\n\t\t\t\t\t<label className=\"checkbox\" style={{ marginLeft: 10 }}>\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" name=\"searchable\" checked={this.state.searchable} onChange={this.toggleCheckbox}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Searchable</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\" style={{ marginLeft: 10 }}>\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" name=\"disabled\" checked={this.state.disabled} onChange={this.toggleCheckbox}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Disabled</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\" style={{ marginLeft: 10 }}>\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" name=\"clearable\" checked={this.state.clearable} onChange={this.toggleCheckbox}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Clearable</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"radio\" className=\"checkbox-control\" checked={this.state.country === 'AU'} value=\"AU\" onChange={this.switchCountry}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Australia</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"radio\" className=\"checkbox-control\" checked={this.state.country === 'US'} value=\"US\" onChange={this.switchCountry}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">United States</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\n\nmodule.exports = StatesField;\n","import React from 'react';\nimport VirtualizedSelect from 'react-virtualized-select';\n\nconst DATA = require('../data/cities');\n\nvar CitiesField = React.createClass({\n\tdisplayName: 'CitiesField',\n\tgetInitialState () {\n\t\treturn {};\n\t},\n\tupdateValue (newValue) {\n\t\tthis.setState({\n\t\t\tselectValue: newValue\n\t\t});\n\t},\n\trender () {\n\t\tvar options = DATA.CITIES;\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">Cities (Large Dataset)</h3>\n\t\t\t\t<VirtualizedSelect ref=\"citySelect\"\n\t\t\t\t\toptions={options}\n\t\t\t\t\tsimpleValue\n\t\t\t\t\tclearable\n\t\t\t\t\tname=\"select-city\"\n\t\t\t\t\tvalue={this.state.selectValue}\n\t\t\t\t\tonChange={this.updateValue}\n\t\t\t\t\tsearchable\n\t\t\t\t\tlabelKey=\"name\"\n\t\t\t\t\tvalueKey=\"name\"\n\t\t\t\t/>\n\t\t\t\t<div className=\"hint\">\n\t\t\t\t\tUses <a href=\"https://github.com/bvaughn/react-virtualized\">react-virtualized</a> and <a href=\"https://github.com/bvaughn/react-virtualized-select/\">react-virtualized-select</a> to display a list of the world's 1,000 largest cities.\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\n\nmodule.exports = CitiesField;\n","exports.CITIES = [\n  { name: 'Abilene' },\n  { name: 'Addison' },\n  { name: 'Akron' },\n  { name: 'Alameda' },\n  { name: 'Albany' },\n  { name: 'Albany' },\n  { name: 'Albany' },\n  { name: 'Albuquerque' },\n  { name: 'Alexandria' },\n  { name: 'Alexandria' },\n  { name: 'Alhambra' },\n  { name: 'Aliso Viejo' },\n  { name: 'Allen' },\n  { name: 'Allentown' },\n  { name: 'Alpharetta' },\n  { name: 'Altamonte Springs' },\n  { name: 'Altoona' },\n  { name: 'Amarillo' },\n  { name: 'Ames' },\n  { name: 'Anaheim' },\n  { name: 'Anchorage' },\n  { name: 'Anderson' },\n  { name: 'Ankeny' },\n  { name: 'Ann Arbor' },\n  { name: 'Annapolis' },\n  { name: 'Antioch' },\n  { name: 'Apache Junction' },\n  { name: 'Apex' },\n  { name: 'Apopka' },\n  { name: 'Apple Valley' },\n  { name: 'Apple Valley' },\n  { name: 'Appleton' },\n  { name: 'Arcadia' },\n  { name: 'Arlington' },\n  { name: 'Arlington Heights' },\n  { name: 'Arvada' },\n  { name: 'Asheville' },\n  { name: 'Athens-Clarke County' },\n  { name: 'Atlanta' },\n  { name: 'Atlantic City' },\n  { name: 'Attleboro' },\n  { name: 'Auburn' },\n  { name: 'Auburn' },\n  { name: 'Augusta-Richmond County' },\n  { name: 'Aurora' },\n  { name: 'Aurora' },\n  { name: 'Austin' },\n  { name: 'Aventura' },\n  { name: 'Avondale' },\n  { name: 'Azusa' },\n  { name: 'Bakersfield' },\n  { name: 'Baldwin Park' },\n  { name: 'Baltimore' },\n  { name: 'Barnstable Town' },\n  { name: 'Bartlett' },\n  { name: 'Bartlett' },\n  { name: 'Baton Rouge' },\n  { name: 'Battle Creek' },\n  { name: 'Bayonne' },\n  { name: 'Baytown' },\n  { name: 'Beaumont' },\n  { name: 'Beaumont' },\n  { name: 'Beavercreek' },\n  { name: 'Beaverton' },\n  { name: 'Bedford' },\n  { name: 'Bell Gardens' },\n  { name: 'Belleville' },\n  { name: 'Bellevue' },\n  { name: 'Bellevue' },\n  { name: 'Bellflower' },\n  { name: 'Bellingham' },\n  { name: 'Beloit' },\n  { name: 'Bend' },\n  { name: 'Bentonville' },\n  { name: 'Berkeley' },\n  { name: 'Berwyn' },\n  { name: 'Bethlehem' },\n  { name: 'Beverly' },\n  { name: 'Billings' },\n  { name: 'Biloxi' },\n  { name: 'Binghamton' },\n  { name: 'Birmingham' },\n  { name: 'Bismarck' },\n  { name: 'Blacksburg' },\n  { name: 'Blaine' },\n  { name: 'Bloomington' },\n  { name: 'Bloomington' },\n  { name: 'Bloomington' },\n  { name: 'Blue Springs' },\n  { name: 'Boca Raton' },\n  { name: 'Boise City' },\n  { name: 'Bolingbrook' },\n  { name: 'Bonita Springs' },\n  { name: 'Bossier City' },\n  { name: 'Boston' },\n  { name: 'Boulder' },\n  { name: 'Bountiful' },\n  { name: 'Bowie' },\n  { name: 'Bowling Green' },\n  { name: 'Boynton Beach' },\n  { name: 'Bozeman' },\n  { name: 'Bradenton' },\n  { name: 'Brea' },\n  { name: 'Bremerton' },\n  { name: 'Brentwood' },\n  { name: 'Brentwood' },\n  { name: 'Bridgeport' },\n  { name: 'Bristol' },\n  { name: 'Brockton' },\n  { name: 'Broken Arrow' },\n  { name: 'Brookfield' },\n  { name: 'Brookhaven' },\n  { name: 'Brooklyn Park' },\n  { name: 'Broomfield' },\n  { name: 'Brownsville' },\n  { name: 'Bryan' },\n  { name: 'Buckeye' },\n  { name: 'Buena Park' },\n  { name: 'Buffalo' },\n  { name: 'Buffalo Grove' },\n  { name: 'Bullhead City' },\n  { name: 'Burbank' },\n  { name: 'Burien' },\n  { name: 'Burleson' },\n  { name: 'Burlington' },\n  { name: 'Burlington' },\n  { name: 'Burnsville' },\n  { name: 'Caldwell' },\n  { name: 'Calexico' },\n  { name: 'Calumet City' },\n  { name: 'Camarillo' },\n  { name: 'Cambridge' },\n  { name: 'Camden' },\n  { name: 'Campbell' },\n  { name: 'Canton' },\n  { name: 'Cape Coral' },\n  { name: 'Cape Girardeau' },\n  { name: 'Carlsbad' },\n  { name: 'Carmel' },\n  { name: 'Carol Stream' },\n  { name: 'Carpentersville' },\n  { name: 'Carrollton' },\n  { name: 'Carson' },\n  { name: 'Carson City' },\n  { name: 'Cary' },\n  { name: 'Casa Grande' },\n  { name: 'Casper' },\n  { name: 'Castle Rock' },\n  { name: 'Cathedral City' },\n  { name: 'Cedar Falls' },\n  { name: 'Cedar Hill' },\n  { name: 'Cedar Park' },\n  { name: 'Cedar Rapids' },\n  { name: 'Centennial' },\n  { name: 'Ceres' },\n  { name: 'Cerritos' },\n  { name: 'Champaign' },\n  { name: 'Chandler' },\n  { name: 'Chapel Hill' },\n  { name: 'Charleston' },\n  { name: 'Charleston' },\n  { name: 'Charlotte' },\n  { name: 'Charlottesville' },\n  { name: 'Chattanooga' },\n  { name: 'Chelsea' },\n  { name: 'Chesapeake' },\n  { name: 'Chesterfield' },\n  { name: 'Cheyenne' },\n  { name: 'Chicago' },\n  { name: 'Chico' },\n  { name: 'Chicopee' },\n  { name: 'Chino' },\n  { name: 'Chino Hills' },\n  { name: 'Chula Vista' },\n  { name: 'Cicero' },\n  { name: 'Cincinnati' },\n  { name: 'Citrus Heights' },\n  { name: 'Clarksville' },\n  { name: 'Clearwater' },\n  { name: 'Cleveland' },\n  { name: 'Cleveland' },\n  { name: 'Cleveland Heights' },\n  { name: 'Clifton' },\n  { name: 'Clovis' },\n  { name: 'Clovis' },\n  { name: 'Coachella' },\n  { name: 'Coconut Creek' },\n  { name: 'Coeur d\\'Alene' },\n  { name: 'College Station' },\n  { name: 'Collierville' },\n  { name: 'Colorado Springs' },\n  { name: 'Colton' },\n  { name: 'Columbia' },\n  { name: 'Columbia' },\n  { name: 'Columbus' },\n  { name: 'Columbus' },\n  { name: 'Columbus' },\n  { name: 'Commerce City' },\n  { name: 'Compton' },\n  { name: 'Concord' },\n  { name: 'Concord' },\n  { name: 'Concord' },\n  { name: 'Conroe' },\n  { name: 'Conway' },\n  { name: 'Coon Rapids' },\n  { name: 'Coppell' },\n  { name: 'Coral Gables' },\n  { name: 'Coral Springs' },\n  { name: 'Corona' },\n  { name: 'Corpus Christi' },\n  { name: 'Corvallis' },\n  { name: 'Costa Mesa' },\n  { name: 'Council Bluffs' },\n  { name: 'Covina' },\n  { name: 'Covington' },\n  { name: 'Cranston' },\n  { name: 'Crystal Lake' },\n  { name: 'Culver City' },\n  { name: 'Cupertino' },\n  { name: 'Cutler Bay' },\n  { name: 'Cuyahoga Falls' },\n  { name: 'Cypress' },\n  { name: 'Dallas' },\n  { name: 'Daly City' },\n  { name: 'Danbury' },\n  { name: 'Danville' },\n  { name: 'Danville' },\n  { name: 'Davenport' },\n  { name: 'Davie' },\n  { name: 'Davis' },\n  { name: 'Dayton' },\n  { name: 'Daytona Beach' },\n  { name: 'DeKalb' },\n  { name: 'DeSoto' },\n  { name: 'Dearborn' },\n  { name: 'Dearborn Heights' },\n  { name: 'Decatur' },\n  { name: 'Decatur' },\n  { name: 'Deerfield Beach' },\n  { name: 'Delano' },\n  { name: 'Delray Beach' },\n  { name: 'Deltona' },\n  { name: 'Denton' },\n  { name: 'Denver' },\n  { name: 'Des Moines' },\n  { name: 'Des Plaines' },\n  { name: 'Detroit' },\n  { name: 'Diamond Bar' },\n  { name: 'Doral' },\n  { name: 'Dothan' },\n  { name: 'Dover' },\n  { name: 'Downers Grove' },\n  { name: 'Downey' },\n  { name: 'Draper' },\n  { name: 'Dublin' },\n  { name: 'Dublin' },\n  { name: 'Dubuque' },\n  { name: 'Duluth' },\n  { name: 'Duncanville' },\n  { name: 'Dunwoody' },\n  { name: 'Durham' },\n  { name: 'Eagan' },\n  { name: 'East Lansing' },\n  { name: 'East Orange' },\n  { name: 'East Providence' },\n  { name: 'Eastvale' },\n  { name: 'Eau Claire' },\n  { name: 'Eden Prairie' },\n  { name: 'Edina' },\n  { name: 'Edinburg' },\n  { name: 'Edmond' },\n  { name: 'Edmonds' },\n  { name: 'El Cajon' },\n  { name: 'El Centro' },\n  { name: 'El Monte' },\n  { name: 'El Paso' },\n  { name: 'Elgin' },\n  { name: 'Elizabeth' },\n  { name: 'Elk Grove' },\n  { name: 'Elkhart' },\n  { name: 'Elmhurst' },\n  { name: 'Elyria' },\n  { name: 'Encinitas' },\n  { name: 'Enid' },\n  { name: 'Erie' },\n  { name: 'Escondido' },\n  { name: 'Euclid' },\n  { name: 'Eugene' },\n  { name: 'Euless' },\n  { name: 'Evanston' },\n  { name: 'Evansville' },\n  { name: 'Everett' },\n  { name: 'Everett' },\n  { name: 'Fairfield' },\n  { name: 'Fairfield' },\n  { name: 'Fall River' },\n  { name: 'Fargo' },\n  { name: 'Farmington' },\n  { name: 'Farmington Hills' },\n  { name: 'Fayetteville' },\n  { name: 'Fayetteville' },\n  { name: 'Federal Way' },\n  { name: 'Findlay' },\n  { name: 'Fishers' },\n  { name: 'Fitchburg' },\n  { name: 'Flagstaff' },\n  { name: 'Flint' },\n  { name: 'Florence' },\n  { name: 'Florence' },\n  { name: 'Florissant' },\n  { name: 'Flower Mound' },\n  { name: 'Folsom' },\n  { name: 'Fond du Lac' },\n  { name: 'Fontana' },\n  { name: 'Fort Collins' },\n  { name: 'Fort Lauderdale' },\n  { name: 'Fort Myers' },\n  { name: 'Fort Pierce' },\n  { name: 'Fort Smith' },\n  { name: 'Fort Wayne' },\n  { name: 'Fort Worth' },\n  { name: 'Fountain Valley' },\n  { name: 'Franklin' },\n  { name: 'Frederick' },\n  { name: 'Freeport' },\n  { name: 'Fremont' },\n  { name: 'Fresno' },\n  { name: 'Friendswood' },\n  { name: 'Frisco' },\n  { name: 'Fullerton' },\n  { name: 'Gainesville' },\n  { name: 'Gaithersburg' },\n  { name: 'Galveston' },\n  { name: 'Garden Grove' },\n  { name: 'Gardena' },\n  { name: 'Garland' },\n  { name: 'Gary' },\n  { name: 'Gastonia' },\n  { name: 'Georgetown' },\n  { name: 'Germantown' },\n  { name: 'Gilbert' },\n  { name: 'Gilroy' },\n  { name: 'Glendale' },\n  { name: 'Glendale' },\n  { name: 'Glendora' },\n  { name: 'Glenview' },\n  { name: 'Goodyear' },\n  { name: 'Goose Creek' },\n  { name: 'Grand Forks' },\n  { name: 'Grand Island' },\n  { name: 'Grand Junction' },\n  { name: 'Grand Prairie' },\n  { name: 'Grand Rapids' },\n  { name: 'Grapevine' },\n  { name: 'Great Falls' },\n  { name: 'Greeley' },\n  { name: 'Green Bay' },\n  { name: 'Greenacres' },\n  { name: 'Greenfield' },\n  { name: 'Greensboro' },\n  { name: 'Greenville' },\n  { name: 'Greenville' },\n  { name: 'Greenwood' },\n  { name: 'Gresham' },\n  { name: 'Grove City' },\n  { name: 'Gulfport' },\n  { name: 'Hackensack' },\n  { name: 'Hagerstown' },\n  { name: 'Hallandale Beach' },\n  { name: 'Haltom City' },\n  { name: 'Hamilton' },\n  { name: 'Hammond' },\n  { name: 'Hampton' },\n  { name: 'Hanford' },\n  { name: 'Hanover Park' },\n  { name: 'Harlingen' },\n  { name: 'Harrisburg' },\n  { name: 'Harrisonburg' },\n  { name: 'Hartford' },\n  { name: 'Hattiesburg' },\n  { name: 'Haverhill' },\n  { name: 'Hawthorne' },\n  { name: 'Hayward' },\n  { name: 'Hemet' },\n  { name: 'Hempstead' },\n  { name: 'Henderson' },\n  { name: 'Hendersonville' },\n  { name: 'Hesperia' },\n  { name: 'Hialeah' },\n  { name: 'Hickory' },\n  { name: 'High Point' },\n  { name: 'Highland' },\n  { name: 'Hillsboro' },\n  { name: 'Hilton Head Island' },\n  { name: 'Hoboken' },\n  { name: 'Hoffman Estates' },\n  { name: 'Hollywood' },\n  { name: 'Holyoke' },\n  { name: 'Homestead' },\n  { name: 'Honolulu' },\n  { name: 'Hoover' },\n  { name: 'Houston' },\n  { name: 'Huber Heights' },\n  { name: 'Huntersville' },\n  { name: 'Huntington' },\n  { name: 'Huntington Beach' },\n  { name: 'Huntington Park' },\n  { name: 'Huntsville' },\n  { name: 'Huntsville' },\n  { name: 'Hurst' },\n  { name: 'Hutchinson' },\n  { name: 'Idaho Falls' },\n  { name: 'Independence' },\n  { name: 'Indianapolis' },\n  { name: 'Indio' },\n  { name: 'Inglewood' },\n  { name: 'Iowa City' },\n  { name: 'Irvine' },\n  { name: 'Irving' },\n  { name: 'Jackson' },\n  { name: 'Jackson' },\n  { name: 'Jacksonville' },\n  { name: 'Jacksonville' },\n  { name: 'Janesville' },\n  { name: 'Jefferson City' },\n  { name: 'Jeffersonville' },\n  { name: 'Jersey City' },\n  { name: 'Johns Creek' },\n  { name: 'Johnson City' },\n  { name: 'Joliet' },\n  { name: 'Jonesboro' },\n  { name: 'Joplin' },\n  { name: 'Jupiter' },\n  { name: 'Jurupa Valley' },\n  { name: 'Kalamazoo' },\n  { name: 'Kannapolis' },\n  { name: 'Kansas City' },\n  { name: 'Kansas City' },\n  { name: 'Kearny' },\n  { name: 'Keizer' },\n  { name: 'Keller' },\n  { name: 'Kenner' },\n  { name: 'Kennewick' },\n  { name: 'Kenosha' },\n  { name: 'Kent' },\n  { name: 'Kentwood' },\n  { name: 'Kettering' },\n  { name: 'Killeen' },\n  { name: 'Kingsport' },\n  { name: 'Kirkland' },\n  { name: 'Kissimmee' },\n  { name: 'Knoxville' },\n  { name: 'Kokomo' },\n  { name: 'La Crosse' },\n  { name: 'La Habra' },\n  { name: 'La Mesa' },\n  { name: 'La Mirada' },\n  { name: 'La Puente' },\n  { name: 'La Quinta' },\n  { name: 'Lacey' },\n  { name: 'Lafayette' },\n  { name: 'Lafayette' },\n  { name: 'Laguna Niguel' },\n  { name: 'Lake Charles' },\n  { name: 'Lake Elsinore' },\n  { name: 'Lake Forest' },\n  { name: 'Lake Havasu City' },\n  { name: 'Lake Oswego' },\n  { name: 'Lakeland' },\n  { name: 'Lakeville' },\n  { name: 'Lakewood' },\n  { name: 'Lakewood' },\n  { name: 'Lakewood' },\n  { name: 'Lakewood' },\n  { name: 'Lancaster' },\n  { name: 'Lancaster' },\n  { name: 'Lancaster' },\n  { name: 'Lancaster' },\n  { name: 'Lansing' },\n  { name: 'Laredo' },\n  { name: 'Largo' },\n  { name: 'Las Cruces' },\n  { name: 'Las Vegas' },\n  { name: 'Lauderhill' },\n  { name: 'Lawrence' },\n  { name: 'Lawrence' },\n  { name: 'Lawrence' },\n  { name: 'Lawton' },\n  { name: 'Layton' },\n  { name: 'League City' },\n  { name: 'Lee\\'s Summit' },\n  { name: 'Leesburg' },\n  { name: 'Lehi' },\n  { name: 'Lenexa' },\n  { name: 'Leominster' },\n  { name: 'Lewisville' },\n  { name: 'Lexington-Fayette' },\n  { name: 'Lima' },\n  { name: 'Lincoln' },\n  { name: 'Lincoln' },\n  { name: 'Lincoln Park' },\n  { name: 'Linden' },\n  { name: 'Little Rock' },\n  { name: 'Littleton' },\n  { name: 'Livermore' },\n  { name: 'Livonia' },\n  { name: 'Lodi' },\n  { name: 'Logan' },\n  { name: 'Lombard' },\n  { name: 'Lompoc' },\n  { name: 'Long Beach' },\n  { name: 'Longmont' },\n  { name: 'Longview' },\n  { name: 'Lorain' },\n  { name: 'Los Angeles' },\n  { name: 'Louisville/Jefferson County' },\n  { name: 'Loveland' },\n  { name: 'Lowell' },\n  { name: 'Lubbock' },\n  { name: 'Lynchburg' },\n  { name: 'Lynn' },\n  { name: 'Lynwood' },\n  { name: 'Macon' },\n  { name: 'Madera' },\n  { name: 'Madison' },\n  { name: 'Madison' },\n  { name: 'Malden' },\n  { name: 'Manassas' },\n  { name: 'Manchester' },\n  { name: 'Manhattan' },\n  { name: 'Mankato' },\n  { name: 'Mansfield' },\n  { name: 'Mansfield' },\n  { name: 'Manteca' },\n  { name: 'Maple Grove' },\n  { name: 'Maplewood' },\n  { name: 'Marana' },\n  { name: 'Margate' },\n  { name: 'Maricopa' },\n  { name: 'Marietta' },\n  { name: 'Marlborough' },\n  { name: 'Martinez' },\n  { name: 'Marysville' },\n  { name: 'McAllen' },\n  { name: 'McKinney' },\n  { name: 'Medford' },\n  { name: 'Medford' },\n  { name: 'Melbourne' },\n  { name: 'Memphis' },\n  { name: 'Menifee' },\n  { name: 'Mentor' },\n  { name: 'Merced' },\n  { name: 'Meriden' },\n  { name: 'Meridian' },\n  { name: 'Meridian' },\n  { name: 'Mesa' },\n  { name: 'Mesquite' },\n  { name: 'Methuen' },\n  { name: 'Miami' },\n  { name: 'Miami Beach' },\n  { name: 'Miami Gardens' },\n  { name: 'Middletown' },\n  { name: 'Middletown' },\n  { name: 'Midland' },\n  { name: 'Midland' },\n  { name: 'Midwest City' },\n  { name: 'Milford' },\n  { name: 'Milpitas' },\n  { name: 'Milwaukee' },\n  { name: 'Minneapolis' },\n  { name: 'Minnetonka' },\n  { name: 'Minot' },\n  { name: 'Miramar' },\n  { name: 'Mishawaka' },\n  { name: 'Mission' },\n  { name: 'Mission Viejo' },\n  { name: 'Missoula' },\n  { name: 'Missouri City' },\n  { name: 'Mobile' },\n  { name: 'Modesto' },\n  { name: 'Moline' },\n  { name: 'Monroe' },\n  { name: 'Monrovia' },\n  { name: 'Montclair' },\n  { name: 'Montebello' },\n  { name: 'Monterey Park' },\n  { name: 'Montgomery' },\n  { name: 'Moore' },\n  { name: 'Moorhead' },\n  { name: 'Moreno Valley' },\n  { name: 'Morgan Hill' },\n  { name: 'Mount Pleasant' },\n  { name: 'Mount Prospect' },\n  { name: 'Mount Vernon' },\n  { name: 'Mountain View' },\n  { name: 'Muncie' },\n  { name: 'Murfreesboro' },\n  { name: 'Murray' },\n  { name: 'Murrieta' },\n  { name: 'Muskegon' },\n  { name: 'Muskogee' },\n  { name: 'Nampa' },\n  { name: 'Napa' },\n  { name: 'Naperville' },\n  { name: 'Nashua' },\n  { name: 'Nashville-Davidson' },\n  { name: 'National City' },\n  { name: 'New Bedford' },\n  { name: 'New Berlin' },\n  { name: 'New Braunfels' },\n  { name: 'New Britain' },\n  { name: 'New Brunswick' },\n  { name: 'New Haven' },\n  { name: 'New Orleans' },\n  { name: 'New Rochelle' },\n  { name: 'New York' },\n  { name: 'Newark' },\n  { name: 'Newark' },\n  { name: 'Newark' },\n  { name: 'Newport Beach' },\n  { name: 'Newport News' },\n  { name: 'Newton' },\n  { name: 'Niagara Falls' },\n  { name: 'Noblesville' },\n  { name: 'Norfolk' },\n  { name: 'Normal' },\n  { name: 'Norman' },\n  { name: 'North Charleston' },\n  { name: 'North Las Vegas' },\n  { name: 'North Lauderdale' },\n  { name: 'North Little Rock' },\n  { name: 'North Miami' },\n  { name: 'North Miami Beach' },\n  { name: 'North Port' },\n  { name: 'North Richland Hills' },\n  { name: 'Northglenn' },\n  { name: 'Norwalk' },\n  { name: 'Norwalk' },\n  { name: 'Norwich' },\n  { name: 'Novato' },\n  { name: 'Novi' },\n  { name: 'O\\'Fallon' },\n  { name: 'Oak Lawn' },\n  { name: 'Oak Park' },\n  { name: 'Oakland' },\n  { name: 'Oakland Park' },\n  { name: 'Oakley' },\n  { name: 'Ocala' },\n  { name: 'Oceanside' },\n  { name: 'Ocoee' },\n  { name: 'Odessa' },\n  { name: 'Ogden' },\n  { name: 'Oklahoma City' },\n  { name: 'Olathe' },\n  { name: 'Olympia' },\n  { name: 'Omaha' },\n  { name: 'Ontario' },\n  { name: 'Orange' },\n  { name: 'Orem' },\n  { name: 'Orland Park' },\n  { name: 'Orlando' },\n  { name: 'Ormond Beach' },\n  { name: 'Oro Valley' },\n  { name: 'Oshkosh' },\n  { name: 'Overland Park' },\n  { name: 'Owensboro' },\n  { name: 'Oxnard' },\n  { name: 'Pacifica' },\n  { name: 'Palatine' },\n  { name: 'Palm Bay' },\n  { name: 'Palm Beach Gardens' },\n  { name: 'Palm Coast' },\n  { name: 'Palm Desert' },\n  { name: 'Palm Springs' },\n  { name: 'Palmdale' },\n  { name: 'Palo Alto' },\n  { name: 'Panama City' },\n  { name: 'Paramount' },\n  { name: 'Park Ridge' },\n  { name: 'Parker' },\n  { name: 'Parma' },\n  { name: 'Pasadena' },\n  { name: 'Pasadena' },\n  { name: 'Pasco' },\n  { name: 'Passaic' },\n  { name: 'Paterson' },\n  { name: 'Pawtucket' },\n  { name: 'Peabody' },\n  { name: 'Peachtree Corners' },\n  { name: 'Pearland' },\n  { name: 'Pembroke Pines' },\n  { name: 'Pensacola' },\n  { name: 'Peoria' },\n  { name: 'Peoria' },\n  { name: 'Perris' },\n  { name: 'Perth Amboy' },\n  { name: 'Petaluma' },\n  { name: 'Pflugerville' },\n  { name: 'Pharr' },\n  { name: 'Phenix City' },\n  { name: 'Philadelphia' },\n  { name: 'Phoenix' },\n  { name: 'Pico Rivera' },\n  { name: 'Pine Bluff' },\n  { name: 'Pinellas Park' },\n  { name: 'Pittsburg' },\n  { name: 'Pittsburgh' },\n  { name: 'Pittsfield' },\n  { name: 'Placentia' },\n  { name: 'Plainfield' },\n  { name: 'Plainfield' },\n  { name: 'Plano' },\n  { name: 'Plantation' },\n  { name: 'Pleasanton' },\n  { name: 'Plymouth' },\n  { name: 'Pocatello' },\n  { name: 'Pomona' },\n  { name: 'Pompano Beach' },\n  { name: 'Pontiac' },\n  { name: 'Port Arthur' },\n  { name: 'Port Orange' },\n  { name: 'Port St. Lucie' },\n  { name: 'Portage' },\n  { name: 'Porterville' },\n  { name: 'Portland' },\n  { name: 'Portland' },\n  { name: 'Portsmouth' },\n  { name: 'Poway' },\n  { name: 'Prescott' },\n  { name: 'Prescott Valley' },\n  { name: 'Providence' },\n  { name: 'Provo' },\n  { name: 'Pueblo' },\n  { name: 'Puyallup' },\n  { name: 'Quincy' },\n  { name: 'Quincy' },\n  { name: 'Racine' },\n  { name: 'Raleigh' },\n  { name: 'Rancho Cordova' },\n  { name: 'Rancho Cucamonga' },\n  { name: 'Rancho Palos Verdes' },\n  { name: 'Rancho Santa Margarita' },\n  { name: 'Rapid City' },\n  { name: 'Reading' },\n  { name: 'Redding' },\n  { name: 'Redlands' },\n  { name: 'Redmond' },\n  { name: 'Redondo Beach' },\n  { name: 'Redwood City' },\n  { name: 'Reno' },\n  { name: 'Renton' },\n  { name: 'Revere' },\n  { name: 'Rialto' },\n  { name: 'Richardson' },\n  { name: 'Richland' },\n  { name: 'Richmond' },\n  { name: 'Richmond' },\n  { name: 'Rio Rancho' },\n  { name: 'Riverside' },\n  { name: 'Riverton' },\n  { name: 'Roanoke' },\n  { name: 'Rochester' },\n  { name: 'Rochester' },\n  { name: 'Rochester Hills' },\n  { name: 'Rock Hill' },\n  { name: 'Rock Island' },\n  { name: 'Rockford' },\n  { name: 'Rocklin' },\n  { name: 'Rockville' },\n  { name: 'Rockwall' },\n  { name: 'Rocky Mount' },\n  { name: 'Rogers' },\n  { name: 'Rohnert Park' },\n  { name: 'Romeoville' },\n  { name: 'Rosemead' },\n  { name: 'Roseville' },\n  { name: 'Roseville' },\n  { name: 'Roswell' },\n  { name: 'Roswell' },\n  { name: 'Round Rock' },\n  { name: 'Rowlett' },\n  { name: 'Roy' },\n  { name: 'Royal Oak' },\n  { name: 'Sacramento' },\n  { name: 'Saginaw' },\n  { name: 'Salem' },\n  { name: 'Salem' },\n  { name: 'Salina' },\n  { name: 'Salinas' },\n  { name: 'Salt Lake City' },\n  { name: 'Sammamish' },\n  { name: 'San Angelo' },\n  { name: 'San Antonio' },\n  { name: 'San Bernardino' },\n  { name: 'San Bruno' },\n  { name: 'San Buenaventura (Ventura)' },\n  { name: 'San Clemente' },\n  { name: 'San Diego' },\n  { name: 'San Francisco' },\n  { name: 'San Gabriel' },\n  { name: 'San Jacinto' },\n  { name: 'San Jose' },\n  { name: 'San Leandro' },\n  { name: 'San Luis Obispo' },\n  { name: 'San Marcos' },\n  { name: 'San Marcos' },\n  { name: 'San Mateo' },\n  { name: 'San Rafael' },\n  { name: 'San Ramon' },\n  { name: 'Sandy' },\n  { name: 'Sandy Springs' },\n  { name: 'Sanford' },\n  { name: 'Santa Ana' },\n  { name: 'Santa Barbara' },\n  { name: 'Santa Clara' },\n  { name: 'Santa Clarita' },\n  { name: 'Santa Cruz' },\n  { name: 'Santa Fe' },\n  { name: 'Santa Maria' },\n  { name: 'Santa Monica' },\n  { name: 'Santa Rosa' },\n  { name: 'Santee' },\n  { name: 'Sarasota' },\n  { name: 'Savannah' },\n  { name: 'Sayreville' },\n  { name: 'Schaumburg' },\n  { name: 'Schenectady' },\n  { name: 'Scottsdale' },\n  { name: 'Scranton' },\n  { name: 'Seattle' },\n  { name: 'Shakopee' },\n  { name: 'Shawnee' },\n  { name: 'Sheboygan' },\n  { name: 'Shelton' },\n  { name: 'Sherman' },\n  { name: 'Shoreline' },\n  { name: 'Shreveport' },\n  { name: 'Sierra Vista' },\n  { name: 'Simi Valley' },\n  { name: 'Sioux City' },\n  { name: 'Sioux Falls' },\n  { name: 'Skokie' },\n  { name: 'Smyrna' },\n  { name: 'Smyrna' },\n  { name: 'Somerville' },\n  { name: 'South Bend' },\n  { name: 'South Gate' },\n  { name: 'South Jordan' },\n  { name: 'South San Francisco' },\n  { name: 'Southaven' },\n  { name: 'Southfield' },\n  { name: 'Spanish Fork' },\n  { name: 'Sparks' },\n  { name: 'Spartanburg' },\n  { name: 'Spokane' },\n  { name: 'Spokane Valley' },\n  { name: 'Springdale' },\n  { name: 'Springfield' },\n  { name: 'Springfield' },\n  { name: 'Springfield' },\n  { name: 'Springfield' },\n  { name: 'Springfield' },\n  { name: 'St. Charles' },\n  { name: 'St. Clair Shores' },\n  { name: 'St. Cloud' },\n  { name: 'St. Cloud' },\n  { name: 'St. George' },\n  { name: 'St. Joseph' },\n  { name: 'St. Louis' },\n  { name: 'St. Louis Park' },\n  { name: 'St. Paul' },\n  { name: 'St. Peters' },\n  { name: 'St. Petersburg' },\n  { name: 'Stamford' },\n  { name: 'Stanton' },\n  { name: 'State College' },\n  { name: 'Sterling Heights' },\n  { name: 'Stillwater' },\n  { name: 'Stockton' },\n  { name: 'Streamwood' },\n  { name: 'Strongsville' },\n  { name: 'Suffolk' },\n  { name: 'Sugar Land' },\n  { name: 'Summerville' },\n  { name: 'Sumter' },\n  { name: 'Sunnyvale' },\n  { name: 'Sunrise' },\n  { name: 'Surprise' },\n  { name: 'Syracuse' },\n  { name: 'Tacoma' },\n  { name: 'Tallahassee' },\n  { name: 'Tamarac' },\n  { name: 'Tampa' },\n  { name: 'Taunton' },\n  { name: 'Taylor' },\n  { name: 'Taylorsville' },\n  { name: 'Temecula' },\n  { name: 'Tempe' },\n  { name: 'Temple' },\n  { name: 'Terre Haute' },\n  { name: 'Texarkana' },\n  { name: 'Texas City' },\n  { name: 'The Colony' },\n  { name: 'Thornton' },\n  { name: 'Thousand Oaks' },\n  { name: 'Tigard' },\n  { name: 'Tinley Park' },\n  { name: 'Titusville' },\n  { name: 'Toledo' },\n  { name: 'Topeka' },\n  { name: 'Torrance' },\n  { name: 'Tracy' },\n  { name: 'Trenton' },\n  { name: 'Troy' },\n  { name: 'Troy' },\n  { name: 'Tucson' },\n  { name: 'Tulare' },\n  { name: 'Tulsa' },\n  { name: 'Turlock' },\n  { name: 'Tuscaloosa' },\n  { name: 'Tustin' },\n  { name: 'Twin Falls' },\n  { name: 'Tyler' },\n  { name: 'Union City' },\n  { name: 'Union City' },\n  { name: 'Upland' },\n  { name: 'Urbana' },\n  { name: 'Urbandale' },\n  { name: 'Utica' },\n  { name: 'Vacaville' },\n  { name: 'Valdosta' },\n  { name: 'Vallejo' },\n  { name: 'Valley Stream' },\n  { name: 'Vancouver' },\n  { name: 'Victoria' },\n  { name: 'Victorville' },\n  { name: 'Vineland' },\n  { name: 'Virginia Beach' },\n  { name: 'Visalia' },\n  { name: 'Vista' },\n  { name: 'Waco' },\n  { name: 'Walnut Creek' },\n  { name: 'Waltham' },\n  { name: 'Warner Robins' },\n  { name: 'Warren' },\n  { name: 'Warren' },\n  { name: 'Warwick' },\n  { name: 'Washington' },\n  { name: 'Waterbury' },\n  { name: 'Waterloo' },\n  { name: 'Watsonville' },\n  { name: 'Waukegan' },\n  { name: 'Waukesha' },\n  { name: 'Wausau' },\n  { name: 'Wauwatosa' },\n  { name: 'Wellington' },\n  { name: 'Weslaco' },\n  { name: 'West Allis' },\n  { name: 'West Covina' },\n  { name: 'West Des Moines' },\n  { name: 'West Haven' },\n  { name: 'West Jordan' },\n  { name: 'West New York' },\n  { name: 'West Palm Beach' },\n  { name: 'West Sacramento' },\n  { name: 'West Valley City' },\n  { name: 'Westerville' },\n  { name: 'Westfield' },\n  { name: 'Westland' },\n  { name: 'Westminster' },\n  { name: 'Westminster' },\n  { name: 'Weston' },\n  { name: 'Weymouth Town' },\n  { name: 'Wheaton' },\n  { name: 'Wheeling' },\n  { name: 'White Plains' },\n  { name: 'Whittier' },\n  { name: 'Wichita' },\n  { name: 'Wichita Falls' },\n  { name: 'Wilkes-Barre' },\n  { name: 'Wilmington' },\n  { name: 'Wilmington' },\n  { name: 'Wilson' },\n  { name: 'Winston-Salem' },\n  { name: 'Winter Garden' },\n  { name: 'Woburn' },\n  { name: 'Woodbury' },\n  { name: 'Woodland' },\n  { name: 'Woonsocket' },\n  { name: 'Worcester' },\n  { name: 'Wylie' },\n  { name: 'Wyoming' },\n  { name: 'Yakima' },\n  { name: 'Yonkers' },\n  { name: 'Yorba Linda' },\n  { name: 'York' },\n  { name: 'Youngstown' },\n  { name: 'Yuba City' },\n  { name: 'Yucaipa' },\n  { name: 'Yuma' }\n];\n","module.exports = [\n\t{ github: 'jedwatson', name: 'Jed Watson' },\n\t{ github: 'bruderstein', name: 'Dave Brotherstone' },\n\t{ github: 'jossmac', name: 'Joss Mackison' },\n\t{ github: 'jniechcial', name: 'Jakub Niechciał' },\n\t{ github: 'craigdallimore', name: 'Craig Dallimore' },\n\t{ github: 'julen', name: 'Julen Ruiz Aizpuru' },\n\t{ github: 'dcousens', name: 'Daniel Cousens' },\n\t{ github: 'jgautsch', name: 'Jon Gautsch' },\n\t{ github: 'dmitry-smirnov', name: 'Dmitry Smirnov' },\n];\n","exports.AU = [\n\t{ value: 'australian-capital-territory', label: 'Australian Capital Territory', className: 'State-ACT' },\n\t{ value: 'new-south-wales', label: 'New South Wales', className: 'State-NSW' },\n\t{ value: 'victoria', label: 'Victoria', className: 'State-Vic' },\n\t{ value: 'queensland', label: 'Queensland', className: 'State-Qld' },\n\t{ value: 'western-australia', label: 'Western Australia', className: 'State-WA' },\n\t{ value: 'south-australia', label: 'South Australia', className: 'State-SA' },\n\t{ value: 'tasmania', label: 'Tasmania', className: 'State-Tas' },\n\t{ value: 'northern-territory', label: 'Northern Territory', className: 'State-NT' },\n];\n\nexports.US = [\n    { value: 'AL', label: 'Alabama', disabled: true },\n    { value: 'AK', label: 'Alaska' },\n    { value: 'AS', label: 'American Samoa' },\n    { value: 'AZ', label: 'Arizona' },\n    { value: 'AR', label: 'Arkansas' },\n    { value: 'CA', label: 'California' },\n    { value: 'CO', label: 'Colorado' },\n    { value: 'CT', label: 'Connecticut' },\n    { value: 'DE', label: 'Delaware' },\n    { value: 'DC', label: 'District Of Columbia' },\n    { value: 'FM', label: 'Federated States Of Micronesia' },\n    { value: 'FL', label: 'Florida' },\n    { value: 'GA', label: 'Georgia' },\n    { value: 'GU', label: 'Guam' },\n    { value: 'HI', label: 'Hawaii' },\n    { value: 'ID', label: 'Idaho' },\n    { value: 'IL', label: 'Illinois' },\n    { value: 'IN', label: 'Indiana' },\n    { value: 'IA', label: 'Iowa' },\n    { value: 'KS', label: 'Kansas' },\n    { value: 'KY', label: 'Kentucky' },\n    { value: 'LA', label: 'Louisiana' },\n    { value: 'ME', label: 'Maine' },\n    { value: 'MH', label: 'Marshall Islands' },\n    { value: 'MD', label: 'Maryland' },\n    { value: 'MA', label: 'Massachusetts' },\n    { value: 'MI', label: 'Michigan' },\n    { value: 'MN', label: 'Minnesota' },\n    { value: 'MS', label: 'Mississippi' },\n    { value: 'MO', label: 'Missouri' },\n    { value: 'MT', label: 'Montana' },\n    { value: 'NE', label: 'Nebraska' },\n    { value: 'NV', label: 'Nevada' },\n    { value: 'NH', label: 'New Hampshire' },\n    { value: 'NJ', label: 'New Jersey' },\n    { value: 'NM', label: 'New Mexico' },\n    { value: 'NY', label: 'New York' },\n    { value: 'NC', label: 'North Carolina' },\n    { value: 'ND', label: 'North Dakota' },\n    { value: 'MP', label: 'Northern Mariana Islands' },\n    { value: 'OH', label: 'Ohio' },\n    { value: 'OK', label: 'Oklahoma' },\n    { value: 'OR', label: 'Oregon' },\n    { value: 'PW', label: 'Palau' },\n    { value: 'PA', label: 'Pennsylvania' },\n    { value: 'PR', label: 'Puerto Rico' },\n    { value: 'RI', label: 'Rhode Island' },\n    { value: 'SC', label: 'South Carolina' },\n    { value: 'SD', label: 'South Dakota' },\n    { value: 'TN', label: 'Tennessee' },\n    { value: 'TX', label: 'Texas' },\n    { value: 'UT', label: 'Utah' },\n    { value: 'VT', label: 'Vermont' },\n    { value: 'VI', label: 'Virgin Islands' },\n    { value: 'VA', label: 'Virginia' },\n    { value: 'WA', label: 'Washington' },\n    { value: 'WV', label: 'West Virginia' },\n    { value: 'WI', label: 'Wisconsin' },\n    { value: 'WY', label: 'Wyoming' },\n];\n","module.exports = [\n\t{ value: 'John Smith', label: 'John Smith', email: 'john@smith.com' },\n\t{ value: 'Merry Jane', label: 'Merry Jane', email: 'merry@jane.com' },\n\t{ value: 'Stan Hoper', label: 'Stan Hoper', email: 'stan@hoper.com' }\n];\n","var charenc = {\n  // UTF-8 encoding\n  utf8: {\n    // Convert a string to a byte array\n    stringToBytes: function(str) {\n      return charenc.bin.stringToBytes(unescape(encodeURIComponent(str)));\n    },\n\n    // Convert a byte array to a string\n    bytesToString: function(bytes) {\n      return decodeURIComponent(escape(charenc.bin.bytesToString(bytes)));\n    }\n  },\n\n  // Binary encoding\n  bin: {\n    // Convert a string to a byte array\n    stringToBytes: function(str) {\n      for (var bytes = [], i = 0; i < str.length; i++)\n        bytes.push(str.charCodeAt(i) & 0xFF);\n      return bytes;\n    },\n\n    // Convert a byte array to a string\n    bytesToString: function(bytes) {\n      for (var str = [], i = 0; i < bytes.length; i++)\n        str.push(String.fromCharCode(bytes[i]));\n      return str.join('');\n    }\n  }\n};\n\nmodule.exports = charenc;\n","(function() {\n  var base64map\n      = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/',\n\n  crypt = {\n    // Bit-wise rotation left\n    rotl: function(n, b) {\n      return (n << b) | (n >>> (32 - b));\n    },\n\n    // Bit-wise rotation right\n    rotr: function(n, b) {\n      return (n << (32 - b)) | (n >>> b);\n    },\n\n    // Swap big-endian to little-endian and vice versa\n    endian: function(n) {\n      // If number given, swap endian\n      if (n.constructor == Number) {\n        return crypt.rotl(n, 8) & 0x00FF00FF | crypt.rotl(n, 24) & 0xFF00FF00;\n      }\n\n      // Else, assume array and swap all items\n      for (var i = 0; i < n.length; i++)\n        n[i] = crypt.endian(n[i]);\n      return n;\n    },\n\n    // Generate an array of any length of random bytes\n    randomBytes: function(n) {\n      for (var bytes = []; n > 0; n--)\n        bytes.push(Math.floor(Math.random() * 256));\n      return bytes;\n    },\n\n    // Convert a byte array to big-endian 32-bit words\n    bytesToWords: function(bytes) {\n      for (var words = [], i = 0, b = 0; i < bytes.length; i++, b += 8)\n        words[b >>> 5] |= bytes[i] << (24 - b % 32);\n      return words;\n    },\n\n    // Convert big-endian 32-bit words to a byte array\n    wordsToBytes: function(words) {\n      for (var bytes = [], b = 0; b < words.length * 32; b += 8)\n        bytes.push((words[b >>> 5] >>> (24 - b % 32)) & 0xFF);\n      return bytes;\n    },\n\n    // Convert a byte array to a hex string\n    bytesToHex: function(bytes) {\n      for (var hex = [], i = 0; i < bytes.length; i++) {\n        hex.push((bytes[i] >>> 4).toString(16));\n        hex.push((bytes[i] & 0xF).toString(16));\n      }\n      return hex.join('');\n    },\n\n    // Convert a hex string to a byte array\n    hexToBytes: function(hex) {\n      for (var bytes = [], c = 0; c < hex.length; c += 2)\n        bytes.push(parseInt(hex.substr(c, 2), 16));\n      return bytes;\n    },\n\n    // Convert a byte array to a base-64 string\n    bytesToBase64: function(bytes) {\n      for (var base64 = [], i = 0; i < bytes.length; i += 3) {\n        var triplet = (bytes[i] << 16) | (bytes[i + 1] << 8) | bytes[i + 2];\n        for (var j = 0; j < 4; j++)\n          if (i * 8 + j * 6 <= bytes.length * 8)\n            base64.push(base64map.charAt((triplet >>> 6 * (3 - j)) & 0x3F));\n          else\n            base64.push('=');\n      }\n      return base64.join('');\n    },\n\n    // Convert a base-64 string to a byte array\n    base64ToBytes: function(base64) {\n      // Remove non-base-64 characters\n      base64 = base64.replace(/[^A-Z0-9+\\/]/ig, '');\n\n      for (var bytes = [], i = 0, imod4 = 0; i < base64.length;\n          imod4 = ++i % 4) {\n        if (imod4 == 0) continue;\n        bytes.push(((base64map.indexOf(base64.charAt(i - 1))\n            & (Math.pow(2, -2 * imod4 + 8) - 1)) << (imod4 * 2))\n            | (base64map.indexOf(base64.charAt(i)) >>> (6 - imod4 * 2)));\n      }\n      return bytes;\n    }\n  };\n\n  module.exports = crypt;\n})();\n","'use strict';\nmodule.exports = !!(typeof window !== 'undefined' && window.document && window.document.createElement);","'use strict';\n\nvar canUseDOM = require('./inDOM');\n\nvar size;\n\nmodule.exports = function (recalc) {\n  if (!size || recalc) {\n    if (canUseDOM) {\n      var scrollDiv = document.createElement('div');\n\n      scrollDiv.style.position = 'absolute';\n      scrollDiv.style.top = '-9999px';\n      scrollDiv.style.width = '50px';\n      scrollDiv.style.height = '50px';\n      scrollDiv.style.overflow = 'scroll';\n\n      document.body.appendChild(scrollDiv);\n      size = scrollDiv.offsetWidth - scrollDiv.clientWidth;\n      document.body.removeChild(scrollDiv);\n    }\n  }\n\n  return size;\n};","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n *\n * @typechecks\n * \n */\n\n/*eslint-disable no-self-compare */\n\n'use strict';\n\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\n/**\n * inlined Object.is polyfill to avoid requiring consumers ship their own\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\n */\nfunction is(x, y) {\n  // SameValue algorithm\n  if (x === y) {\n    // Steps 1-5, 7-10\n    // Steps 6.b-6.e: +0 != -0\n    // Added the nonzero y check to make Flow happy, but it is redundant\n    return x !== 0 || y !== 0 || 1 / x === 1 / y;\n  } else {\n    // Step 6.a: NaN == NaN\n    return x !== x && y !== y;\n  }\n}\n\n/**\n * Performs equality by iterating through keys on an object and returning false\n * when any key has values which are not strictly equal between the arguments.\n * Returns true when the values of all keys are strictly equal.\n */\nfunction shallowEqual(objA, objB) {\n  if (is(objA, objB)) {\n    return true;\n  }\n\n  if (typeof objA !== 'object' || objA === null || typeof objB !== 'object' || objB === null) {\n    return false;\n  }\n\n  var keysA = Object.keys(objA);\n  var keysB = Object.keys(objB);\n\n  if (keysA.length !== keysB.length) {\n    return false;\n  }\n\n  // Test for A's keys different from B.\n  for (var i = 0; i < keysA.length; i++) {\n    if (!hasOwnProperty.call(objB, keysA[i]) || !is(objA[keysA[i]], objB[keysA[i]])) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nmodule.exports = shallowEqual;","/*!\n * Determine if an object is a Buffer\n *\n * @author   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license  MIT\n */\n\n// The _isBuffer check is for Safari 5-7 support, because it's missing\n// Object.prototype.constructor. Remove this eventually\nmodule.exports = function (obj) {\n  return obj != null && (isBuffer(obj) || isSlowBuffer(obj) || !!obj._isBuffer)\n}\n\nfunction isBuffer (obj) {\n  return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj)\n}\n\n// For Node v0.10 support. Remove this eventually.\nfunction isSlowBuffer (obj) {\n  return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isBuffer(obj.slice(0, 0))\n}\n","module.exports = function() {\n  var mediaQuery;\n  if (typeof window !== \"undefined\" && window !== null) {\n    mediaQuery = \"(-webkit-min-device-pixel-ratio: 1.25), (min--moz-device-pixel-ratio: 1.25), (-o-min-device-pixel-ratio: 5/4), (min-resolution: 1.25dppx)\";\n    if (window.devicePixelRatio > 1.25) {\n      return true;\n    }\n    if (window.matchMedia && window.matchMedia(mediaQuery).matches) {\n      return true;\n    }\n  }\n  return false;\n};\n","// the whatwg-fetch polyfill installs the fetch() function\n// on the global object (window or self)\n//\n// Return that as the export for use in Webpack, Browserify etc.\nrequire('whatwg-fetch');\nmodule.exports = self.fetch.bind(self);\n","(function(){\r\n  var crypt = require('crypt'),\r\n      utf8 = require('charenc').utf8,\r\n      isBuffer = require('is-buffer'),\r\n      bin = require('charenc').bin,\r\n\r\n  // The core\r\n  md5 = function (message, options) {\r\n    // Convert to byte array\r\n    if (message.constructor == String)\r\n      if (options && options.encoding === 'binary')\r\n        message = bin.stringToBytes(message);\r\n      else\r\n        message = utf8.stringToBytes(message);\r\n    else if (isBuffer(message))\r\n      message = Array.prototype.slice.call(message, 0);\r\n    else if (!Array.isArray(message))\r\n      message = message.toString();\r\n    // else, assume byte array already\r\n\r\n    var m = crypt.bytesToWords(message),\r\n        l = message.length * 8,\r\n        a =  1732584193,\r\n        b = -271733879,\r\n        c = -1732584194,\r\n        d =  271733878;\r\n\r\n    // Swap endian\r\n    for (var i = 0; i < m.length; i++) {\r\n      m[i] = ((m[i] <<  8) | (m[i] >>> 24)) & 0x00FF00FF |\r\n             ((m[i] << 24) | (m[i] >>>  8)) & 0xFF00FF00;\r\n    }\r\n\r\n    // Padding\r\n    m[l >>> 5] |= 0x80 << (l % 32);\r\n    m[(((l + 64) >>> 9) << 4) + 14] = l;\r\n\r\n    // Method shortcuts\r\n    var FF = md5._ff,\r\n        GG = md5._gg,\r\n        HH = md5._hh,\r\n        II = md5._ii;\r\n\r\n    for (var i = 0; i < m.length; i += 16) {\r\n\r\n      var aa = a,\r\n          bb = b,\r\n          cc = c,\r\n          dd = d;\r\n\r\n      a = FF(a, b, c, d, m[i+ 0],  7, -680876936);\r\n      d = FF(d, a, b, c, m[i+ 1], 12, -389564586);\r\n      c = FF(c, d, a, b, m[i+ 2], 17,  606105819);\r\n      b = FF(b, c, d, a, m[i+ 3], 22, -1044525330);\r\n      a = FF(a, b, c, d, m[i+ 4],  7, -176418897);\r\n      d = FF(d, a, b, c, m[i+ 5], 12,  1200080426);\r\n      c = FF(c, d, a, b, m[i+ 6], 17, -1473231341);\r\n      b = FF(b, c, d, a, m[i+ 7], 22, -45705983);\r\n      a = FF(a, b, c, d, m[i+ 8],  7,  1770035416);\r\n      d = FF(d, a, b, c, m[i+ 9], 12, -1958414417);\r\n      c = FF(c, d, a, b, m[i+10], 17, -42063);\r\n      b = FF(b, c, d, a, m[i+11], 22, -1990404162);\r\n      a = FF(a, b, c, d, m[i+12],  7,  1804603682);\r\n      d = FF(d, a, b, c, m[i+13], 12, -40341101);\r\n      c = FF(c, d, a, b, m[i+14], 17, -1502002290);\r\n      b = FF(b, c, d, a, m[i+15], 22,  1236535329);\r\n\r\n      a = GG(a, b, c, d, m[i+ 1],  5, -165796510);\r\n      d = GG(d, a, b, c, m[i+ 6],  9, -1069501632);\r\n      c = GG(c, d, a, b, m[i+11], 14,  643717713);\r\n      b = GG(b, c, d, a, m[i+ 0], 20, -373897302);\r\n      a = GG(a, b, c, d, m[i+ 5],  5, -701558691);\r\n      d = GG(d, a, b, c, m[i+10],  9,  38016083);\r\n      c = GG(c, d, a, b, m[i+15], 14, -660478335);\r\n      b = GG(b, c, d, a, m[i+ 4], 20, -405537848);\r\n      a = GG(a, b, c, d, m[i+ 9],  5,  568446438);\r\n      d = GG(d, a, b, c, m[i+14],  9, -1019803690);\r\n      c = GG(c, d, a, b, m[i+ 3], 14, -187363961);\r\n      b = GG(b, c, d, a, m[i+ 8], 20,  1163531501);\r\n      a = GG(a, b, c, d, m[i+13],  5, -1444681467);\r\n      d = GG(d, a, b, c, m[i+ 2],  9, -51403784);\r\n      c = GG(c, d, a, b, m[i+ 7], 14,  1735328473);\r\n      b = GG(b, c, d, a, m[i+12], 20, -1926607734);\r\n\r\n      a = HH(a, b, c, d, m[i+ 5],  4, -378558);\r\n      d = HH(d, a, b, c, m[i+ 8], 11, -2022574463);\r\n      c = HH(c, d, a, b, m[i+11], 16,  1839030562);\r\n      b = HH(b, c, d, a, m[i+14], 23, -35309556);\r\n      a = HH(a, b, c, d, m[i+ 1],  4, -1530992060);\r\n      d = HH(d, a, b, c, m[i+ 4], 11,  1272893353);\r\n      c = HH(c, d, a, b, m[i+ 7], 16, -155497632);\r\n      b = HH(b, c, d, a, m[i+10], 23, -1094730640);\r\n      a = HH(a, b, c, d, m[i+13],  4,  681279174);\r\n      d = HH(d, a, b, c, m[i+ 0], 11, -358537222);\r\n      c = HH(c, d, a, b, m[i+ 3], 16, -722521979);\r\n      b = HH(b, c, d, a, m[i+ 6], 23,  76029189);\r\n      a = HH(a, b, c, d, m[i+ 9],  4, -640364487);\r\n      d = HH(d, a, b, c, m[i+12], 11, -421815835);\r\n      c = HH(c, d, a, b, m[i+15], 16,  530742520);\r\n      b = HH(b, c, d, a, m[i+ 2], 23, -995338651);\r\n\r\n      a = II(a, b, c, d, m[i+ 0],  6, -198630844);\r\n      d = II(d, a, b, c, m[i+ 7], 10,  1126891415);\r\n      c = II(c, d, a, b, m[i+14], 15, -1416354905);\r\n      b = II(b, c, d, a, m[i+ 5], 21, -57434055);\r\n      a = II(a, b, c, d, m[i+12],  6,  1700485571);\r\n      d = II(d, a, b, c, m[i+ 3], 10, -1894986606);\r\n      c = II(c, d, a, b, m[i+10], 15, -1051523);\r\n      b = II(b, c, d, a, m[i+ 1], 21, -2054922799);\r\n      a = II(a, b, c, d, m[i+ 8],  6,  1873313359);\r\n      d = II(d, a, b, c, m[i+15], 10, -30611744);\r\n      c = II(c, d, a, b, m[i+ 6], 15, -1560198380);\r\n      b = II(b, c, d, a, m[i+13], 21,  1309151649);\r\n      a = II(a, b, c, d, m[i+ 4],  6, -145523070);\r\n      d = II(d, a, b, c, m[i+11], 10, -1120210379);\r\n      c = II(c, d, a, b, m[i+ 2], 15,  718787259);\r\n      b = II(b, c, d, a, m[i+ 9], 21, -343485551);\r\n\r\n      a = (a + aa) >>> 0;\r\n      b = (b + bb) >>> 0;\r\n      c = (c + cc) >>> 0;\r\n      d = (d + dd) >>> 0;\r\n    }\r\n\r\n    return crypt.endian([a, b, c, d]);\r\n  };\r\n\r\n  // Auxiliary functions\r\n  md5._ff  = function (a, b, c, d, x, s, t) {\r\n    var n = a + (b & c | ~b & d) + (x >>> 0) + t;\r\n    return ((n << s) | (n >>> (32 - s))) + b;\r\n  };\r\n  md5._gg  = function (a, b, c, d, x, s, t) {\r\n    var n = a + (b & d | c & ~d) + (x >>> 0) + t;\r\n    return ((n << s) | (n >>> (32 - s))) + b;\r\n  };\r\n  md5._hh  = function (a, b, c, d, x, s, t) {\r\n    var n = a + (b ^ c ^ d) + (x >>> 0) + t;\r\n    return ((n << s) | (n >>> (32 - s))) + b;\r\n  };\r\n  md5._ii  = function (a, b, c, d, x, s, t) {\r\n    var n = a + (c ^ (b | ~d)) + (x >>> 0) + t;\r\n    return ((n << s) | (n >>> (32 - s))) + b;\r\n  };\r\n\r\n  // Package private blocksize\r\n  md5._blocksize = 16;\r\n  md5._digestsize = 16;\r\n\r\n  module.exports = function (message, options) {\r\n    if (message === undefined || message === null)\r\n      throw new Error('Illegal argument ' + message);\r\n\r\n    var digestbytes = crypt.wordsToBytes(md5(message, options));\r\n    return options && options.asBytes ? digestbytes :\r\n        options && options.asString ? bin.bytesToString(digestbytes) :\r\n        crypt.bytesToHex(digestbytes);\r\n  };\r\n\r\n})();\r\n","'use strict';\n/* eslint-disable no-unused-vars */\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc');  // eslint-disable-line\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (e) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (Object.getOwnPropertySymbols) {\n\t\t\tsymbols = Object.getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","// Generated by CoffeeScript 1.7.1\n(function() {\n  var getNanoSeconds, hrtime, loadTime;\n\n  if ((typeof performance !== \"undefined\" && performance !== null) && performance.now) {\n    module.exports = function() {\n      return performance.now();\n    };\n  } else if ((typeof process !== \"undefined\" && process !== null) && process.hrtime) {\n    module.exports = function() {\n      return (getNanoSeconds() - loadTime) / 1e6;\n    };\n    hrtime = process.hrtime;\n    getNanoSeconds = function() {\n      var hr;\n      hr = hrtime();\n      return hr[0] * 1e9 + hr[1];\n    };\n    loadTime = getNanoSeconds();\n  } else if (Date.now) {\n    module.exports = function() {\n      return Date.now() - loadTime;\n    };\n    loadTime = Date.now();\n  } else {\n    module.exports = function() {\n      return new Date().getTime() - loadTime;\n    };\n    loadTime = new Date().getTime();\n  }\n\n}).call(this);\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things.  But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals.  It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n    throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n    throw new Error('clearTimeout has not been defined');\n}\n(function () {\n    try {\n        if (typeof setTimeout === 'function') {\n            cachedSetTimeout = setTimeout;\n        } else {\n            cachedSetTimeout = defaultSetTimout;\n        }\n    } catch (e) {\n        cachedSetTimeout = defaultSetTimout;\n    }\n    try {\n        if (typeof clearTimeout === 'function') {\n            cachedClearTimeout = clearTimeout;\n        } else {\n            cachedClearTimeout = defaultClearTimeout;\n        }\n    } catch (e) {\n        cachedClearTimeout = defaultClearTimeout;\n    }\n} ())\nfunction runTimeout(fun) {\n    if (cachedSetTimeout === setTimeout) {\n        //normal enviroments in sane situations\n        return setTimeout(fun, 0);\n    }\n    // if setTimeout wasn't available but was latter defined\n    if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n        cachedSetTimeout = setTimeout;\n        return setTimeout(fun, 0);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedSetTimeout(fun, 0);\n    } catch(e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n            return cachedSetTimeout.call(null, fun, 0);\n        } catch(e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n            return cachedSetTimeout.call(this, fun, 0);\n        }\n    }\n\n\n}\nfunction runClearTimeout(marker) {\n    if (cachedClearTimeout === clearTimeout) {\n        //normal enviroments in sane situations\n        return clearTimeout(marker);\n    }\n    // if clearTimeout wasn't available but was latter defined\n    if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n        cachedClearTimeout = clearTimeout;\n        return clearTimeout(marker);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedClearTimeout(marker);\n    } catch (e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't  trust the global object when called normally\n            return cachedClearTimeout.call(null, marker);\n        } catch (e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n            // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n            return cachedClearTimeout.call(this, marker);\n        }\n    }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = runTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        runTimeout(drainQueue);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","'use strict';\nvar strictUriEncode = require('strict-uri-encode');\nvar objectAssign = require('object-assign');\n\nfunction encode(value, opts) {\n\tif (opts.encode) {\n\t\treturn opts.strict ? strictUriEncode(value) : encodeURIComponent(value);\n\t}\n\n\treturn value;\n}\n\nexports.extract = function (str) {\n\treturn str.split('?')[1] || '';\n};\n\nexports.parse = function (str) {\n\t// Create an object with no prototype\n\t// https://github.com/sindresorhus/query-string/issues/47\n\tvar ret = Object.create(null);\n\n\tif (typeof str !== 'string') {\n\t\treturn ret;\n\t}\n\n\tstr = str.trim().replace(/^(\\?|#|&)/, '');\n\n\tif (!str) {\n\t\treturn ret;\n\t}\n\n\tstr.split('&').forEach(function (param) {\n\t\tvar parts = param.replace(/\\+/g, ' ').split('=');\n\t\t// Firefox (pre 40) decodes `%3D` to `=`\n\t\t// https://github.com/sindresorhus/query-string/pull/37\n\t\tvar key = parts.shift();\n\t\tvar val = parts.length > 0 ? parts.join('=') : undefined;\n\n\t\tkey = decodeURIComponent(key);\n\n\t\t// missing `=` should be `null`:\n\t\t// http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n\t\tval = val === undefined ? null : decodeURIComponent(val);\n\n\t\tif (ret[key] === undefined) {\n\t\t\tret[key] = val;\n\t\t} else if (Array.isArray(ret[key])) {\n\t\t\tret[key].push(val);\n\t\t} else {\n\t\t\tret[key] = [ret[key], val];\n\t\t}\n\t});\n\n\treturn ret;\n};\n\nexports.stringify = function (obj, opts) {\n\tvar defaults = {\n\t\tencode: true,\n\t\tstrict: true\n\t};\n\n\topts = objectAssign(defaults, opts);\n\n\treturn obj ? Object.keys(obj).sort().map(function (key) {\n\t\tvar val = obj[key];\n\n\t\tif (val === undefined) {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (val === null) {\n\t\t\treturn encode(key, opts);\n\t\t}\n\n\t\tif (Array.isArray(val)) {\n\t\t\tvar result = [];\n\n\t\t\tval.slice().forEach(function (val2) {\n\t\t\t\tif (val2 === undefined) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (val2 === null) {\n\t\t\t\t\tresult.push(encode(key, opts));\n\t\t\t\t} else {\n\t\t\t\t\tresult.push(encode(key, opts) + '=' + encode(val2, opts));\n\t\t\t\t}\n\t\t\t});\n\n\t\t\treturn result.join('&');\n\t\t}\n\n\t\treturn encode(key, opts) + '=' + encode(val, opts);\n\t}).filter(function (x) {\n\t\treturn x.length > 0;\n\t}).join('&') : '';\n};\n","var now = require('performance-now')\n  , root = typeof window === 'undefined' ? global : window\n  , vendors = ['moz', 'webkit']\n  , suffix = 'AnimationFrame'\n  , raf = root['request' + suffix]\n  , caf = root['cancel' + suffix] || root['cancelRequest' + suffix]\n\nfor(var i = 0; !raf && i < vendors.length; i++) {\n  raf = root[vendors[i] + 'Request' + suffix]\n  caf = root[vendors[i] + 'Cancel' + suffix]\n      || root[vendors[i] + 'CancelRequest' + suffix]\n}\n\n// Some versions of FF have rAF but not cAF\nif(!raf || !caf) {\n  var last = 0\n    , id = 0\n    , queue = []\n    , frameDuration = 1000 / 60\n\n  raf = function(callback) {\n    if(queue.length === 0) {\n      var _now = now()\n        , next = Math.max(0, frameDuration - (_now - last))\n      last = next + _now\n      setTimeout(function() {\n        var cp = queue.slice(0)\n        // Clear queue here to prevent\n        // callbacks from appending listeners\n        // to the current frame's queue\n        queue.length = 0\n        for(var i = 0; i < cp.length; i++) {\n          if(!cp[i].cancelled) {\n            try{\n              cp[i].callback(last)\n            } catch(e) {\n              setTimeout(function() { throw e }, 0)\n            }\n          }\n        }\n      }, Math.round(next))\n    }\n    queue.push({\n      handle: ++id,\n      callback: callback,\n      cancelled: false\n    })\n    return id\n  }\n\n  caf = function(handle) {\n    for(var i = 0; i < queue.length; i++) {\n      if(queue[i].handle === handle) {\n        queue[i].cancelled = true\n      }\n    }\n  }\n}\n\nmodule.exports = function(fn) {\n  // Wrap in a new function to prevent\n  // `cancel` potentially being assigned\n  // to the native rAF function\n  return raf.call(root, fn)\n}\nmodule.exports.cancel = function() {\n  caf.apply(root, arguments)\n}\nmodule.exports.polyfill = function() {\n  root.requestAnimationFrame = raf\n  root.cancelAnimationFrame = caf\n}\n","module.exports = require('react/lib/shallowCompare');","'use strict';\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _md = require('md5');\n\nvar _md2 = _interopRequireDefault(_md);\n\nvar _queryString = require('query-string');\n\nvar _queryString2 = _interopRequireDefault(_queryString);\n\nvar _isRetina = require('is-retina');\n\nvar _isRetina2 = _interopRequireDefault(_isRetina);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Gravatar = function (_React$Component) {\n  _inherits(Gravatar, _React$Component);\n\n  function Gravatar() {\n    _classCallCheck(this, Gravatar);\n\n    return _possibleConstructorReturn(this, Object.getPrototypeOf(Gravatar).apply(this, arguments));\n  }\n\n  _createClass(Gravatar, [{\n    key: 'render',\n    value: function render() {\n      var base = '//www.gravatar.com/avatar/';\n\n      var query = _queryString2.default.stringify({\n        s: this.props.size,\n        r: this.props.rating,\n        d: this.props.default\n      });\n\n      var retinaQuery = _queryString2.default.stringify({\n        s: this.props.size * 2,\n        r: this.props.rating,\n        d: this.props.default\n      });\n\n      // Gravatar service currently trims and lowercases all registered emails\n      var formattedEmail = ('' + this.props.email).trim().toLowerCase();\n\n      var hash = void 0;\n      if (this.props.md5) {\n        hash = this.props.md5;\n      } else if (typeof this.props.email === 'string') {\n        hash = (0, _md2.default)(formattedEmail);\n      } else {\n        console.warn('Gravatar image can not be fetched. Either the \"email\" or \"md5\" prop must be specified.');\n        return _react2.default.createElement('script', null);\n      }\n\n      var src = '' + base + hash + '?' + query;\n      var retinaSrc = '' + base + hash + '?' + retinaQuery;\n\n      var modernBrowser = true; // server-side, we render for modern browsers\n\n      if (typeof window !== 'undefined') {\n        // this is not NodeJS\n        modernBrowser = 'srcset' in document.createElement('img');\n      }\n\n      var className = 'react-gravatar';\n      if (this.props.className) {\n        className = className + ' ' + this.props.className;\n      }\n\n      // Clone this.props and then delete Component specific props so we can\n      // spread the rest into the img.\n\n      var rest = _objectWithoutProperties(this.props, []);\n\n      delete rest.md5;\n      delete rest.email;\n      delete rest.rating;\n      delete rest.size;\n      delete rest.style;\n      delete rest.className;\n      delete rest.default;\n      if (!modernBrowser && (0, _isRetina2.default)()) {\n        return _react2.default.createElement('img', _extends({\n          alt: 'Gravatar for ' + formattedEmail,\n          style: this.props.style,\n          src: retinaSrc,\n          height: this.props.size,\n          width: this.props.size\n        }, rest, {\n          className: className\n        }));\n      }\n      return _react2.default.createElement('img', _extends({\n        alt: 'Gravatar for ' + formattedEmail,\n        style: this.props.style,\n        src: src,\n        srcSet: retinaSrc + ' 2x',\n        height: this.props.size,\n        width: this.props.size\n      }, rest, {\n        className: className\n      }));\n    }\n  }]);\n\n  return Gravatar;\n}(_react2.default.Component);\n\nGravatar.displayName = 'Gravatar';\nGravatar.propTypes = {\n  email: _react2.default.PropTypes.string,\n  md5: _react2.default.PropTypes.string,\n  size: _react2.default.PropTypes.number,\n  rating: _react2.default.PropTypes.string,\n  default: _react2.default.PropTypes.string,\n  className: _react2.default.PropTypes.string,\n  style: _react2.default.PropTypes.object\n};\nGravatar.defaultProps = {\n  size: 50,\n  rating: 'g',\n  default: 'retro'\n};\n\n\nmodule.exports = Gravatar;","module.exports =\n/******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId])\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\texports: {},\n/******/ \t\t\tid: moduleId,\n/******/ \t\t\tloaded: false\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.loaded = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(0);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = __webpack_require__(1);\n\n\n/***/ },\n/* 1 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, '__esModule', {\n\t  value: true\n\t});\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\t\n\tvar _Highlighter = __webpack_require__(2);\n\t\n\tvar _Highlighter2 = _interopRequireDefault(_Highlighter);\n\t\n\tvar _utils = __webpack_require__(4);\n\t\n\texports['default'] = _Highlighter2['default'];\n\texports.combineChunks = _utils.combineChunks;\n\texports.fillInChunks = _utils.fillInChunks;\n\texports.findAll = _utils.findAll;\n\texports.findChunks = _utils.findChunks;\n\n/***/ },\n/* 2 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, '__esModule', {\n\t  value: true\n\t});\n\texports['default'] = Highlighter;\n\t\n\tfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj['default'] = obj; return newObj; } }\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\t\n\tvar _react = __webpack_require__(3);\n\t\n\tvar _react2 = _interopRequireDefault(_react);\n\t\n\tvar _utilsJs = __webpack_require__(4);\n\t\n\tvar Chunks = _interopRequireWildcard(_utilsJs);\n\t\n\tHighlighter.propTypes = {\n\t  highlightClassName: _react.PropTypes.string,\n\t  highlightStyle: _react.PropTypes.object,\n\t  searchWords: _react.PropTypes.arrayOf(_react.PropTypes.string).isRequired,\n\t  textToHighlight: _react.PropTypes.string.isRequired,\n\t  sanitize: _react.PropTypes.func\n\t};\n\t\n\t/**\n\t * Highlights all occurrences of search terms (searchText) within a string (textToHighlight).\n\t * This function returns an array of strings and <span>s (wrapping highlighted words).\n\t */\n\t\n\tfunction Highlighter(_ref) {\n\t  var _ref$highlightClassName = _ref.highlightClassName;\n\t  var highlightClassName = _ref$highlightClassName === undefined ? '' : _ref$highlightClassName;\n\t  var _ref$highlightStyle = _ref.highlightStyle;\n\t  var highlightStyle = _ref$highlightStyle === undefined ? {} : _ref$highlightStyle;\n\t  var searchWords = _ref.searchWords;\n\t  var textToHighlight = _ref.textToHighlight;\n\t  var sanitize = _ref.sanitize;\n\t\n\t  var chunks = Chunks.findAll(textToHighlight, searchWords, sanitize);\n\t\n\t  return _react2['default'].createElement(\n\t    'span',\n\t    null,\n\t    chunks.map(function (chunk, index) {\n\t      var text = textToHighlight.substr(chunk.start, chunk.end - chunk.start);\n\t\n\t      if (chunk.highlight) {\n\t        return _react2['default'].createElement(\n\t          'mark',\n\t          {\n\t            className: highlightClassName,\n\t            key: index,\n\t            style: highlightStyle\n\t          },\n\t          text\n\t        );\n\t      } else {\n\t        return _react2['default'].createElement(\n\t          'span',\n\t          { key: index },\n\t          text\n\t        );\n\t      }\n\t    })\n\t  );\n\t}\n\t\n\tmodule.exports = exports['default'];\n\n/***/ },\n/* 3 */\n/***/ function(module, exports) {\n\n\tmodule.exports = require(\"react\");\n\n/***/ },\n/* 4 */\n/***/ function(module, exports) {\n\n\t/**\n\t * Creates an array of chunk objects representing both higlightable and non highlightable pieces of text that match each search word.\n\t * @param searchWords string[]\n\t * @param textToSearch string\n\t * @return {start:number, end:number, highlight:boolean}[]\n\t */\n\t'use strict';\n\t\n\tObject.defineProperty(exports, '__esModule', {\n\t  value: true\n\t});\n\tvar findAll = function findAll(textToSearch, wordsToFind, sanitize) {\n\t  return fillInChunks(combineChunks(findChunks(textToSearch, wordsToFind, sanitize)), textToSearch.length);\n\t};\n\t\n\texports.findAll = findAll;\n\t/**\n\t * Takes an array of {start:number, end:number} objects and combines chunks that overlap into single chunks.\n\t * @param chunks {start:number, end:number}[]\n\t * @return {start:number, end:number}[]\n\t */\n\tvar combineChunks = function combineChunks(chunks) {\n\t  chunks = chunks.sort(function (first, second) {\n\t    return first.start - second.start;\n\t  }).reduce(function (processedChunks, nextChunk) {\n\t    // First chunk just goes straight in the array...\n\t    if (processedChunks.length === 0) {\n\t      return [nextChunk];\n\t    } else {\n\t      // ... subsequent chunks get checked to see if they overlap...\n\t      var prevChunk = processedChunks.pop();\n\t      if (nextChunk.start <= prevChunk.end) {\n\t        // It may be the case that prevChunk completely surrounds nextChunk, so take the\n\t        // largest of the end indeces.\n\t        var endIndex = Math.max(prevChunk.end, nextChunk.end);\n\t        processedChunks.push({ start: prevChunk.start, end: endIndex });\n\t      } else {\n\t        processedChunks.push(prevChunk, nextChunk);\n\t      }\n\t      return processedChunks;\n\t    }\n\t  }, []);\n\t\n\t  return chunks;\n\t};\n\t\n\texports.combineChunks = combineChunks;\n\t/**\n\t * Examine textToSearch for any matches.\n\t * If we find matches, add them to the returned array as a \"chunk\" object ({start:number, end:number}).\n\t * @param textToSearch string\n\t * @param wordsToFind string[]\n\t * @param sanitize Process and optionally modify textToSearch and wordsToFind before comparison; this can be used to eg. remove accents\n\t * @return {start:number, end:number}[]\n\t */\n\tvar findChunks = function findChunks(textToSearch, wordsToFind) {\n\t  var sanitize = arguments.length <= 2 || arguments[2] === undefined ? identity : arguments[2];\n\t  return wordsToFind.filter(function (searchWord) {\n\t    return searchWord;\n\t  }) // Remove empty words\n\t  .reduce(function (chunks, searchWord) {\n\t    var normalizedWord = sanitize(searchWord);\n\t    var normalizedText = sanitize(textToSearch);\n\t    var regex = new RegExp(normalizedWord, 'gi');\n\t    var match = undefined;\n\t    while ((match = regex.exec(normalizedText)) != null) {\n\t      chunks.push({ start: match.index, end: regex.lastIndex });\n\t    }\n\t    return chunks;\n\t  }, []);\n\t};\n\t\n\texports.findChunks = findChunks;\n\t/**\n\t * Given a set of chunks to highlight, create an additional set of chunks\n\t * to represent the bits of text between the highlighted text.\n\t * @param chunksToHighlight {start:number, end:number}[]\n\t * @param totalLength number\n\t * @return {start:number, end:number, highlight:boolean}[]\n\t */\n\tvar fillInChunks = function fillInChunks(chunksToHighlight, totalLength) {\n\t  var allChunks = [];\n\t  var append = function append(start, end, highlight) {\n\t    if (end - start > 0) {\n\t      allChunks.push({ start: start, end: end, highlight: highlight });\n\t    }\n\t  };\n\t\n\t  if (chunksToHighlight.length === 0) {\n\t    append(0, totalLength, false);\n\t  } else {\n\t    (function () {\n\t      var lastIndex = 0;\n\t      chunksToHighlight.forEach(function (chunk) {\n\t        append(lastIndex, chunk.start, false);\n\t        append(chunk.start, chunk.end, true);\n\t        lastIndex = chunk.end;\n\t      });\n\t      append(lastIndex, totalLength, false);\n\t    })();\n\t  }\n\t  return allChunks;\n\t};\n\t\n\texports.fillInChunks = fillInChunks;\n\tfunction identity(value) {\n\t  return value;\n\t}\n\n/***/ }\n/******/ ]);\n//# sourceMappingURL=main.js.map","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactSelect = require('react-select');\n\nvar _reactSelect2 = _interopRequireDefault(_reactSelect);\n\nvar _reactVirtualized = require('react-virtualized');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar VirtualizedSelect = function (_Component) {\n  _inherits(VirtualizedSelect, _Component);\n\n  function VirtualizedSelect(props, context) {\n    _classCallCheck(this, VirtualizedSelect);\n\n    var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(VirtualizedSelect).call(this, props, context));\n\n    _this._renderMenu = _this._renderMenu.bind(_this);\n    _this._optionRenderer = _this._optionRenderer.bind(_this);\n    return _this;\n  }\n\n  /** See VirtualScroll#recomputeRowHeights */\n\n\n  _createClass(VirtualizedSelect, [{\n    key: 'recomputeOptionHeights',\n    value: function recomputeOptionHeights() {\n      var index = arguments.length <= 0 || arguments[0] === undefined ? 0 : arguments[0];\n\n      if (this._virtualScroll) {\n        this._virtualScroll.recomputeRowHeights(index);\n      }\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var SelectComponent = this._getSelectComponent();\n\n      return _react2.default.createElement(SelectComponent, _extends({}, this.props, {\n        menuRenderer: this._renderMenu,\n        menuStyle: { overflow: 'hidden' }\n      }));\n    }\n\n    // See https://github.com/JedWatson/react-select/#effeciently-rendering-large-lists-with-windowing\n\n  }, {\n    key: '_renderMenu',\n    value: function _renderMenu(_ref) {\n      var _this2 = this;\n\n      var focusedOption = _ref.focusedOption;\n      var focusOption = _ref.focusOption;\n      var labelKey = _ref.labelKey;\n      var options = _ref.options;\n      var selectValue = _ref.selectValue;\n      var valueArray = _ref.valueArray;\n      var optionRenderer = this.props.optionRenderer;\n\n      var focusedOptionIndex = options.indexOf(focusedOption);\n      var height = this._calculateVirtualScrollHeight({ options: options });\n      var innerRowRenderer = optionRenderer || this._optionRenderer;\n\n      function wrappedRowRenderer(_ref2) {\n        var index = _ref2.index;\n\n        var option = options[index];\n\n        return innerRowRenderer({\n          focusedOption: focusedOption,\n          focusedOptionIndex: focusedOptionIndex,\n          focusOption: focusOption,\n          labelKey: labelKey,\n          option: option,\n          optionIndex: index,\n          options: options,\n          selectValue: selectValue,\n          valueArray: valueArray\n        });\n      }\n\n      return _react2.default.createElement(\n        _reactVirtualized.AutoSizer,\n        { disableHeight: true },\n        function (_ref3) {\n          var width = _ref3.width;\n          return _react2.default.createElement(_reactVirtualized.VirtualScroll, {\n            className: 'VirtualSelectGrid',\n            height: height,\n            ref: function ref(_ref5) {\n              return _this2._virtualScroll = _ref5;\n            },\n            rowCount: options.length,\n            rowHeight: function rowHeight(_ref4) {\n              var index = _ref4.index;\n              return _this2._getOptionHeight({\n                option: options[index]\n              });\n            },\n            rowRenderer: wrappedRowRenderer,\n            scrollToIndex: focusedOptionIndex,\n            width: width\n          });\n        }\n      );\n    }\n  }, {\n    key: '_calculateVirtualScrollHeight',\n    value: function _calculateVirtualScrollHeight(_ref6) {\n      var options = _ref6.options;\n      var maxHeight = this.props.maxHeight;\n\n\n      var height = 0;\n\n      for (var optionIndex = 0; optionIndex < options.length; optionIndex++) {\n        var option = options[optionIndex];\n\n        height += this._getOptionHeight({ option: option });\n\n        if (height > maxHeight) {\n          return maxHeight;\n        }\n      }\n\n      return height;\n    }\n  }, {\n    key: '_getOptionHeight',\n    value: function _getOptionHeight(_ref7) {\n      var option = _ref7.option;\n      var optionHeight = this.props.optionHeight;\n\n\n      return optionHeight instanceof Function ? optionHeight({ option: option }) : optionHeight;\n    }\n  }, {\n    key: '_getSelectComponent',\n    value: function _getSelectComponent() {\n      var _props = this.props;\n      var async = _props.async;\n      var selectComponent = _props.selectComponent;\n\n\n      if (selectComponent) {\n        return selectComponent;\n      } else if (async) {\n        return _reactSelect2.default.Async;\n      } else {\n        return _reactSelect2.default;\n      }\n    }\n  }, {\n    key: '_optionRenderer',\n    value: function _optionRenderer(_ref8) {\n      var focusedOption = _ref8.focusedOption;\n      var focusOption = _ref8.focusOption;\n      var labelKey = _ref8.labelKey;\n      var option = _ref8.option;\n      var selectValue = _ref8.selectValue;\n\n      var height = this._getOptionHeight({ option: option });\n\n      var className = ['VirtualizedSelectOption'];\n\n      if (option === focusedOption) {\n        className.push('VirtualizedSelectFocusedOption');\n      }\n\n      if (option.disabled) {\n        className.push('VirtualizedSelectDisabledOption');\n      }\n\n      var events = option.disabled ? {} : {\n        onClick: function onClick() {\n          return selectValue(option);\n        },\n        onMouseOver: function onMouseOver() {\n          return focusOption(option);\n        }\n      };\n\n      return _react2.default.createElement(\n        'div',\n        _extends({\n          className: className.join(' '),\n          style: { height: height }\n        }, events),\n        option[labelKey]\n      );\n    }\n  }]);\n\n  return VirtualizedSelect;\n}(_react.Component);\n\nVirtualizedSelect.propTypes = {\n  async: _react.PropTypes.bool,\n  maxHeight: _react.PropTypes.number.isRequired,\n  optionHeight: _react.PropTypes.oneOfType([_react.PropTypes.number, _react.PropTypes.func]).isRequired,\n  optionRenderer: _react.PropTypes.func,\n  selectComponent: _react.PropTypes.func\n};\nVirtualizedSelect.defaultProps = {\n  async: false,\n  maxHeight: 200,\n  optionHeight: 35\n};\nexports.default = VirtualizedSelect;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = undefined;\n\nvar _VirtualizedSelect = require('./VirtualizedSelect');\n\nvar _VirtualizedSelect2 = _interopRequireDefault(_VirtualizedSelect);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _VirtualizedSelect2.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * This HOC decorates a virtualized component and responds to arrow-key events by scrolling one row or column at a time.\n */\nvar ArrowKeyStepper = function (_Component) {\n  _inherits(ArrowKeyStepper, _Component);\n\n  function ArrowKeyStepper(props, context) {\n    _classCallCheck(this, ArrowKeyStepper);\n\n    var _this = _possibleConstructorReturn(this, (ArrowKeyStepper.__proto__ || Object.getPrototypeOf(ArrowKeyStepper)).call(this, props, context));\n\n    _this.state = {\n      scrollToColumn: 0,\n      scrollToRow: 0\n    };\n\n    _this._columnStartIndex = 0;\n    _this._columnStopIndex = 0;\n    _this._rowStartIndex = 0;\n    _this._rowStopIndex = 0;\n\n    _this._onKeyDown = _this._onKeyDown.bind(_this);\n    _this._onSectionRendered = _this._onSectionRendered.bind(_this);\n    return _this;\n  }\n\n  _createClass(ArrowKeyStepper, [{\n    key: 'render',\n    value: function render() {\n      var _props = this.props;\n      var className = _props.className;\n      var children = _props.children;\n      var _state = this.state;\n      var scrollToColumn = _state.scrollToColumn;\n      var scrollToRow = _state.scrollToRow;\n\n\n      return _react2.default.createElement(\n        'div',\n        {\n          className: className,\n          onKeyDown: this._onKeyDown\n        },\n        children({\n          onSectionRendered: this._onSectionRendered,\n          scrollToColumn: scrollToColumn,\n          scrollToRow: scrollToRow\n        })\n      );\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_onKeyDown',\n    value: function _onKeyDown(event) {\n      var _props2 = this.props;\n      var columnCount = _props2.columnCount;\n      var rowCount = _props2.rowCount;\n\n      // The above cases all prevent default event event behavior.\n      // This is to keep the grid from scrolling after the snap-to update.\n\n      switch (event.key) {\n        case 'ArrowDown':\n          event.preventDefault();\n          this.setState({\n            scrollToRow: Math.min(this._rowStopIndex + 1, rowCount - 1)\n          });\n          break;\n        case 'ArrowLeft':\n          event.preventDefault();\n          this.setState({\n            scrollToColumn: Math.max(this._columnStartIndex - 1, 0)\n          });\n          break;\n        case 'ArrowRight':\n          event.preventDefault();\n          this.setState({\n            scrollToColumn: Math.min(this._columnStopIndex + 1, columnCount - 1)\n          });\n          break;\n        case 'ArrowUp':\n          event.preventDefault();\n          this.setState({\n            scrollToRow: Math.max(this._rowStartIndex - 1, 0)\n          });\n          break;\n      }\n    }\n  }, {\n    key: '_onSectionRendered',\n    value: function _onSectionRendered(_ref) {\n      var columnStartIndex = _ref.columnStartIndex;\n      var columnStopIndex = _ref.columnStopIndex;\n      var rowStartIndex = _ref.rowStartIndex;\n      var rowStopIndex = _ref.rowStopIndex;\n\n      this._columnStartIndex = columnStartIndex;\n      this._columnStopIndex = columnStopIndex;\n      this._rowStartIndex = rowStartIndex;\n      this._rowStopIndex = rowStopIndex;\n    }\n  }]);\n\n  return ArrowKeyStepper;\n}(_react.Component);\n\nArrowKeyStepper.propTypes = {\n  children: _react.PropTypes.func.isRequired,\n  className: _react.PropTypes.string,\n  columnCount: _react.PropTypes.number.isRequired,\n  rowCount: _react.PropTypes.number.isRequired\n};\nexports.default = ArrowKeyStepper;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.ArrowKeyStepper = exports.default = undefined;\n\nvar _ArrowKeyStepper2 = require('./ArrowKeyStepper');\n\nvar _ArrowKeyStepper3 = _interopRequireDefault(_ArrowKeyStepper2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _ArrowKeyStepper3.default;\nexports.ArrowKeyStepper = _ArrowKeyStepper3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * Decorator component that automatically adjusts the width and height of a single child.\n * Child component should not be declared as a child but should rather be specified by a `ChildComponent` property.\n * All other properties will be passed through to the child component.\n */\nvar AutoSizer = function (_Component) {\n  _inherits(AutoSizer, _Component);\n\n  function AutoSizer(props) {\n    _classCallCheck(this, AutoSizer);\n\n    var _this = _possibleConstructorReturn(this, (AutoSizer.__proto__ || Object.getPrototypeOf(AutoSizer)).call(this, props));\n\n    _this.state = {\n      height: 0,\n      width: 0\n    };\n\n    _this._onResize = _this._onResize.bind(_this);\n    _this._onScroll = _this._onScroll.bind(_this);\n    _this._setRef = _this._setRef.bind(_this);\n    return _this;\n  }\n\n  _createClass(AutoSizer, [{\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      // Delay access of parentNode until mount.\n      // This handles edge-cases where the component has already been unmounted before its ref has been set,\n      // As well as libraries like react-lite which have a slightly different lifecycle.\n      this._parentNode = this._autoSizer.parentNode;\n\n      // Defer requiring resize handler in order to support server-side rendering.\n      // See issue #41\n      this._detectElementResize = require('../vendor/detectElementResize');\n      this._detectElementResize.addResizeListener(this._parentNode, this._onResize);\n\n      this._onResize();\n    }\n  }, {\n    key: 'componentWillUnmount',\n    value: function componentWillUnmount() {\n      if (this._detectElementResize) {\n        this._detectElementResize.removeResizeListener(this._parentNode, this._onResize);\n      }\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _props = this.props;\n      var children = _props.children;\n      var disableHeight = _props.disableHeight;\n      var disableWidth = _props.disableWidth;\n      var _state = this.state;\n      var height = _state.height;\n      var width = _state.width;\n\n      // Outer div should not force width/height since that may prevent containers from shrinking.\n      // Inner component should overflow and use calculated width/height.\n      // See issue #68 for more information.\n\n      var outerStyle = { overflow: 'visible' };\n\n      if (!disableHeight) {\n        outerStyle.height = 0;\n      }\n\n      if (!disableWidth) {\n        outerStyle.width = 0;\n      }\n\n      return _react2.default.createElement(\n        'div',\n        {\n          ref: this._setRef,\n          onScroll: this._onScroll,\n          style: outerStyle\n        },\n        children({ height: height, width: width })\n      );\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_onResize',\n    value: function _onResize() {\n      var onResize = this.props.onResize;\n\n      // Gaurd against AutoSizer component being removed from the DOM immediately after being added.\n      // This can result in invalid style values which can result in NaN values if we don't handle them.\n      // See issue #150 for more context.\n\n      var boundingRect = this._parentNode.getBoundingClientRect();\n      var height = boundingRect.height || 0;\n      var width = boundingRect.width || 0;\n\n      var style = getComputedStyle(this._parentNode);\n      var paddingLeft = parseInt(style.paddingLeft, 10) || 0;\n      var paddingRight = parseInt(style.paddingRight, 10) || 0;\n      var paddingTop = parseInt(style.paddingTop, 10) || 0;\n      var paddingBottom = parseInt(style.paddingBottom, 10) || 0;\n\n      this.setState({\n        height: height - paddingTop - paddingBottom,\n        width: width - paddingLeft - paddingRight\n      });\n\n      onResize({ height: height, width: width });\n    }\n  }, {\n    key: '_onScroll',\n    value: function _onScroll(event) {\n      // Prevent detectElementResize library from being triggered by this scroll event.\n      event.stopPropagation();\n    }\n  }, {\n    key: '_setRef',\n    value: function _setRef(autoSizer) {\n      this._autoSizer = autoSizer;\n    }\n  }]);\n\n  return AutoSizer;\n}(_react.Component);\n\nAutoSizer.propTypes = {\n  /**\n   * Function respondible for rendering children.\n   * This function should implement the following signature:\n   * ({ height, width }) => PropTypes.element\n   */\n  children: _react.PropTypes.func.isRequired,\n\n  /** Disable dynamic :height property */\n  disableHeight: _react.PropTypes.bool,\n\n  /** Disable dynamic :width property */\n  disableWidth: _react.PropTypes.bool,\n\n  /** Callback to be invoked on-resize: ({ height, width }) */\n  onResize: _react.PropTypes.func.isRequired\n};\nAutoSizer.defaultProps = {\n  onResize: function onResize() {}\n};\nexports.default = AutoSizer;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.AutoSizer = exports.default = undefined;\n\nvar _AutoSizer2 = require('./AutoSizer');\n\nvar _AutoSizer3 = _interopRequireDefault(_AutoSizer2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _AutoSizer3.default;\nexports.AutoSizer = _AutoSizer3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nvar _reactDom = require('react-dom');\n\nvar _reactDom2 = _interopRequireDefault(_reactDom);\n\nvar _defaultCellSizeCache = require('./defaultCellSizeCache');\n\nvar _defaultCellSizeCache2 = _interopRequireDefault(_defaultCellSizeCache);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * Measures a Grid cell's contents by rendering them in a way that is not visible to the user.\n * Either a fixed width or height may be provided if it is desirable to measure only in one direction.\n */\nvar CellMeasurer = function (_Component) {\n  _inherits(CellMeasurer, _Component);\n\n  function CellMeasurer(props, state) {\n    _classCallCheck(this, CellMeasurer);\n\n    var _this = _possibleConstructorReturn(this, (CellMeasurer.__proto__ || Object.getPrototypeOf(CellMeasurer)).call(this, props, state));\n\n    _this._cellSizeCache = props.cellSizeCache || new _defaultCellSizeCache2.default();\n\n    _this.getColumnWidth = _this.getColumnWidth.bind(_this);\n    _this.getRowHeight = _this.getRowHeight.bind(_this);\n    _this.resetMeasurements = _this.resetMeasurements.bind(_this);\n    _this.resetMeasurementForColumn = _this.resetMeasurementForColumn.bind(_this);\n    _this.resetMeasurementForRow = _this.resetMeasurementForRow.bind(_this);\n    return _this;\n  }\n\n  _createClass(CellMeasurer, [{\n    key: 'getColumnWidth',\n    value: function getColumnWidth(_ref) {\n      var index = _ref.index;\n\n      if (this._cellSizeCache.hasColumnWidth(index)) {\n        return this._cellSizeCache.getColumnWidth(index);\n      }\n\n      var rowCount = this.props.rowCount;\n\n\n      var maxWidth = 0;\n\n      for (var rowIndex = 0; rowIndex < rowCount; rowIndex++) {\n        var _measureCell2 = this._measureCell({\n          clientWidth: true,\n          columnIndex: index,\n          rowIndex: rowIndex\n        });\n\n        var width = _measureCell2.width;\n\n\n        maxWidth = Math.max(maxWidth, width);\n      }\n\n      this._cellSizeCache.setColumnWidth(index, maxWidth);\n\n      return maxWidth;\n    }\n  }, {\n    key: 'getRowHeight',\n    value: function getRowHeight(_ref2) {\n      var index = _ref2.index;\n\n      if (this._cellSizeCache.hasRowHeight(index)) {\n        return this._cellSizeCache.getRowHeight(index);\n      }\n\n      var columnCount = this.props.columnCount;\n\n\n      var maxHeight = 0;\n\n      for (var columnIndex = 0; columnIndex < columnCount; columnIndex++) {\n        var _measureCell3 = this._measureCell({\n          clientHeight: true,\n          columnIndex: columnIndex,\n          rowIndex: index\n        });\n\n        var height = _measureCell3.height;\n\n\n        maxHeight = Math.max(maxHeight, height);\n      }\n\n      this._cellSizeCache.setRowHeight(index, maxHeight);\n\n      return maxHeight;\n    }\n  }, {\n    key: 'resetMeasurementForColumn',\n    value: function resetMeasurementForColumn(columnIndex) {\n      this._cellSizeCache.clearColumnWidth(columnIndex);\n    }\n  }, {\n    key: 'resetMeasurementForRow',\n    value: function resetMeasurementForRow(rowIndex) {\n      this._cellSizeCache.clearRowHeight(rowIndex);\n    }\n  }, {\n    key: 'resetMeasurements',\n    value: function resetMeasurements() {\n      this._cellSizeCache.clearAllColumnWidths();\n      this._cellSizeCache.clearAllRowHeights();\n    }\n  }, {\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      this._renderAndMount();\n    }\n  }, {\n    key: 'componentWillReceiveProps',\n    value: function componentWillReceiveProps(nextProps) {\n      var cellSizeCache = this.props.cellSizeCache;\n\n\n      if (cellSizeCache !== nextProps.cellSizeCache) {\n        this._cellSizeCache = nextProps.cellSizeCache;\n      }\n\n      this._updateDivDimensions(nextProps);\n    }\n  }, {\n    key: 'componentWillUnmount',\n    value: function componentWillUnmount() {\n      this._unmountContainer();\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var children = this.props.children;\n\n\n      return children({\n        getColumnWidth: this.getColumnWidth,\n        getRowHeight: this.getRowHeight,\n        resetMeasurements: this.resetMeasurements,\n        resetMeasurementForColumn: this.resetMeasurementForColumn,\n        resetMeasurementForRow: this.resetMeasurementForRow\n      });\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_getContainerNode',\n    value: function _getContainerNode(props) {\n      var container = props.container;\n\n\n      if (container) {\n        return _reactDom2.default.findDOMNode(typeof container === 'function' ? container() : container);\n      } else {\n        return document.body;\n      }\n    }\n  }, {\n    key: '_measureCell',\n    value: function _measureCell(_ref3) {\n      var _ref3$clientHeight = _ref3.clientHeight;\n      var clientHeight = _ref3$clientHeight === undefined ? false : _ref3$clientHeight;\n      var _ref3$clientWidth = _ref3.clientWidth;\n      var clientWidth = _ref3$clientWidth === undefined ? true : _ref3$clientWidth;\n      var columnIndex = _ref3.columnIndex;\n      var rowIndex = _ref3.rowIndex;\n      var cellRenderer = this.props.cellRenderer;\n\n\n      var rendered = cellRenderer({\n        columnIndex: columnIndex,\n        rowIndex: rowIndex\n      });\n\n      // Handle edge case where this method is called before the CellMeasurer has completed its initial render (and mounted).\n      this._renderAndMount();\n\n      // @TODO Keep an eye on this for future React updates as the interface may change:\n      // https://twitter.com/soprano/status/737316379712331776\n      _reactDom2.default.unstable_renderSubtreeIntoContainer(this, rendered, this._div);\n\n      var measurements = {\n        height: clientHeight && this._div.clientHeight,\n        width: clientWidth && this._div.clientWidth\n      };\n\n      _reactDom2.default.unmountComponentAtNode(this._div);\n\n      return measurements;\n    }\n  }, {\n    key: '_renderAndMount',\n    value: function _renderAndMount() {\n      if (!this._div) {\n        this._div = document.createElement('div');\n        this._div.style.display = 'inline-block';\n        this._div.style.position = 'absolute';\n        this._div.style.visibility = 'hidden';\n        this._div.style.zIndex = -1;\n\n        this._updateDivDimensions(this.props);\n\n        this._containerNode = this._getContainerNode(this.props);\n        this._containerNode.appendChild(this._div);\n      }\n    }\n  }, {\n    key: '_unmountContainer',\n    value: function _unmountContainer() {\n      if (this._div) {\n        this._containerNode.removeChild(this._div);\n\n        this._div = null;\n      }\n\n      this._containerNode = null;\n    }\n  }, {\n    key: '_updateDivDimensions',\n    value: function _updateDivDimensions(props) {\n      var height = props.height;\n      var width = props.width;\n\n\n      if (height && height !== this._divHeight) {\n        this._divHeight = height;\n        this._div.style.height = height + 'px';\n      }\n\n      if (width && width !== this._divWidth) {\n        this._divWidth = width;\n        this._div.style.width = width + 'px';\n      }\n    }\n  }]);\n\n  return CellMeasurer;\n}(_react.Component);\n\nCellMeasurer.propTypes = {\n  /**\n   * Renders a cell given its indices.\n   * Should implement the following interface: ({ columnIndex: number, rowIndex: number }): PropTypes.node\n   */\n  cellRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Optional, custom caching strategy for cell sizes.\n   */\n  cellSizeCache: _react.PropTypes.object,\n\n  /**\n   * Function respondible for rendering a virtualized component.\n   * This function should implement the following signature:\n   * ({ getColumnWidth, getRowHeight, resetMeasurements }) => PropTypes.element\n   */\n  children: _react.PropTypes.func.isRequired,\n\n  /**\n   * Number of columns in grid.\n   */\n  columnCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * A Node, Component instance, or function that returns either.\n   * If this property is not specified the document body will be used.\n   */\n  container: _react2.default.PropTypes.oneOfType([_react2.default.PropTypes.func, _react2.default.PropTypes.node]),\n\n  /**\n   * Assign a fixed :height in order to measure dynamic text :width only.\n   */\n  height: _react.PropTypes.number,\n\n  /**\n   * Number of rows in grid.\n   */\n  rowCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Assign a fixed :width in order to measure dynamic text :height only.\n   */\n  width: _react.PropTypes.number\n};\nexports.default = CellMeasurer;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\n * Default CellMeasurer `cellSizeCache` implementation.\n * Permanently caches all cell sizes (identified by column and row index) unless explicitly cleared.\n * Can be configured to handle uniform cell widths and/or heights as a way of optimizing certain use cases.\n */\nvar CellSizeCache = function () {\n  function CellSizeCache() {\n    var _ref = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n    var _ref$uniformRowHeight = _ref.uniformRowHeight;\n    var uniformRowHeight = _ref$uniformRowHeight === undefined ? false : _ref$uniformRowHeight;\n    var _ref$uniformColumnWid = _ref.uniformColumnWidth;\n    var uniformColumnWidth = _ref$uniformColumnWid === undefined ? false : _ref$uniformColumnWid;\n\n    _classCallCheck(this, CellSizeCache);\n\n    this._uniformRowHeight = uniformRowHeight;\n    this._uniformColumnWidth = uniformColumnWidth;\n\n    this._cachedColumnWidths = {};\n    this._cachedRowHeights = {};\n  }\n\n  _createClass(CellSizeCache, [{\n    key: \"clearAllColumnWidths\",\n    value: function clearAllColumnWidths() {\n      this._cachedColumnWidth = undefined;\n      this._cachedColumnWidths = {};\n    }\n  }, {\n    key: \"clearAllRowHeights\",\n    value: function clearAllRowHeights() {\n      this._cachedRowHeight = undefined;\n      this._cachedRowHeights = {};\n    }\n  }, {\n    key: \"clearColumnWidth\",\n    value: function clearColumnWidth(index) {\n      this._cachedColumnWidth = undefined;\n\n      delete this._cachedColumnWidths[index];\n    }\n  }, {\n    key: \"clearRowHeight\",\n    value: function clearRowHeight(index) {\n      this._cachedRowHeight = undefined;\n\n      delete this._cachedRowHeights[index];\n    }\n  }, {\n    key: \"getColumnWidth\",\n    value: function getColumnWidth(index) {\n      return this._uniformColumnWidth ? this._cachedColumnWidth : this._cachedColumnWidths[index];\n    }\n  }, {\n    key: \"getRowHeight\",\n    value: function getRowHeight(index) {\n      return this._uniformRowHeight ? this._cachedRowHeight : this._cachedRowHeights[index];\n    }\n  }, {\n    key: \"hasColumnWidth\",\n    value: function hasColumnWidth(index) {\n      return this._uniformColumnWidth ? !!this._cachedColumnWidth : !!this._cachedColumnWidths[index];\n    }\n  }, {\n    key: \"hasRowHeight\",\n    value: function hasRowHeight(index) {\n      return this._uniformRowHeight ? !!this._cachedRowHeight : !!this._cachedRowHeights[index];\n    }\n  }, {\n    key: \"setColumnWidth\",\n    value: function setColumnWidth(index, width) {\n      this._cachedColumnWidth = width;\n      this._cachedColumnWidths[index] = width;\n    }\n  }, {\n    key: \"setRowHeight\",\n    value: function setRowHeight(index, height) {\n      this._cachedRowHeight = height;\n      this._cachedRowHeights[index] = height;\n    }\n  }]);\n\n  return CellSizeCache;\n}();\n\nexports.default = CellSizeCache;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.defaultCellSizeCache = exports.CellMeasurer = exports.default = undefined;\n\nvar _CellMeasurer2 = require('./CellMeasurer');\n\nvar _CellMeasurer3 = _interopRequireDefault(_CellMeasurer2);\n\nvar _defaultCellSizeCache2 = require('./defaultCellSizeCache');\n\nvar _defaultCellSizeCache3 = _interopRequireDefault(_defaultCellSizeCache2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _CellMeasurer3.default;\nexports.CellMeasurer = _CellMeasurer3.default;\nexports.defaultCellSizeCache = _defaultCellSizeCache3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _CollectionView = require('./CollectionView');\n\nvar _CollectionView2 = _interopRequireDefault(_CollectionView);\n\nvar _calculateSizeAndPositionData2 = require('./utils/calculateSizeAndPositionData');\n\nvar _calculateSizeAndPositionData3 = _interopRequireDefault(_calculateSizeAndPositionData2);\n\nvar _getUpdatedOffsetForIndex = require('../utils/getUpdatedOffsetForIndex');\n\nvar _getUpdatedOffsetForIndex2 = _interopRequireDefault(_getUpdatedOffsetForIndex);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * Renders scattered or non-linear data.\n * Unlike Grid, which renders checkerboard data, Collection can render arbitrarily positioned- even overlapping- data.\n */\nvar Collection = function (_Component) {\n  _inherits(Collection, _Component);\n\n  function Collection(props, context) {\n    _classCallCheck(this, Collection);\n\n    var _this = _possibleConstructorReturn(this, (Collection.__proto__ || Object.getPrototypeOf(Collection)).call(this, props, context));\n\n    _this._cellMetadata = [];\n    _this._lastRenderedCellIndices = [];\n\n    // Cell cache during scroll (for perforamnce)\n    _this._cellCache = [];\n\n    _this._isScrollingChange = _this._isScrollingChange.bind(_this);\n    return _this;\n  }\n\n  /** See Collection#recomputeCellSizesAndPositions */\n\n\n  _createClass(Collection, [{\n    key: 'recomputeCellSizesAndPositions',\n    value: function recomputeCellSizesAndPositions() {\n      this._cellCache = [];\n      this._collectionView.recomputeCellSizesAndPositions();\n    }\n\n    /** React lifecycle methods */\n\n  }, {\n    key: 'render',\n    value: function render() {\n      var _this2 = this;\n\n      var props = _objectWithoutProperties(this.props, []);\n\n      return _react2.default.createElement(_CollectionView2.default, _extends({\n        cellLayoutManager: this,\n        isScrollingChange: this._isScrollingChange,\n        ref: function ref(_ref) {\n          _this2._collectionView = _ref;\n        }\n      }, props));\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n\n    /** CellLayoutManager interface */\n\n  }, {\n    key: 'calculateSizeAndPositionData',\n    value: function calculateSizeAndPositionData() {\n      var _props = this.props;\n      var cellCount = _props.cellCount;\n      var cellSizeAndPositionGetter = _props.cellSizeAndPositionGetter;\n      var sectionSize = _props.sectionSize;\n\n\n      var data = (0, _calculateSizeAndPositionData3.default)({\n        cellCount: cellCount,\n        cellSizeAndPositionGetter: cellSizeAndPositionGetter,\n        sectionSize: sectionSize\n      });\n\n      this._cellMetadata = data.cellMetadata;\n      this._sectionManager = data.sectionManager;\n      this._height = data.height;\n      this._width = data.width;\n    }\n\n    /**\n     * Returns the most recently rendered set of cell indices.\n     */\n\n  }, {\n    key: 'getLastRenderedIndices',\n    value: function getLastRenderedIndices() {\n      return this._lastRenderedCellIndices;\n    }\n\n    /**\n     * Calculates the minimum amount of change from the current scroll position to ensure the specified cell is (fully) visible.\n     */\n\n  }, {\n    key: 'getScrollPositionForCell',\n    value: function getScrollPositionForCell(_ref2) {\n      var align = _ref2.align;\n      var cellIndex = _ref2.cellIndex;\n      var height = _ref2.height;\n      var scrollLeft = _ref2.scrollLeft;\n      var scrollTop = _ref2.scrollTop;\n      var width = _ref2.width;\n      var cellCount = this.props.cellCount;\n\n\n      if (cellIndex >= 0 && cellIndex < cellCount) {\n        var cellMetadata = this._cellMetadata[cellIndex];\n\n        scrollLeft = (0, _getUpdatedOffsetForIndex2.default)({\n          align: align,\n          cellOffset: cellMetadata.x,\n          cellSize: cellMetadata.width,\n          containerSize: width,\n          currentOffset: scrollLeft,\n          targetIndex: cellIndex\n        });\n\n        scrollTop = (0, _getUpdatedOffsetForIndex2.default)({\n          align: align,\n          cellOffset: cellMetadata.y,\n          cellSize: cellMetadata.height,\n          containerSize: height,\n          currentOffset: scrollTop,\n          targetIndex: cellIndex\n        });\n      }\n\n      return {\n        scrollLeft: scrollLeft,\n        scrollTop: scrollTop\n      };\n    }\n  }, {\n    key: 'getTotalSize',\n    value: function getTotalSize() {\n      return {\n        height: this._height,\n        width: this._width\n      };\n    }\n  }, {\n    key: 'cellRenderers',\n    value: function cellRenderers(_ref3) {\n      var _this3 = this;\n\n      var height = _ref3.height;\n      var isScrolling = _ref3.isScrolling;\n      var width = _ref3.width;\n      var x = _ref3.x;\n      var y = _ref3.y;\n      var _props2 = this.props;\n      var cellGroupRenderer = _props2.cellGroupRenderer;\n      var cellRenderer = _props2.cellRenderer;\n\n      // Store for later calls to getLastRenderedIndices()\n\n      this._lastRenderedCellIndices = this._sectionManager.getCellIndices({\n        height: height,\n        width: width,\n        x: x,\n        y: y\n      });\n\n      return cellGroupRenderer({\n        cellCache: this._cellCache,\n        cellRenderer: cellRenderer,\n        cellSizeAndPositionGetter: function cellSizeAndPositionGetter(_ref4) {\n          var index = _ref4.index;\n          return _this3._sectionManager.getCellMetadata({ index: index });\n        },\n        indices: this._lastRenderedCellIndices,\n        isScrolling: isScrolling\n      });\n    }\n  }, {\n    key: '_isScrollingChange',\n    value: function _isScrollingChange(isScrolling) {\n      if (!isScrolling) {\n        this._cellCache = [];\n      }\n    }\n  }]);\n\n  return Collection;\n}(_react.Component);\n\nCollection.propTypes = {\n  'aria-label': _react.PropTypes.string,\n\n  /**\n   * Number of cells in Collection.\n   */\n  cellCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Responsible for rendering a group of cells given their indices.\n   * Should implement the following interface: ({\n   *   cellSizeAndPositionGetter:Function,\n   *   indices: Array<number>,\n   *   cellRenderer: Function\n   * }): Array<PropTypes.node>\n   */\n  cellGroupRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Responsible for rendering a cell given an row and column index.\n   * Should implement the following interface: ({ index: number }): PropTypes.element\n   */\n  cellRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Callback responsible for returning size and offset/position information for a given cell (index).\n   * ({ index: number }): { height: number, width: number, x: number, y: number }\n   */\n  cellSizeAndPositionGetter: _react.PropTypes.func.isRequired,\n\n  /**\n   * Optionally override the size of the sections a Collection's cells are split into.\n   */\n  sectionSize: _react.PropTypes.number\n};\nCollection.defaultProps = {\n  'aria-label': 'grid',\n  cellGroupRenderer: defaultCellGroupRenderer\n};\nexports.default = Collection;\n\n\nfunction defaultCellGroupRenderer(_ref5) {\n  var cellCache = _ref5.cellCache;\n  var cellRenderer = _ref5.cellRenderer;\n  var cellSizeAndPositionGetter = _ref5.cellSizeAndPositionGetter;\n  var indices = _ref5.indices;\n  var isScrolling = _ref5.isScrolling;\n\n  return indices.map(function (index) {\n    var cellMetadata = cellSizeAndPositionGetter({ index: index });\n\n    // Avoid re-creating cells while scrolling.\n    // This can lead to the same cell being created many times and can cause performance issues for \"heavy\" cells.\n    // If a scroll is in progress- cache and reuse cells.\n    // This cache will be thrown away once scrolling complets.\n    var renderedCell = void 0;\n\n    if (isScrolling) {\n      if (!(index in cellCache)) {\n        cellCache[index] = cellRenderer({\n          index: index,\n          isScrolling: isScrolling\n        });\n      }\n\n      renderedCell = cellCache[index];\n    } else {\n      renderedCell = cellRenderer({\n        index: index,\n        isScrolling: isScrolling\n      });\n    }\n\n    if (renderedCell == null || renderedCell === false) {\n      return null;\n    }\n\n    return _react2.default.createElement(\n      'div',\n      {\n        className: 'Collection__cell',\n        key: index,\n        style: {\n          height: cellMetadata.height,\n          left: cellMetadata.x,\n          top: cellMetadata.y,\n          width: cellMetadata.width\n        }\n      },\n      renderedCell\n    );\n  }).filter(function (renderedCell) {\n    return !!renderedCell;\n  });\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _classnames = require('classnames');\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nvar _createCallbackMemoizer = require('../utils/createCallbackMemoizer');\n\nvar _createCallbackMemoizer2 = _interopRequireDefault(_createCallbackMemoizer);\n\nvar _scrollbarSize = require('dom-helpers/util/scrollbarSize');\n\nvar _scrollbarSize2 = _interopRequireDefault(_scrollbarSize);\n\nvar _raf = require('raf');\n\nvar _raf2 = _interopRequireDefault(_raf);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n// @TODO It would be nice to refactor Grid to use this code as well.\n\n/**\n * Specifies the number of miliseconds during which to disable pointer events while a scroll is in progress.\n * This improves performance and makes scrolling smoother.\n */\nvar IS_SCROLLING_TIMEOUT = 150;\n\n/**\n * Controls whether the Grid updates the DOM element's scrollLeft/scrollTop based on the current state or just observes it.\n * This prevents Grid from interrupting mouse-wheel animations (see issue #2).\n */\nvar SCROLL_POSITION_CHANGE_REASONS = {\n  OBSERVED: 'observed',\n  REQUESTED: 'requested'\n};\n\n/**\n * Monitors changes in properties (eg. cellCount) and state (eg. scroll offsets) to determine when rendering needs to occur.\n * This component does not render any visible content itself; it defers to the specified :cellLayoutManager.\n */\n\nvar CollectionView = function (_Component) {\n  _inherits(CollectionView, _Component);\n\n  function CollectionView(props, context) {\n    _classCallCheck(this, CollectionView);\n\n    var _this = _possibleConstructorReturn(this, (CollectionView.__proto__ || Object.getPrototypeOf(CollectionView)).call(this, props, context));\n\n    _this.state = {\n      calculateSizeAndPositionDataOnNextUpdate: false,\n      isScrolling: false,\n      scrollLeft: 0,\n      scrollTop: 0\n    };\n\n    // Invokes callbacks only when their values have changed.\n    _this._onSectionRenderedMemoizer = (0, _createCallbackMemoizer2.default)();\n    _this._onScrollMemoizer = (0, _createCallbackMemoizer2.default)(false);\n\n    // Bind functions to instance so they don't lose context when passed around.\n    _this._invokeOnSectionRenderedHelper = _this._invokeOnSectionRenderedHelper.bind(_this);\n    _this._onScroll = _this._onScroll.bind(_this);\n    _this._updateScrollPositionForScrollToCell = _this._updateScrollPositionForScrollToCell.bind(_this);\n    return _this;\n  }\n\n  /**\n   * Forced recompute of cell sizes and positions.\n   * This function should be called if cell sizes have changed but nothing else has.\n   * Since cell positions are calculated by callbacks, the collection view has no way of detecting when the underlying data has changed.\n   */\n\n\n  _createClass(CollectionView, [{\n    key: 'recomputeCellSizesAndPositions',\n    value: function recomputeCellSizesAndPositions() {\n      this.setState({\n        calculateSizeAndPositionDataOnNextUpdate: true\n      });\n    }\n\n    /* ---------------------------- Component lifecycle methods ---------------------------- */\n\n  }, {\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      var _props = this.props;\n      var cellLayoutManager = _props.cellLayoutManager;\n      var scrollLeft = _props.scrollLeft;\n      var scrollToCell = _props.scrollToCell;\n      var scrollTop = _props.scrollTop;\n\n      // If this component was first rendered server-side, scrollbar size will be undefined.\n      // In that event we need to remeasure.\n\n      if (!this._scrollbarSizeMeasured) {\n        this._scrollbarSize = (0, _scrollbarSize2.default)();\n        this._scrollbarSizeMeasured = true;\n        this.setState({});\n      }\n\n      if (scrollToCell >= 0) {\n        this._updateScrollPositionForScrollToCell();\n      } else if (scrollLeft >= 0 || scrollTop >= 0) {\n        this._setScrollPosition({ scrollLeft: scrollLeft, scrollTop: scrollTop });\n      }\n\n      // Update onSectionRendered callback.\n      this._invokeOnSectionRenderedHelper();\n\n      var _cellLayoutManager$ge = cellLayoutManager.getTotalSize();\n\n      var totalHeight = _cellLayoutManager$ge.height;\n      var totalWidth = _cellLayoutManager$ge.width;\n\n      // Initialize onScroll callback.\n\n      this._invokeOnScrollMemoizer({\n        scrollLeft: scrollLeft || 0,\n        scrollTop: scrollTop || 0,\n        totalHeight: totalHeight,\n        totalWidth: totalWidth\n      });\n    }\n  }, {\n    key: 'componentDidUpdate',\n    value: function componentDidUpdate(prevProps, prevState) {\n      var _props2 = this.props;\n      var height = _props2.height;\n      var scrollToCell = _props2.scrollToCell;\n      var width = _props2.width;\n      var _state = this.state;\n      var scrollLeft = _state.scrollLeft;\n      var scrollPositionChangeReason = _state.scrollPositionChangeReason;\n      var scrollToAlignment = _state.scrollToAlignment;\n      var scrollTop = _state.scrollTop;\n\n      // Make sure requested changes to :scrollLeft or :scrollTop get applied.\n      // Assigning to scrollLeft/scrollTop tells the browser to interrupt any running scroll animations,\n      // And to discard any pending async changes to the scroll position that may have happened in the meantime (e.g. on a separate scrolling thread).\n      // So we only set these when we require an adjustment of the scroll position.\n      // See issue #2 for more information.\n\n      if (scrollPositionChangeReason === SCROLL_POSITION_CHANGE_REASONS.REQUESTED) {\n        if (scrollLeft >= 0 && scrollLeft !== prevState.scrollLeft && scrollLeft !== this._scrollingContainer.scrollLeft) {\n          this._scrollingContainer.scrollLeft = scrollLeft;\n        }\n        if (scrollTop >= 0 && scrollTop !== prevState.scrollTop && scrollTop !== this._scrollingContainer.scrollTop) {\n          this._scrollingContainer.scrollTop = scrollTop;\n        }\n      }\n\n      // Update scroll offsets if the current :scrollToCell values requires it\n      if (height !== prevProps.height || scrollToAlignment !== prevProps.scrollToAlignment || scrollToCell !== prevProps.scrollToCell || width !== prevProps.width) {\n        this._updateScrollPositionForScrollToCell();\n      }\n\n      // Update onRowsRendered callback if start/stop indices have changed\n      this._invokeOnSectionRenderedHelper();\n    }\n  }, {\n    key: 'componentWillMount',\n    value: function componentWillMount() {\n      var cellLayoutManager = this.props.cellLayoutManager;\n\n\n      cellLayoutManager.calculateSizeAndPositionData();\n\n      // If this component is being rendered server-side, getScrollbarSize() will return undefined.\n      // We handle this case in componentDidMount()\n      this._scrollbarSize = (0, _scrollbarSize2.default)();\n      if (this._scrollbarSize === undefined) {\n        this._scrollbarSizeMeasured = false;\n        this._scrollbarSize = 0;\n      } else {\n        this._scrollbarSizeMeasured = true;\n      }\n    }\n  }, {\n    key: 'componentWillUnmount',\n    value: function componentWillUnmount() {\n      if (this._disablePointerEventsTimeoutId) {\n        clearTimeout(this._disablePointerEventsTimeoutId);\n      }\n\n      if (this._setNextStateAnimationFrameId) {\n        _raf2.default.cancel(this._setNextStateAnimationFrameId);\n      }\n    }\n\n    /**\n     * @private\n     * This method updates scrollLeft/scrollTop in state for the following conditions:\n     * 1) Empty content (0 rows or columns)\n     * 2) New scroll props overriding the current state\n     * 3) Cells-count or cells-size has changed, making previous scroll offsets invalid\n     */\n\n  }, {\n    key: 'componentWillUpdate',\n    value: function componentWillUpdate(nextProps, nextState) {\n      if (nextProps.cellCount === 0 && (nextState.scrollLeft !== 0 || nextState.scrollTop !== 0)) {\n        this._setScrollPosition({\n          scrollLeft: 0,\n          scrollTop: 0\n        });\n      } else if (nextProps.scrollLeft !== this.props.scrollLeft || nextProps.scrollTop !== this.props.scrollTop) {\n        this._setScrollPosition({\n          scrollLeft: nextProps.scrollLeft,\n          scrollTop: nextProps.scrollTop\n        });\n      }\n\n      if (nextProps.cellCount !== this.props.cellCount || nextProps.cellLayoutManager !== this.props.cellLayoutManager || nextState.calculateSizeAndPositionDataOnNextUpdate) {\n        nextProps.cellLayoutManager.calculateSizeAndPositionData();\n      }\n\n      if (nextState.calculateSizeAndPositionDataOnNextUpdate) {\n        this.setState({\n          calculateSizeAndPositionDataOnNextUpdate: false\n        });\n      }\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _this2 = this;\n\n      var _props3 = this.props;\n      var autoHeight = _props3.autoHeight;\n      var cellCount = _props3.cellCount;\n      var cellLayoutManager = _props3.cellLayoutManager;\n      var className = _props3.className;\n      var height = _props3.height;\n      var horizontalOverscanSize = _props3.horizontalOverscanSize;\n      var noContentRenderer = _props3.noContentRenderer;\n      var style = _props3.style;\n      var verticalOverscanSize = _props3.verticalOverscanSize;\n      var width = _props3.width;\n      var _state2 = this.state;\n      var isScrolling = _state2.isScrolling;\n      var scrollLeft = _state2.scrollLeft;\n      var scrollTop = _state2.scrollTop;\n\n      var _cellLayoutManager$ge2 = cellLayoutManager.getTotalSize();\n\n      var totalHeight = _cellLayoutManager$ge2.height;\n      var totalWidth = _cellLayoutManager$ge2.width;\n\n      // Safely expand the rendered area by the specified overscan amount\n\n      var left = Math.max(0, scrollLeft - horizontalOverscanSize);\n      var top = Math.max(0, scrollTop - verticalOverscanSize);\n      var right = Math.min(totalWidth, scrollLeft + width + horizontalOverscanSize);\n      var bottom = Math.min(totalHeight, scrollTop + height + verticalOverscanSize);\n\n      var childrenToDisplay = height > 0 && width > 0 ? cellLayoutManager.cellRenderers({\n        height: bottom - top,\n        isScrolling: isScrolling,\n        width: right - left,\n        x: left,\n        y: top\n      }) : [];\n\n      var collectionStyle = {\n        height: autoHeight ? 'auto' : height,\n        width: width\n      };\n\n      // Force browser to hide scrollbars when we know they aren't necessary.\n      // Otherwise once scrollbars appear they may not disappear again.\n      // For more info see issue #116\n      var verticalScrollBarSize = totalHeight > height ? this._scrollbarSize : 0;\n      var horizontalScrollBarSize = totalWidth > width ? this._scrollbarSize : 0;\n      if (totalWidth + verticalScrollBarSize <= width) {\n        collectionStyle.overflowX = 'hidden';\n      }\n      if (totalHeight + horizontalScrollBarSize <= height) {\n        collectionStyle.overflowY = 'hidden';\n      }\n\n      return _react2.default.createElement(\n        'div',\n        {\n          ref: function ref(_ref) {\n            _this2._scrollingContainer = _ref;\n          },\n          'aria-label': this.props['aria-label'],\n          className: (0, _classnames2.default)('Collection', className),\n          onScroll: this._onScroll,\n          role: 'grid',\n          style: _extends({}, collectionStyle, style),\n          tabIndex: 0\n        },\n        cellCount > 0 && _react2.default.createElement(\n          'div',\n          {\n            className: 'Collection__innerScrollContainer',\n            style: {\n              height: totalHeight,\n              maxHeight: totalHeight,\n              maxWidth: totalWidth,\n              pointerEvents: isScrolling ? 'none' : '',\n              width: totalWidth\n            }\n          },\n          childrenToDisplay\n        ),\n        cellCount === 0 && noContentRenderer()\n      );\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n\n    /* ---------------------------- Helper methods ---------------------------- */\n\n    /**\n     * Sets an :isScrolling flag for a small window of time.\n     * This flag is used to disable pointer events on the scrollable portion of the Collection.\n     * This prevents jerky/stuttery mouse-wheel scrolling.\n     */\n\n  }, {\n    key: '_enablePointerEventsAfterDelay',\n    value: function _enablePointerEventsAfterDelay() {\n      var _this3 = this;\n\n      if (this._disablePointerEventsTimeoutId) {\n        clearTimeout(this._disablePointerEventsTimeoutId);\n      }\n\n      this._disablePointerEventsTimeoutId = setTimeout(function () {\n        var isScrollingChange = _this3.props.isScrollingChange;\n\n\n        isScrollingChange(false);\n\n        _this3._disablePointerEventsTimeoutId = null;\n        _this3.setState({\n          isScrolling: false\n        });\n      }, IS_SCROLLING_TIMEOUT);\n    }\n  }, {\n    key: '_invokeOnSectionRenderedHelper',\n    value: function _invokeOnSectionRenderedHelper() {\n      var _props4 = this.props;\n      var cellLayoutManager = _props4.cellLayoutManager;\n      var onSectionRendered = _props4.onSectionRendered;\n\n\n      this._onSectionRenderedMemoizer({\n        callback: onSectionRendered,\n        indices: {\n          indices: cellLayoutManager.getLastRenderedIndices()\n        }\n      });\n    }\n  }, {\n    key: '_invokeOnScrollMemoizer',\n    value: function _invokeOnScrollMemoizer(_ref2) {\n      var _this4 = this;\n\n      var scrollLeft = _ref2.scrollLeft;\n      var scrollTop = _ref2.scrollTop;\n      var totalHeight = _ref2.totalHeight;\n      var totalWidth = _ref2.totalWidth;\n\n      this._onScrollMemoizer({\n        callback: function callback(_ref3) {\n          var scrollLeft = _ref3.scrollLeft;\n          var scrollTop = _ref3.scrollTop;\n          var _props5 = _this4.props;\n          var height = _props5.height;\n          var onScroll = _props5.onScroll;\n          var width = _props5.width;\n\n\n          onScroll({\n            clientHeight: height,\n            clientWidth: width,\n            scrollHeight: totalHeight,\n            scrollLeft: scrollLeft,\n            scrollTop: scrollTop,\n            scrollWidth: totalWidth\n          });\n        },\n        indices: {\n          scrollLeft: scrollLeft,\n          scrollTop: scrollTop\n        }\n      });\n    }\n\n    /**\n     * Updates the state during the next animation frame.\n     * Use this method to avoid multiple renders in a small span of time.\n     * This helps performance for bursty events (like onScroll).\n     */\n\n  }, {\n    key: '_setNextState',\n    value: function _setNextState(state) {\n      var _this5 = this;\n\n      if (this._setNextStateAnimationFrameId) {\n        _raf2.default.cancel(this._setNextStateAnimationFrameId);\n      }\n\n      this._setNextStateAnimationFrameId = (0, _raf2.default)(function () {\n        _this5._setNextStateAnimationFrameId = null;\n        _this5.setState(state);\n      });\n    }\n  }, {\n    key: '_setScrollPosition',\n    value: function _setScrollPosition(_ref4) {\n      var scrollLeft = _ref4.scrollLeft;\n      var scrollTop = _ref4.scrollTop;\n\n      var newState = {\n        scrollPositionChangeReason: SCROLL_POSITION_CHANGE_REASONS.REQUESTED\n      };\n\n      if (scrollLeft >= 0) {\n        newState.scrollLeft = scrollLeft;\n      }\n\n      if (scrollTop >= 0) {\n        newState.scrollTop = scrollTop;\n      }\n\n      if (scrollLeft >= 0 && scrollLeft !== this.state.scrollLeft || scrollTop >= 0 && scrollTop !== this.state.scrollTop) {\n        this.setState(newState);\n      }\n    }\n  }, {\n    key: '_updateScrollPositionForScrollToCell',\n    value: function _updateScrollPositionForScrollToCell() {\n      var _props6 = this.props;\n      var cellLayoutManager = _props6.cellLayoutManager;\n      var height = _props6.height;\n      var scrollToAlignment = _props6.scrollToAlignment;\n      var scrollToCell = _props6.scrollToCell;\n      var width = _props6.width;\n      var _state3 = this.state;\n      var scrollLeft = _state3.scrollLeft;\n      var scrollTop = _state3.scrollTop;\n\n\n      if (scrollToCell >= 0) {\n        var scrollPosition = cellLayoutManager.getScrollPositionForCell({\n          align: scrollToAlignment,\n          cellIndex: scrollToCell,\n          height: height,\n          scrollLeft: scrollLeft,\n          scrollTop: scrollTop,\n          width: width\n        });\n\n        if (scrollPosition.scrollLeft !== scrollLeft || scrollPosition.scrollTop !== scrollTop) {\n          this._setScrollPosition(scrollPosition);\n        }\n      }\n    }\n  }, {\n    key: '_onScroll',\n    value: function _onScroll(event) {\n      // In certain edge-cases React dispatches an onScroll event with an invalid target.scrollLeft / target.scrollTop.\n      // This invalid event can be detected by comparing event.target to this component's scrollable DOM element.\n      // See issue #404 for more information.\n      if (event.target !== this._scrollingContainer) {\n        return;\n      }\n\n      // Prevent pointer events from interrupting a smooth scroll\n      this._enablePointerEventsAfterDelay();\n\n      // When this component is shrunk drastically, React dispatches a series of back-to-back scroll events,\n      // Gradually converging on a scrollTop that is within the bounds of the new, smaller height.\n      // This causes a series of rapid renders that is slow for long lists.\n      // We can avoid that by doing some simple bounds checking to ensure that scrollTop never exceeds the total height.\n      var _props7 = this.props;\n      var cellLayoutManager = _props7.cellLayoutManager;\n      var height = _props7.height;\n      var isScrollingChange = _props7.isScrollingChange;\n      var width = _props7.width;\n\n      var scrollbarSize = this._scrollbarSize;\n\n      var _cellLayoutManager$ge3 = cellLayoutManager.getTotalSize();\n\n      var totalHeight = _cellLayoutManager$ge3.height;\n      var totalWidth = _cellLayoutManager$ge3.width;\n\n      var scrollLeft = Math.max(0, Math.min(totalWidth - width + scrollbarSize, event.target.scrollLeft));\n      var scrollTop = Math.max(0, Math.min(totalHeight - height + scrollbarSize, event.target.scrollTop));\n\n      // Certain devices (like Apple touchpad) rapid-fire duplicate events.\n      // Don't force a re-render if this is the case.\n      // The mouse may move faster then the animation frame does.\n      // Use requestAnimationFrame to avoid over-updating.\n      if (this.state.scrollLeft !== scrollLeft || this.state.scrollTop !== scrollTop) {\n        // Browsers with cancelable scroll events (eg. Firefox) interrupt scrolling animations if scrollTop/scrollLeft is set.\n        // Other browsers (eg. Safari) don't scroll as well without the help under certain conditions (DOM or style changes during scrolling).\n        // All things considered, this seems to be the best current work around that I'm aware of.\n        // For more information see https://github.com/bvaughn/react-virtualized/pull/124\n        var scrollPositionChangeReason = event.cancelable ? SCROLL_POSITION_CHANGE_REASONS.OBSERVED : SCROLL_POSITION_CHANGE_REASONS.REQUESTED;\n\n        // Synchronously set :isScrolling the first time (since _setNextState will reschedule its animation frame each time it's called)\n        if (!this.state.isScrolling) {\n          isScrollingChange(true);\n\n          this.setState({\n            isScrolling: true\n          });\n        }\n\n        this._setNextState({\n          isScrolling: true,\n          scrollLeft: scrollLeft,\n          scrollPositionChangeReason: scrollPositionChangeReason,\n          scrollTop: scrollTop\n        });\n      }\n\n      this._invokeOnScrollMemoizer({\n        scrollLeft: scrollLeft,\n        scrollTop: scrollTop,\n        totalWidth: totalWidth,\n        totalHeight: totalHeight\n      });\n    }\n  }]);\n\n  return CollectionView;\n}(_react.Component);\n\nCollectionView.propTypes = {\n  'aria-label': _react.PropTypes.string,\n\n  /**\n   * Removes fixed height from the scrollingContainer so that the total height\n   * of rows can stretch the window. Intended for use with WindowScroller\n   */\n  autoHeight: _react.PropTypes.bool,\n\n  /**\n   * Number of cells in collection.\n   */\n  cellCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Calculates cell sizes and positions and manages rendering the appropriate cells given a specified window.\n   */\n  cellLayoutManager: _react.PropTypes.object.isRequired,\n\n  /**\n   * Optional custom CSS class name to attach to root Collection element.\n   */\n  className: _react.PropTypes.string,\n\n  /**\n   * Height of Collection; this property determines the number of visible (vs virtualized) rows.\n   */\n  height: _react.PropTypes.number.isRequired,\n\n  /**\n   * Enables the `Collection` to horiontally \"overscan\" its content similar to how `Grid` does.\n   * This can reduce flicker around the edges when a user scrolls quickly.\n   */\n  horizontalOverscanSize: _react.PropTypes.number.isRequired,\n\n  isScrollingChange: _react.PropTypes.func,\n\n  /**\n   * Optional renderer to be used in place of rows when either :rowCount or :cellCount is 0.\n   */\n  noContentRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Callback invoked whenever the scroll offset changes within the inner scrollable region.\n   * This callback can be used to sync scrolling between lists, tables, or grids.\n   * ({ clientHeight, clientWidth, scrollHeight, scrollLeft, scrollTop, scrollWidth }): void\n   */\n  onScroll: _react.PropTypes.func.isRequired,\n\n  /**\n   * Callback invoked with information about the section of the Collection that was just rendered.\n   * This callback is passed a named :indices parameter which is an Array of the most recently rendered section indices.\n   */\n  onSectionRendered: _react.PropTypes.func.isRequired,\n\n  /**\n   * Horizontal offset.\n   */\n  scrollLeft: _react.PropTypes.number,\n\n  /**\n   * Controls scroll-to-cell behavior of the Grid.\n   * The default (\"auto\") scrolls the least amount possible to ensure that the specified cell is fully visible.\n   * Use \"start\" to align cells to the top/left of the Grid and \"end\" to align bottom/right.\n   */\n  scrollToAlignment: _react.PropTypes.oneOf(['auto', 'end', 'start', 'center']).isRequired,\n\n  /**\n   * Cell index to ensure visible (by forcefully scrolling if necessary).\n   */\n  scrollToCell: _react.PropTypes.number,\n\n  /**\n   * Vertical offset.\n   */\n  scrollTop: _react.PropTypes.number,\n\n  /**\n   * Optional custom inline style to attach to root Collection element.\n   */\n  style: _react.PropTypes.object,\n\n  /**\n   * Enables the `Collection` to vertically \"overscan\" its content similar to how `Grid` does.\n   * This can reduce flicker around the edges when a user scrolls quickly.\n   */\n  verticalOverscanSize: _react.PropTypes.number.isRequired,\n\n  /**\n   * Width of Collection; this property determines the number of visible (vs virtualized) columns.\n   */\n  width: _react.PropTypes.number.isRequired\n};\nCollectionView.defaultProps = {\n  'aria-label': 'grid',\n  horizontalOverscanSize: 0,\n  noContentRenderer: function noContentRenderer() {\n    return null;\n  },\n  onScroll: function onScroll() {\n    return null;\n  },\n  onSectionRendered: function onSectionRendered() {\n    return null;\n  },\n  scrollToAlignment: 'auto',\n  style: {},\n  verticalOverscanSize: 0\n};\nexports.default = CollectionView;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\n * A section of the Window.\n * Window Sections are used to group nearby cells.\n * This enables us to more quickly determine which cells to display in a given region of the Window.\n * Sections have a fixed size and contain 0 to many cells (tracked by their indices).\n */\nvar Section = function () {\n  function Section(_ref) {\n    var height = _ref.height;\n    var width = _ref.width;\n    var x = _ref.x;\n    var y = _ref.y;\n\n    _classCallCheck(this, Section);\n\n    this.height = height;\n    this.width = width;\n    this.x = x;\n    this.y = y;\n\n    this._indexMap = {};\n    this._indices = [];\n  }\n\n  /** Add a cell to this section. */\n\n\n  _createClass(Section, [{\n    key: 'addCellIndex',\n    value: function addCellIndex(_ref2) {\n      var index = _ref2.index;\n\n      if (!this._indexMap[index]) {\n        this._indexMap[index] = true;\n        this._indices.push(index);\n      }\n    }\n\n    /** Get all cell indices that have been added to this section. */\n\n  }, {\n    key: 'getCellIndices',\n    value: function getCellIndices() {\n      return this._indices;\n    }\n\n    /** Intended for debugger/test purposes only */\n\n  }, {\n    key: 'toString',\n    value: function toString() {\n      return this.x + ',' + this.y + ' ' + this.width + 'x' + this.height;\n    }\n  }]);\n\n  return Section;\n}(); /** @rlow */\n\n\nexports.default = Section;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); /**\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      * Window Sections are used to group nearby cells.\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      * This enables us to more quickly determine which cells to display in a given region of the Window.\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      * \n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      */\n\n\nvar _Section = require('./Section');\n\nvar _Section2 = _interopRequireDefault(_Section);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar SECTION_SIZE = 100;\n\n/**\n * Contains 0 to many Sections.\n * Grows (and adds Sections) dynamically as cells are registered.\n * Automatically adds cells to the appropriate Section(s).\n */\nvar SectionManager = function () {\n  function SectionManager() {\n    var sectionSize = arguments.length <= 0 || arguments[0] === undefined ? SECTION_SIZE : arguments[0];\n\n    _classCallCheck(this, SectionManager);\n\n    this._sectionSize = sectionSize;\n\n    this._cellMetadata = [];\n    this._sections = {};\n  }\n\n  /**\n   * Gets all cell indices contained in the specified region.\n   * A region may encompass 1 or more Sections.\n   */\n\n\n  _createClass(SectionManager, [{\n    key: 'getCellIndices',\n    value: function getCellIndices(_ref) {\n      var height = _ref.height;\n      var width = _ref.width;\n      var x = _ref.x;\n      var y = _ref.y;\n\n      var indices = {};\n\n      this.getSections({ height: height, width: width, x: x, y: y }).forEach(function (section) {\n        return section.getCellIndices().forEach(function (index) {\n          indices[index] = index;\n        });\n      });\n\n      // Object keys are strings; this function returns numbers\n      return Object.keys(indices).map(function (index) {\n        return indices[index];\n      });\n    }\n\n    /** Get size and position information for the cell specified. */\n\n  }, {\n    key: 'getCellMetadata',\n    value: function getCellMetadata(_ref2) {\n      var index = _ref2.index;\n\n      return this._cellMetadata[index];\n    }\n\n    /** Get all Sections overlapping the specified region. */\n\n  }, {\n    key: 'getSections',\n    value: function getSections(_ref3) {\n      var height = _ref3.height;\n      var width = _ref3.width;\n      var x = _ref3.x;\n      var y = _ref3.y;\n\n      var sectionXStart = Math.floor(x / this._sectionSize);\n      var sectionXStop = Math.floor((x + width - 1) / this._sectionSize);\n      var sectionYStart = Math.floor(y / this._sectionSize);\n      var sectionYStop = Math.floor((y + height - 1) / this._sectionSize);\n\n      var sections = [];\n\n      for (var sectionX = sectionXStart; sectionX <= sectionXStop; sectionX++) {\n        for (var sectionY = sectionYStart; sectionY <= sectionYStop; sectionY++) {\n          var key = sectionX + '.' + sectionY;\n\n          if (!this._sections[key]) {\n            this._sections[key] = new _Section2.default({\n              height: this._sectionSize,\n              width: this._sectionSize,\n              x: sectionX * this._sectionSize,\n              y: sectionY * this._sectionSize\n            });\n          }\n\n          sections.push(this._sections[key]);\n        }\n      }\n\n      return sections;\n    }\n\n    /** Total number of Sections based on the currently registered cells. */\n\n  }, {\n    key: 'getTotalSectionCount',\n    value: function getTotalSectionCount() {\n      return Object.keys(this._sections).length;\n    }\n\n    /** Intended for debugger/test purposes only */\n\n  }, {\n    key: 'toString',\n    value: function toString() {\n      var _this = this;\n\n      return Object.keys(this._sections).map(function (index) {\n        return _this._sections[index].toString();\n      });\n    }\n\n    /** Adds a cell to the appropriate Sections and registers it metadata for later retrievable. */\n\n  }, {\n    key: 'registerCell',\n    value: function registerCell(_ref4) {\n      var cellMetadatum = _ref4.cellMetadatum;\n      var index = _ref4.index;\n\n      this._cellMetadata[index] = cellMetadatum;\n\n      this.getSections(cellMetadatum).forEach(function (section) {\n        return section.addCellIndex({ index: index });\n      });\n    }\n  }]);\n\n  return SectionManager;\n}();\n\nexports.default = SectionManager;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.Collection = exports.default = undefined;\n\nvar _Collection2 = require('./Collection');\n\nvar _Collection3 = _interopRequireDefault(_Collection2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _Collection3.default;\nexports.Collection = _Collection3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = calculateSizeAndPositionData;\n\nvar _SectionManager = require('../SectionManager');\n\nvar _SectionManager2 = _interopRequireDefault(_SectionManager);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction calculateSizeAndPositionData(_ref) {\n  var cellCount = _ref.cellCount;\n  var cellSizeAndPositionGetter = _ref.cellSizeAndPositionGetter;\n  var sectionSize = _ref.sectionSize;\n\n  var cellMetadata = [];\n  var sectionManager = new _SectionManager2.default(sectionSize);\n  var height = 0;\n  var width = 0;\n\n  for (var index = 0; index < cellCount; index++) {\n    var cellMetadatum = cellSizeAndPositionGetter({ index: index });\n\n    if (cellMetadatum.height == null || isNaN(cellMetadatum.height) || cellMetadatum.width == null || isNaN(cellMetadatum.width) || cellMetadatum.x == null || isNaN(cellMetadatum.x) || cellMetadatum.y == null || isNaN(cellMetadatum.y)) {\n      throw Error('Invalid metadata returned for cell ' + index + ':\\n        x:' + cellMetadatum.x + ', y:' + cellMetadatum.y + ', width:' + cellMetadatum.width + ', height:' + cellMetadatum.height);\n    }\n\n    height = Math.max(height, cellMetadatum.y + cellMetadatum.height);\n    width = Math.max(width, cellMetadatum.x + cellMetadatum.width);\n\n    cellMetadata[index] = cellMetadatum;\n    sectionManager.registerCell({\n      cellMetadatum: cellMetadatum,\n      index: index\n    });\n  }\n\n  return {\n    cellMetadata: cellMetadata,\n    height: height,\n    sectionManager: sectionManager,\n    width: width\n  };\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nvar _Grid = require('../Grid');\n\nvar _Grid2 = _interopRequireDefault(_Grid);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * High-order component that auto-calculates column-widths for `Grid` cells.\n */\nvar ColumnSizer = function (_Component) {\n  _inherits(ColumnSizer, _Component);\n\n  function ColumnSizer(props, context) {\n    _classCallCheck(this, ColumnSizer);\n\n    var _this = _possibleConstructorReturn(this, (ColumnSizer.__proto__ || Object.getPrototypeOf(ColumnSizer)).call(this, props, context));\n\n    _this._registerChild = _this._registerChild.bind(_this);\n    return _this;\n  }\n\n  _createClass(ColumnSizer, [{\n    key: 'componentDidUpdate',\n    value: function componentDidUpdate(prevProps, prevState) {\n      var _props = this.props;\n      var columnMaxWidth = _props.columnMaxWidth;\n      var columnMinWidth = _props.columnMinWidth;\n      var columnCount = _props.columnCount;\n      var width = _props.width;\n\n\n      if (columnMaxWidth !== prevProps.columnMaxWidth || columnMinWidth !== prevProps.columnMinWidth || columnCount !== prevProps.columnCount || width !== prevProps.width) {\n        if (this._registeredChild) {\n          this._registeredChild.recomputeGridSize();\n        }\n      }\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _props2 = this.props;\n      var children = _props2.children;\n      var columnMaxWidth = _props2.columnMaxWidth;\n      var columnMinWidth = _props2.columnMinWidth;\n      var columnCount = _props2.columnCount;\n      var width = _props2.width;\n\n\n      var safeColumnMinWidth = columnMinWidth || 1;\n\n      var safeColumnMaxWidth = columnMaxWidth ? Math.min(columnMaxWidth, width) : width;\n\n      var columnWidth = width / columnCount;\n      columnWidth = Math.max(safeColumnMinWidth, columnWidth);\n      columnWidth = Math.min(safeColumnMaxWidth, columnWidth);\n      columnWidth = Math.floor(columnWidth);\n\n      var adjustedWidth = Math.min(width, columnWidth * columnCount);\n\n      return children({\n        adjustedWidth: adjustedWidth,\n        getColumnWidth: function getColumnWidth() {\n          return columnWidth;\n        },\n        registerChild: this._registerChild\n      });\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_registerChild',\n    value: function _registerChild(child) {\n      if (child !== null && !(child instanceof _Grid2.default)) {\n        throw Error('Unexpected child type registered; only Grid children are supported.');\n      }\n\n      this._registeredChild = child;\n\n      if (this._registeredChild) {\n        this._registeredChild.recomputeGridSize();\n      }\n    }\n  }]);\n\n  return ColumnSizer;\n}(_react.Component);\n\nColumnSizer.propTypes = {\n  /**\n   * Function respondible for rendering a virtualized Grid.\n   * This function should implement the following signature:\n   * ({ adjustedWidth, getColumnWidth, registerChild }) => PropTypes.element\n   *\n   * The specified :getColumnWidth function should be passed to the Grid's :columnWidth property.\n   * The :registerChild should be passed to the Grid's :ref property.\n   * The :adjustedWidth property is optional; it reflects the lesser of the overall width or the width of all columns.\n   */\n  children: _react.PropTypes.func.isRequired,\n\n  /** Optional maximum allowed column width */\n  columnMaxWidth: _react.PropTypes.number,\n\n  /** Optional minimum allowed column width */\n  columnMinWidth: _react.PropTypes.number,\n\n  /** Number of columns in Grid or FlexTable child */\n  columnCount: _react.PropTypes.number.isRequired,\n\n  /** Width of Grid or FlexTable child */\n  width: _react.PropTypes.number.isRequired\n};\nexports.default = ColumnSizer;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.ColumnSizer = exports.default = undefined;\n\nvar _ColumnSizer2 = require('./ColumnSizer');\n\nvar _ColumnSizer3 = _interopRequireDefault(_ColumnSizer2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _ColumnSizer3.default;\nexports.ColumnSizer = _ColumnSizer3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _react = require('react');\n\nvar _defaultHeaderRenderer = require('./defaultHeaderRenderer');\n\nvar _defaultHeaderRenderer2 = _interopRequireDefault(_defaultHeaderRenderer);\n\nvar _defaultCellRenderer = require('./defaultCellRenderer');\n\nvar _defaultCellRenderer2 = _interopRequireDefault(_defaultCellRenderer);\n\nvar _defaultCellDataGetter = require('./defaultCellDataGetter');\n\nvar _defaultCellDataGetter2 = _interopRequireDefault(_defaultCellDataGetter);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * Describes the header and cell contents of a table column.\n */\nvar Column = function (_Component) {\n  _inherits(Column, _Component);\n\n  function Column() {\n    _classCallCheck(this, Column);\n\n    return _possibleConstructorReturn(this, (Column.__proto__ || Object.getPrototypeOf(Column)).apply(this, arguments));\n  }\n\n  return Column;\n}(_react.Component);\n\nColumn.defaultProps = {\n  cellDataGetter: _defaultCellDataGetter2.default,\n  cellRenderer: _defaultCellRenderer2.default,\n  flexGrow: 0,\n  flexShrink: 1,\n  headerRenderer: _defaultHeaderRenderer2.default,\n  style: {}\n};\nColumn.propTypes = {\n  /** Optional aria-label value to set on the column header */\n  'aria-label': _react.PropTypes.string,\n\n  /**\n   * Callback responsible for returning a cell's data, given its :dataKey\n   * ({ columnData: any, dataKey: string, rowData: any }): any\n   */\n  cellDataGetter: _react.PropTypes.func,\n\n  /**\n   * Callback responsible for rendering a cell's contents.\n   * ({ cellData: any, columnData: any, dataKey: string, rowData: any, rowIndex: number }): node\n   */\n  cellRenderer: _react.PropTypes.func,\n\n  /** Optional CSS class to apply to cell */\n  className: _react.PropTypes.string,\n\n  /** Optional additional data passed to this column's :cellDataGetter */\n  columnData: _react.PropTypes.object,\n\n  /** Uniquely identifies the row-data attribute correspnding to this cell */\n  dataKey: _react.PropTypes.any.isRequired,\n\n  /** If sort is enabled for the table at large, disable it for this column */\n  disableSort: _react.PropTypes.bool,\n\n  /** Flex grow style; defaults to 0 */\n  flexGrow: _react.PropTypes.number,\n\n  /** Flex shrink style; defaults to 1 */\n  flexShrink: _react.PropTypes.number,\n\n  /** Optional CSS class to apply to this column's header */\n  headerClassName: _react.PropTypes.string,\n\n  /**\n   * Optional callback responsible for rendering a column header contents.\n   * ({ columnData: object, dataKey: string, disableSort: boolean, label: string, sortBy: string, sortDirection: string }): PropTypes.node\n   */\n  headerRenderer: _react.PropTypes.func.isRequired,\n\n  /** Header label for this column */\n  label: _react.PropTypes.string,\n\n  /** Maximum width of column; this property will only be used if :flexGrow is > 0. */\n  maxWidth: _react.PropTypes.number,\n\n  /** Minimum width of column. */\n  minWidth: _react.PropTypes.number,\n\n  /** Optional inline style to apply to cell */\n  style: _react.PropTypes.object,\n\n  /** Flex basis (width) for this column; This value can grow or shrink based on :flexGrow and :flexShrink properties. */\n  width: _react.PropTypes.number.isRequired\n};\nexports.default = Column;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _classnames = require('classnames');\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nvar _FlexColumn = require('./FlexColumn');\n\nvar _FlexColumn2 = _interopRequireDefault(_FlexColumn);\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactDom = require('react-dom');\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nvar _Grid = require('../Grid');\n\nvar _Grid2 = _interopRequireDefault(_Grid);\n\nvar _defaultRowRenderer = require('./defaultRowRenderer');\n\nvar _defaultRowRenderer2 = _interopRequireDefault(_defaultRowRenderer);\n\nvar _SortDirection = require('./SortDirection');\n\nvar _SortDirection2 = _interopRequireDefault(_SortDirection);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * Table component with fixed headers and virtualized rows for improved performance with large data sets.\n * This component expects explicit width, height, and padding parameters.\n */\nvar FlexTable = function (_Component) {\n  _inherits(FlexTable, _Component);\n\n  function FlexTable(props) {\n    _classCallCheck(this, FlexTable);\n\n    var _this = _possibleConstructorReturn(this, (FlexTable.__proto__ || Object.getPrototypeOf(FlexTable)).call(this, props));\n\n    _this.state = {\n      scrollbarWidth: 0\n    };\n\n    _this._cellClassName = _this._cellClassName.bind(_this);\n    _this._cellStyle = _this._cellStyle.bind(_this);\n    _this._createColumn = _this._createColumn.bind(_this);\n    _this._createRow = _this._createRow.bind(_this);\n    _this._onScroll = _this._onScroll.bind(_this);\n    _this._onSectionRendered = _this._onSectionRendered.bind(_this);\n    return _this;\n  }\n\n  _createClass(FlexTable, [{\n    key: 'forceUpdateGrid',\n    value: function forceUpdateGrid() {\n      this.Grid.forceUpdate();\n    }\n\n    /** See Grid#measureAllCells */\n\n  }, {\n    key: 'measureAllRows',\n    value: function measureAllRows() {\n      this.Grid.measureAllCells();\n    }\n\n    /** See Grid#recomputeGridSize */\n\n  }, {\n    key: 'recomputeRowHeights',\n    value: function recomputeRowHeights() {\n      var index = arguments.length <= 0 || arguments[0] === undefined ? 0 : arguments[0];\n\n      this.Grid.recomputeGridSize({\n        rowIndex: index\n      });\n      this.forceUpdateGrid();\n    }\n  }, {\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      this._setScrollbarWidth();\n    }\n  }, {\n    key: 'componentDidUpdate',\n    value: function componentDidUpdate() {\n      this._setScrollbarWidth();\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _this2 = this;\n\n      var _props = this.props;\n      var children = _props.children;\n      var className = _props.className;\n      var disableHeader = _props.disableHeader;\n      var gridClassName = _props.gridClassName;\n      var gridStyle = _props.gridStyle;\n      var headerHeight = _props.headerHeight;\n      var height = _props.height;\n      var noRowsRenderer = _props.noRowsRenderer;\n      var rowClassName = _props.rowClassName;\n      var rowStyle = _props.rowStyle;\n      var scrollToIndex = _props.scrollToIndex;\n      var style = _props.style;\n      var width = _props.width;\n      var scrollbarWidth = this.state.scrollbarWidth;\n\n\n      var availableRowsHeight = height - headerHeight;\n\n      var rowClass = rowClassName instanceof Function ? rowClassName({ index: -1 }) : rowClassName;\n      var rowStyleObject = rowStyle instanceof Function ? rowStyle({ index: -1 }) : rowStyle;\n\n      // Precompute and cache column styles before rendering rows and columns to speed things up\n      this._cachedColumnStyles = [];\n      _react2.default.Children.toArray(children).forEach(function (column, index) {\n        _this2._cachedColumnStyles[index] = _this2._getFlexStyleForColumn(column, column.props.style);\n      });\n\n      // Note that we specify :numChildren, :scrollbarWidth, :sortBy, and :sortDirection as properties on Grid even though these have nothing to do with Grid.\n      // This is done because Grid is a pure component and won't update unless its properties or state has changed.\n      // Any property that should trigger a re-render of Grid then is specified here to avoid a stale display.\n      return _react2.default.createElement(\n        'div',\n        {\n          className: (0, _classnames2.default)('FlexTable', className),\n          style: style\n        },\n        !disableHeader && _react2.default.createElement(\n          'div',\n          {\n            className: (0, _classnames2.default)('FlexTable__headerRow', rowClass),\n            style: _extends({}, rowStyleObject, {\n              height: headerHeight,\n              paddingRight: scrollbarWidth,\n              width: width\n            })\n          },\n          this._getRenderedHeaderRow()\n        ),\n        _react2.default.createElement(_Grid2.default, _extends({}, this.props, {\n          autoContainerWidth: true,\n          className: (0, _classnames2.default)('FlexTable__Grid', gridClassName),\n          cellClassName: this._cellClassName,\n          cellRenderer: this._createRow,\n          cellStyle: this._cellStyle,\n          columnWidth: width,\n          columnCount: 1,\n          height: availableRowsHeight,\n          noContentRenderer: noRowsRenderer,\n          onScroll: this._onScroll,\n          onSectionRendered: this._onSectionRendered,\n          ref: function ref(_ref) {\n            _this2.Grid = _ref;\n          },\n          scrollbarWidth: scrollbarWidth,\n          scrollToRow: scrollToIndex,\n          style: gridStyle\n        }))\n      );\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_cellClassName',\n    value: function _cellClassName(_ref2) {\n      var rowIndex = _ref2.rowIndex;\n      var rowWrapperClassName = this.props.rowWrapperClassName;\n\n\n      return rowWrapperClassName instanceof Function ? rowWrapperClassName({ index: rowIndex - 1 }) : rowWrapperClassName;\n    }\n  }, {\n    key: '_cellStyle',\n    value: function _cellStyle(_ref3) {\n      var rowIndex = _ref3.rowIndex;\n      var rowWrapperStyle = this.props.rowWrapperStyle;\n\n\n      return rowWrapperStyle instanceof Function ? rowWrapperStyle({ index: rowIndex - 1 }) : rowWrapperStyle;\n    }\n  }, {\n    key: '_createColumn',\n    value: function _createColumn(_ref4) {\n      var column = _ref4.column;\n      var columnIndex = _ref4.columnIndex;\n      var isScrolling = _ref4.isScrolling;\n      var rowData = _ref4.rowData;\n      var rowIndex = _ref4.rowIndex;\n      var _column$props = column.props;\n      var cellDataGetter = _column$props.cellDataGetter;\n      var cellRenderer = _column$props.cellRenderer;\n      var className = _column$props.className;\n      var columnData = _column$props.columnData;\n      var dataKey = _column$props.dataKey;\n\n\n      var cellData = cellDataGetter({ columnData: columnData, dataKey: dataKey, rowData: rowData });\n      var renderedCell = cellRenderer({ cellData: cellData, columnData: columnData, dataKey: dataKey, isScrolling: isScrolling, rowData: rowData, rowIndex: rowIndex });\n\n      var style = this._cachedColumnStyles[columnIndex];\n\n      var title = typeof renderedCell === 'string' ? renderedCell : null;\n\n      return _react2.default.createElement(\n        'div',\n        {\n          key: 'Row' + rowIndex + '-Col' + columnIndex,\n          className: (0, _classnames2.default)('FlexTable__rowColumn', className),\n          style: style,\n          title: title\n        },\n        renderedCell\n      );\n    }\n  }, {\n    key: '_createHeader',\n    value: function _createHeader(_ref5) {\n      var column = _ref5.column;\n      var index = _ref5.index;\n      var _props2 = this.props;\n      var headerClassName = _props2.headerClassName;\n      var headerStyle = _props2.headerStyle;\n      var onHeaderClick = _props2.onHeaderClick;\n      var sort = _props2.sort;\n      var sortBy = _props2.sortBy;\n      var sortDirection = _props2.sortDirection;\n      var _column$props2 = column.props;\n      var dataKey = _column$props2.dataKey;\n      var disableSort = _column$props2.disableSort;\n      var headerRenderer = _column$props2.headerRenderer;\n      var label = _column$props2.label;\n      var columnData = _column$props2.columnData;\n\n      var sortEnabled = !disableSort && sort;\n\n      var classNames = (0, _classnames2.default)('FlexTable__headerColumn', headerClassName, column.props.headerClassName, {\n        'FlexTable__sortableHeaderColumn': sortEnabled\n      });\n      var style = this._getFlexStyleForColumn(column, headerStyle);\n\n      var renderedHeader = headerRenderer({\n        columnData: columnData,\n        dataKey: dataKey,\n        disableSort: disableSort,\n        label: label,\n        sortBy: sortBy,\n        sortDirection: sortDirection\n      });\n\n      var a11yProps = {};\n\n      if (sortEnabled || onHeaderClick) {\n        (function () {\n          // If this is a sortable header, clicking it should update the table data's sorting.\n          var newSortDirection = sortBy !== dataKey || sortDirection === _SortDirection2.default.DESC ? _SortDirection2.default.ASC : _SortDirection2.default.DESC;\n\n          var onClick = function onClick() {\n            sortEnabled && sort({\n              sortBy: dataKey,\n              sortDirection: newSortDirection\n            });\n            onHeaderClick && onHeaderClick({ columnData: columnData, dataKey: dataKey });\n          };\n\n          var onKeyDown = function onKeyDown(event) {\n            if (event.key === 'Enter' || event.key === ' ') {\n              onClick();\n            }\n          };\n\n          a11yProps['aria-label'] = column.props['aria-label'] || label || dataKey;\n          a11yProps.role = 'rowheader';\n          a11yProps.tabIndex = 0;\n          a11yProps.onClick = onClick;\n          a11yProps.onKeyDown = onKeyDown;\n        })();\n      }\n\n      return _react2.default.createElement(\n        'div',\n        _extends({}, a11yProps, {\n          key: 'Header-Col' + index,\n          className: classNames,\n          style: style\n        }),\n        renderedHeader\n      );\n    }\n  }, {\n    key: '_createRow',\n    value: function _createRow(_ref6) {\n      var _this3 = this;\n\n      var index = _ref6.rowIndex;\n      var isScrolling = _ref6.isScrolling;\n      var _props3 = this.props;\n      var children = _props3.children;\n      var onRowClick = _props3.onRowClick;\n      var onRowDoubleClick = _props3.onRowDoubleClick;\n      var onRowMouseOver = _props3.onRowMouseOver;\n      var onRowMouseOut = _props3.onRowMouseOut;\n      var rowClassName = _props3.rowClassName;\n      var rowGetter = _props3.rowGetter;\n      var rowRenderer = _props3.rowRenderer;\n      var rowStyle = _props3.rowStyle;\n      var scrollbarWidth = this.state.scrollbarWidth;\n\n\n      var rowClass = rowClassName instanceof Function ? rowClassName({ index: index }) : rowClassName;\n      var rowStyleObject = rowStyle instanceof Function ? rowStyle({ index: index }) : rowStyle;\n      var rowData = rowGetter({ index: index });\n\n      var columns = _react2.default.Children.toArray(children).map(function (column, columnIndex) {\n        return _this3._createColumn({\n          column: column,\n          columnIndex: columnIndex,\n          isScrolling: isScrolling,\n          rowData: rowData,\n          rowIndex: index,\n          scrollbarWidth: scrollbarWidth\n        });\n      });\n\n      var className = (0, _classnames2.default)('FlexTable__row', rowClass);\n      var style = _extends({}, rowStyleObject, {\n        height: this._getRowHeight(index),\n        paddingRight: scrollbarWidth\n      });\n\n      return rowRenderer({\n        className: className,\n        columns: columns,\n        index: index,\n        isScrolling: isScrolling,\n        onRowClick: onRowClick,\n        onRowDoubleClick: onRowDoubleClick,\n        onRowMouseOver: onRowMouseOver,\n        onRowMouseOut: onRowMouseOut,\n        rowData: rowData,\n        style: style\n      });\n    }\n\n    /**\n     * Determines the flex-shrink, flex-grow, and width values for a cell (header or column).\n     */\n\n  }, {\n    key: '_getFlexStyleForColumn',\n    value: function _getFlexStyleForColumn(column) {\n      var customStyle = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1];\n\n      var flexValue = column.props.flexGrow + ' ' + column.props.flexShrink + ' ' + column.props.width + 'px';\n\n      var style = _extends({}, customStyle, {\n        flex: flexValue,\n        msFlex: flexValue,\n        WebkitFlex: flexValue\n      });\n\n      if (column.props.maxWidth) {\n        style.maxWidth = column.props.maxWidth;\n      }\n\n      if (column.props.minWidth) {\n        style.minWidth = column.props.minWidth;\n      }\n\n      return style;\n    }\n  }, {\n    key: '_getRenderedHeaderRow',\n    value: function _getRenderedHeaderRow() {\n      var _this4 = this;\n\n      var _props4 = this.props;\n      var children = _props4.children;\n      var disableHeader = _props4.disableHeader;\n\n      var items = disableHeader ? [] : _react2.default.Children.toArray(children);\n\n      return items.map(function (column, index) {\n        return _this4._createHeader({ column: column, index: index });\n      });\n    }\n  }, {\n    key: '_getRowHeight',\n    value: function _getRowHeight(rowIndex) {\n      var rowHeight = this.props.rowHeight;\n\n\n      return rowHeight instanceof Function ? rowHeight({ index: rowIndex }) : rowHeight;\n    }\n  }, {\n    key: '_onScroll',\n    value: function _onScroll(_ref7) {\n      var clientHeight = _ref7.clientHeight;\n      var scrollHeight = _ref7.scrollHeight;\n      var scrollTop = _ref7.scrollTop;\n      var onScroll = this.props.onScroll;\n\n\n      onScroll({ clientHeight: clientHeight, scrollHeight: scrollHeight, scrollTop: scrollTop });\n    }\n  }, {\n    key: '_onSectionRendered',\n    value: function _onSectionRendered(_ref8) {\n      var rowOverscanStartIndex = _ref8.rowOverscanStartIndex;\n      var rowOverscanStopIndex = _ref8.rowOverscanStopIndex;\n      var rowStartIndex = _ref8.rowStartIndex;\n      var rowStopIndex = _ref8.rowStopIndex;\n      var onRowsRendered = this.props.onRowsRendered;\n\n\n      onRowsRendered({\n        overscanStartIndex: rowOverscanStartIndex,\n        overscanStopIndex: rowOverscanStopIndex,\n        startIndex: rowStartIndex,\n        stopIndex: rowStopIndex\n      });\n    }\n  }, {\n    key: '_setScrollbarWidth',\n    value: function _setScrollbarWidth() {\n      var Grid = (0, _reactDom.findDOMNode)(this.Grid);\n      var clientWidth = Grid.clientWidth || 0;\n      var offsetWidth = Grid.offsetWidth || 0;\n      var scrollbarWidth = offsetWidth - clientWidth;\n\n      this.setState({ scrollbarWidth: scrollbarWidth });\n    }\n  }]);\n\n  return FlexTable;\n}(_react.Component);\n\nFlexTable.propTypes = {\n  'aria-label': _react.PropTypes.string,\n\n  /**\n   * Removes fixed height from the scrollingContainer so that the total height\n   * of rows can stretch the window. Intended for use with WindowScroller\n   */\n  autoHeight: _react.PropTypes.bool,\n\n  /** One or more FlexColumns describing the data displayed in this row */\n  children: function children(props, propName, componentName) {\n    var children = _react2.default.Children.toArray(props.children);\n    for (var i = 0; i < children.length; i++) {\n      if (children[i].type !== _FlexColumn2.default) {\n        return new Error('FlexTable only accepts children of type FlexColumn');\n      }\n    }\n  },\n\n  /** Optional CSS class name */\n  className: _react.PropTypes.string,\n\n  /** Disable rendering the header at all */\n  disableHeader: _react.PropTypes.bool,\n\n  /**\n   * Used to estimate the total height of a FlexTable before all of its rows have actually been measured.\n   * The estimated total height is adjusted as rows are rendered.\n   */\n  estimatedRowSize: _react.PropTypes.number.isRequired,\n\n  /** Optional custom CSS class name to attach to inner Grid element. */\n  gridClassName: _react.PropTypes.string,\n\n  /** Optional inline style to attach to inner Grid element. */\n  gridStyle: _react.PropTypes.object,\n\n  /** Optional CSS class to apply to all column headers */\n  headerClassName: _react.PropTypes.string,\n\n  /** Fixed height of header row */\n  headerHeight: _react.PropTypes.number.isRequired,\n\n  /** Fixed/available height for out DOM element */\n  height: _react.PropTypes.number.isRequired,\n\n  /** Optional renderer to be used in place of table body rows when rowCount is 0 */\n  noRowsRenderer: _react.PropTypes.func,\n\n  /**\n  * Optional callback when a column's header is clicked.\n  * ({ columnData: any, dataKey: string }): void\n  */\n  onHeaderClick: _react.PropTypes.func,\n\n  /** Optional custom inline style to attach to table header columns. */\n  headerStyle: _react.PropTypes.object,\n\n  /**\n   * Callback invoked when a user clicks on a table row.\n   * ({ index: number }): void\n   */\n  onRowClick: _react.PropTypes.func,\n\n  /**\n   * Callback invoked when a user double-clicks on a table row.\n   * ({ index: number }): void\n   */\n  onRowDoubleClick: _react.PropTypes.func,\n\n  /**\n   * Callback invoked when the mouse leaves a table row.\n   * ({ index: number }): void\n   */\n  onRowMouseOut: _react.PropTypes.func,\n\n  /**\n   * Callback invoked when a user moves the mouse over a table row.\n   * ({ index: number }): void\n   */\n  onRowMouseOver: _react.PropTypes.func,\n\n  /**\n   * Callback invoked with information about the slice of rows that were just rendered.\n   * ({ startIndex, stopIndex }): void\n   */\n  onRowsRendered: _react.PropTypes.func,\n\n  /**\n   * Callback invoked whenever the scroll offset changes within the inner scrollable region.\n   * This callback can be used to sync scrolling between lists, tables, or grids.\n   * ({ clientHeight, scrollHeight, scrollTop }): void\n   */\n  onScroll: _react.PropTypes.func.isRequired,\n\n  /**\n   * Number of rows to render above/below the visible bounds of the list.\n   * These rows can help for smoother scrolling on touch devices.\n   */\n  overscanRowCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Optional CSS class to apply to all table rows (including the header row).\n   * This property can be a CSS class name (string) or a function that returns a class name.\n   * If a function is provided its signature should be: ({ index: number }): string\n   */\n  rowClassName: _react.PropTypes.oneOfType([_react.PropTypes.string, _react.PropTypes.func]),\n\n  /**\n   * Callback responsible for returning a data row given an index.\n   * ({ index: number }): any\n   */\n  rowGetter: _react.PropTypes.func.isRequired,\n\n  /**\n   * Either a fixed row height (number) or a function that returns the height of a row given its index.\n   * ({ index: number }): number\n   */\n  rowHeight: _react.PropTypes.oneOfType([_react.PropTypes.number, _react.PropTypes.func]).isRequired,\n\n  /** Number of rows in table. */\n  rowCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Responsible for rendering a table row given an array of columns:\n   * Should implement the following interface: ({\n   *   className: string,\n   *   columns: Array,\n   *   index: number,\n   *   isScrolling: boolean,\n   *   onRowClick: ?Function,\n   *   onRowDoubleClick: ?Function,\n   *   onRowMouseOver: ?Function,\n   *   onRowMouseOut: ?Function,\n   *   rowData: any,\n   *   style: any\n   * }): PropTypes.node\n   */\n  rowRenderer: _react.PropTypes.func,\n\n  /** Optional custom inline style to attach to table rows. */\n  rowStyle: _react.PropTypes.oneOfType([_react.PropTypes.object, _react.PropTypes.func]).isRequired,\n\n  /** Optional custom CSS class for individual rows */\n  rowWrapperClassName: _react.PropTypes.oneOfType([_react.PropTypes.string, _react.PropTypes.func]),\n\n  /** Optional custom CSS class for individual rows */\n  rowWrapperStyle: _react.PropTypes.oneOfType([_react.PropTypes.object, _react.PropTypes.func]),\n\n  /** See Grid#scrollToAlignment */\n  scrollToAlignment: _react.PropTypes.oneOf(['auto', 'end', 'start', 'center']).isRequired,\n\n  /** Row index to ensure visible (by forcefully scrolling if necessary) */\n  scrollToIndex: _react.PropTypes.number,\n\n  /** Vertical offset. */\n  scrollTop: _react.PropTypes.number,\n\n  /**\n   * Sort function to be called if a sortable header is clicked.\n   * ({ sortBy: string, sortDirection: SortDirection }): void\n   */\n  sort: _react.PropTypes.func,\n\n  /** FlexTable data is currently sorted by this :dataKey (if it is sorted at all) */\n  sortBy: _react.PropTypes.string,\n\n  /** FlexTable data is currently sorted in this direction (if it is sorted at all) */\n  sortDirection: _react.PropTypes.oneOf([_SortDirection2.default.ASC, _SortDirection2.default.DESC]),\n\n  /** Optional inline style */\n  style: _react.PropTypes.object,\n\n  /** Tab index for focus */\n  tabIndex: _react.PropTypes.number,\n\n  /** Width of list */\n  width: _react.PropTypes.number.isRequired\n};\nFlexTable.defaultProps = {\n  disableHeader: false,\n  estimatedRowSize: 30,\n  headerHeight: 0,\n  headerStyle: {},\n  noRowsRenderer: function noRowsRenderer() {\n    return null;\n  },\n  onRowsRendered: function onRowsRendered() {\n    return null;\n  },\n  onScroll: function onScroll() {\n    return null;\n  },\n  overscanRowCount: 10,\n  rowRenderer: _defaultRowRenderer2.default,\n  rowStyle: {},\n  scrollToAlignment: 'auto',\n  style: {}\n};\nexports.default = FlexTable;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nvar SortDirection = {\n  /**\n   * Sort items in ascending order.\n   * This means arranging from the lowest value to the highest (e.g. a-z, 0-9).\n   */\n  ASC: 'ASC',\n\n  /**\n   * Sort items in descending order.\n   * This means arranging from the highest value to the lowest (e.g. z-a, 9-0).\n   */\n  DESC: 'DESC'\n};\n\nexports.default = SortDirection;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = SortIndicator;\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _classnames = require('classnames');\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nvar _SortDirection = require('./SortDirection');\n\nvar _SortDirection2 = _interopRequireDefault(_SortDirection);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Displayed beside a header to indicate that a FlexTable is currently sorted by this column.\n */\nfunction SortIndicator(_ref) {\n  var sortDirection = _ref.sortDirection;\n\n  var classNames = (0, _classnames2.default)('FlexTable__sortableHeaderIcon', {\n    'FlexTable__sortableHeaderIcon--ASC': sortDirection === _SortDirection2.default.ASC,\n    'FlexTable__sortableHeaderIcon--DESC': sortDirection === _SortDirection2.default.DESC\n  });\n\n  return _react2.default.createElement(\n    'svg',\n    {\n      className: classNames,\n      width: 18,\n      height: 18,\n      viewBox: '0 0 24 24'\n    },\n    sortDirection === _SortDirection2.default.ASC ? _react2.default.createElement('path', { d: 'M7 14l5-5 5 5z' }) : _react2.default.createElement('path', { d: 'M7 10l5 5 5-5z' }),\n    _react2.default.createElement('path', { d: 'M0 0h24v24H0z', fill: 'none' })\n  );\n}\nSortIndicator.propTypes = {\n  sortDirection: _react.PropTypes.oneOf([_SortDirection2.default.ASC, _SortDirection2.default.DESC])\n};","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = defaultCellDataGetter;\n\n\n/**\n * Default accessor for returning a cell value for a given attribute.\n * This function expects to operate on either a vanilla Object or an Immutable Map.\n * You should override the column's cellDataGetter if your data is some other type of object.\n */\nfunction defaultCellDataGetter(_ref) {\n  var columnData = _ref.columnData;\n  var dataKey = _ref.dataKey;\n  var rowData = _ref.rowData;\n\n  if (rowData.get instanceof Function) {\n    return rowData.get(dataKey);\n  } else {\n    return rowData[dataKey];\n  }\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = defaultCellRenderer;\n\n\n/**\n * Default cell renderer that displays an attribute as a simple string\n * You should override the column's cellRenderer if your data is some other type of object.\n */\nfunction defaultCellRenderer(_ref) {\n  var cellData = _ref.cellData;\n  var cellDataKey = _ref.cellDataKey;\n  var columnData = _ref.columnData;\n  var rowData = _ref.rowData;\n  var rowIndex = _ref.rowIndex;\n\n  if (cellData == null) {\n    return '';\n  } else {\n    return String(cellData);\n  }\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = defaultHeaderRenderer;\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _SortIndicator = require('./SortIndicator');\n\nvar _SortIndicator2 = _interopRequireDefault(_SortIndicator);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Default table header renderer.\n */\nfunction defaultHeaderRenderer(_ref) {\n  var columnData = _ref.columnData;\n  var dataKey = _ref.dataKey;\n  var disableSort = _ref.disableSort;\n  var label = _ref.label;\n  var sortBy = _ref.sortBy;\n  var sortDirection = _ref.sortDirection;\n\n  var showSortIndicator = sortBy === dataKey;\n  var children = [_react2.default.createElement(\n    'span',\n    {\n      className: 'FlexTable__headerTruncatedText',\n      key: 'label',\n      title: label\n    },\n    label\n  )];\n\n  if (showSortIndicator) {\n    children.push(_react2.default.createElement(_SortIndicator2.default, {\n      key: 'SortIndicator',\n      sortDirection: sortDirection\n    }));\n  }\n\n  return children;\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nexports.default = defaultRowRenderer;\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Default row renderer for FlexTable.\n */\nfunction defaultRowRenderer(_ref) {\n  var className = _ref.className;\n  var columns = _ref.columns;\n  var index = _ref.index;\n  var isScrolling = _ref.isScrolling;\n  var onRowClick = _ref.onRowClick;\n  var onRowDoubleClick = _ref.onRowDoubleClick;\n  var onRowMouseOver = _ref.onRowMouseOver;\n  var onRowMouseOut = _ref.onRowMouseOut;\n  var rowData = _ref.rowData;\n  var style = _ref.style;\n\n  var a11yProps = {};\n\n  if (onRowClick || onRowDoubleClick || onRowMouseOver || onRowMouseOut) {\n    a11yProps['aria-label'] = 'row';\n    a11yProps.role = 'row';\n    a11yProps.tabIndex = 0;\n\n    if (onRowClick) {\n      a11yProps.onClick = function () {\n        return onRowClick({ index: index });\n      };\n    }\n    if (onRowDoubleClick) {\n      a11yProps.onDoubleClick = function () {\n        return onRowDoubleClick({ index: index });\n      };\n    }\n    if (onRowMouseOut) {\n      a11yProps.onMouseOut = function () {\n        return onRowMouseOut({ index: index });\n      };\n    }\n    if (onRowMouseOver) {\n      a11yProps.onMouseOver = function () {\n        return onRowMouseOver({ index: index });\n      };\n    }\n  }\n\n  return _react2.default.createElement(\n    'div',\n    _extends({}, a11yProps, {\n      className: className,\n      style: style\n    }),\n    columns\n  );\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.SortIndicator = exports.SortDirection = exports.FlexColumn = exports.FlexTable = exports.defaultRowRenderer = exports.defaultHeaderRenderer = exports.defaultCellRenderer = exports.defaultCellDataGetter = exports.default = undefined;\n\nvar _FlexTable2 = require('./FlexTable');\n\nvar _FlexTable3 = _interopRequireDefault(_FlexTable2);\n\nvar _defaultCellDataGetter2 = require('./defaultCellDataGetter');\n\nvar _defaultCellDataGetter3 = _interopRequireDefault(_defaultCellDataGetter2);\n\nvar _defaultCellRenderer2 = require('./defaultCellRenderer');\n\nvar _defaultCellRenderer3 = _interopRequireDefault(_defaultCellRenderer2);\n\nvar _defaultHeaderRenderer2 = require('./defaultHeaderRenderer');\n\nvar _defaultHeaderRenderer3 = _interopRequireDefault(_defaultHeaderRenderer2);\n\nvar _defaultRowRenderer2 = require('./defaultRowRenderer');\n\nvar _defaultRowRenderer3 = _interopRequireDefault(_defaultRowRenderer2);\n\nvar _FlexColumn2 = require('./FlexColumn');\n\nvar _FlexColumn3 = _interopRequireDefault(_FlexColumn2);\n\nvar _SortDirection2 = require('./SortDirection');\n\nvar _SortDirection3 = _interopRequireDefault(_SortDirection2);\n\nvar _SortIndicator2 = require('./SortIndicator');\n\nvar _SortIndicator3 = _interopRequireDefault(_SortIndicator2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _FlexTable3.default;\nexports.defaultCellDataGetter = _defaultCellDataGetter3.default;\nexports.defaultCellRenderer = _defaultCellRenderer3.default;\nexports.defaultHeaderRenderer = _defaultHeaderRenderer3.default;\nexports.defaultRowRenderer = _defaultRowRenderer3.default;\nexports.FlexTable = _FlexTable3.default;\nexports.FlexColumn = _FlexColumn3.default;\nexports.SortDirection = _SortDirection3.default;\nexports.SortIndicator = _SortIndicator3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.DEFAULT_SCROLLING_RESET_TIME_INTERVAL = undefined;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _classnames = require('classnames');\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nvar _calculateSizeAndPositionDataAndUpdateScrollOffset = require('./utils/calculateSizeAndPositionDataAndUpdateScrollOffset');\n\nvar _calculateSizeAndPositionDataAndUpdateScrollOffset2 = _interopRequireDefault(_calculateSizeAndPositionDataAndUpdateScrollOffset);\n\nvar _ScalingCellSizeAndPositionManager = require('./utils/ScalingCellSizeAndPositionManager');\n\nvar _ScalingCellSizeAndPositionManager2 = _interopRequireDefault(_ScalingCellSizeAndPositionManager);\n\nvar _createCallbackMemoizer = require('../utils/createCallbackMemoizer');\n\nvar _createCallbackMemoizer2 = _interopRequireDefault(_createCallbackMemoizer);\n\nvar _getOverscanIndices = require('./utils/getOverscanIndices');\n\nvar _getOverscanIndices2 = _interopRequireDefault(_getOverscanIndices);\n\nvar _scrollbarSize = require('dom-helpers/util/scrollbarSize');\n\nvar _scrollbarSize2 = _interopRequireDefault(_scrollbarSize);\n\nvar _raf = require('raf');\n\nvar _raf2 = _interopRequireDefault(_raf);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nvar _updateScrollIndexHelper = require('./utils/updateScrollIndexHelper');\n\nvar _updateScrollIndexHelper2 = _interopRequireDefault(_updateScrollIndexHelper);\n\nvar _defaultCellRangeRenderer = require('./defaultCellRangeRenderer');\n\nvar _defaultCellRangeRenderer2 = _interopRequireDefault(_defaultCellRangeRenderer);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * Specifies the number of miliseconds during which to disable pointer events while a scroll is in progress.\n * This improves performance and makes scrolling smoother.\n */\nvar DEFAULT_SCROLLING_RESET_TIME_INTERVAL = exports.DEFAULT_SCROLLING_RESET_TIME_INTERVAL = 150;\n\n/**\n * Controls whether the Grid updates the DOM element's scrollLeft/scrollTop based on the current state or just observes it.\n * This prevents Grid from interrupting mouse-wheel animations (see issue #2).\n */\nvar SCROLL_POSITION_CHANGE_REASONS = {\n  OBSERVED: 'observed',\n  REQUESTED: 'requested'\n};\n\n/**\n * Renders tabular data with virtualization along the vertical and horizontal axes.\n * Row heights and column widths must be known ahead of time and specified as properties.\n */\n\nvar Grid = function (_Component) {\n  _inherits(Grid, _Component);\n\n  function Grid(props, context) {\n    _classCallCheck(this, Grid);\n\n    var _this = _possibleConstructorReturn(this, (Grid.__proto__ || Object.getPrototypeOf(Grid)).call(this, props, context));\n\n    _this.state = {\n      isScrolling: false,\n      scrollDirectionHorizontal: _getOverscanIndices.SCROLL_DIRECTION_FIXED,\n      scrollDirectionVertical: _getOverscanIndices.SCROLL_DIRECTION_FIXED,\n      scrollLeft: 0,\n      scrollTop: 0\n    };\n\n    // Invokes onSectionRendered callback only when start/stop row or column indices change\n    _this._onGridRenderedMemoizer = (0, _createCallbackMemoizer2.default)();\n    _this._onScrollMemoizer = (0, _createCallbackMemoizer2.default)(false);\n\n    // Bind functions to instance so they don't lose context when passed around\n    _this._enablePointerEventsAfterDelayCallback = _this._enablePointerEventsAfterDelayCallback.bind(_this);\n    _this._invokeOnGridRenderedHelper = _this._invokeOnGridRenderedHelper.bind(_this);\n    _this._onScroll = _this._onScroll.bind(_this);\n    _this._setNextStateCallback = _this._setNextStateCallback.bind(_this);\n    _this._updateScrollLeftForScrollToColumn = _this._updateScrollLeftForScrollToColumn.bind(_this);\n    _this._updateScrollTopForScrollToRow = _this._updateScrollTopForScrollToRow.bind(_this);\n\n    _this._columnWidthGetter = _this._wrapSizeGetter(props.columnWidth);\n    _this._rowHeightGetter = _this._wrapSizeGetter(props.rowHeight);\n\n    _this._columnSizeAndPositionManager = new _ScalingCellSizeAndPositionManager2.default({\n      cellCount: props.columnCount,\n      cellSizeGetter: function cellSizeGetter(index) {\n        return _this._columnWidthGetter(index);\n      },\n      estimatedCellSize: _this._getEstimatedColumnSize(props)\n    });\n    _this._rowSizeAndPositionManager = new _ScalingCellSizeAndPositionManager2.default({\n      cellCount: props.rowCount,\n      cellSizeGetter: function cellSizeGetter(index) {\n        return _this._rowHeightGetter(index);\n      },\n      estimatedCellSize: _this._getEstimatedRowSize(props)\n    });\n\n    // See defaultCellRangeRenderer() for more information on the usage of this cache\n    _this._cellCache = {};\n    return _this;\n  }\n\n  /**\n   * Pre-measure all columns and rows in a Grid.\n   * Typically cells are only measured as needed and estimated sizes are used for cells that have not yet been measured.\n   * This method ensures that the next call to getTotalSize() returns an exact size (as opposed to just an estimated one).\n   */\n\n\n  _createClass(Grid, [{\n    key: 'measureAllCells',\n    value: function measureAllCells() {\n      var _props = this.props;\n      var columnCount = _props.columnCount;\n      var rowCount = _props.rowCount;\n\n\n      this._columnSizeAndPositionManager.getSizeAndPositionOfCell(columnCount - 1);\n      this._rowSizeAndPositionManager.getSizeAndPositionOfCell(rowCount - 1);\n    }\n\n    /**\n     * Forced recompute of row heights and column widths.\n     * This function should be called if dynamic column or row sizes have changed but nothing else has.\n     * Since Grid only receives :columnCount and :rowCount it has no way of detecting when the underlying data changes.\n     */\n\n  }, {\n    key: 'recomputeGridSize',\n    value: function recomputeGridSize() {\n      var _ref = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n      var _ref$columnIndex = _ref.columnIndex;\n      var columnIndex = _ref$columnIndex === undefined ? 0 : _ref$columnIndex;\n      var _ref$rowIndex = _ref.rowIndex;\n      var rowIndex = _ref$rowIndex === undefined ? 0 : _ref$rowIndex;\n\n      this._columnSizeAndPositionManager.resetCell(columnIndex);\n      this._rowSizeAndPositionManager.resetCell(rowIndex);\n\n      // Clear cell cache in case we are scrolling;\n      // Invalid row heights likely mean invalid cached content as well.\n      this._cellCache = {};\n\n      this.forceUpdate();\n    }\n  }, {\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      var _props2 = this.props;\n      var scrollLeft = _props2.scrollLeft;\n      var scrollToColumn = _props2.scrollToColumn;\n      var scrollTop = _props2.scrollTop;\n      var scrollToRow = _props2.scrollToRow;\n\n      // If this component was first rendered server-side, scrollbar size will be undefined.\n      // In that event we need to remeasure.\n\n      if (!this._scrollbarSizeMeasured) {\n        this._scrollbarSize = (0, _scrollbarSize2.default)();\n        this._scrollbarSizeMeasured = true;\n        this.setState({});\n      }\n\n      if (scrollLeft >= 0 || scrollTop >= 0) {\n        this._setScrollPosition({ scrollLeft: scrollLeft, scrollTop: scrollTop });\n      }\n\n      if (scrollToColumn >= 0 || scrollToRow >= 0) {\n        this._updateScrollLeftForScrollToColumn();\n        this._updateScrollTopForScrollToRow();\n      }\n\n      // Update onRowsRendered callback\n      this._invokeOnGridRenderedHelper();\n\n      // Initialize onScroll callback\n      this._invokeOnScrollMemoizer({\n        scrollLeft: scrollLeft || 0,\n        scrollTop: scrollTop || 0,\n        totalColumnsWidth: this._columnSizeAndPositionManager.getTotalSize(),\n        totalRowsHeight: this._rowSizeAndPositionManager.getTotalSize()\n      });\n    }\n\n    /**\n     * @private\n     * This method updates scrollLeft/scrollTop in state for the following conditions:\n     * 1) New scroll-to-cell props have been set\n     */\n\n  }, {\n    key: 'componentDidUpdate',\n    value: function componentDidUpdate(prevProps, prevState) {\n      var _this2 = this;\n\n      var _props3 = this.props;\n      var autoHeight = _props3.autoHeight;\n      var columnCount = _props3.columnCount;\n      var height = _props3.height;\n      var rowCount = _props3.rowCount;\n      var scrollToAlignment = _props3.scrollToAlignment;\n      var scrollToColumn = _props3.scrollToColumn;\n      var scrollToRow = _props3.scrollToRow;\n      var width = _props3.width;\n      var _state = this.state;\n      var scrollLeft = _state.scrollLeft;\n      var scrollPositionChangeReason = _state.scrollPositionChangeReason;\n      var scrollTop = _state.scrollTop;\n\n      // Handle edge case where column or row count has only just increased over 0.\n      // In this case we may have to restore a previously-specified scroll offset.\n      // For more info see bvaughn/react-virtualized/issues/218\n\n      var columnOrRowCountJustIncreasedFromZero = columnCount > 0 && prevProps.columnCount === 0 || rowCount > 0 && prevProps.rowCount === 0;\n\n      // Make sure requested changes to :scrollLeft or :scrollTop get applied.\n      // Assigning to scrollLeft/scrollTop tells the browser to interrupt any running scroll animations,\n      // And to discard any pending async changes to the scroll position that may have happened in the meantime (e.g. on a separate scrolling thread).\n      // So we only set these when we require an adjustment of the scroll position.\n      // See issue #2 for more information.\n      if (scrollPositionChangeReason === SCROLL_POSITION_CHANGE_REASONS.REQUESTED) {\n        if (scrollLeft >= 0 && (scrollLeft !== prevState.scrollLeft && scrollLeft !== this._scrollingContainer.scrollLeft || columnOrRowCountJustIncreasedFromZero)) {\n          this._scrollingContainer.scrollLeft = scrollLeft;\n        }\n\n        // @TRICKY :autoHeight property instructs Grid to leave :scrollTop management to an external HOC (eg WindowScroller).\n        // In this case we should avoid checking scrollingContainer.scrollTop since it forces layout/flow.\n        if (!autoHeight && scrollTop >= 0 && (scrollTop !== prevState.scrollTop && scrollTop !== this._scrollingContainer.scrollTop || columnOrRowCountJustIncreasedFromZero)) {\n          this._scrollingContainer.scrollTop = scrollTop;\n        }\n      }\n\n      // Update scroll offsets if the current :scrollToColumn or :scrollToRow values requires it\n      // @TODO Do we also need this check or can the one in componentWillUpdate() suffice?\n      (0, _updateScrollIndexHelper2.default)({\n        cellSizeAndPositionManager: this._columnSizeAndPositionManager,\n        previousCellsCount: prevProps.columnCount,\n        previousCellSize: prevProps.columnWidth,\n        previousScrollToAlignment: prevProps.scrollToAlignment,\n        previousScrollToIndex: prevProps.scrollToColumn,\n        previousSize: prevProps.width,\n        scrollOffset: scrollLeft,\n        scrollToAlignment: scrollToAlignment,\n        scrollToIndex: scrollToColumn,\n        size: width,\n        updateScrollIndexCallback: function updateScrollIndexCallback(scrollToColumn) {\n          return _this2._updateScrollLeftForScrollToColumn(_extends({}, _this2.props, { scrollToColumn: scrollToColumn }));\n        }\n      });\n      (0, _updateScrollIndexHelper2.default)({\n        cellSizeAndPositionManager: this._rowSizeAndPositionManager,\n        previousCellsCount: prevProps.rowCount,\n        previousCellSize: prevProps.rowHeight,\n        previousScrollToAlignment: prevProps.scrollToAlignment,\n        previousScrollToIndex: prevProps.scrollToRow,\n        previousSize: prevProps.height,\n        scrollOffset: scrollTop,\n        scrollToAlignment: scrollToAlignment,\n        scrollToIndex: scrollToRow,\n        size: height,\n        updateScrollIndexCallback: function updateScrollIndexCallback(scrollToRow) {\n          return _this2._updateScrollTopForScrollToRow(_extends({}, _this2.props, { scrollToRow: scrollToRow }));\n        }\n      });\n\n      // Update onRowsRendered callback if start/stop indices have changed\n      this._invokeOnGridRenderedHelper();\n    }\n  }, {\n    key: 'componentWillMount',\n    value: function componentWillMount() {\n      // If this component is being rendered server-side, getScrollbarSize() will return undefined.\n      // We handle this case in componentDidMount()\n      this._scrollbarSize = (0, _scrollbarSize2.default)();\n      if (this._scrollbarSize === undefined) {\n        this._scrollbarSizeMeasured = false;\n        this._scrollbarSize = 0;\n      } else {\n        this._scrollbarSizeMeasured = true;\n      }\n\n      this._calculateChildrenToRender();\n    }\n  }, {\n    key: 'componentWillUnmount',\n    value: function componentWillUnmount() {\n      if (this._disablePointerEventsTimeoutId) {\n        clearTimeout(this._disablePointerEventsTimeoutId);\n      }\n\n      if (this._setNextStateAnimationFrameId) {\n        _raf2.default.cancel(this._setNextStateAnimationFrameId);\n      }\n    }\n\n    /**\n     * @private\n     * This method updates scrollLeft/scrollTop in state for the following conditions:\n     * 1) Empty content (0 rows or columns)\n     * 2) New scroll props overriding the current state\n     * 3) Cells-count or cells-size has changed, making previous scroll offsets invalid\n     */\n\n  }, {\n    key: 'componentWillUpdate',\n    value: function componentWillUpdate(nextProps, nextState) {\n      var _this3 = this;\n\n      if (nextProps.columnCount === 0 && nextState.scrollLeft !== 0 || nextProps.rowCount === 0 && nextState.scrollTop !== 0) {\n        this._setScrollPosition({\n          scrollLeft: 0,\n          scrollTop: 0\n        });\n      } else if (nextProps.scrollLeft !== this.props.scrollLeft || nextProps.scrollTop !== this.props.scrollTop) {\n        this._setScrollPosition({\n          scrollLeft: nextProps.scrollLeft,\n          scrollTop: nextProps.scrollTop\n        });\n      }\n\n      this._columnWidthGetter = this._wrapSizeGetter(nextProps.columnWidth);\n      this._rowHeightGetter = this._wrapSizeGetter(nextProps.rowHeight);\n\n      this._columnSizeAndPositionManager.configure({\n        cellCount: nextProps.columnCount,\n        estimatedCellSize: this._getEstimatedColumnSize(nextProps)\n      });\n      this._rowSizeAndPositionManager.configure({\n        cellCount: nextProps.rowCount,\n        estimatedCellSize: this._getEstimatedRowSize(nextProps)\n      });\n\n      // Update scroll offsets if the size or number of cells have changed, invalidating the previous value\n      (0, _calculateSizeAndPositionDataAndUpdateScrollOffset2.default)({\n        cellCount: this.props.columnCount,\n        cellSize: this.props.columnWidth,\n        computeMetadataCallback: function computeMetadataCallback() {\n          return _this3._columnSizeAndPositionManager.resetCell(0);\n        },\n        computeMetadataCallbackProps: nextProps,\n        nextCellsCount: nextProps.columnCount,\n        nextCellSize: nextProps.columnWidth,\n        nextScrollToIndex: nextProps.scrollToColumn,\n        scrollToIndex: this.props.scrollToColumn,\n        updateScrollOffsetForScrollToIndex: function updateScrollOffsetForScrollToIndex() {\n          return _this3._updateScrollLeftForScrollToColumn(nextProps, nextState);\n        }\n      });\n      (0, _calculateSizeAndPositionDataAndUpdateScrollOffset2.default)({\n        cellCount: this.props.rowCount,\n        cellSize: this.props.rowHeight,\n        computeMetadataCallback: function computeMetadataCallback() {\n          return _this3._rowSizeAndPositionManager.resetCell(0);\n        },\n        computeMetadataCallbackProps: nextProps,\n        nextCellsCount: nextProps.rowCount,\n        nextCellSize: nextProps.rowHeight,\n        nextScrollToIndex: nextProps.scrollToRow,\n        scrollToIndex: this.props.scrollToRow,\n        updateScrollOffsetForScrollToIndex: function updateScrollOffsetForScrollToIndex() {\n          return _this3._updateScrollTopForScrollToRow(nextProps, nextState);\n        }\n      });\n\n      this._calculateChildrenToRender(nextProps, nextState);\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _this4 = this;\n\n      var _props4 = this.props;\n      var autoContainerWidth = _props4.autoContainerWidth;\n      var autoHeight = _props4.autoHeight;\n      var className = _props4.className;\n      var height = _props4.height;\n      var noContentRenderer = _props4.noContentRenderer;\n      var style = _props4.style;\n      var tabIndex = _props4.tabIndex;\n      var width = _props4.width;\n      var isScrolling = this.state.isScrolling;\n\n\n      var gridStyle = {\n        height: autoHeight ? 'auto' : height,\n        width: width\n      };\n\n      var totalColumnsWidth = this._columnSizeAndPositionManager.getTotalSize();\n      var totalRowsHeight = this._rowSizeAndPositionManager.getTotalSize();\n\n      // Force browser to hide scrollbars when we know they aren't necessary.\n      // Otherwise once scrollbars appear they may not disappear again.\n      // For more info see issue #116\n      var verticalScrollBarSize = totalRowsHeight > height ? this._scrollbarSize : 0;\n      var horizontalScrollBarSize = totalColumnsWidth > width ? this._scrollbarSize : 0;\n\n      // Also explicitly init styles to 'auto' if scrollbars are required.\n      // This works around an obscure edge case where external CSS styles have not yet been loaded,\n      // But an initial scroll index of offset is set as an external prop.\n      // Without this style, Grid would render the correct range of cells but would NOT update its internal offset.\n      // This was originally reported via clauderic/react-infinite-calendar/issues/23\n      gridStyle.overflowX = totalColumnsWidth + verticalScrollBarSize <= width ? 'hidden' : 'auto';\n      gridStyle.overflowY = totalRowsHeight + horizontalScrollBarSize <= height ? 'hidden' : 'auto';\n\n      var childrenToDisplay = this._childrenToDisplay;\n\n      var showNoContentRenderer = childrenToDisplay.length === 0 && height > 0 && width > 0;\n\n      return _react2.default.createElement(\n        'div',\n        {\n          ref: function ref(_ref2) {\n            _this4._scrollingContainer = _ref2;\n          },\n          'aria-label': this.props['aria-label'],\n          className: (0, _classnames2.default)('Grid', className),\n          onScroll: this._onScroll,\n          role: 'grid',\n          style: _extends({}, gridStyle, style),\n          tabIndex: tabIndex\n        },\n        childrenToDisplay.length > 0 && _react2.default.createElement(\n          'div',\n          {\n            className: 'Grid__innerScrollContainer',\n            style: {\n              width: autoContainerWidth ? 'auto' : totalColumnsWidth,\n              height: totalRowsHeight,\n              maxWidth: totalColumnsWidth,\n              maxHeight: totalRowsHeight,\n              pointerEvents: isScrolling ? 'none' : ''\n            }\n          },\n          childrenToDisplay\n        ),\n        showNoContentRenderer && noContentRenderer()\n      );\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n\n    /* ---------------------------- Helper methods ---------------------------- */\n\n  }, {\n    key: '_calculateChildrenToRender',\n    value: function _calculateChildrenToRender() {\n      var props = arguments.length <= 0 || arguments[0] === undefined ? this.props : arguments[0];\n      var state = arguments.length <= 1 || arguments[1] === undefined ? this.state : arguments[1];\n      var cellClassName = props.cellClassName;\n      var cellRenderer = props.cellRenderer;\n      var cellRangeRenderer = props.cellRangeRenderer;\n      var cellStyle = props.cellStyle;\n      var columnCount = props.columnCount;\n      var height = props.height;\n      var overscanColumnCount = props.overscanColumnCount;\n      var overscanRowCount = props.overscanRowCount;\n      var rowCount = props.rowCount;\n      var width = props.width;\n      var isScrolling = state.isScrolling;\n      var scrollDirectionHorizontal = state.scrollDirectionHorizontal;\n      var scrollDirectionVertical = state.scrollDirectionVertical;\n      var scrollLeft = state.scrollLeft;\n      var scrollTop = state.scrollTop;\n\n\n      this._childrenToDisplay = [];\n\n      // Render only enough columns and rows to cover the visible area of the grid.\n      if (height > 0 && width > 0) {\n        var visibleColumnIndices = this._columnSizeAndPositionManager.getVisibleCellRange({\n          containerSize: width,\n          offset: scrollLeft\n        });\n        var visibleRowIndices = this._rowSizeAndPositionManager.getVisibleCellRange({\n          containerSize: height,\n          offset: scrollTop\n        });\n\n        var horizontalOffsetAdjustment = this._columnSizeAndPositionManager.getOffsetAdjustment({\n          containerSize: width,\n          offset: scrollLeft\n        });\n        var verticalOffsetAdjustment = this._rowSizeAndPositionManager.getOffsetAdjustment({\n          containerSize: height,\n          offset: scrollTop\n        });\n\n        // Store for _invokeOnGridRenderedHelper()\n        this._renderedColumnStartIndex = visibleColumnIndices.start;\n        this._renderedColumnStopIndex = visibleColumnIndices.stop;\n        this._renderedRowStartIndex = visibleRowIndices.start;\n        this._renderedRowStopIndex = visibleRowIndices.stop;\n\n        var overscanColumnIndices = (0, _getOverscanIndices2.default)({\n          cellCount: columnCount,\n          overscanCellsCount: overscanColumnCount,\n          scrollDirection: scrollDirectionHorizontal,\n          startIndex: this._renderedColumnStartIndex,\n          stopIndex: this._renderedColumnStopIndex\n        });\n\n        var overscanRowIndices = (0, _getOverscanIndices2.default)({\n          cellCount: rowCount,\n          overscanCellsCount: overscanRowCount,\n          scrollDirection: scrollDirectionVertical,\n          startIndex: this._renderedRowStartIndex,\n          stopIndex: this._renderedRowStopIndex\n        });\n\n        // Store for _invokeOnGridRenderedHelper()\n        this._columnStartIndex = overscanColumnIndices.overscanStartIndex;\n        this._columnStopIndex = overscanColumnIndices.overscanStopIndex;\n        this._rowStartIndex = overscanRowIndices.overscanStartIndex;\n        this._rowStopIndex = overscanRowIndices.overscanStopIndex;\n\n        this._childrenToDisplay = cellRangeRenderer({\n          cellCache: this._cellCache,\n          cellClassName: this._wrapCellClassNameGetter(cellClassName),\n          cellRenderer: cellRenderer,\n          cellStyle: this._wrapCellStyleGetter(cellStyle),\n          columnSizeAndPositionManager: this._columnSizeAndPositionManager,\n          columnStartIndex: this._columnStartIndex,\n          columnStopIndex: this._columnStopIndex,\n          horizontalOffsetAdjustment: horizontalOffsetAdjustment,\n          isScrolling: isScrolling,\n          rowSizeAndPositionManager: this._rowSizeAndPositionManager,\n          rowStartIndex: this._rowStartIndex,\n          rowStopIndex: this._rowStopIndex,\n          scrollLeft: scrollLeft,\n          scrollTop: scrollTop,\n          verticalOffsetAdjustment: verticalOffsetAdjustment\n        });\n      }\n    }\n\n    /**\n     * Sets an :isScrolling flag for a small window of time.\n     * This flag is used to disable pointer events on the scrollable portion of the Grid.\n     * This prevents jerky/stuttery mouse-wheel scrolling.\n     */\n\n  }, {\n    key: '_enablePointerEventsAfterDelay',\n    value: function _enablePointerEventsAfterDelay() {\n      var scrollingResetTimeInterval = this.props.scrollingResetTimeInterval;\n\n\n      if (this._disablePointerEventsTimeoutId) {\n        clearTimeout(this._disablePointerEventsTimeoutId);\n      }\n\n      this._disablePointerEventsTimeoutId = setTimeout(this._enablePointerEventsAfterDelayCallback, scrollingResetTimeInterval);\n    }\n  }, {\n    key: '_enablePointerEventsAfterDelayCallback',\n    value: function _enablePointerEventsAfterDelayCallback() {\n      this._disablePointerEventsTimeoutId = null;\n\n      // Throw away cell cache once scrolling is complete\n      this._cellCache = {};\n\n      this.setState({\n        isScrolling: false,\n        scrollDirectionHorizontal: _getOverscanIndices.SCROLL_DIRECTION_FIXED,\n        scrollDirectionVertical: _getOverscanIndices.SCROLL_DIRECTION_FIXED\n      });\n    }\n  }, {\n    key: '_getEstimatedColumnSize',\n    value: function _getEstimatedColumnSize(props) {\n      return typeof props.columnWidth === 'number' ? props.columnWidth : props.estimatedColumnSize;\n    }\n  }, {\n    key: '_getEstimatedRowSize',\n    value: function _getEstimatedRowSize(props) {\n      return typeof props.rowHeight === 'number' ? props.rowHeight : props.estimatedRowSize;\n    }\n  }, {\n    key: '_invokeOnGridRenderedHelper',\n    value: function _invokeOnGridRenderedHelper() {\n      var onSectionRendered = this.props.onSectionRendered;\n\n\n      this._onGridRenderedMemoizer({\n        callback: onSectionRendered,\n        indices: {\n          columnOverscanStartIndex: this._columnStartIndex,\n          columnOverscanStopIndex: this._columnStopIndex,\n          columnStartIndex: this._renderedColumnStartIndex,\n          columnStopIndex: this._renderedColumnStopIndex,\n          rowOverscanStartIndex: this._rowStartIndex,\n          rowOverscanStopIndex: this._rowStopIndex,\n          rowStartIndex: this._renderedRowStartIndex,\n          rowStopIndex: this._renderedRowStopIndex\n        }\n      });\n    }\n  }, {\n    key: '_invokeOnScrollMemoizer',\n    value: function _invokeOnScrollMemoizer(_ref3) {\n      var _this5 = this;\n\n      var scrollLeft = _ref3.scrollLeft;\n      var scrollTop = _ref3.scrollTop;\n      var totalColumnsWidth = _ref3.totalColumnsWidth;\n      var totalRowsHeight = _ref3.totalRowsHeight;\n\n      this._onScrollMemoizer({\n        callback: function callback(_ref4) {\n          var scrollLeft = _ref4.scrollLeft;\n          var scrollTop = _ref4.scrollTop;\n          var _props5 = _this5.props;\n          var height = _props5.height;\n          var onScroll = _props5.onScroll;\n          var width = _props5.width;\n\n\n          onScroll({\n            clientHeight: height,\n            clientWidth: width,\n            scrollHeight: totalRowsHeight,\n            scrollLeft: scrollLeft,\n            scrollTop: scrollTop,\n            scrollWidth: totalColumnsWidth\n          });\n        },\n        indices: {\n          scrollLeft: scrollLeft,\n          scrollTop: scrollTop\n        }\n      });\n    }\n\n    /**\n     * Updates the state during the next animation frame.\n     * Use this method to avoid multiple renders in a small span of time.\n     * This helps performance for bursty events (like onScroll).\n     */\n\n  }, {\n    key: '_setNextState',\n    value: function _setNextState(state) {\n      this._nextState = state;\n\n      if (!this._setNextStateAnimationFrameId) {\n        this._setNextStateAnimationFrameId = (0, _raf2.default)(this._setNextStateCallback);\n      }\n    }\n  }, {\n    key: '_setNextStateCallback',\n    value: function _setNextStateCallback() {\n      var state = this._nextState;\n\n      this._setNextStateAnimationFrameId = null;\n      this._nextState = null;\n\n      this.setState(state);\n    }\n  }, {\n    key: '_setScrollPosition',\n    value: function _setScrollPosition(_ref5) {\n      var scrollLeft = _ref5.scrollLeft;\n      var scrollTop = _ref5.scrollTop;\n\n      var newState = {\n        scrollPositionChangeReason: SCROLL_POSITION_CHANGE_REASONS.REQUESTED\n      };\n\n      if (scrollLeft >= 0) {\n        newState.scrollLeft = scrollLeft;\n      }\n\n      if (scrollTop >= 0) {\n        newState.scrollTop = scrollTop;\n      }\n\n      if (scrollLeft >= 0 && scrollLeft !== this.state.scrollLeft || scrollTop >= 0 && scrollTop !== this.state.scrollTop) {\n        this.setState(newState);\n      }\n    }\n  }, {\n    key: '_wrapCellClassNameGetter',\n    value: function _wrapCellClassNameGetter(className) {\n      return this._wrapPropertyGetter(className);\n    }\n  }, {\n    key: '_wrapCellStyleGetter',\n    value: function _wrapCellStyleGetter(style) {\n      return this._wrapPropertyGetter(style);\n    }\n  }, {\n    key: '_wrapPropertyGetter',\n    value: function _wrapPropertyGetter(value) {\n      return value instanceof Function ? value : function () {\n        return value;\n      };\n    }\n  }, {\n    key: '_wrapSizeGetter',\n    value: function _wrapSizeGetter(size) {\n      return this._wrapPropertyGetter(size);\n    }\n  }, {\n    key: '_updateScrollLeftForScrollToColumn',\n    value: function _updateScrollLeftForScrollToColumn() {\n      var props = arguments.length <= 0 || arguments[0] === undefined ? this.props : arguments[0];\n      var state = arguments.length <= 1 || arguments[1] === undefined ? this.state : arguments[1];\n      var columnCount = props.columnCount;\n      var scrollToAlignment = props.scrollToAlignment;\n      var scrollToColumn = props.scrollToColumn;\n      var width = props.width;\n      var scrollLeft = state.scrollLeft;\n\n\n      if (scrollToColumn >= 0 && columnCount > 0) {\n        var targetIndex = Math.max(0, Math.min(columnCount - 1, scrollToColumn));\n\n        var calculatedScrollLeft = this._columnSizeAndPositionManager.getUpdatedOffsetForIndex({\n          align: scrollToAlignment,\n          containerSize: width,\n          currentOffset: scrollLeft,\n          targetIndex: targetIndex\n        });\n\n        if (scrollLeft !== calculatedScrollLeft) {\n          this._setScrollPosition({\n            scrollLeft: calculatedScrollLeft\n          });\n        }\n      }\n    }\n  }, {\n    key: '_updateScrollTopForScrollToRow',\n    value: function _updateScrollTopForScrollToRow() {\n      var props = arguments.length <= 0 || arguments[0] === undefined ? this.props : arguments[0];\n      var state = arguments.length <= 1 || arguments[1] === undefined ? this.state : arguments[1];\n      var height = props.height;\n      var rowCount = props.rowCount;\n      var scrollToAlignment = props.scrollToAlignment;\n      var scrollToRow = props.scrollToRow;\n      var scrollTop = state.scrollTop;\n\n\n      if (scrollToRow >= 0 && rowCount > 0) {\n        var targetIndex = Math.max(0, Math.min(rowCount - 1, scrollToRow));\n\n        var calculatedScrollTop = this._rowSizeAndPositionManager.getUpdatedOffsetForIndex({\n          align: scrollToAlignment,\n          containerSize: height,\n          currentOffset: scrollTop,\n          targetIndex: targetIndex\n        });\n\n        if (scrollTop !== calculatedScrollTop) {\n          this._setScrollPosition({\n            scrollTop: calculatedScrollTop\n          });\n        }\n      }\n    }\n  }, {\n    key: '_onScroll',\n    value: function _onScroll(event) {\n      // In certain edge-cases React dispatches an onScroll event with an invalid target.scrollLeft / target.scrollTop.\n      // This invalid event can be detected by comparing event.target to this component's scrollable DOM element.\n      // See issue #404 for more information.\n      if (event.target !== this._scrollingContainer) {\n        return;\n      }\n\n      // Prevent pointer events from interrupting a smooth scroll\n      this._enablePointerEventsAfterDelay();\n\n      // When this component is shrunk drastically, React dispatches a series of back-to-back scroll events,\n      // Gradually converging on a scrollTop that is within the bounds of the new, smaller height.\n      // This causes a series of rapid renders that is slow for long lists.\n      // We can avoid that by doing some simple bounds checking to ensure that scrollTop never exceeds the total height.\n      var _props6 = this.props;\n      var height = _props6.height;\n      var width = _props6.width;\n\n      var scrollbarSize = this._scrollbarSize;\n      var totalRowsHeight = this._rowSizeAndPositionManager.getTotalSize();\n      var totalColumnsWidth = this._columnSizeAndPositionManager.getTotalSize();\n      var scrollLeft = Math.min(Math.max(0, totalColumnsWidth - width + scrollbarSize), event.target.scrollLeft);\n      var scrollTop = Math.min(Math.max(0, totalRowsHeight - height + scrollbarSize), event.target.scrollTop);\n\n      // Certain devices (like Apple touchpad) rapid-fire duplicate events.\n      // Don't force a re-render if this is the case.\n      // The mouse may move faster then the animation frame does.\n      // Use requestAnimationFrame to avoid over-updating.\n      if (this.state.scrollLeft !== scrollLeft || this.state.scrollTop !== scrollTop) {\n        // Browsers with cancelable scroll events (eg. Firefox) interrupt scrolling animations if scrollTop/scrollLeft is set.\n        // Other browsers (eg. Safari) don't scroll as well without the help under certain conditions (DOM or style changes during scrolling).\n        // All things considered, this seems to be the best current work around that I'm aware of.\n        // For more information see https://github.com/bvaughn/react-virtualized/pull/124\n        var scrollPositionChangeReason = event.cancelable ? SCROLL_POSITION_CHANGE_REASONS.OBSERVED : SCROLL_POSITION_CHANGE_REASONS.REQUESTED;\n\n        // Track scrolling direction so we can more efficiently overscan rows to reduce empty space around the edges while scrolling.\n        var scrollDirectionVertical = scrollTop > this.state.scrollTop ? _getOverscanIndices.SCROLL_DIRECTION_FORWARD : _getOverscanIndices.SCROLL_DIRECTION_BACKWARD;\n        var scrollDirectionHorizontal = scrollLeft > this.state.scrollLeft ? _getOverscanIndices.SCROLL_DIRECTION_FORWARD : _getOverscanIndices.SCROLL_DIRECTION_BACKWARD;\n\n        if (!this.state.isScrolling) {\n          this.setState({\n            isScrolling: true\n          });\n        }\n\n        this._setNextState({\n          isScrolling: true,\n          scrollDirectionHorizontal: scrollDirectionHorizontal,\n          scrollDirectionVertical: scrollDirectionVertical,\n          scrollLeft: scrollLeft,\n          scrollPositionChangeReason: scrollPositionChangeReason,\n          scrollTop: scrollTop\n        });\n      }\n\n      this._invokeOnScrollMemoizer({ scrollLeft: scrollLeft, scrollTop: scrollTop, totalColumnsWidth: totalColumnsWidth, totalRowsHeight: totalRowsHeight });\n    }\n  }]);\n\n  return Grid;\n}(_react.Component);\n\nGrid.propTypes = {\n  'aria-label': _react.PropTypes.string,\n\n  /**\n   * Set the width of the inner scrollable container to 'auto'.\n   * This is useful for single-column Grids to ensure that the column doesn't extend below a vertical scrollbar.\n   */\n  autoContainerWidth: _react.PropTypes.bool,\n\n  /**\n   * Removes fixed height from the scrollingContainer so that the total height\n   * of rows can stretch the window. Intended for use with WindowScroller\n   */\n  autoHeight: _react.PropTypes.bool,\n\n  /** Optional custom CSS class for individual cells */\n  cellClassName: _react.PropTypes.oneOfType([_react.PropTypes.string, _react.PropTypes.func]),\n\n  /** Optional custom styles for individual cells */\n  cellStyle: _react.PropTypes.oneOfType([_react.PropTypes.object, _react.PropTypes.func]),\n\n  /**\n   * Responsible for rendering a cell given an row and column index.\n   * Should implement the following interface: ({ columnIndex: number, rowIndex: number }): PropTypes.node\n   */\n  cellRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Responsible for rendering a group of cells given their index ranges.\n   * Should implement the following interface: ({\n   *   cellCache: Map,\n   *   cellRenderer: Function,\n   *   columnSizeAndPositionManager: CellSizeAndPositionManager,\n   *   columnStartIndex: number,\n   *   columnStopIndex: number,\n   *   isScrolling: boolean,\n   *   rowSizeAndPositionManager: CellSizeAndPositionManager,\n   *   rowStartIndex: number,\n   *   rowStopIndex: number,\n   *   scrollLeft: number,\n   *   scrollTop: number\n   * }): Array<PropTypes.node>\n   */\n  cellRangeRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Optional custom CSS class name to attach to root Grid element.\n   */\n  className: _react.PropTypes.string,\n\n  /**\n   * Number of columns in grid.\n   */\n  columnCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Either a fixed column width (number) or a function that returns the width of a column given its index.\n   * Should implement the following interface: (index: number): number\n   */\n  columnWidth: _react.PropTypes.oneOfType([_react.PropTypes.number, _react.PropTypes.func]).isRequired,\n\n  /**\n   * Used to estimate the total width of a Grid before all of its columns have actually been measured.\n   * The estimated total width is adjusted as columns are rendered.\n   */\n  estimatedColumnSize: _react.PropTypes.number.isRequired,\n\n  /**\n   * Used to estimate the total height of a Grid before all of its rows have actually been measured.\n   * The estimated total height is adjusted as rows are rendered.\n   */\n  estimatedRowSize: _react.PropTypes.number.isRequired,\n\n  /**\n   * Height of Grid; this property determines the number of visible (vs virtualized) rows.\n   */\n  height: _react.PropTypes.number.isRequired,\n\n  /**\n   * Optional renderer to be used in place of rows when either :rowCount or :columnCount is 0.\n   */\n  noContentRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Callback invoked whenever the scroll offset changes within the inner scrollable region.\n   * This callback can be used to sync scrolling between lists, tables, or grids.\n   * ({ clientHeight, clientWidth, scrollHeight, scrollLeft, scrollTop, scrollWidth }): void\n   */\n  onScroll: _react.PropTypes.func.isRequired,\n\n  /**\n   * Callback invoked with information about the section of the Grid that was just rendered.\n   * ({ columnStartIndex, columnStopIndex, rowStartIndex, rowStopIndex }): void\n   */\n  onSectionRendered: _react.PropTypes.func.isRequired,\n\n  /**\n   * Number of columns to render before/after the visible section of the grid.\n   * These columns can help for smoother scrolling on touch devices or browsers that send scroll events infrequently.\n   */\n  overscanColumnCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Number of rows to render above/below the visible section of the grid.\n   * These rows can help for smoother scrolling on touch devices or browsers that send scroll events infrequently.\n   */\n  overscanRowCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Either a fixed row height (number) or a function that returns the height of a row given its index.\n   * Should implement the following interface: ({ index: number }): number\n   */\n  rowHeight: _react.PropTypes.oneOfType([_react.PropTypes.number, _react.PropTypes.func]).isRequired,\n\n  /**\n   * Number of rows in grid.\n   */\n  rowCount: _react.PropTypes.number.isRequired,\n\n  /** Wait this amount of time after the last scroll event before resetting Grid `pointer-events`. */\n  scrollingResetTimeInterval: _react.PropTypes.number,\n\n  /** Horizontal offset. */\n  scrollLeft: _react.PropTypes.number,\n\n  /**\n   * Controls scroll-to-cell behavior of the Grid.\n   * The default (\"auto\") scrolls the least amount possible to ensure that the specified cell is fully visible.\n   * Use \"start\" to align cells to the top/left of the Grid and \"end\" to align bottom/right.\n   */\n  scrollToAlignment: _react.PropTypes.oneOf(['auto', 'end', 'start', 'center']).isRequired,\n\n  /**\n   * Column index to ensure visible (by forcefully scrolling if necessary)\n   */\n  scrollToColumn: _react.PropTypes.number,\n\n  /** Vertical offset. */\n  scrollTop: _react.PropTypes.number,\n\n  /**\n   * Row index to ensure visible (by forcefully scrolling if necessary)\n   */\n  scrollToRow: _react.PropTypes.number,\n\n  /** Optional inline style */\n  style: _react.PropTypes.object,\n\n  /** Tab index for focus */\n  tabIndex: _react.PropTypes.number,\n\n  /**\n   * Width of Grid; this property determines the number of visible (vs virtualized) columns.\n   */\n  width: _react.PropTypes.number.isRequired\n};\nGrid.defaultProps = {\n  'aria-label': 'grid',\n  cellStyle: {},\n  cellRangeRenderer: _defaultCellRangeRenderer2.default,\n  estimatedColumnSize: 100,\n  estimatedRowSize: 30,\n  noContentRenderer: function noContentRenderer() {\n    return null;\n  },\n  onScroll: function onScroll() {\n    return null;\n  },\n  onSectionRendered: function onSectionRendered() {\n    return null;\n  },\n  overscanColumnCount: 0,\n  overscanRowCount: 10,\n  scrollingResetTimeInterval: DEFAULT_SCROLLING_RESET_TIME_INTERVAL,\n  scrollToAlignment: 'auto',\n  style: {},\n  tabIndex: 0\n};\nexports.default = Grid;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nexports.default = defaultCellRangeRenderer;\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _classnames = require('classnames');\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Default implementation of cellRangeRenderer used by Grid.\n * This renderer supports cell-caching while the user is scrolling.\n */\nfunction defaultCellRangeRenderer(_ref) {\n  var cellCache = _ref.cellCache;\n  var cellClassName = _ref.cellClassName;\n  var cellRenderer = _ref.cellRenderer;\n  var cellStyle = _ref.cellStyle;\n  var columnSizeAndPositionManager = _ref.columnSizeAndPositionManager;\n  var columnStartIndex = _ref.columnStartIndex;\n  var columnStopIndex = _ref.columnStopIndex;\n  var horizontalOffsetAdjustment = _ref.horizontalOffsetAdjustment;\n  var isScrolling = _ref.isScrolling;\n  var rowSizeAndPositionManager = _ref.rowSizeAndPositionManager;\n  var rowStartIndex = _ref.rowStartIndex;\n  var rowStopIndex = _ref.rowStopIndex;\n  var scrollLeft = _ref.scrollLeft;\n  var scrollTop = _ref.scrollTop;\n  var verticalOffsetAdjustment = _ref.verticalOffsetAdjustment;\n\n  var renderedCells = [];\n\n  for (var rowIndex = rowStartIndex; rowIndex <= rowStopIndex; rowIndex++) {\n    var rowDatum = rowSizeAndPositionManager.getSizeAndPositionOfCell(rowIndex);\n\n    for (var columnIndex = columnStartIndex; columnIndex <= columnStopIndex; columnIndex++) {\n      var columnDatum = columnSizeAndPositionManager.getSizeAndPositionOfCell(columnIndex);\n      var key = rowIndex + '-' + columnIndex;\n      var cellStyleObject = cellStyle({ rowIndex: rowIndex, columnIndex: columnIndex });\n      var renderedCell = void 0;\n\n      // Avoid re-creating cells while scrolling.\n      // This can lead to the same cell being created many times and can cause performance issues for \"heavy\" cells.\n      // If a scroll is in progress- cache and reuse cells.\n      // This cache will be thrown away once scrolling complets.\n      if (isScrolling) {\n        if (!cellCache[key]) {\n          cellCache[key] = cellRenderer({\n            columnIndex: columnIndex,\n            isScrolling: isScrolling,\n            rowIndex: rowIndex\n          });\n        }\n        renderedCell = cellCache[key];\n        // If the user is no longer scrolling, don't cache cells.\n        // This makes dynamic cell content difficult for users and would also lead to a heavier memory footprint.\n      } else {\n        renderedCell = cellRenderer({\n          columnIndex: columnIndex,\n          isScrolling: isScrolling,\n          rowIndex: rowIndex\n        });\n      }\n\n      if (renderedCell == null || renderedCell === false) {\n        continue;\n      }\n\n      var className = cellClassName({ columnIndex: columnIndex, rowIndex: rowIndex });\n\n      var child = _react2.default.createElement(\n        'div',\n        {\n          key: key,\n          className: (0, _classnames2.default)('Grid__cell', className),\n          style: _extends({\n            height: rowDatum.size,\n            left: columnDatum.offset + horizontalOffsetAdjustment,\n            top: rowDatum.offset + verticalOffsetAdjustment,\n            width: columnDatum.size\n          }, cellStyleObject)\n        },\n        renderedCell\n      );\n\n      renderedCells.push(child);\n    }\n  }\n\n  return renderedCells;\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.defaultCellRangeRenderer = exports.Grid = exports.default = undefined;\n\nvar _Grid2 = require('./Grid');\n\nvar _Grid3 = _interopRequireDefault(_Grid2);\n\nvar _defaultCellRangeRenderer2 = require('./defaultCellRangeRenderer');\n\nvar _defaultCellRangeRenderer3 = _interopRequireDefault(_defaultCellRangeRenderer2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _Grid3.default;\nexports.Grid = _Grid3.default;\nexports.defaultCellRangeRenderer = _defaultCellRangeRenderer3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\n * Just-in-time calculates and caches size and position information for a collection of cells.\n */\nvar CellSizeAndPositionManager = function () {\n  function CellSizeAndPositionManager(_ref) {\n    var cellCount = _ref.cellCount;\n    var cellSizeGetter = _ref.cellSizeGetter;\n    var estimatedCellSize = _ref.estimatedCellSize;\n\n    _classCallCheck(this, CellSizeAndPositionManager);\n\n    this._cellSizeGetter = cellSizeGetter;\n    this._cellCount = cellCount;\n    this._estimatedCellSize = estimatedCellSize;\n\n    // Cache of size and position data for cells, mapped by cell index.\n    // Note that invalid values may exist in this map so only rely on cells up to this._lastMeasuredIndex\n    this._cellSizeAndPositionData = {};\n\n    // Measurements for cells up to this index can be trusted; cells afterward should be estimated.\n    this._lastMeasuredIndex = -1;\n  }\n\n  _createClass(CellSizeAndPositionManager, [{\n    key: 'configure',\n    value: function configure(_ref2) {\n      var cellCount = _ref2.cellCount;\n      var estimatedCellSize = _ref2.estimatedCellSize;\n\n      this._cellCount = cellCount;\n      this._estimatedCellSize = estimatedCellSize;\n    }\n  }, {\n    key: 'getCellCount',\n    value: function getCellCount() {\n      return this._cellCount;\n    }\n  }, {\n    key: 'getEstimatedCellSize',\n    value: function getEstimatedCellSize() {\n      return this._estimatedCellSize;\n    }\n  }, {\n    key: 'getLastMeasuredIndex',\n    value: function getLastMeasuredIndex() {\n      return this._lastMeasuredIndex;\n    }\n\n    /**\n     * This method returns the size and position for the cell at the specified index.\n     * It just-in-time calculates (or used cached values) for cells leading up to the index.\n     */\n\n  }, {\n    key: 'getSizeAndPositionOfCell',\n    value: function getSizeAndPositionOfCell(index) {\n      if (index < 0 || index >= this._cellCount) {\n        throw Error('Requested index ' + index + ' is outside of range 0..' + this._cellCount);\n      }\n\n      if (index > this._lastMeasuredIndex) {\n        var lastMeasuredCellSizeAndPosition = this.getSizeAndPositionOfLastMeasuredCell();\n        var _offset = lastMeasuredCellSizeAndPosition.offset + lastMeasuredCellSizeAndPosition.size;\n\n        for (var i = this._lastMeasuredIndex + 1; i <= index; i++) {\n          var _size = this._cellSizeGetter({ index: i });\n\n          if (_size == null || isNaN(_size)) {\n            throw Error('Invalid size returned for cell ' + i + ' of value ' + _size);\n          }\n\n          this._cellSizeAndPositionData[i] = {\n            offset: _offset,\n            size: _size\n          };\n\n          _offset += _size;\n        }\n\n        this._lastMeasuredIndex = index;\n      }\n\n      return this._cellSizeAndPositionData[index];\n    }\n  }, {\n    key: 'getSizeAndPositionOfLastMeasuredCell',\n    value: function getSizeAndPositionOfLastMeasuredCell() {\n      return this._lastMeasuredIndex >= 0 ? this._cellSizeAndPositionData[this._lastMeasuredIndex] : {\n        offset: 0,\n        size: 0\n      };\n    }\n\n    /**\n     * Total size of all cells being measured.\n     * This value will be completedly estimated initially.\n     * As cells as measured the estimate will be updated.\n     */\n\n  }, {\n    key: 'getTotalSize',\n    value: function getTotalSize() {\n      var lastMeasuredCellSizeAndPosition = this.getSizeAndPositionOfLastMeasuredCell();\n\n      return lastMeasuredCellSizeAndPosition.offset + lastMeasuredCellSizeAndPosition.size + (this._cellCount - this._lastMeasuredIndex - 1) * this._estimatedCellSize;\n    }\n\n    /**\n     * Determines a new offset that ensures a certain cell is visible, given the current offset.\n     * If the cell is already visible then the current offset will be returned.\n     * If the current offset is too great or small, it will be adjusted just enough to ensure the specified index is visible.\n     *\n     * @param align Desired alignment within container; one of \"auto\" (default), \"start\", or \"end\"\n     * @param containerSize Size (width or height) of the container viewport\n     * @param currentOffset Container's current (x or y) offset\n     * @param totalSize Total size (width or height) of all cells\n     * @return Offset to use to ensure the specified cell is visible\n     */\n\n  }, {\n    key: 'getUpdatedOffsetForIndex',\n    value: function getUpdatedOffsetForIndex(_ref3) {\n      var _ref3$align = _ref3.align;\n      var align = _ref3$align === undefined ? 'auto' : _ref3$align;\n      var containerSize = _ref3.containerSize;\n      var currentOffset = _ref3.currentOffset;\n      var targetIndex = _ref3.targetIndex;\n\n      var datum = this.getSizeAndPositionOfCell(targetIndex);\n      var maxOffset = datum.offset;\n      var minOffset = maxOffset - containerSize + datum.size;\n\n      var idealOffset = void 0;\n\n      switch (align) {\n        case 'start':\n          idealOffset = maxOffset;\n          break;\n        case 'end':\n          idealOffset = minOffset;\n          break;\n        case 'center':\n          idealOffset = maxOffset - (containerSize - datum.size) / 2;\n          break;\n        default:\n          idealOffset = Math.max(minOffset, Math.min(maxOffset, currentOffset));\n          break;\n      }\n\n      var totalSize = this.getTotalSize();\n\n      return Math.max(0, Math.min(totalSize - containerSize, idealOffset));\n    }\n  }, {\n    key: 'getVisibleCellRange',\n    value: function getVisibleCellRange(_ref4) {\n      var containerSize = _ref4.containerSize;\n      var offset = _ref4.offset;\n\n      var totalSize = this.getTotalSize();\n\n      if (totalSize === 0) {\n        return {};\n      }\n\n      var maxOffset = offset + containerSize;\n      var start = this._findNearestCell(offset);\n\n      var datum = this.getSizeAndPositionOfCell(start);\n      offset = datum.offset + datum.size;\n\n      var stop = start;\n\n      while (offset < maxOffset && stop < this._cellCount - 1) {\n        stop++;\n\n        offset += this.getSizeAndPositionOfCell(stop).size;\n      }\n\n      return {\n        start: start,\n        stop: stop\n      };\n    }\n\n    /**\n     * Clear all cached values for cells after the specified index.\n     * This method should be called for any cell that has changed its size.\n     * It will not immediately perform any calculations; they'll be performed the next time getSizeAndPositionOfCell() is called.\n     */\n\n  }, {\n    key: 'resetCell',\n    value: function resetCell(index) {\n      this._lastMeasuredIndex = Math.min(this._lastMeasuredIndex, index - 1);\n    }\n  }, {\n    key: '_binarySearch',\n    value: function _binarySearch(_ref5) {\n      var high = _ref5.high;\n      var low = _ref5.low;\n      var offset = _ref5.offset;\n\n      var middle = void 0;\n      var currentOffset = void 0;\n\n      while (low <= high) {\n        middle = low + Math.floor((high - low) / 2);\n        currentOffset = this.getSizeAndPositionOfCell(middle).offset;\n\n        if (currentOffset === offset) {\n          return middle;\n        } else if (currentOffset < offset) {\n          low = middle + 1;\n        } else if (currentOffset > offset) {\n          high = middle - 1;\n        }\n      }\n\n      if (low > 0) {\n        return low - 1;\n      }\n    }\n  }, {\n    key: '_exponentialSearch',\n    value: function _exponentialSearch(_ref6) {\n      var index = _ref6.index;\n      var offset = _ref6.offset;\n\n      var interval = 1;\n\n      while (index < this._cellCount && this.getSizeAndPositionOfCell(index).offset < offset) {\n        index += interval;\n        interval *= 2;\n      }\n\n      return this._binarySearch({\n        high: Math.min(index, this._cellCount - 1),\n        low: Math.floor(index / 2),\n        offset: offset\n      });\n    }\n\n    /**\n     * Searches for the cell (index) nearest the specified offset.\n     *\n     * If no exact match is found the next lowest cell index will be returned.\n     * This allows partially visible cells (with offsets just before/above the fold) to be visible.\n     */\n\n  }, {\n    key: '_findNearestCell',\n    value: function _findNearestCell(offset) {\n      if (isNaN(offset)) {\n        throw Error('Invalid offset ' + offset + ' specified');\n      }\n\n      // Our search algorithms find the nearest match at or below the specified offset.\n      // So make sure the offset is at least 0 or no match will be found.\n      offset = Math.max(0, offset);\n\n      var lastMeasuredCellSizeAndPosition = this.getSizeAndPositionOfLastMeasuredCell();\n      var lastMeasuredIndex = Math.max(0, this._lastMeasuredIndex);\n\n      if (lastMeasuredCellSizeAndPosition.offset >= offset) {\n        // If we've already measured cells within this range just use a binary search as it's faster.\n        return this._binarySearch({\n          high: lastMeasuredIndex,\n          low: 0,\n          offset: offset\n        });\n      } else {\n        // If we haven't yet measured this high, fallback to an exponential search with an inner binary search.\n        // The exponential search avoids pre-computing sizes for the full set of cells as a binary search would.\n        // The overall complexity for this approach is O(log n).\n        return this._exponentialSearch({\n          index: lastMeasuredIndex,\n          offset: offset\n        });\n      }\n    }\n  }]);\n\n  return CellSizeAndPositionManager;\n}();\n\nexports.default = CellSizeAndPositionManager;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.DEFAULT_MAX_SCROLL_SIZE = undefined;\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _CellSizeAndPositionManager = require('./CellSizeAndPositionManager');\n\nvar _CellSizeAndPositionManager2 = _interopRequireDefault(_CellSizeAndPositionManager);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\n * Browsers have scroll offset limitations (eg Chrome stops scrolling at ~33.5M pixels where as Edge tops out at ~1.5M pixels).\n * After a certain position, the browser won't allow the user to scroll further (even via JavaScript scroll offset adjustments).\n * This util picks a lower ceiling for max size and artificially adjusts positions within to make it transparent for users.\n */\nvar DEFAULT_MAX_SCROLL_SIZE = exports.DEFAULT_MAX_SCROLL_SIZE = 1500000;\n\n/**\n * Extends CellSizeAndPositionManager and adds scaling behavior for lists that are too large to fit within a browser's native limits.\n */\n\nvar ScalingCellSizeAndPositionManager = function () {\n  function ScalingCellSizeAndPositionManager(_ref) {\n    var _ref$maxScrollSize = _ref.maxScrollSize;\n    var maxScrollSize = _ref$maxScrollSize === undefined ? DEFAULT_MAX_SCROLL_SIZE : _ref$maxScrollSize;\n\n    var params = _objectWithoutProperties(_ref, ['maxScrollSize']);\n\n    _classCallCheck(this, ScalingCellSizeAndPositionManager);\n\n    // Favor composition over inheritance to simplify IE10 support\n    this._cellSizeAndPositionManager = new _CellSizeAndPositionManager2.default(params);\n    this._maxScrollSize = maxScrollSize;\n  }\n\n  _createClass(ScalingCellSizeAndPositionManager, [{\n    key: 'configure',\n    value: function configure(params) {\n      this._cellSizeAndPositionManager.configure(params);\n    }\n  }, {\n    key: 'getCellCount',\n    value: function getCellCount() {\n      return this._cellSizeAndPositionManager.getCellCount();\n    }\n  }, {\n    key: 'getEstimatedCellSize',\n    value: function getEstimatedCellSize() {\n      return this._cellSizeAndPositionManager.getEstimatedCellSize();\n    }\n  }, {\n    key: 'getLastMeasuredIndex',\n    value: function getLastMeasuredIndex() {\n      return this._cellSizeAndPositionManager.getLastMeasuredIndex();\n    }\n\n    /**\n     * Number of pixels a cell at the given position (offset) should be shifted in order to fit within the scaled container.\n     * The offset passed to this function is scalled (safe) as well.\n     */\n\n  }, {\n    key: 'getOffsetAdjustment',\n    value: function getOffsetAdjustment(_ref2) {\n      var containerSize = _ref2.containerSize;\n      var offset = _ref2.offset;\n\n      var totalSize = this._cellSizeAndPositionManager.getTotalSize();\n      var safeTotalSize = this.getTotalSize();\n      var offsetPercentage = this._getOffsetPercentage({\n        containerSize: containerSize,\n        offset: offset,\n        totalSize: safeTotalSize\n      });\n\n      return Math.round(offsetPercentage * (safeTotalSize - totalSize));\n    }\n  }, {\n    key: 'getSizeAndPositionOfCell',\n    value: function getSizeAndPositionOfCell(index) {\n      return this._cellSizeAndPositionManager.getSizeAndPositionOfCell(index);\n    }\n  }, {\n    key: 'getSizeAndPositionOfLastMeasuredCell',\n    value: function getSizeAndPositionOfLastMeasuredCell() {\n      return this._cellSizeAndPositionManager.getSizeAndPositionOfLastMeasuredCell();\n    }\n\n    /** See CellSizeAndPositionManager#getTotalSize */\n\n  }, {\n    key: 'getTotalSize',\n    value: function getTotalSize() {\n      return Math.min(this._maxScrollSize, this._cellSizeAndPositionManager.getTotalSize());\n    }\n\n    /** See CellSizeAndPositionManager#getUpdatedOffsetForIndex */\n\n  }, {\n    key: 'getUpdatedOffsetForIndex',\n    value: function getUpdatedOffsetForIndex(_ref3) {\n      var _ref3$align = _ref3.align;\n      var align = _ref3$align === undefined ? 'auto' : _ref3$align;\n      var containerSize = _ref3.containerSize;\n      var currentOffset = _ref3.currentOffset;\n      var targetIndex = _ref3.targetIndex;\n      var totalSize = _ref3.totalSize;\n\n      currentOffset = this._safeOffsetToOffset({\n        containerSize: containerSize,\n        offset: currentOffset\n      });\n\n      var offset = this._cellSizeAndPositionManager.getUpdatedOffsetForIndex({\n        align: align,\n        containerSize: containerSize,\n        currentOffset: currentOffset,\n        targetIndex: targetIndex,\n        totalSize: totalSize\n      });\n\n      return this._offsetToSafeOffset({\n        containerSize: containerSize,\n        offset: offset\n      });\n    }\n\n    /** See CellSizeAndPositionManager#getVisibleCellRange */\n\n  }, {\n    key: 'getVisibleCellRange',\n    value: function getVisibleCellRange(_ref4) {\n      var containerSize = _ref4.containerSize;\n      var offset = _ref4.offset;\n\n      offset = this._safeOffsetToOffset({\n        containerSize: containerSize,\n        offset: offset\n      });\n\n      return this._cellSizeAndPositionManager.getVisibleCellRange({\n        containerSize: containerSize,\n        offset: offset\n      });\n    }\n  }, {\n    key: 'resetCell',\n    value: function resetCell(index) {\n      this._cellSizeAndPositionManager.resetCell(index);\n    }\n  }, {\n    key: '_getOffsetPercentage',\n    value: function _getOffsetPercentage(_ref5) {\n      var containerSize = _ref5.containerSize;\n      var offset = _ref5.offset;\n      var totalSize = _ref5.totalSize;\n\n      return totalSize <= containerSize ? 0 : offset / (totalSize - containerSize);\n    }\n  }, {\n    key: '_offsetToSafeOffset',\n    value: function _offsetToSafeOffset(_ref6) {\n      var containerSize = _ref6.containerSize;\n      var offset = _ref6.offset;\n\n      var totalSize = this._cellSizeAndPositionManager.getTotalSize();\n      var safeTotalSize = this.getTotalSize();\n\n      if (totalSize === safeTotalSize) {\n        return offset;\n      } else {\n        var offsetPercentage = this._getOffsetPercentage({\n          containerSize: containerSize,\n          offset: offset,\n          totalSize: totalSize\n        });\n\n        return Math.round(offsetPercentage * (safeTotalSize - containerSize));\n      }\n    }\n  }, {\n    key: '_safeOffsetToOffset',\n    value: function _safeOffsetToOffset(_ref7) {\n      var containerSize = _ref7.containerSize;\n      var offset = _ref7.offset;\n\n      var totalSize = this._cellSizeAndPositionManager.getTotalSize();\n      var safeTotalSize = this.getTotalSize();\n\n      if (totalSize === safeTotalSize) {\n        return offset;\n      } else {\n        var offsetPercentage = this._getOffsetPercentage({\n          containerSize: containerSize,\n          offset: offset,\n          totalSize: safeTotalSize\n        });\n\n        return Math.round(offsetPercentage * (totalSize - containerSize));\n      }\n    }\n  }]);\n\n  return ScalingCellSizeAndPositionManager;\n}();\n\nexports.default = ScalingCellSizeAndPositionManager;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = calculateSizeAndPositionDataAndUpdateScrollOffset;\n/**\n * Helper method that determines when to recalculate row or column metadata.\n *\n * @param cellCount Number of rows or columns in the current axis\n * @param cellsSize Width or height of cells for the current axis\n * @param computeMetadataCallback Method to invoke if cell metadata should be recalculated\n * @param computeMetadataCallbackProps Parameters to pass to :computeMetadataCallback\n * @param nextCellsCount Newly updated number of rows or columns in the current axis\n * @param nextCellsSize Newly updated width or height of cells for the current axis\n * @param nextScrollToIndex Newly updated scroll-to-index\n * @param scrollToIndex Scroll-to-index\n * @param updateScrollOffsetForScrollToIndex Callback to invoke if the scroll position should be recalculated\n */\nfunction calculateSizeAndPositionDataAndUpdateScrollOffset(_ref) {\n  var cellCount = _ref.cellCount;\n  var cellSize = _ref.cellSize;\n  var computeMetadataCallback = _ref.computeMetadataCallback;\n  var computeMetadataCallbackProps = _ref.computeMetadataCallbackProps;\n  var nextCellsCount = _ref.nextCellsCount;\n  var nextCellSize = _ref.nextCellSize;\n  var nextScrollToIndex = _ref.nextScrollToIndex;\n  var scrollToIndex = _ref.scrollToIndex;\n  var updateScrollOffsetForScrollToIndex = _ref.updateScrollOffsetForScrollToIndex;\n\n  // Don't compare cell sizes if they are functions because inline functions would cause infinite loops.\n  // In that event users should use the manual recompute methods to inform of changes.\n  if (cellCount !== nextCellsCount || (typeof cellSize === 'number' || typeof nextCellSize === 'number') && cellSize !== nextCellSize) {\n    computeMetadataCallback(computeMetadataCallbackProps);\n\n    // Updated cell metadata may have hidden the previous scrolled-to item.\n    // In this case we should also update the scrollTop to ensure it stays visible.\n    if (scrollToIndex >= 0 && scrollToIndex === nextScrollToIndex) {\n      updateScrollOffsetForScrollToIndex();\n    }\n  }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = getOverscanIndices;\nvar SCROLL_DIRECTION_BACKWARD = exports.SCROLL_DIRECTION_BACKWARD = -1;\nvar SCROLL_DIRECTION_FIXED = exports.SCROLL_DIRECTION_FIXED = 0;\nvar SCROLL_DIRECTION_FORWARD = exports.SCROLL_DIRECTION_FORWARD = 1;\n\n/**\n * Calculates the number of cells to overscan before and after a specified range.\n * This function ensures that overscanning doesn't exceed the available cells.\n *\n * @param cellCount Number of rows or columns in the current axis\n * @param scrollDirection One of SCROLL_DIRECTION_BACKWARD\n * @param overscanCellsCount Maximum number of cells to over-render in either direction\n * @param startIndex Begin of range of visible cells\n * @param stopIndex End of range of visible cells\n */\nfunction getOverscanIndices(_ref) {\n  var cellCount = _ref.cellCount;\n  var overscanCellsCount = _ref.overscanCellsCount;\n  var scrollDirection = _ref.scrollDirection;\n  var startIndex = _ref.startIndex;\n  var stopIndex = _ref.stopIndex;\n\n  var overscanStartIndex = void 0;\n  var overscanStopIndex = void 0;\n\n  if (scrollDirection === SCROLL_DIRECTION_FORWARD) {\n    overscanStartIndex = startIndex;\n    overscanStopIndex = stopIndex + overscanCellsCount * 2;\n  } else if (scrollDirection === SCROLL_DIRECTION_BACKWARD) {\n    overscanStartIndex = startIndex - overscanCellsCount * 2;\n    overscanStopIndex = stopIndex;\n  } else {\n    overscanStartIndex = startIndex - overscanCellsCount;\n    overscanStopIndex = stopIndex + overscanCellsCount;\n  }\n\n  return {\n    overscanStartIndex: Math.max(0, overscanStartIndex),\n    overscanStopIndex: Math.min(cellCount - 1, overscanStopIndex)\n  };\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = updateScrollIndexHelper;\n/**\n * Helper function that determines when to update scroll offsets to ensure that a scroll-to-index remains visible.\n * This function also ensures that the scroll ofset isn't past the last column/row of cells.\n *\n * @param cellsSize Width or height of cells for the current axis\n * @param cellSizeAndPositionManager Manages size and position metadata of cells\n * @param previousCellsCount Previous number of rows or columns\n * @param previousCellsSize Previous width or height of cells\n * @param previousScrollToIndex Previous scroll-to-index\n * @param previousSize Previous width or height of the virtualized container\n * @param scrollOffset Current scrollLeft or scrollTop\n * @param scrollToIndex Scroll-to-index\n * @param size Width or height of the virtualized container\n * @param updateScrollIndexCallback Callback to invoke with an scroll-to-index value\n */\nfunction updateScrollIndexHelper(_ref) {\n  var cellSize = _ref.cellSize;\n  var cellSizeAndPositionManager = _ref.cellSizeAndPositionManager;\n  var previousCellsCount = _ref.previousCellsCount;\n  var previousCellSize = _ref.previousCellSize;\n  var previousScrollToAlignment = _ref.previousScrollToAlignment;\n  var previousScrollToIndex = _ref.previousScrollToIndex;\n  var previousSize = _ref.previousSize;\n  var scrollOffset = _ref.scrollOffset;\n  var scrollToAlignment = _ref.scrollToAlignment;\n  var scrollToIndex = _ref.scrollToIndex;\n  var size = _ref.size;\n  var updateScrollIndexCallback = _ref.updateScrollIndexCallback;\n\n  var cellCount = cellSizeAndPositionManager.getCellCount();\n  var hasScrollToIndex = scrollToIndex >= 0 && scrollToIndex < cellCount;\n  var sizeHasChanged = size !== previousSize || !previousCellSize || typeof cellSize === 'number' && cellSize !== previousCellSize;\n\n  // If we have a new scroll target OR if height/row-height has changed,\n  // We should ensure that the scroll target is visible.\n  if (hasScrollToIndex && (sizeHasChanged || scrollToAlignment !== previousScrollToAlignment || scrollToIndex !== previousScrollToIndex)) {\n    updateScrollIndexCallback(scrollToIndex);\n\n    // If we don't have a selected item but list size or number of children have decreased,\n    // Make sure we aren't scrolled too far past the current content.\n  } else if (!hasScrollToIndex && cellCount > 0 && (size < previousSize || cellCount < previousCellsCount)) {\n    // We need to ensure that the current scroll offset is still within the collection's range.\n    // To do this, we don't need to measure everything; CellMeasurer would perform poorly.\n    // Just check to make sure we're still okay.\n    // Only adjust the scroll position if we've scrolled below the last set of rows.\n    if (scrollOffset > cellSizeAndPositionManager.getTotalSize() - size) {\n      updateScrollIndexCallback(cellCount - 1);\n    }\n  }\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nexports.isRangeVisible = isRangeVisible;\nexports.scanForUnloadedRanges = scanForUnloadedRanges;\nexports.forceUpdateReactVirtualizedComponent = forceUpdateReactVirtualizedComponent;\n\nvar _react = require('react');\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nvar _createCallbackMemoizer = require('../utils/createCallbackMemoizer');\n\nvar _createCallbackMemoizer2 = _interopRequireDefault(_createCallbackMemoizer);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * Higher-order component that manages lazy-loading for \"infinite\" data.\n * This component decorates a virtual component and just-in-time prefetches rows as a user scrolls.\n * It is intended as a convenience component; fork it if you'd like finer-grained control over data-loading.\n */\nvar InfiniteLoader = function (_Component) {\n  _inherits(InfiniteLoader, _Component);\n\n  function InfiniteLoader(props, context) {\n    _classCallCheck(this, InfiniteLoader);\n\n    var _this = _possibleConstructorReturn(this, (InfiniteLoader.__proto__ || Object.getPrototypeOf(InfiniteLoader)).call(this, props, context));\n\n    _this._loadMoreRowsMemoizer = (0, _createCallbackMemoizer2.default)();\n\n    _this._onRowsRendered = _this._onRowsRendered.bind(_this);\n    _this._registerChild = _this._registerChild.bind(_this);\n    return _this;\n  }\n\n  _createClass(InfiniteLoader, [{\n    key: 'render',\n    value: function render() {\n      var children = this.props.children;\n\n\n      return children({\n        onRowsRendered: this._onRowsRendered,\n        registerChild: this._registerChild\n      });\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_loadUnloadedRanges',\n    value: function _loadUnloadedRanges(unloadedRanges) {\n      var _this2 = this;\n\n      var loadMoreRows = this.props.loadMoreRows;\n\n\n      unloadedRanges.forEach(function (unloadedRange) {\n        var promise = loadMoreRows(unloadedRange);\n        if (promise) {\n          promise.then(function () {\n            // Refresh the visible rows if any of them have just been loaded.\n            // Otherwise they will remain in their unloaded visual state.\n            if (isRangeVisible({\n              lastRenderedStartIndex: _this2._lastRenderedStartIndex,\n              lastRenderedStopIndex: _this2._lastRenderedStopIndex,\n              startIndex: unloadedRange.startIndex,\n              stopIndex: unloadedRange.stopIndex\n            })) {\n              if (_this2._registeredChild) {\n                forceUpdateReactVirtualizedComponent(_this2._registeredChild);\n              }\n            }\n          });\n        }\n      });\n    }\n  }, {\n    key: '_onRowsRendered',\n    value: function _onRowsRendered(_ref) {\n      var _this3 = this;\n\n      var startIndex = _ref.startIndex;\n      var stopIndex = _ref.stopIndex;\n      var _props = this.props;\n      var isRowLoaded = _props.isRowLoaded;\n      var minimumBatchSize = _props.minimumBatchSize;\n      var rowCount = _props.rowCount;\n      var threshold = _props.threshold;\n\n\n      this._lastRenderedStartIndex = startIndex;\n      this._lastRenderedStopIndex = stopIndex;\n\n      var unloadedRanges = scanForUnloadedRanges({\n        isRowLoaded: isRowLoaded,\n        minimumBatchSize: minimumBatchSize,\n        rowCount: rowCount,\n        startIndex: Math.max(0, startIndex - threshold),\n        stopIndex: Math.min(rowCount - 1, stopIndex + threshold)\n      });\n\n      // For memoize comparison\n      var squashedUnloadedRanges = unloadedRanges.reduce(function (reduced, unloadedRange) {\n        return reduced.concat([unloadedRange.startIndex, unloadedRange.stopIndex]);\n      }, []);\n\n      this._loadMoreRowsMemoizer({\n        callback: function callback() {\n          _this3._loadUnloadedRanges(unloadedRanges);\n        },\n        indices: { squashedUnloadedRanges: squashedUnloadedRanges }\n      });\n    }\n  }, {\n    key: '_registerChild',\n    value: function _registerChild(registeredChild) {\n      this._registeredChild = registeredChild;\n    }\n  }]);\n\n  return InfiniteLoader;\n}(_react.Component);\n\n/**\n * Determines if the specified start/stop range is visible based on the most recently rendered range.\n */\n\n\nInfiniteLoader.propTypes = {\n  /**\n   * Function respondible for rendering a virtualized component.\n   * This function should implement the following signature:\n   * ({ onRowsRendered, registerChild }) => PropTypes.element\n   *\n   * The specified :onRowsRendered function should be passed through to the child's :onRowsRendered property.\n   * The :registerChild callback should be set as the virtualized component's :ref.\n   */\n  children: _react.PropTypes.func.isRequired,\n\n  /**\n   * Function responsible for tracking the loaded state of each row.\n   * It should implement the following signature: ({ index: number }): boolean\n   */\n  isRowLoaded: _react.PropTypes.func.isRequired,\n\n  /**\n   * Callback to be invoked when more rows must be loaded.\n   * It should implement the following signature: ({ startIndex, stopIndex }): Promise\n   * The returned Promise should be resolved once row data has finished loading.\n   * It will be used to determine when to refresh the list with the newly-loaded data.\n   * This callback may be called multiple times in reaction to a single scroll event.\n   */\n  loadMoreRows: _react.PropTypes.func.isRequired,\n\n  /**\n   * Minimum number of rows to be loaded at a time.\n   * This property can be used to batch requests to reduce HTTP requests.\n   */\n  minimumBatchSize: _react.PropTypes.number.isRequired,\n\n  /**\n   * Number of rows in list; can be arbitrary high number if actual number is unknown.\n   */\n  rowCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Threshold at which to pre-fetch data.\n   * A threshold X means that data will start loading when a user scrolls within X rows.\n   * This value defaults to 15.\n   */\n  threshold: _react.PropTypes.number.isRequired\n};\nInfiniteLoader.defaultProps = {\n  minimumBatchSize: 10,\n  rowCount: 0,\n  threshold: 15\n};\nexports.default = InfiniteLoader;\nfunction isRangeVisible(_ref2) {\n  var lastRenderedStartIndex = _ref2.lastRenderedStartIndex;\n  var lastRenderedStopIndex = _ref2.lastRenderedStopIndex;\n  var startIndex = _ref2.startIndex;\n  var stopIndex = _ref2.stopIndex;\n\n  return !(startIndex > lastRenderedStopIndex || stopIndex < lastRenderedStartIndex);\n}\n\n/**\n * Returns all of the ranges within a larger range that contain unloaded rows.\n */\nfunction scanForUnloadedRanges(_ref3) {\n  var isRowLoaded = _ref3.isRowLoaded;\n  var minimumBatchSize = _ref3.minimumBatchSize;\n  var rowCount = _ref3.rowCount;\n  var startIndex = _ref3.startIndex;\n  var stopIndex = _ref3.stopIndex;\n\n  var unloadedRanges = [];\n\n  var rangeStartIndex = null;\n  var rangeStopIndex = null;\n\n  for (var index = startIndex; index <= stopIndex; index++) {\n    var loaded = isRowLoaded({ index: index });\n\n    if (!loaded) {\n      rangeStopIndex = index;\n      if (rangeStartIndex === null) {\n        rangeStartIndex = index;\n      }\n    } else if (rangeStopIndex !== null) {\n      unloadedRanges.push({\n        startIndex: rangeStartIndex,\n        stopIndex: rangeStopIndex\n      });\n\n      rangeStartIndex = rangeStopIndex = null;\n    }\n  }\n\n  // If :rangeStopIndex is not null it means we haven't ran out of unloaded rows.\n  // Scan forward to try filling our :minimumBatchSize.\n  if (rangeStopIndex !== null) {\n    var potentialStopIndex = Math.min(Math.max(rangeStopIndex, rangeStartIndex + minimumBatchSize - 1), rowCount - 1);\n\n    for (var _index = rangeStopIndex + 1; _index <= potentialStopIndex; _index++) {\n      if (!isRowLoaded({ index: _index })) {\n        rangeStopIndex = _index;\n      } else {\n        break;\n      }\n    }\n\n    unloadedRanges.push({\n      startIndex: rangeStartIndex,\n      stopIndex: rangeStopIndex\n    });\n  }\n\n  // Check to see if our first range ended prematurely.\n  // In this case we should scan backwards to try filling our :minimumBatchSize.\n  if (unloadedRanges.length) {\n    var firstUnloadedRange = unloadedRanges[0];\n\n    while (firstUnloadedRange.stopIndex - firstUnloadedRange.startIndex + 1 < minimumBatchSize && firstUnloadedRange.startIndex > 0) {\n      var _index2 = firstUnloadedRange.startIndex - 1;\n\n      if (!isRowLoaded({ index: _index2 })) {\n        firstUnloadedRange.startIndex = _index2;\n      } else {\n        break;\n      }\n    }\n  }\n\n  return unloadedRanges;\n}\n\n/**\n * Since RV components use shallowCompare we need to force a render (even though props haven't changed).\n * However InfiniteLoader may wrap a Grid or it may wrap a FlexTable or VirtualScroll.\n * In the first case the built-in React forceUpdate() method is sufficient to force a re-render,\n * But in the latter cases we need to use the RV-specific forceUpdateGrid() method.\n * Else the inner Grid will not be re-rendered and visuals may be stale.\n */\nfunction forceUpdateReactVirtualizedComponent(component) {\n  typeof component.forceUpdateGrid === 'function' ? component.forceUpdateGrid() : component.forceUpdate();\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.InfiniteLoader = exports.default = undefined;\n\nvar _InfiniteLoader2 = require('./InfiniteLoader');\n\nvar _InfiniteLoader3 = _interopRequireDefault(_InfiniteLoader2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _InfiniteLoader3.default;\nexports.InfiniteLoader = _InfiniteLoader3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * HOC that simplifies the process of synchronizing scrolling between two or more virtualized components.\n */\nvar ScrollSync = function (_Component) {\n  _inherits(ScrollSync, _Component);\n\n  function ScrollSync(props, context) {\n    _classCallCheck(this, ScrollSync);\n\n    var _this = _possibleConstructorReturn(this, (ScrollSync.__proto__ || Object.getPrototypeOf(ScrollSync)).call(this, props, context));\n\n    _this.state = {\n      clientHeight: 0,\n      clientWidth: 0,\n      scrollHeight: 0,\n      scrollLeft: 0,\n      scrollTop: 0,\n      scrollWidth: 0\n    };\n\n    _this._onScroll = _this._onScroll.bind(_this);\n    return _this;\n  }\n\n  _createClass(ScrollSync, [{\n    key: 'render',\n    value: function render() {\n      var children = this.props.children;\n      var _state = this.state;\n      var clientHeight = _state.clientHeight;\n      var clientWidth = _state.clientWidth;\n      var scrollHeight = _state.scrollHeight;\n      var scrollLeft = _state.scrollLeft;\n      var scrollTop = _state.scrollTop;\n      var scrollWidth = _state.scrollWidth;\n\n\n      return children({\n        clientHeight: clientHeight,\n        clientWidth: clientWidth,\n        onScroll: this._onScroll,\n        scrollHeight: scrollHeight,\n        scrollLeft: scrollLeft,\n        scrollTop: scrollTop,\n        scrollWidth: scrollWidth\n      });\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_onScroll',\n    value: function _onScroll(_ref) {\n      var clientHeight = _ref.clientHeight;\n      var clientWidth = _ref.clientWidth;\n      var scrollHeight = _ref.scrollHeight;\n      var scrollLeft = _ref.scrollLeft;\n      var scrollTop = _ref.scrollTop;\n      var scrollWidth = _ref.scrollWidth;\n\n      this.setState({ clientHeight: clientHeight, clientWidth: clientWidth, scrollHeight: scrollHeight, scrollLeft: scrollLeft, scrollTop: scrollTop, scrollWidth: scrollWidth });\n    }\n  }]);\n\n  return ScrollSync;\n}(_react.Component);\n\nScrollSync.propTypes = {\n  /**\n   * Function respondible for rendering 2 or more virtualized components.\n   * This function should implement the following signature:\n   * ({ onScroll, scrollLeft, scrollTop }) => PropTypes.element\n   */\n  children: _react.PropTypes.func.isRequired\n};\nexports.default = ScrollSync;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.ScrollSync = exports.default = undefined;\n\nvar _ScrollSync2 = require('./ScrollSync');\n\nvar _ScrollSync3 = _interopRequireDefault(_ScrollSync2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _ScrollSync3.default;\nexports.ScrollSync = _ScrollSync3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _Grid = require('../Grid');\n\nvar _Grid2 = _interopRequireDefault(_Grid);\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _classnames = require('classnames');\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * It is inefficient to create and manage a large list of DOM elements within a scrolling container\n * if only a few of those elements are visible. The primary purpose of this component is to improve\n * performance by only rendering the DOM nodes that a user is able to see based on their current\n * scroll position.\n *\n * This component renders a virtualized list of elements with either fixed or dynamic heights.\n */\nvar VirtualScroll = function (_Component) {\n  _inherits(VirtualScroll, _Component);\n\n  function VirtualScroll(props, context) {\n    _classCallCheck(this, VirtualScroll);\n\n    var _this = _possibleConstructorReturn(this, (VirtualScroll.__proto__ || Object.getPrototypeOf(VirtualScroll)).call(this, props, context));\n\n    _this._cellRenderer = _this._cellRenderer.bind(_this);\n    _this._createRowClassNameGetter = _this._createRowClassNameGetter.bind(_this);\n    _this._createRowStyleGetter = _this._createRowStyleGetter.bind(_this);\n    _this._onScroll = _this._onScroll.bind(_this);\n    _this._onSectionRendered = _this._onSectionRendered.bind(_this);\n    return _this;\n  }\n\n  _createClass(VirtualScroll, [{\n    key: 'forceUpdateGrid',\n    value: function forceUpdateGrid() {\n      this.Grid.forceUpdate();\n    }\n\n    /** See Grid#measureAllCells */\n\n  }, {\n    key: 'measureAllRows',\n    value: function measureAllRows() {\n      this.Grid.measureAllCells();\n    }\n\n    /** See Grid#recomputeGridSize */\n\n  }, {\n    key: 'recomputeRowHeights',\n    value: function recomputeRowHeights() {\n      var index = arguments.length <= 0 || arguments[0] === undefined ? 0 : arguments[0];\n\n      this.Grid.recomputeGridSize({\n        rowIndex: index\n      });\n      this.forceUpdateGrid();\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _this2 = this;\n\n      var _props = this.props;\n      var className = _props.className;\n      var noRowsRenderer = _props.noRowsRenderer;\n      var scrollToIndex = _props.scrollToIndex;\n      var width = _props.width;\n\n\n      var classNames = (0, _classnames2.default)('VirtualScroll', className);\n\n      return _react2.default.createElement(_Grid2.default, _extends({}, this.props, {\n        autoContainerWidth: true,\n        cellRenderer: this._cellRenderer,\n        cellClassName: this._createRowClassNameGetter(),\n        cellStyle: this._createRowStyleGetter(),\n        className: classNames,\n        columnWidth: width,\n        columnCount: 1,\n        noContentRenderer: noRowsRenderer,\n        onScroll: this._onScroll,\n        onSectionRendered: this._onSectionRendered,\n        ref: function ref(_ref) {\n          _this2.Grid = _ref;\n        },\n        scrollToRow: scrollToIndex\n      }));\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_cellRenderer',\n    value: function _cellRenderer(_ref2) {\n      var columnIndex = _ref2.columnIndex;\n      var isScrolling = _ref2.isScrolling;\n      var rowIndex = _ref2.rowIndex;\n      var rowRenderer = this.props.rowRenderer;\n\n\n      return rowRenderer({\n        index: rowIndex,\n        isScrolling: isScrolling\n      });\n    }\n  }, {\n    key: '_createRowClassNameGetter',\n    value: function _createRowClassNameGetter() {\n      var rowClassName = this.props.rowClassName;\n\n\n      return rowClassName instanceof Function ? function (_ref3) {\n        var rowIndex = _ref3.rowIndex;\n        return rowClassName({ index: rowIndex });\n      } : function () {\n        return rowClassName;\n      };\n    }\n  }, {\n    key: '_createRowStyleGetter',\n    value: function _createRowStyleGetter() {\n      var rowStyle = this.props.rowStyle;\n\n\n      var wrapped = rowStyle instanceof Function ? rowStyle : function () {\n        return rowStyle;\n      };\n\n      // Default width to 100% to prevent list rows from flowing under the vertical scrollbar\n      return function (_ref4) {\n        var rowIndex = _ref4.rowIndex;\n        return _extends({\n          width: '100%'\n        }, wrapped({ index: rowIndex }));\n      };\n    }\n  }, {\n    key: '_onScroll',\n    value: function _onScroll(_ref5) {\n      var clientHeight = _ref5.clientHeight;\n      var scrollHeight = _ref5.scrollHeight;\n      var scrollTop = _ref5.scrollTop;\n      var onScroll = this.props.onScroll;\n\n\n      onScroll({ clientHeight: clientHeight, scrollHeight: scrollHeight, scrollTop: scrollTop });\n    }\n  }, {\n    key: '_onSectionRendered',\n    value: function _onSectionRendered(_ref6) {\n      var rowOverscanStartIndex = _ref6.rowOverscanStartIndex;\n      var rowOverscanStopIndex = _ref6.rowOverscanStopIndex;\n      var rowStartIndex = _ref6.rowStartIndex;\n      var rowStopIndex = _ref6.rowStopIndex;\n      var onRowsRendered = this.props.onRowsRendered;\n\n\n      onRowsRendered({\n        overscanStartIndex: rowOverscanStartIndex,\n        overscanStopIndex: rowOverscanStopIndex,\n        startIndex: rowStartIndex,\n        stopIndex: rowStopIndex\n      });\n    }\n  }]);\n\n  return VirtualScroll;\n}(_react.Component);\n\nVirtualScroll.propTypes = {\n  'aria-label': _react.PropTypes.string,\n\n  /**\n   * Removes fixed height from the scrollingContainer so that the total height\n   * of rows can stretch the window. Intended for use with WindowScroller\n   */\n  autoHeight: _react.PropTypes.bool,\n\n  /** Optional CSS class name */\n  className: _react.PropTypes.string,\n\n  /**\n   * Used to estimate the total height of a VirtualScroll before all of its rows have actually been measured.\n   * The estimated total height is adjusted as rows are rendered.\n   */\n  estimatedRowSize: _react.PropTypes.number.isRequired,\n\n  /** Height constraint for list (determines how many actual rows are rendered) */\n  height: _react.PropTypes.number.isRequired,\n\n  /** Optional renderer to be used in place of rows when rowCount is 0 */\n  noRowsRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Callback invoked with information about the slice of rows that were just rendered.\n   * ({ startIndex, stopIndex }): void\n   */\n  onRowsRendered: _react.PropTypes.func.isRequired,\n\n  /**\n   * Number of rows to render above/below the visible bounds of the list.\n   * These rows can help for smoother scrolling on touch devices.\n   */\n  overscanRowCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Callback invoked whenever the scroll offset changes within the inner scrollable region.\n   * This callback can be used to sync scrolling between lists, tables, or grids.\n   * ({ clientHeight, scrollHeight, scrollTop }): void\n   */\n  onScroll: _react.PropTypes.func.isRequired,\n\n  /**\n   * Either a fixed row height (number) or a function that returns the height of a row given its index.\n   * ({ index: number }): number\n   */\n  rowHeight: _react.PropTypes.oneOfType([_react.PropTypes.number, _react.PropTypes.func]).isRequired,\n\n  /** Responsbile for rendering a row given an index; ({ index: number }): node */\n  rowRenderer: _react.PropTypes.func.isRequired,\n\n  /** Optional custom CSS class for individual rows */\n  rowClassName: _react.PropTypes.oneOfType([_react.PropTypes.string, _react.PropTypes.func]),\n\n  /** Number of rows in list. */\n  rowCount: _react.PropTypes.number.isRequired,\n\n  /** Optional custom styles for individual cells */\n  rowStyle: _react.PropTypes.oneOfType([_react.PropTypes.object, _react.PropTypes.func]),\n\n  /** See Grid#scrollToAlignment */\n  scrollToAlignment: _react.PropTypes.oneOf(['auto', 'end', 'start', 'center']).isRequired,\n\n  /** Row index to ensure visible (by forcefully scrolling if necessary) */\n  scrollToIndex: _react.PropTypes.number,\n\n  /** Vertical offset. */\n  scrollTop: _react.PropTypes.number,\n\n  /** Optional inline style */\n  style: _react.PropTypes.object,\n\n  /** Tab index for focus */\n  tabIndex: _react.PropTypes.number,\n\n  /** Width of list */\n  width: _react.PropTypes.number.isRequired\n};\nVirtualScroll.defaultProps = {\n  estimatedRowSize: 30,\n  noRowsRenderer: function noRowsRenderer() {\n    return null;\n  },\n  onRowsRendered: function onRowsRendered() {\n    return null;\n  },\n  onScroll: function onScroll() {\n    return null;\n  },\n  overscanRowCount: 10,\n  scrollToAlignment: 'auto',\n  style: {}\n};\nexports.default = VirtualScroll;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.VirtualScroll = exports.default = undefined;\n\nvar _VirtualScroll2 = require('./VirtualScroll');\n\nvar _VirtualScroll3 = _interopRequireDefault(_VirtualScroll2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _VirtualScroll3.default;\nexports.VirtualScroll = _VirtualScroll3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactDom = require('react-dom');\n\nvar _reactDom2 = _interopRequireDefault(_reactDom);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nvar _raf = require('raf');\n\nvar _raf2 = _interopRequireDefault(_raf);\n\nvar _onScroll = require('./utils/onScroll');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar WindowScroller = function (_Component) {\n  _inherits(WindowScroller, _Component);\n\n  function WindowScroller(props) {\n    _classCallCheck(this, WindowScroller);\n\n    var _this = _possibleConstructorReturn(this, (WindowScroller.__proto__ || Object.getPrototypeOf(WindowScroller)).call(this, props));\n\n    var height = typeof window !== 'undefined' ? window.innerHeight : 0;\n\n    _this.state = {\n      isScrolling: false,\n      height: height,\n      scrollTop: 0\n    };\n\n    _this._onScrollWindow = _this._onScrollWindow.bind(_this);\n    _this._onResizeWindow = _this._onResizeWindow.bind(_this);\n    _this._enablePointerEventsAfterDelayCallback = _this._enablePointerEventsAfterDelayCallback.bind(_this);\n    return _this;\n  }\n\n  _createClass(WindowScroller, [{\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      var height = this.state.height;\n\n      // Subtract documentElement top to handle edge-case where a user is navigating back (history) from an already-scrolled bage.\n      // In this case the body's top position will be a negative number and this element's top will be increased (by that amount).\n\n      this._positionFromTop = _reactDom2.default.findDOMNode(this).getBoundingClientRect().top - document.documentElement.getBoundingClientRect().top;\n\n      if (height !== window.innerHeight) {\n        this.setState({\n          height: window.innerHeight\n        });\n      }\n\n      (0, _onScroll.registerScrollListener)(this);\n      window.addEventListener('resize', this._onResizeWindow, false);\n    }\n  }, {\n    key: 'componentWillUnmount',\n    value: function componentWillUnmount() {\n      (0, _onScroll.unregisterScrollListener)(this);\n\n      window.removeEventListener('resize', this._onResizeWindow, false);\n    }\n\n    /**\n     * Updates the state during the next animation frame.\n     * Use this method to avoid multiple renders in a small span of time.\n     * This helps performance for bursty events (like onScroll).\n     */\n\n  }, {\n    key: '_setNextState',\n    value: function _setNextState(state) {\n      var _this2 = this;\n\n      if (this._setNextStateAnimationFrameId) {\n        _raf2.default.cancel(this._setNextStateAnimationFrameId);\n      }\n\n      this._setNextStateAnimationFrameId = (0, _raf2.default)(function () {\n        _this2._setNextStateAnimationFrameId = null;\n        _this2.setState(state);\n      });\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var children = this.props.children;\n      var _state = this.state;\n      var isScrolling = _state.isScrolling;\n      var scrollTop = _state.scrollTop;\n      var height = _state.height;\n\n\n      return _react2.default.createElement(\n        'div',\n        null,\n        children({\n          height: height,\n          isScrolling: isScrolling,\n          scrollTop: scrollTop\n        })\n      );\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_enablePointerEventsAfterDelayCallback',\n    value: function _enablePointerEventsAfterDelayCallback() {\n      this.setState({\n        isScrolling: false\n      });\n    }\n  }, {\n    key: '_onResizeWindow',\n    value: function _onResizeWindow(event) {\n      var onResize = this.props.onResize;\n\n\n      var height = window.innerHeight || 0;\n\n      this.setState({ height: height });\n\n      onResize({ height: height });\n    }\n  }, {\n    key: '_onScrollWindow',\n    value: function _onScrollWindow(event) {\n      var onScroll = this.props.onScroll;\n\n      // In IE10+ scrollY is undefined, so we replace that with the latter\n\n      var scrollY = 'scrollY' in window ? window.scrollY : document.documentElement.scrollTop;\n\n      var scrollTop = Math.max(0, scrollY - this._positionFromTop);\n\n      var state = {\n        isScrolling: true,\n        scrollTop: scrollTop\n      };\n\n      if (!this.state.isScrolling) {\n        this.setState(state);\n      } else {\n        this._setNextState(state);\n      }\n\n      onScroll({ scrollTop: scrollTop });\n    }\n  }]);\n\n  return WindowScroller;\n}(_react.Component);\n\nWindowScroller.propTypes = {\n  /**\n   * Function respondible for rendering children.\n   * This function should implement the following signature:\n   * ({ height, scrollTop }) => PropTypes.element\n   */\n  children: _react.PropTypes.func.isRequired,\n\n  /** Callback to be invoked on-resize: ({ height }) */\n  onResize: _react.PropTypes.func.isRequired,\n\n  /** Callback to be invoked on-scroll: ({ scrollTop }) */\n  onScroll: _react.PropTypes.func.isRequired\n};\nWindowScroller.defaultProps = {\n  onResize: function onResize() {},\n  onScroll: function onScroll() {}\n};\nexports.default = WindowScroller;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.IS_SCROLLING_TIMEOUT = exports.WindowScroller = exports.default = undefined;\n\nvar _WindowScroller2 = require('./WindowScroller');\n\nvar _WindowScroller3 = _interopRequireDefault(_WindowScroller2);\n\nvar _onScroll = require('./utils/onScroll');\n\nvar _onScroll2 = _interopRequireDefault(_onScroll);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _WindowScroller3.default;\nexports.WindowScroller = _WindowScroller3.default;\nexports.IS_SCROLLING_TIMEOUT = _onScroll2.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.registerScrollListener = registerScrollListener;\nexports.unregisterScrollListener = unregisterScrollListener;\nvar mountedInstances = [];\nvar originalBodyPointerEvents = null;\nvar disablePointerEventsTimeoutId = null;\n\n/**\n * Specifies the number of miliseconds during which to disable pointer events while a scroll is in progress.\n * This improves performance and makes scrolling smoother.\n */\nvar IS_SCROLLING_TIMEOUT = exports.IS_SCROLLING_TIMEOUT = 150;\n\nfunction enablePointerEventsIfDisabled() {\n  if (disablePointerEventsTimeoutId) {\n    disablePointerEventsTimeoutId = null;\n\n    document.body.style.pointerEvents = originalBodyPointerEvents;\n\n    originalBodyPointerEvents = null;\n  }\n}\n\nfunction enablePointerEventsAfterDelayCallback() {\n  enablePointerEventsIfDisabled();\n  mountedInstances.forEach(function (component) {\n    return component._enablePointerEventsAfterDelayCallback();\n  });\n}\n\nfunction enablePointerEventsAfterDelay() {\n  if (disablePointerEventsTimeoutId) {\n    clearTimeout(disablePointerEventsTimeoutId);\n  }\n\n  disablePointerEventsTimeoutId = setTimeout(enablePointerEventsAfterDelayCallback, IS_SCROLLING_TIMEOUT);\n}\n\nfunction onScrollWindow(event) {\n  if (originalBodyPointerEvents == null) {\n    originalBodyPointerEvents = document.body.style.pointerEvents;\n\n    document.body.style.pointerEvents = 'none';\n\n    enablePointerEventsAfterDelay();\n  }\n  mountedInstances.forEach(function (component) {\n    return component._onScrollWindow(event);\n  });\n}\n\nfunction registerScrollListener(component) {\n  if (!mountedInstances.length) {\n    window.addEventListener('scroll', onScrollWindow);\n  }\n  mountedInstances.push(component);\n}\n\nfunction unregisterScrollListener(component) {\n  mountedInstances = mountedInstances.filter(function (c) {\n    return c !== component;\n  });\n  if (!mountedInstances.length) {\n    window.removeEventListener('scroll', onScrollWindow);\n    if (disablePointerEventsTimeoutId) {\n      clearTimeout(disablePointerEventsTimeoutId);\n      enablePointerEventsIfDisabled();\n    }\n  }\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _ArrowKeyStepper = require('./ArrowKeyStepper');\n\nObject.defineProperty(exports, 'ArrowKeyStepper', {\n  enumerable: true,\n  get: function get() {\n    return _ArrowKeyStepper.ArrowKeyStepper;\n  }\n});\n\nvar _AutoSizer = require('./AutoSizer');\n\nObject.defineProperty(exports, 'AutoSizer', {\n  enumerable: true,\n  get: function get() {\n    return _AutoSizer.AutoSizer;\n  }\n});\n\nvar _CellMeasurer = require('./CellMeasurer');\n\nObject.defineProperty(exports, 'CellMeasurer', {\n  enumerable: true,\n  get: function get() {\n    return _CellMeasurer.CellMeasurer;\n  }\n});\nObject.defineProperty(exports, 'defaultCellMeasurerCellSizeCache', {\n  enumerable: true,\n  get: function get() {\n    return _CellMeasurer.defaultCellSizeCache;\n  }\n});\nObject.defineProperty(exports, 'uniformSizeCellMeasurerCellSizeCache', {\n  enumerable: true,\n  get: function get() {\n    return _CellMeasurer.defaultCellSizeCache;\n  }\n});\n\nvar _Collection = require('./Collection');\n\nObject.defineProperty(exports, 'Collection', {\n  enumerable: true,\n  get: function get() {\n    return _Collection.Collection;\n  }\n});\n\nvar _ColumnSizer = require('./ColumnSizer');\n\nObject.defineProperty(exports, 'ColumnSizer', {\n  enumerable: true,\n  get: function get() {\n    return _ColumnSizer.ColumnSizer;\n  }\n});\n\nvar _FlexTable = require('./FlexTable');\n\nObject.defineProperty(exports, 'defaultFlexTableCellDataGetter', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.defaultCellDataGetter;\n  }\n});\nObject.defineProperty(exports, 'defaultFlexTableCellRenderer', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.defaultCellRenderer;\n  }\n});\nObject.defineProperty(exports, 'defaultFlexTableHeaderRenderer', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.defaultHeaderRenderer;\n  }\n});\nObject.defineProperty(exports, 'defaultFlexTableRowRenderer', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.defaultRowRenderer;\n  }\n});\nObject.defineProperty(exports, 'FlexTable', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.FlexTable;\n  }\n});\nObject.defineProperty(exports, 'FlexColumn', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.FlexColumn;\n  }\n});\nObject.defineProperty(exports, 'SortDirection', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.SortDirection;\n  }\n});\nObject.defineProperty(exports, 'SortIndicator', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.SortIndicator;\n  }\n});\n\nvar _Grid = require('./Grid');\n\nObject.defineProperty(exports, 'defaultCellRangeRenderer', {\n  enumerable: true,\n  get: function get() {\n    return _Grid.defaultCellRangeRenderer;\n  }\n});\nObject.defineProperty(exports, 'Grid', {\n  enumerable: true,\n  get: function get() {\n    return _Grid.Grid;\n  }\n});\n\nvar _InfiniteLoader = require('./InfiniteLoader');\n\nObject.defineProperty(exports, 'InfiniteLoader', {\n  enumerable: true,\n  get: function get() {\n    return _InfiniteLoader.InfiniteLoader;\n  }\n});\n\nvar _ScrollSync = require('./ScrollSync');\n\nObject.defineProperty(exports, 'ScrollSync', {\n  enumerable: true,\n  get: function get() {\n    return _ScrollSync.ScrollSync;\n  }\n});\n\nvar _VirtualScroll = require('./VirtualScroll');\n\nObject.defineProperty(exports, 'VirtualScroll', {\n  enumerable: true,\n  get: function get() {\n    return _VirtualScroll.VirtualScroll;\n  }\n});\n\nvar _WindowScroller = require('./WindowScroller');\n\nObject.defineProperty(exports, 'WindowScroller', {\n  enumerable: true,\n  get: function get() {\n    return _WindowScroller.WindowScroller;\n  }\n});","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = createCallbackMemoizer;\n/**\n * Helper utility that updates the specified callback whenever any of the specified indices have changed.\n */\nfunction createCallbackMemoizer() {\n  var requireAllKeys = arguments.length <= 0 || arguments[0] === undefined ? true : arguments[0];\n\n  var cachedIndices = {};\n\n  return function (_ref) {\n    var callback = _ref.callback;\n    var indices = _ref.indices;\n\n    var keys = Object.keys(indices);\n    var allInitialized = !requireAllKeys || keys.every(function (key) {\n      var value = indices[key];\n      return Array.isArray(value) ? value.length > 0 : value >= 0;\n    });\n    var indexChanged = keys.length !== Object.keys(cachedIndices).length || keys.some(function (key) {\n      var cachedValue = cachedIndices[key];\n      var value = indices[key];\n\n      return Array.isArray(value) ? cachedValue.join(',') !== value.join(',') : cachedValue !== value;\n    });\n\n    cachedIndices = indices;\n\n    if (allInitialized && indexChanged) {\n      callback(indices);\n    }\n  };\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = getUpdatedOffsetForIndex;\n/**\n * Determines a new offset that ensures a certain cell is visible, given the current offset.\n * If the cell is already visible then the current offset will be returned.\n * If the current offset is too great or small, it will be adjusted just enough to ensure the specified index is visible.\n *\n * @param align Desired alignment within container; one of \"auto\" (default), \"start\", or \"end\"\n * @param cellOffset Offset (x or y) position for cell\n * @param cellSize Size (width or height) of cell\n * @param containerSize Total size (width or height) of the container\n * @param currentOffset Container's current (x or y) offset\n * @return Offset to use to ensure the specified cell is visible\n */\nfunction getUpdatedOffsetForIndex(_ref) {\n  var _ref$align = _ref.align;\n  var align = _ref$align === undefined ? 'auto' : _ref$align;\n  var cellOffset = _ref.cellOffset;\n  var cellSize = _ref.cellSize;\n  var containerSize = _ref.containerSize;\n  var currentOffset = _ref.currentOffset;\n\n  var maxOffset = cellOffset;\n  var minOffset = maxOffset - containerSize + cellSize;\n\n  switch (align) {\n    case 'start':\n      return maxOffset;\n    case 'end':\n      return minOffset;\n    case 'center':\n      return maxOffset - (containerSize - cellSize) / 2;\n    default:\n      return Math.max(minOffset, Math.min(maxOffset, currentOffset));\n  }\n}","'use strict';\n\n/**\n* Detect Element Resize.\n* Forked in order to guard against unsafe 'window' and 'document' references.\n*\n* https://github.com/sdecima/javascript-detect-element-resize\n* Sebastian Decima\n*\n* version: 0.5.3\n**/\n\n// Check `document` and `window` in case of server-side rendering\nvar _window;\nif (typeof window !== 'undefined') {\n  _window = window;\n} else if (typeof self !== 'undefined') {\n  _window = self;\n} else {\n  _window = undefined;\n}\n\nvar attachEvent = typeof document !== 'undefined' && document.attachEvent;\nvar stylesCreated = false;\n\nif (!attachEvent) {\n  var requestFrame = function () {\n    var raf = _window.requestAnimationFrame || _window.mozRequestAnimationFrame || _window.webkitRequestAnimationFrame || function (fn) {\n      return _window.setTimeout(fn, 20);\n    };\n    return function (fn) {\n      return raf(fn);\n    };\n  }();\n\n  var cancelFrame = function () {\n    var cancel = _window.cancelAnimationFrame || _window.mozCancelAnimationFrame || _window.webkitCancelAnimationFrame || _window.clearTimeout;\n    return function (id) {\n      return cancel(id);\n    };\n  }();\n\n  var resetTriggers = function resetTriggers(element) {\n    var triggers = element.__resizeTriggers__,\n        expand = triggers.firstElementChild,\n        contract = triggers.lastElementChild,\n        expandChild = expand.firstElementChild;\n    contract.scrollLeft = contract.scrollWidth;\n    contract.scrollTop = contract.scrollHeight;\n    expandChild.style.width = expand.offsetWidth + 1 + 'px';\n    expandChild.style.height = expand.offsetHeight + 1 + 'px';\n    expand.scrollLeft = expand.scrollWidth;\n    expand.scrollTop = expand.scrollHeight;\n  };\n\n  var checkTriggers = function checkTriggers(element) {\n    return element.offsetWidth != element.__resizeLast__.width || element.offsetHeight != element.__resizeLast__.height;\n  };\n\n  var scrollListener = function scrollListener(e) {\n    var element = this;\n    resetTriggers(this);\n    if (this.__resizeRAF__) cancelFrame(this.__resizeRAF__);\n    this.__resizeRAF__ = requestFrame(function () {\n      if (checkTriggers(element)) {\n        element.__resizeLast__.width = element.offsetWidth;\n        element.__resizeLast__.height = element.offsetHeight;\n        element.__resizeListeners__.forEach(function (fn) {\n          fn.call(element, e);\n        });\n      }\n    });\n  };\n\n  /* Detect CSS Animations support to detect element display/re-attach */\n  var animation = false,\n      animationstring = 'animation',\n      keyframeprefix = '',\n      animationstartevent = 'animationstart',\n      domPrefixes = 'Webkit Moz O ms'.split(' '),\n      startEvents = 'webkitAnimationStart animationstart oAnimationStart MSAnimationStart'.split(' '),\n      pfx = '';\n  {\n    var elm = document.createElement('fakeelement');\n    if (elm.style.animationName !== undefined) {\n      animation = true;\n    }\n\n    if (animation === false) {\n      for (var i = 0; i < domPrefixes.length; i++) {\n        if (elm.style[domPrefixes[i] + 'AnimationName'] !== undefined) {\n          pfx = domPrefixes[i];\n          animationstring = pfx + 'Animation';\n          keyframeprefix = '-' + pfx.toLowerCase() + '-';\n          animationstartevent = startEvents[i];\n          animation = true;\n          break;\n        }\n      }\n    }\n  }\n\n  var animationName = 'resizeanim';\n  var animationKeyframes = '@' + keyframeprefix + 'keyframes ' + animationName + ' { from { opacity: 0; } to { opacity: 0; } } ';\n  var animationStyle = keyframeprefix + 'animation: 1ms ' + animationName + '; ';\n}\n\nvar createStyles = function createStyles() {\n  if (!stylesCreated) {\n    //opacity:0 works around a chrome bug https://code.google.com/p/chromium/issues/detail?id=286360\n    var css = (animationKeyframes ? animationKeyframes : '') + '.resize-triggers { ' + (animationStyle ? animationStyle : '') + 'visibility: hidden; opacity: 0; } ' + '.resize-triggers, .resize-triggers > div, .contract-trigger:before { content: \\\" \\\"; display: block; position: absolute; top: 0; left: 0; height: 100%; width: 100%; overflow: hidden; } .resize-triggers > div { background: #eee; overflow: auto; } .contract-trigger:before { width: 200%; height: 200%; }',\n        head = document.head || document.getElementsByTagName('head')[0],\n        style = document.createElement('style');\n\n    style.type = 'text/css';\n    if (style.styleSheet) {\n      style.styleSheet.cssText = css;\n    } else {\n      style.appendChild(document.createTextNode(css));\n    }\n\n    head.appendChild(style);\n    stylesCreated = true;\n  }\n};\n\nvar addResizeListener = function addResizeListener(element, fn) {\n  if (attachEvent) element.attachEvent('onresize', fn);else {\n    if (!element.__resizeTriggers__) {\n      if (getComputedStyle(element).position == 'static') element.style.position = 'relative';\n      createStyles();\n      element.__resizeLast__ = {};\n      element.__resizeListeners__ = [];\n      (element.__resizeTriggers__ = document.createElement('div')).className = 'resize-triggers';\n      element.__resizeTriggers__.innerHTML = '<div class=\"expand-trigger\"><div></div></div>' + '<div class=\"contract-trigger\"></div>';\n      element.appendChild(element.__resizeTriggers__);\n      resetTriggers(element);\n      element.addEventListener('scroll', scrollListener, true);\n\n      /* Listen for a css animation to detect element display/re-attach */\n      animationstartevent && element.__resizeTriggers__.addEventListener(animationstartevent, function (e) {\n        if (e.animationName == animationName) resetTriggers(element);\n      });\n    }\n    element.__resizeListeners__.push(fn);\n  }\n};\n\nvar removeResizeListener = function removeResizeListener(element, fn) {\n  if (attachEvent) element.detachEvent('onresize', fn);else {\n    element.__resizeListeners__.splice(element.__resizeListeners__.indexOf(fn), 1);\n    if (!element.__resizeListeners__.length) {\n      element.removeEventListener('scroll', scrollListener, true);\n      element.__resizeTriggers__ = !element.removeChild(element.__resizeTriggers__);\n    }\n  }\n};\n\nmodule.exports = {\n  addResizeListener: addResizeListener,\n  removeResizeListener: removeResizeListener\n};","/**\n * Copyright 2013-present, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n *\n* @providesModule shallowCompare\n*/\n\n'use strict';\n\nvar shallowEqual = require('fbjs/lib/shallowEqual');\n\n/**\n * Does a shallow comparison for props and state.\n * See ReactComponentWithPureRenderMixin\n * See also https://facebook.github.io/react/docs/shallow-compare.html\n */\nfunction shallowCompare(instance, nextProps, nextState) {\n  return !shallowEqual(instance.props, nextProps) || !shallowEqual(instance.state, nextState);\n}\n\nmodule.exports = shallowCompare;","'use strict';\nmodule.exports = function (str) {\n\treturn encodeURIComponent(str).replace(/[!'()*]/g, function (c) {\n\t\treturn '%' + c.charCodeAt(0).toString(16).toUpperCase();\n\t});\n};\n","(function(self) {\n  'use strict';\n\n  if (self.fetch) {\n    return\n  }\n\n  var support = {\n    searchParams: 'URLSearchParams' in self,\n    iterable: 'Symbol' in self && 'iterator' in Symbol,\n    blob: 'FileReader' in self && 'Blob' in self && (function() {\n      try {\n        new Blob()\n        return true\n      } catch(e) {\n        return false\n      }\n    })(),\n    formData: 'FormData' in self,\n    arrayBuffer: 'ArrayBuffer' in self\n  }\n\n  function normalizeName(name) {\n    if (typeof name !== 'string') {\n      name = String(name)\n    }\n    if (/[^a-z0-9\\-#$%&'*+.\\^_`|~]/i.test(name)) {\n      throw new TypeError('Invalid character in header field name')\n    }\n    return name.toLowerCase()\n  }\n\n  function normalizeValue(value) {\n    if (typeof value !== 'string') {\n      value = String(value)\n    }\n    return value\n  }\n\n  // Build a destructive iterator for the value list\n  function iteratorFor(items) {\n    var iterator = {\n      next: function() {\n        var value = items.shift()\n        return {done: value === undefined, value: value}\n      }\n    }\n\n    if (support.iterable) {\n      iterator[Symbol.iterator] = function() {\n        return iterator\n      }\n    }\n\n    return iterator\n  }\n\n  function Headers(headers) {\n    this.map = {}\n\n    if (headers instanceof Headers) {\n      headers.forEach(function(value, name) {\n        this.append(name, value)\n      }, this)\n\n    } else if (headers) {\n      Object.getOwnPropertyNames(headers).forEach(function(name) {\n        this.append(name, headers[name])\n      }, this)\n    }\n  }\n\n  Headers.prototype.append = function(name, value) {\n    name = normalizeName(name)\n    value = normalizeValue(value)\n    var list = this.map[name]\n    if (!list) {\n      list = []\n      this.map[name] = list\n    }\n    list.push(value)\n  }\n\n  Headers.prototype['delete'] = function(name) {\n    delete this.map[normalizeName(name)]\n  }\n\n  Headers.prototype.get = function(name) {\n    var values = this.map[normalizeName(name)]\n    return values ? values[0] : null\n  }\n\n  Headers.prototype.getAll = function(name) {\n    return this.map[normalizeName(name)] || []\n  }\n\n  Headers.prototype.has = function(name) {\n    return this.map.hasOwnProperty(normalizeName(name))\n  }\n\n  Headers.prototype.set = function(name, value) {\n    this.map[normalizeName(name)] = [normalizeValue(value)]\n  }\n\n  Headers.prototype.forEach = function(callback, thisArg) {\n    Object.getOwnPropertyNames(this.map).forEach(function(name) {\n      this.map[name].forEach(function(value) {\n        callback.call(thisArg, value, name, this)\n      }, this)\n    }, this)\n  }\n\n  Headers.prototype.keys = function() {\n    var items = []\n    this.forEach(function(value, name) { items.push(name) })\n    return iteratorFor(items)\n  }\n\n  Headers.prototype.values = function() {\n    var items = []\n    this.forEach(function(value) { items.push(value) })\n    return iteratorFor(items)\n  }\n\n  Headers.prototype.entries = function() {\n    var items = []\n    this.forEach(function(value, name) { items.push([name, value]) })\n    return iteratorFor(items)\n  }\n\n  if (support.iterable) {\n    Headers.prototype[Symbol.iterator] = Headers.prototype.entries\n  }\n\n  function consumed(body) {\n    if (body.bodyUsed) {\n      return Promise.reject(new TypeError('Already read'))\n    }\n    body.bodyUsed = true\n  }\n\n  function fileReaderReady(reader) {\n    return new Promise(function(resolve, reject) {\n      reader.onload = function() {\n        resolve(reader.result)\n      }\n      reader.onerror = function() {\n        reject(reader.error)\n      }\n    })\n  }\n\n  function readBlobAsArrayBuffer(blob) {\n    var reader = new FileReader()\n    reader.readAsArrayBuffer(blob)\n    return fileReaderReady(reader)\n  }\n\n  function readBlobAsText(blob) {\n    var reader = new FileReader()\n    reader.readAsText(blob)\n    return fileReaderReady(reader)\n  }\n\n  function Body() {\n    this.bodyUsed = false\n\n    this._initBody = function(body) {\n      this._bodyInit = body\n      if (typeof body === 'string') {\n        this._bodyText = body\n      } else if (support.blob && Blob.prototype.isPrototypeOf(body)) {\n        this._bodyBlob = body\n      } else if (support.formData && FormData.prototype.isPrototypeOf(body)) {\n        this._bodyFormData = body\n      } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n        this._bodyText = body.toString()\n      } else if (!body) {\n        this._bodyText = ''\n      } else if (support.arrayBuffer && ArrayBuffer.prototype.isPrototypeOf(body)) {\n        // Only support ArrayBuffers for POST method.\n        // Receiving ArrayBuffers happens via Blobs, instead.\n      } else {\n        throw new Error('unsupported BodyInit type')\n      }\n\n      if (!this.headers.get('content-type')) {\n        if (typeof body === 'string') {\n          this.headers.set('content-type', 'text/plain;charset=UTF-8')\n        } else if (this._bodyBlob && this._bodyBlob.type) {\n          this.headers.set('content-type', this._bodyBlob.type)\n        } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n          this.headers.set('content-type', 'application/x-www-form-urlencoded;charset=UTF-8')\n        }\n      }\n    }\n\n    if (support.blob) {\n      this.blob = function() {\n        var rejected = consumed(this)\n        if (rejected) {\n          return rejected\n        }\n\n        if (this._bodyBlob) {\n          return Promise.resolve(this._bodyBlob)\n        } else if (this._bodyFormData) {\n          throw new Error('could not read FormData body as blob')\n        } else {\n          return Promise.resolve(new Blob([this._bodyText]))\n        }\n      }\n\n      this.arrayBuffer = function() {\n        return this.blob().then(readBlobAsArrayBuffer)\n      }\n\n      this.text = function() {\n        var rejected = consumed(this)\n        if (rejected) {\n          return rejected\n        }\n\n        if (this._bodyBlob) {\n          return readBlobAsText(this._bodyBlob)\n        } else if (this._bodyFormData) {\n          throw new Error('could not read FormData body as text')\n        } else {\n          return Promise.resolve(this._bodyText)\n        }\n      }\n    } else {\n      this.text = function() {\n        var rejected = consumed(this)\n        return rejected ? rejected : Promise.resolve(this._bodyText)\n      }\n    }\n\n    if (support.formData) {\n      this.formData = function() {\n        return this.text().then(decode)\n      }\n    }\n\n    this.json = function() {\n      return this.text().then(JSON.parse)\n    }\n\n    return this\n  }\n\n  // HTTP methods whose capitalization should be normalized\n  var methods = ['DELETE', 'GET', 'HEAD', 'OPTIONS', 'POST', 'PUT']\n\n  function normalizeMethod(method) {\n    var upcased = method.toUpperCase()\n    return (methods.indexOf(upcased) > -1) ? upcased : method\n  }\n\n  function Request(input, options) {\n    options = options || {}\n    var body = options.body\n    if (Request.prototype.isPrototypeOf(input)) {\n      if (input.bodyUsed) {\n        throw new TypeError('Already read')\n      }\n      this.url = input.url\n      this.credentials = input.credentials\n      if (!options.headers) {\n        this.headers = new Headers(input.headers)\n      }\n      this.method = input.method\n      this.mode = input.mode\n      if (!body) {\n        body = input._bodyInit\n        input.bodyUsed = true\n      }\n    } else {\n      this.url = input\n    }\n\n    this.credentials = options.credentials || this.credentials || 'omit'\n    if (options.headers || !this.headers) {\n      this.headers = new Headers(options.headers)\n    }\n    this.method = normalizeMethod(options.method || this.method || 'GET')\n    this.mode = options.mode || this.mode || null\n    this.referrer = null\n\n    if ((this.method === 'GET' || this.method === 'HEAD') && body) {\n      throw new TypeError('Body not allowed for GET or HEAD requests')\n    }\n    this._initBody(body)\n  }\n\n  Request.prototype.clone = function() {\n    return new Request(this)\n  }\n\n  function decode(body) {\n    var form = new FormData()\n    body.trim().split('&').forEach(function(bytes) {\n      if (bytes) {\n        var split = bytes.split('=')\n        var name = split.shift().replace(/\\+/g, ' ')\n        var value = split.join('=').replace(/\\+/g, ' ')\n        form.append(decodeURIComponent(name), decodeURIComponent(value))\n      }\n    })\n    return form\n  }\n\n  function headers(xhr) {\n    var head = new Headers()\n    var pairs = (xhr.getAllResponseHeaders() || '').trim().split('\\n')\n    pairs.forEach(function(header) {\n      var split = header.trim().split(':')\n      var key = split.shift().trim()\n      var value = split.join(':').trim()\n      head.append(key, value)\n    })\n    return head\n  }\n\n  Body.call(Request.prototype)\n\n  function Response(bodyInit, options) {\n    if (!options) {\n      options = {}\n    }\n\n    this.type = 'default'\n    this.status = options.status\n    this.ok = this.status >= 200 && this.status < 300\n    this.statusText = options.statusText\n    this.headers = options.headers instanceof Headers ? options.headers : new Headers(options.headers)\n    this.url = options.url || ''\n    this._initBody(bodyInit)\n  }\n\n  Body.call(Response.prototype)\n\n  Response.prototype.clone = function() {\n    return new Response(this._bodyInit, {\n      status: this.status,\n      statusText: this.statusText,\n      headers: new Headers(this.headers),\n      url: this.url\n    })\n  }\n\n  Response.error = function() {\n    var response = new Response(null, {status: 0, statusText: ''})\n    response.type = 'error'\n    return response\n  }\n\n  var redirectStatuses = [301, 302, 303, 307, 308]\n\n  Response.redirect = function(url, status) {\n    if (redirectStatuses.indexOf(status) === -1) {\n      throw new RangeError('Invalid status code')\n    }\n\n    return new Response(null, {status: status, headers: {location: url}})\n  }\n\n  self.Headers = Headers\n  self.Request = Request\n  self.Response = Response\n\n  self.fetch = function(input, init) {\n    return new Promise(function(resolve, reject) {\n      var request\n      if (Request.prototype.isPrototypeOf(input) && !init) {\n        request = input\n      } else {\n        request = new Request(input, init)\n      }\n\n      var xhr = new XMLHttpRequest()\n\n      function responseURL() {\n        if ('responseURL' in xhr) {\n          return xhr.responseURL\n        }\n\n        // Avoid security warnings on getResponseHeader when not allowed by CORS\n        if (/^X-Request-URL:/m.test(xhr.getAllResponseHeaders())) {\n          return xhr.getResponseHeader('X-Request-URL')\n        }\n\n        return\n      }\n\n      xhr.onload = function() {\n        var options = {\n          status: xhr.status,\n          statusText: xhr.statusText,\n          headers: headers(xhr),\n          url: responseURL()\n        }\n        var body = 'response' in xhr ? xhr.response : xhr.responseText\n        resolve(new Response(body, options))\n      }\n\n      xhr.onerror = function() {\n        reject(new TypeError('Network request failed'))\n      }\n\n      xhr.ontimeout = function() {\n        reject(new TypeError('Network request failed'))\n      }\n\n      xhr.open(request.method, request.url, true)\n\n      if (request.credentials === 'include') {\n        xhr.withCredentials = true\n      }\n\n      if ('responseType' in xhr && support.blob) {\n        xhr.responseType = 'blob'\n      }\n\n      request.headers.forEach(function(value, name) {\n        xhr.setRequestHeader(name, value)\n      })\n\n      xhr.send(typeof request._bodyInit === 'undefined' ? null : request._bodyInit)\n    })\n  }\n  self.fetch.polyfill = true\n})(typeof self !== 'undefined' ? self : this);\n"]} +//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","/Users/SVITY/www/github/react-select/examples/src/app.js","/Users/SVITY/www/github/react-select/examples/src/components/BooleanSelect.js","/Users/SVITY/www/github/react-select/examples/src/components/Contributors.js","/Users/SVITY/www/github/react-select/examples/src/components/Creatable.js","/Users/SVITY/www/github/react-select/examples/src/components/CustomComponents.js","/Users/SVITY/www/github/react-select/examples/src/components/CustomRender.js","/Users/SVITY/www/github/react-select/examples/src/components/GithubUsers.js","/Users/SVITY/www/github/react-select/examples/src/components/Multiselect.js","/Users/SVITY/www/github/react-select/examples/src/components/NumericSelect.js","/Users/SVITY/www/github/react-select/examples/src/components/States.js","/Users/SVITY/www/github/react-select/examples/src/components/Virtualized.js","/Users/SVITY/www/github/react-select/examples/src/data/cities.js","/Users/SVITY/www/github/react-select/examples/src/data/contributors.js","/Users/SVITY/www/github/react-select/examples/src/data/states.js","/Users/SVITY/www/github/react-select/examples/src/data/users.js","node_modules/charenc/charenc.js","node_modules/crypt/crypt.js","node_modules/dom-helpers/util/inDOM.js","node_modules/dom-helpers/util/scrollbarSize.js","node_modules/fbjs/lib/shallowEqual.js","node_modules/is-buffer/index.js","node_modules/is-retina/index.js","node_modules/isomorphic-fetch/fetch-npm-browserify.js","node_modules/md5/md5.js","node_modules/object-assign/index.js","node_modules/performance-now/lib/performance-now.js","node_modules/process/browser.js","node_modules/query-string/index.js","node_modules/raf/index.js","node_modules/react-addons-shallow-compare/index.js","node_modules/react-gravatar/dist/index.js","node_modules/react-highlight-words/dist/main.js","node_modules/react-virtualized-select/dist/commonjs/VirtualizedSelect/VirtualizedSelect.js","node_modules/react-virtualized-select/dist/commonjs/VirtualizedSelect/index.js","node_modules/react-virtualized/dist/commonjs/ArrowKeyStepper/ArrowKeyStepper.js","node_modules/react-virtualized/dist/commonjs/ArrowKeyStepper/index.js","node_modules/react-virtualized/dist/commonjs/AutoSizer/AutoSizer.js","node_modules/react-virtualized/dist/commonjs/AutoSizer/index.js","node_modules/react-virtualized/dist/commonjs/CellMeasurer/CellMeasurer.js","node_modules/react-virtualized/dist/commonjs/CellMeasurer/defaultCellSizeCache.js","node_modules/react-virtualized/dist/commonjs/CellMeasurer/index.js","node_modules/react-virtualized/dist/commonjs/Collection/Collection.js","node_modules/react-virtualized/dist/commonjs/Collection/CollectionView.js","node_modules/react-virtualized/dist/commonjs/Collection/Section.js","node_modules/react-virtualized/dist/commonjs/Collection/SectionManager.js","node_modules/react-virtualized/dist/commonjs/Collection/index.js","node_modules/react-virtualized/dist/commonjs/Collection/utils/calculateSizeAndPositionData.js","node_modules/react-virtualized/dist/commonjs/ColumnSizer/ColumnSizer.js","node_modules/react-virtualized/dist/commonjs/ColumnSizer/index.js","node_modules/react-virtualized/dist/commonjs/FlexTable/FlexColumn.js","node_modules/react-virtualized/dist/commonjs/FlexTable/FlexTable.js","node_modules/react-virtualized/dist/commonjs/FlexTable/SortDirection.js","node_modules/react-virtualized/dist/commonjs/FlexTable/SortIndicator.js","node_modules/react-virtualized/dist/commonjs/FlexTable/defaultCellDataGetter.js","node_modules/react-virtualized/dist/commonjs/FlexTable/defaultCellRenderer.js","node_modules/react-virtualized/dist/commonjs/FlexTable/defaultHeaderRenderer.js","node_modules/react-virtualized/dist/commonjs/FlexTable/defaultRowRenderer.js","node_modules/react-virtualized/dist/commonjs/FlexTable/index.js","node_modules/react-virtualized/dist/commonjs/Grid/Grid.js","node_modules/react-virtualized/dist/commonjs/Grid/defaultCellRangeRenderer.js","node_modules/react-virtualized/dist/commonjs/Grid/index.js","node_modules/react-virtualized/dist/commonjs/Grid/utils/CellSizeAndPositionManager.js","node_modules/react-virtualized/dist/commonjs/Grid/utils/ScalingCellSizeAndPositionManager.js","node_modules/react-virtualized/dist/commonjs/Grid/utils/calculateSizeAndPositionDataAndUpdateScrollOffset.js","node_modules/react-virtualized/dist/commonjs/Grid/utils/getOverscanIndices.js","node_modules/react-virtualized/dist/commonjs/Grid/utils/updateScrollIndexHelper.js","node_modules/react-virtualized/dist/commonjs/InfiniteLoader/InfiniteLoader.js","node_modules/react-virtualized/dist/commonjs/InfiniteLoader/index.js","node_modules/react-virtualized/dist/commonjs/ScrollSync/ScrollSync.js","node_modules/react-virtualized/dist/commonjs/ScrollSync/index.js","node_modules/react-virtualized/dist/commonjs/VirtualScroll/VirtualScroll.js","node_modules/react-virtualized/dist/commonjs/VirtualScroll/index.js","node_modules/react-virtualized/dist/commonjs/WindowScroller/WindowScroller.js","node_modules/react-virtualized/dist/commonjs/WindowScroller/index.js","node_modules/react-virtualized/dist/commonjs/WindowScroller/utils/onScroll.js","node_modules/react-virtualized/dist/commonjs/index.js","node_modules/react-virtualized/dist/commonjs/utils/createCallbackMemoizer.js","node_modules/react-virtualized/dist/commonjs/utils/getUpdatedOffsetForIndex.js","node_modules/react-virtualized/dist/commonjs/vendor/detectElementResize.js","node_modules/react/lib/shallowCompare.js","node_modules/strict-uri-encode/index.js","node_modules/whatwg-fetch/fetch.js"],"names":[],"mappings":"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C,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,eAAe,EAAE,EACvC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,WAAW,EAAE,EACnC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,CACpC,CAAC;;;;;ACvEF,MAAM,CAAC,OAAO,GAAG,CAChB,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,gBAAgB,EAAE,EACrE,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,gBAAgB,EAAE,EACrE,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,gBAAgB,EAAE,CACrE,CAAC;;;ACJF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChGA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AClGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACxEA;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/QA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClqBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChhCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7RA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/* eslint react/prop-types: 0 */\n\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport Select from 'react-select';\n\nimport Creatable from './components/Creatable';\nimport Contributors from './components/Contributors';\nimport GithubUsers from './components/GithubUsers';\nimport CustomComponents from './components/CustomComponents';\nimport CustomRender from './components/CustomRender';\nimport Multiselect from './components/Multiselect';\nimport NumericSelect from './components/NumericSelect';\nimport BooleanSelect from './components/BooleanSelect';\nimport Virtualized from './components/Virtualized';\nimport States from './components/States';\n\nReactDOM.render(\n\t<div>\n\t\t<States label=\"States\" searchable />\n\t\t<Multiselect label=\"Multiselect\" />\n\t\t<Virtualized label=\"Virtualized\" />\n\t\t<Contributors label=\"Contributors (Async)\" />\n\t\t<GithubUsers label=\"Github users (Async with fetch.js)\" />\n\t\t<NumericSelect label=\"Numeric Values\" />\n\t\t<BooleanSelect label=\"Boolean Values\" />\n\t\t<CustomRender label=\"Custom Render Methods\"/>\n\t\t<CustomComponents label=\"Custom Placeholder, Option, Value, and Arrow Components\" />\n\t\t<Creatable\n\t\t\thint=\"Enter a value that's NOT in the list, then hit return\"\n\t\t\tlabel=\"Custom tag creation\"\n\t\t/>\n\t</div>,\n\tdocument.getElementById('example')\n);\n","import React from 'react';\nimport Select from 'react-select';\n\nvar ValuesAsBooleansField = React.createClass({\n\tdisplayName: 'ValuesAsBooleansField',\n\tpropTypes: {\n\t\tlabel: React.PropTypes.string\n\t},\n\tgetInitialState () {\n\t\treturn {\n\t\t\toptions: [\n\t\t\t\t{ value: true, label: 'Yes' },\n\t\t\t\t{ value: false, label: 'No' }\n\t\t\t],\n\t\t\tmatchPos: 'any',\n\t\t\tmatchValue: true,\n\t\t\tmatchLabel: true,\n\t\t\tvalue: null,\n\t\t\tmulti: false\n\t\t};\n\t},\n\tonChangeMatchStart(event) {\n\t\tthis.setState({\n\t\t\tmatchPos: event.target.checked ? 'start' : 'any'\n\t\t});\n\t},\n\tonChangeMatchValue(event) {\n\t\tthis.setState({\n\t\t\tmatchValue: event.target.checked\n\t\t});\n\t},\n\tonChangeMatchLabel(event) {\n\t\tthis.setState({\n\t\t\tmatchLabel: event.target.checked\n\t\t});\n\t},\n\tonChange(value) {\n\t\tthis.setState({ value });\n\t\tconsole.log('Boolean Select value changed to', value);\n\t},\n\tonChangeMulti(event) {\n\t\tthis.setState({\n\t\t\tmulti: event.target.checked\n\t\t});\n\t},\n\trender () {\n\t\tvar matchProp = 'any';\n\t\tif (this.state.matchLabel && !this.state.matchValue) {\n\t\t\tmatchProp = 'label';\n\t\t}\n\t\tif (!this.state.matchLabel && this.state.matchValue) {\n\t\t\tmatchProp = 'value';\n\t\t}\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select\n\t\t\t\t\tmatchPos={this.state.matchPos}\n\t\t\t\t\tmatchProp={matchProp}\n\t\t\t\t\tmulti={this.state.multi}\n\t\t\t\t\tonChange={this.onChange}\n\t\t\t\t\toptions={this.state.options}\n\t\t\t\t\tsimpleValue\n\t\t\t\t\tvalue={this.state.value}\n\t\t\t\t\t/>\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.multi} onChange={this.onChangeMulti} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Multi-Select</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.matchValue} onChange={this.onChangeMatchValue} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Match value</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.matchLabel} onChange={this.onChangeMatchLabel} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Match label</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.matchPos === 'start'} onChange={this.onChangeMatchStart} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Only include matches from the start of the string</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"hint\">This example uses simple boolean values</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nmodule.exports = ValuesAsBooleansField;\n","import React from 'react';\nimport Select from 'react-select';\n\nconst CONTRIBUTORS = require('../data/contributors');\nconst MAX_CONTRIBUTORS = 6;\nconst ASYNC_DELAY = 500;\n\nconst Contributors = React.createClass({\n\tdisplayName: 'Contributors',\n\tpropTypes: {\n\t\tlabel: React.PropTypes.string,\n\t},\n\tgetInitialState () {\n\t\treturn {\n\t\t\tmulti: true,\n\t\t\tvalue: [CONTRIBUTORS[0]],\n\t\t};\n\t},\n\tonChange (value) {\n\t\tthis.setState({\n\t\t\tvalue: value,\n\t\t});\n\t},\n\tswitchToMulti () {\n\t\tthis.setState({\n\t\t\tmulti: true,\n\t\t\tvalue: [this.state.value],\n\t\t});\n\t},\n\tswitchToSingle () {\n\t\tthis.setState({\n\t\t\tmulti: false,\n\t\t\tvalue: this.state.value[0],\n\t\t});\n\t},\n\tgetContributors (input, callback) {\n\t\tinput = input.toLowerCase();\n\t\tvar options = CONTRIBUTORS.filter(i => {\n\t\t\treturn i.github.substr(0, input.length) === input;\n\t\t});\n\t\tvar data = {\n\t\t\toptions: options.slice(0, MAX_CONTRIBUTORS),\n\t\t\tcomplete: options.length <= MAX_CONTRIBUTORS,\n\t\t};\n\t\tsetTimeout(function() {\n\t\t\tcallback(null, data);\n\t\t}, ASYNC_DELAY);\n\t},\n\tgotoContributor (value, event) {\n\t\twindow.open('https://github.com/' + value.github);\n\t},\n\trender () {\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select.Async multi={this.state.multi} value={this.state.value} onChange={this.onChange} onValueClick={this.gotoContributor} valueKey=\"github\" labelKey=\"name\" loadOptions={this.getContributors} />\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"radio\" className=\"checkbox-control\" checked={this.state.multi} onChange={this.switchToMulti}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Multiselect</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"radio\" className=\"checkbox-control\" checked={!this.state.multi} onChange={this.switchToSingle}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Single Value</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"hint\">This example implements custom label and value properties, async options and opens the github profiles in a new window when values are clicked</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nmodule.exports = Contributors;\n","import React from 'react';\nimport Select from 'react-select';\n\nvar CreatableDemo = React.createClass({\n\tdisplayName: 'CreatableDemo',\n\tpropTypes: {\n\t\thint: React.PropTypes.string,\n\t\tlabel: React.PropTypes.string\n\t},\n\tgetInitialState () {\n\t\treturn {\n\t\t\tmulti: true,\n\t\t\tmultiValue: [],\n\t\t\toptions: [\n\t\t\t\t{ value: 'R', label: 'Red' },\n\t\t\t\t{ value: 'G', label: 'Green' },\n\t\t\t\t{ value: 'B', label: 'Blue' }\n\t\t\t],\n\t\t\tvalue: undefined\n\t\t};\n\t},\n\thandleOnChange (value) {\n\t\tconst { multi } = this.state;\n\t\tif (multi) {\n\t\t\tthis.setState({ multiValue: value });\n\t\t} else {\n\t\t\tthis.setState({ value });\n\t\t}\n\t},\n\trender () {\n\t\tconst { multi, multiValue, options, value } = this.state;\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select.Creatable\n\t\t\t\t\tmulti={multi}\n\t\t\t\t\toptions={options}\n\t\t\t\t\tonChange={this.handleOnChange}\n\t\t\t\t\tvalue={multi ? multiValue : value}\n\t\t\t\t/>\n\t\t\t\t<div className=\"hint\">{this.props.hint}</div>\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input\n\t\t\t\t\t\t\ttype=\"radio\"\n\t\t\t\t\t\t\tclassName=\"checkbox-control\"\n\t\t\t\t\t\t\tchecked={multi}\n\t\t\t\t\t\t\tonChange={() => this.setState({ multi: true })}\n\t\t\t\t\t\t/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Multiselect</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input\n\t\t\t\t\t\t\ttype=\"radio\"\n\t\t\t\t\t\t\tclassName=\"checkbox-control\"\n\t\t\t\t\t\t\tchecked={!multi}\n\t\t\t\t\t\t\tonChange={() => this.setState({ multi: false })}\n\t\t\t\t\t\t/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Single Value</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nmodule.exports = CreatableDemo;\n","import React from 'react';\nimport Select from 'react-select';\nimport Gravatar from 'react-gravatar';\n\nconst USERS = require('../data/users');\nconst GRAVATAR_SIZE = 15;\n\nconst GravatarOption = React.createClass({\n\tpropTypes: {\n\t\tchildren: React.PropTypes.node,\n\t\tclassName: React.PropTypes.string,\n\t\tisDisabled: React.PropTypes.bool,\n\t\tisFocused: React.PropTypes.bool,\n\t\tisSelected: React.PropTypes.bool,\n\t\tonFocus: React.PropTypes.func,\n\t\tonSelect: React.PropTypes.func,\n\t\toption: React.PropTypes.object.isRequired,\n\t},\n\thandleMouseDown (event) {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\tthis.props.onSelect(this.props.option, event);\n\t},\n\thandleMouseEnter (event) {\n\t\tthis.props.onFocus(this.props.option, event);\n\t},\n\thandleMouseMove (event) {\n\t\tif (this.props.isFocused) return;\n\t\tthis.props.onFocus(this.props.option, event);\n\t},\n\trender () {\n\t\tlet gravatarStyle = {\n\t\t\tborderRadius: 3,\n\t\t\tdisplay: 'inline-block',\n\t\t\tmarginRight: 10,\n\t\t\tposition: 'relative',\n\t\t\ttop: -2,\n\t\t\tverticalAlign: 'middle',\n\t\t};\n\t\treturn (\n\t\t\t<div className={this.props.className}\n\t\t\t\tonMouseDown={this.handleMouseDown}\n\t\t\t\tonMouseEnter={this.handleMouseEnter}\n\t\t\t\tonMouseMove={this.handleMouseMove}\n\t\t\t\ttitle={this.props.option.title}>\n\t\t\t\t<Gravatar email={this.props.option.email} size={GRAVATAR_SIZE} style={gravatarStyle} />\n\t\t\t\t{this.props.children}\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nconst GravatarValue = React.createClass({\n\tpropTypes: {\n\t\tchildren: React.PropTypes.node,\n\t\tplaceholder: React.PropTypes.string,\n\t\tvalue: React.PropTypes.object\n\t},\n\trender () {\n\t\tvar gravatarStyle = {\n\t\t\tborderRadius: 3,\n\t\t\tdisplay: 'inline-block',\n\t\t\tmarginRight: 10,\n\t\t\tposition: 'relative',\n\t\t\ttop: -2,\n\t\t\tverticalAlign: 'middle',\n\t\t};\n\t\treturn (\n\t\t\t<div className=\"Select-value\" title={this.props.value.title}>\n\t\t\t\t<span className=\"Select-value-label\">\n\t\t\t\t\t<Gravatar email={this.props.value.email} size={GRAVATAR_SIZE} style={gravatarStyle} />\n\t\t\t\t\t{this.props.children}\n\t\t\t\t</span>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nconst UsersField = React.createClass({\n\tpropTypes: {\n\t\thint: React.PropTypes.string,\n\t\tlabel: React.PropTypes.string,\n\t},\n\tgetInitialState () {\n\t\treturn {};\n\t},\n\tsetValue (value) {\n\t\tthis.setState({ value });\n\t},\n\trender () {\n\t\tvar placeholder = <span>&#9786; Select User</span>;\n\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select\n\t\t\t\t\tarrowRenderer={arrowRenderer}\n\t\t\t\t\tonChange={this.setValue}\n\t\t\t\t\toptionComponent={GravatarOption}\n\t\t\t\t\toptions={USERS}\n\t\t\t\t\tplaceholder={placeholder}\n\t\t\t\t\tvalue={this.state.value}\n\t\t\t\t\tvalueComponent={GravatarValue}\n\t\t\t\t\t/>\n\t\t\t\t<div className=\"hint\">\n\t\t\t\t\tThis example implements custom Option and Value components to render a Gravatar image for each user based on their email.\n\t\t\t\t\tIt also demonstrates rendering HTML elements as the placeholder.\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nfunction arrowRenderer () {\n\treturn (\n\t\t<span>+</span>\n\t);\n}\n\nmodule.exports = UsersField;\n","import React from 'react';\nimport Select from 'react-select';\nimport Highlighter from 'react-highlight-words';\n\nvar DisabledUpsellOptions = React.createClass({\n\tdisplayName: 'DisabledUpsellOptions',\n\tpropTypes: {\n\t\tlabel: React.PropTypes.string,\n\t},\n\tgetInitialState () {\n\t\treturn {};\n\t},\n\tsetValue (value) {\n\t\tthis.setState({ value });\n\t\tconsole.log('Support level selected:', value.label);\n\t},\n\trenderLink: function() {\n\t\treturn <a style={{ marginLeft: 5 }} href=\"/upgrade\" target=\"_blank\">Upgrade here!</a>;\n\t},\n\trenderOption: function(option) {\n\t\treturn (\n\t\t\t<Highlighter\n\t\t\t  searchWords={[this._inputValue]}\n\t\t\t  textToHighlight={option.label}\n\t\t\t/>\n\t\t);\n\t},\n\trenderValue: function(option) {\n\t\treturn <strong style={{ color: option.color }}>{option.label}</strong>;\n\t},\n\trender: function() {\n\t\tvar options = [\n\t\t\t{ label: 'Basic customer support', value: 'basic', color: '#E31864' },\n\t\t\t{ label: 'Premium customer support', value: 'premium', color: '#6216A3' },\n\t\t\t{ label: 'Pro customer support', value: 'pro', disabled: true, link: this.renderLink() },\n\t\t];\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select\n\t\t\t\t\tonInputChange={(inputValue) => this._inputValue = inputValue}\n\t\t\t\t\toptions={options}\n\t\t\t\t\toptionRenderer={this.renderOption}\n\t\t\t\t\tonChange={this.setValue}\n\t\t\t\t\tvalue={this.state.value}\n\t\t\t\t\tvalueRenderer={this.renderValue}\n\t\t\t\t\t/>\n\t\t\t\t<div className=\"hint\">This demonstates custom render methods and links in disabled options</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\nmodule.exports = DisabledUpsellOptions;\n","import React from 'react';\nimport Select from 'react-select';\nimport fetch from 'isomorphic-fetch';\n\n\nconst GithubUsers = React.createClass({\n\tdisplayName: 'GithubUsers',\n\tpropTypes: {\n\t\tlabel: React.PropTypes.string,\n\t},\n\tgetInitialState () {\n\t\treturn {\n\t\t\tbackspaceRemoves: true,\n\t\t\tmulti: true\n\t\t};\n\t},\n\tonChange (value) {\n\t\tthis.setState({\n\t\t\tvalue: value,\n\t\t});\n\t},\n\tswitchToMulti () {\n\t\tthis.setState({\n\t\t\tmulti: true,\n\t\t\tvalue: [this.state.value],\n\t\t});\n\t},\n\tswitchToSingle () {\n\t\tthis.setState({\n\t\t\tmulti: false,\n\t\t\tvalue: this.state.value ? this.state.value[0] : null\n\t\t});\n\t},\n\tgetUsers (input) {\n\t\tif (!input) {\n\t\t\treturn Promise.resolve({ options: [] });\n\t\t}\n\n\t\treturn fetch(`https://api.github.com/search/users?q=${input}`)\n\t\t.then((response) => response.json())\n\t\t.then((json) => {\n\t\t\treturn { options: json.items };\n\t\t});\n\t},\n\tgotoUser (value, event) {\n\t\twindow.open(value.html_url);\n\t},\n\ttoggleBackspaceRemoves () {\n\t\tthis.setState({\n\t\t\tbackspaceRemoves: !this.state.backspaceRemoves\n\t\t});\n\t},\n\ttoggleCreatable () {\n\t\tthis.setState({\n\t\t\tcreatable: !this.state.creatable\n\t\t});\n\t},\n\trender () {\n\t\tconst AsyncComponent = this.state.creatable\n\t\t\t? Select.AsyncCreatable\n\t\t\t: Select.Async;\n\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<AsyncComponent multi={this.state.multi} value={this.state.value} onChange={this.onChange} onValueClick={this.gotoUser} valueKey=\"id\" labelKey=\"login\" loadOptions={this.getUsers} backspaceRemoves={this.state.backspaceRemoves} />\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"radio\" className=\"checkbox-control\" checked={this.state.multi} onChange={this.switchToMulti}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Multiselect</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"radio\" className=\"checkbox-control\" checked={!this.state.multi} onChange={this.switchToSingle}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Single Value</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t   <input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.creatable} onChange={this.toggleCreatable} />\n\t\t\t\t\t   <span className=\"checkbox-label\">Creatable?</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t   <input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.backspaceRemoves} onChange={this.toggleBackspaceRemoves} />\n\t\t\t\t\t   <span className=\"checkbox-label\">Backspace Removes?</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"hint\">This example uses fetch.js for showing Async options with Promises</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nmodule.exports = GithubUsers;\n","import React from 'react';\nimport Select from 'react-select';\n\nconst FLAVOURS = [\n\t{ label: 'Chocolate', value: 'chocolate' },\n\t{ label: 'Vanilla', value: 'vanilla' },\n\t{ label: 'Strawberry', value: 'strawberry' },\n\t{ label: 'Caramel', value: 'caramel' },\n\t{ label: 'Cookies and Cream', value: 'cookiescream' },\n\t{ label: 'Peppermint', value: 'peppermint' },\n];\n\nconst WHY_WOULD_YOU = [\n\t{ label: 'Chocolate (are you crazy?)', value: 'chocolate', disabled: true },\n].concat(FLAVOURS.slice(1));\n\nvar MultiSelectField = React.createClass({\n\tdisplayName: 'MultiSelectField',\n\tpropTypes: {\n\t\tlabel: React.PropTypes.string,\n\t},\n\tgetInitialState () {\n\t\treturn {\n\t\t\tdisabled: false,\n\t\t\tcrazy: false,\n\t\t\toptions: FLAVOURS,\n\t\t\tvalue: [],\n\t\t};\n\t},\n\thandleSelectChange (value) {\n\t\tconsole.log('You\\'ve selected:', value);\n\t\tthis.setState({ value });\n\t},\n\ttoggleDisabled (e) {\n\t\tthis.setState({ disabled: e.target.checked });\n\t},\n\ttoggleChocolate (e) {\n\t\tlet crazy = e.target.checked;\n\t\tthis.setState({\n\t\t\tcrazy: crazy,\n\t\t\toptions: crazy ? WHY_WOULD_YOU : FLAVOURS,\n\t\t});\n\t},\n\trender () {\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select multi simpleValue disabled={this.state.disabled} value={this.state.value} placeholder=\"Select your favourite(s)\" options={this.state.options} onChange={this.handleSelectChange} />\n\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.disabled} onChange={this.toggleDisabled} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Disable the control</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.crazy} onChange={this.toggleChocolate} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">I don't like Chocolate (disabled the option)</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nmodule.exports = MultiSelectField;\n","import React from 'react';\nimport Select from 'react-select';\n\nvar ValuesAsNumbersField = React.createClass({\n\tdisplayName: 'ValuesAsNumbersField',\n\tpropTypes: {\n\t\tlabel: React.PropTypes.string\n\t},\n\tgetInitialState () {\n\t\treturn {\n\t\t\toptions: [\n\t\t\t\t{ value: 10, label: 'Ten' },\n\t\t\t\t{ value: 11, label: 'Eleven' },\n\t\t\t\t{ value: 12, label: 'Twelve' },\n\t\t\t\t{ value: 23, label: 'Twenty-three' },\n\t\t\t\t{ value: 24, label: 'Twenty-four' }\n\t\t\t],\n\t\t\tmatchPos: 'any',\n\t\t\tmatchValue: true,\n\t\t\tmatchLabel: true,\n\t\t\tvalue: null,\n\t\t\tmulti: false\n\t\t};\n\t},\n\tonChangeMatchStart(event) {\n\t\tthis.setState({\n\t\t\tmatchPos: event.target.checked ? 'start' : 'any'\n\t\t});\n\t},\n\tonChangeMatchValue(event) {\n\t\tthis.setState({\n\t\t\tmatchValue: event.target.checked\n\t\t});\n\t},\n\tonChangeMatchLabel(event) {\n\t\tthis.setState({\n\t\t\tmatchLabel: event.target.checked\n\t\t});\n\t},\n\tonChange(value) {\n\t\tthis.setState({ value });\n\t\tconsole.log('Numeric Select value changed to', value);\n\t},\n\tonChangeMulti(event) {\n\t\tthis.setState({\n\t\t\tmulti: event.target.checked\n\t\t});\n\t},\n\trender () {\n\t\tvar matchProp = 'any';\n\t\tif (this.state.matchLabel && !this.state.matchValue) {\n\t\t\tmatchProp = 'label';\n\t\t}\n\t\tif (!this.state.matchLabel && this.state.matchValue) {\n\t\t\tmatchProp = 'value';\n\t\t}\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select\n\t\t\t\t\tmatchPos={this.state.matchPos}\n\t\t\t\t\tmatchProp={matchProp}\n\t\t\t\t\tmulti={this.state.multi}\n\t\t\t\t\tonChange={this.onChange}\n\t\t\t\t\toptions={this.state.options}\n\t\t\t\t\tsimpleValue\n\t\t\t\t\tvalue={this.state.value}\n\t\t\t\t\t/>\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.multi} onChange={this.onChangeMulti} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Multi-Select</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.matchValue} onChange={this.onChangeMatchValue} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Match value</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.matchLabel} onChange={this.onChangeMatchLabel} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Match label</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" checked={this.state.matchPos === 'start'} onChange={this.onChangeMatchStart} />\n\t\t\t\t\t\t<span className=\"checkbox-label\">Only include matches from the start of the string</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"hint\">This example uses simple numeric values</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nmodule.exports = ValuesAsNumbersField;\n","import React from 'react';\nimport Select from 'react-select';\n\nconst STATES = require('../data/states');\n\nvar StatesField = React.createClass({\n\tdisplayName: 'StatesField',\n\tpropTypes: {\n\t\tlabel: React.PropTypes.string,\n\t\tsearchable: React.PropTypes.bool,\n\t},\n\tgetDefaultProps () {\n\t\treturn {\n\t\t\tlabel: 'States:',\n\t\t\tsearchable: true,\n\t\t};\n\t},\n\tgetInitialState () {\n\t\treturn {\n\t\t\tcountry: 'AU',\n\t\t\tdisabled: false,\n\t\t\tsearchable: this.props.searchable,\n\t\t\tselectValue: 'new-south-wales',\n\t\t\tclearable: true,\n\t\t};\n\t},\n\tswitchCountry (e) {\n\t\tvar newCountry = e.target.value;\n\t\tconsole.log('Country changed to ' + newCountry);\n\t\tthis.setState({\n\t\t\tcountry: newCountry,\n\t\t\tselectValue: null\n\t\t});\n\t},\n\tupdateValue (newValue) {\n\t\tconsole.log('State changed to ' + newValue);\n\t\tthis.setState({\n\t\t\tselectValue: newValue\n\t\t});\n\t},\n\tfocusStateSelect () {\n\t\tthis.refs.stateSelect.focus();\n\t},\n\ttoggleCheckbox (e) {\n\t\tlet newState = {};\n\t\tnewState[e.target.name] = e.target.checked;\n\t\tthis.setState(newState);\n\t},\n\trender () {\n\t\tvar options = STATES[this.state.country];\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">{this.props.label}</h3>\n\t\t\t\t<Select ref=\"stateSelect\" autofocus options={options} simpleValue clearable={this.state.clearable} name=\"selected-state\" disabled={this.state.disabled} value={this.state.selectValue} onChange={this.updateValue} searchable={this.state.searchable} />\n\n\t\t\t\t<div style={{ marginTop: 14 }}>\n\t\t\t\t\t<button type=\"button\" onClick={this.focusStateSelect}>Focus Select</button>\n\t\t\t\t\t<label className=\"checkbox\" style={{ marginLeft: 10 }}>\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" name=\"searchable\" checked={this.state.searchable} onChange={this.toggleCheckbox}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Searchable</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\" style={{ marginLeft: 10 }}>\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" name=\"disabled\" checked={this.state.disabled} onChange={this.toggleCheckbox}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Disabled</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\" style={{ marginLeft: 10 }}>\n\t\t\t\t\t\t<input type=\"checkbox\" className=\"checkbox-control\" name=\"clearable\" checked={this.state.clearable} onChange={this.toggleCheckbox}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Clearable</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t\t<div className=\"checkbox-list\">\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"radio\" className=\"checkbox-control\" checked={this.state.country === 'AU'} value=\"AU\" onChange={this.switchCountry}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">Australia</span>\n\t\t\t\t\t</label>\n\t\t\t\t\t<label className=\"checkbox\">\n\t\t\t\t\t\t<input type=\"radio\" className=\"checkbox-control\" checked={this.state.country === 'US'} value=\"US\" onChange={this.switchCountry}/>\n\t\t\t\t\t\t<span className=\"checkbox-label\">United States</span>\n\t\t\t\t\t</label>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\n\nmodule.exports = StatesField;\n","import React from 'react';\nimport VirtualizedSelect from 'react-virtualized-select';\n\nconst DATA = require('../data/cities');\n\nvar CitiesField = React.createClass({\n\tdisplayName: 'CitiesField',\n\tgetInitialState () {\n\t\treturn {};\n\t},\n\tupdateValue (newValue) {\n\t\tthis.setState({\n\t\t\tselectValue: newValue\n\t\t});\n\t},\n\trender () {\n\t\tvar options = DATA.CITIES;\n\t\treturn (\n\t\t\t<div className=\"section\">\n\t\t\t\t<h3 className=\"section-heading\">Cities (Large Dataset)</h3>\n\t\t\t\t<VirtualizedSelect ref=\"citySelect\"\n\t\t\t\t\toptions={options}\n\t\t\t\t\tsimpleValue\n\t\t\t\t\tclearable\n\t\t\t\t\tname=\"select-city\"\n\t\t\t\t\tvalue={this.state.selectValue}\n\t\t\t\t\tonChange={this.updateValue}\n\t\t\t\t\tsearchable\n\t\t\t\t\tlabelKey=\"name\"\n\t\t\t\t\tvalueKey=\"name\"\n\t\t\t\t/>\n\t\t\t\t<div className=\"hint\">\n\t\t\t\t\tUses <a href=\"https://github.com/bvaughn/react-virtualized\">react-virtualized</a> and <a href=\"https://github.com/bvaughn/react-virtualized-select/\">react-virtualized-select</a> to display a list of the world's 1,000 largest cities.\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t}\n});\n\n\nmodule.exports = CitiesField;\n","exports.CITIES = [\n  { name: 'Abilene' },\n  { name: 'Addison' },\n  { name: 'Akron' },\n  { name: 'Alameda' },\n  { name: 'Albany' },\n  { name: 'Albany' },\n  { name: 'Albany' },\n  { name: 'Albuquerque' },\n  { name: 'Alexandria' },\n  { name: 'Alexandria' },\n  { name: 'Alhambra' },\n  { name: 'Aliso Viejo' },\n  { name: 'Allen' },\n  { name: 'Allentown' },\n  { name: 'Alpharetta' },\n  { name: 'Altamonte Springs' },\n  { name: 'Altoona' },\n  { name: 'Amarillo' },\n  { name: 'Ames' },\n  { name: 'Anaheim' },\n  { name: 'Anchorage' },\n  { name: 'Anderson' },\n  { name: 'Ankeny' },\n  { name: 'Ann Arbor' },\n  { name: 'Annapolis' },\n  { name: 'Antioch' },\n  { name: 'Apache Junction' },\n  { name: 'Apex' },\n  { name: 'Apopka' },\n  { name: 'Apple Valley' },\n  { name: 'Apple Valley' },\n  { name: 'Appleton' },\n  { name: 'Arcadia' },\n  { name: 'Arlington' },\n  { name: 'Arlington Heights' },\n  { name: 'Arvada' },\n  { name: 'Asheville' },\n  { name: 'Athens-Clarke County' },\n  { name: 'Atlanta' },\n  { name: 'Atlantic City' },\n  { name: 'Attleboro' },\n  { name: 'Auburn' },\n  { name: 'Auburn' },\n  { name: 'Augusta-Richmond County' },\n  { name: 'Aurora' },\n  { name: 'Aurora' },\n  { name: 'Austin' },\n  { name: 'Aventura' },\n  { name: 'Avondale' },\n  { name: 'Azusa' },\n  { name: 'Bakersfield' },\n  { name: 'Baldwin Park' },\n  { name: 'Baltimore' },\n  { name: 'Barnstable Town' },\n  { name: 'Bartlett' },\n  { name: 'Bartlett' },\n  { name: 'Baton Rouge' },\n  { name: 'Battle Creek' },\n  { name: 'Bayonne' },\n  { name: 'Baytown' },\n  { name: 'Beaumont' },\n  { name: 'Beaumont' },\n  { name: 'Beavercreek' },\n  { name: 'Beaverton' },\n  { name: 'Bedford' },\n  { name: 'Bell Gardens' },\n  { name: 'Belleville' },\n  { name: 'Bellevue' },\n  { name: 'Bellevue' },\n  { name: 'Bellflower' },\n  { name: 'Bellingham' },\n  { name: 'Beloit' },\n  { name: 'Bend' },\n  { name: 'Bentonville' },\n  { name: 'Berkeley' },\n  { name: 'Berwyn' },\n  { name: 'Bethlehem' },\n  { name: 'Beverly' },\n  { name: 'Billings' },\n  { name: 'Biloxi' },\n  { name: 'Binghamton' },\n  { name: 'Birmingham' },\n  { name: 'Bismarck' },\n  { name: 'Blacksburg' },\n  { name: 'Blaine' },\n  { name: 'Bloomington' },\n  { name: 'Bloomington' },\n  { name: 'Bloomington' },\n  { name: 'Blue Springs' },\n  { name: 'Boca Raton' },\n  { name: 'Boise City' },\n  { name: 'Bolingbrook' },\n  { name: 'Bonita Springs' },\n  { name: 'Bossier City' },\n  { name: 'Boston' },\n  { name: 'Boulder' },\n  { name: 'Bountiful' },\n  { name: 'Bowie' },\n  { name: 'Bowling Green' },\n  { name: 'Boynton Beach' },\n  { name: 'Bozeman' },\n  { name: 'Bradenton' },\n  { name: 'Brea' },\n  { name: 'Bremerton' },\n  { name: 'Brentwood' },\n  { name: 'Brentwood' },\n  { name: 'Bridgeport' },\n  { name: 'Bristol' },\n  { name: 'Brockton' },\n  { name: 'Broken Arrow' },\n  { name: 'Brookfield' },\n  { name: 'Brookhaven' },\n  { name: 'Brooklyn Park' },\n  { name: 'Broomfield' },\n  { name: 'Brownsville' },\n  { name: 'Bryan' },\n  { name: 'Buckeye' },\n  { name: 'Buena Park' },\n  { name: 'Buffalo' },\n  { name: 'Buffalo Grove' },\n  { name: 'Bullhead City' },\n  { name: 'Burbank' },\n  { name: 'Burien' },\n  { name: 'Burleson' },\n  { name: 'Burlington' },\n  { name: 'Burlington' },\n  { name: 'Burnsville' },\n  { name: 'Caldwell' },\n  { name: 'Calexico' },\n  { name: 'Calumet City' },\n  { name: 'Camarillo' },\n  { name: 'Cambridge' },\n  { name: 'Camden' },\n  { name: 'Campbell' },\n  { name: 'Canton' },\n  { name: 'Cape Coral' },\n  { name: 'Cape Girardeau' },\n  { name: 'Carlsbad' },\n  { name: 'Carmel' },\n  { name: 'Carol Stream' },\n  { name: 'Carpentersville' },\n  { name: 'Carrollton' },\n  { name: 'Carson' },\n  { name: 'Carson City' },\n  { name: 'Cary' },\n  { name: 'Casa Grande' },\n  { name: 'Casper' },\n  { name: 'Castle Rock' },\n  { name: 'Cathedral City' },\n  { name: 'Cedar Falls' },\n  { name: 'Cedar Hill' },\n  { name: 'Cedar Park' },\n  { name: 'Cedar Rapids' },\n  { name: 'Centennial' },\n  { name: 'Ceres' },\n  { name: 'Cerritos' },\n  { name: 'Champaign' },\n  { name: 'Chandler' },\n  { name: 'Chapel Hill' },\n  { name: 'Charleston' },\n  { name: 'Charleston' },\n  { name: 'Charlotte' },\n  { name: 'Charlottesville' },\n  { name: 'Chattanooga' },\n  { name: 'Chelsea' },\n  { name: 'Chesapeake' },\n  { name: 'Chesterfield' },\n  { name: 'Cheyenne' },\n  { name: 'Chicago' },\n  { name: 'Chico' },\n  { name: 'Chicopee' },\n  { name: 'Chino' },\n  { name: 'Chino Hills' },\n  { name: 'Chula Vista' },\n  { name: 'Cicero' },\n  { name: 'Cincinnati' },\n  { name: 'Citrus Heights' },\n  { name: 'Clarksville' },\n  { name: 'Clearwater' },\n  { name: 'Cleveland' },\n  { name: 'Cleveland' },\n  { name: 'Cleveland Heights' },\n  { name: 'Clifton' },\n  { name: 'Clovis' },\n  { name: 'Clovis' },\n  { name: 'Coachella' },\n  { name: 'Coconut Creek' },\n  { name: 'Coeur d\\'Alene' },\n  { name: 'College Station' },\n  { name: 'Collierville' },\n  { name: 'Colorado Springs' },\n  { name: 'Colton' },\n  { name: 'Columbia' },\n  { name: 'Columbia' },\n  { name: 'Columbus' },\n  { name: 'Columbus' },\n  { name: 'Columbus' },\n  { name: 'Commerce City' },\n  { name: 'Compton' },\n  { name: 'Concord' },\n  { name: 'Concord' },\n  { name: 'Concord' },\n  { name: 'Conroe' },\n  { name: 'Conway' },\n  { name: 'Coon Rapids' },\n  { name: 'Coppell' },\n  { name: 'Coral Gables' },\n  { name: 'Coral Springs' },\n  { name: 'Corona' },\n  { name: 'Corpus Christi' },\n  { name: 'Corvallis' },\n  { name: 'Costa Mesa' },\n  { name: 'Council Bluffs' },\n  { name: 'Covina' },\n  { name: 'Covington' },\n  { name: 'Cranston' },\n  { name: 'Crystal Lake' },\n  { name: 'Culver City' },\n  { name: 'Cupertino' },\n  { name: 'Cutler Bay' },\n  { name: 'Cuyahoga Falls' },\n  { name: 'Cypress' },\n  { name: 'Dallas' },\n  { name: 'Daly City' },\n  { name: 'Danbury' },\n  { name: 'Danville' },\n  { name: 'Danville' },\n  { name: 'Davenport' },\n  { name: 'Davie' },\n  { name: 'Davis' },\n  { name: 'Dayton' },\n  { name: 'Daytona Beach' },\n  { name: 'DeKalb' },\n  { name: 'DeSoto' },\n  { name: 'Dearborn' },\n  { name: 'Dearborn Heights' },\n  { name: 'Decatur' },\n  { name: 'Decatur' },\n  { name: 'Deerfield Beach' },\n  { name: 'Delano' },\n  { name: 'Delray Beach' },\n  { name: 'Deltona' },\n  { name: 'Denton' },\n  { name: 'Denver' },\n  { name: 'Des Moines' },\n  { name: 'Des Plaines' },\n  { name: 'Detroit' },\n  { name: 'Diamond Bar' },\n  { name: 'Doral' },\n  { name: 'Dothan' },\n  { name: 'Dover' },\n  { name: 'Downers Grove' },\n  { name: 'Downey' },\n  { name: 'Draper' },\n  { name: 'Dublin' },\n  { name: 'Dublin' },\n  { name: 'Dubuque' },\n  { name: 'Duluth' },\n  { name: 'Duncanville' },\n  { name: 'Dunwoody' },\n  { name: 'Durham' },\n  { name: 'Eagan' },\n  { name: 'East Lansing' },\n  { name: 'East Orange' },\n  { name: 'East Providence' },\n  { name: 'Eastvale' },\n  { name: 'Eau Claire' },\n  { name: 'Eden Prairie' },\n  { name: 'Edina' },\n  { name: 'Edinburg' },\n  { name: 'Edmond' },\n  { name: 'Edmonds' },\n  { name: 'El Cajon' },\n  { name: 'El Centro' },\n  { name: 'El Monte' },\n  { name: 'El Paso' },\n  { name: 'Elgin' },\n  { name: 'Elizabeth' },\n  { name: 'Elk Grove' },\n  { name: 'Elkhart' },\n  { name: 'Elmhurst' },\n  { name: 'Elyria' },\n  { name: 'Encinitas' },\n  { name: 'Enid' },\n  { name: 'Erie' },\n  { name: 'Escondido' },\n  { name: 'Euclid' },\n  { name: 'Eugene' },\n  { name: 'Euless' },\n  { name: 'Evanston' },\n  { name: 'Evansville' },\n  { name: 'Everett' },\n  { name: 'Everett' },\n  { name: 'Fairfield' },\n  { name: 'Fairfield' },\n  { name: 'Fall River' },\n  { name: 'Fargo' },\n  { name: 'Farmington' },\n  { name: 'Farmington Hills' },\n  { name: 'Fayetteville' },\n  { name: 'Fayetteville' },\n  { name: 'Federal Way' },\n  { name: 'Findlay' },\n  { name: 'Fishers' },\n  { name: 'Fitchburg' },\n  { name: 'Flagstaff' },\n  { name: 'Flint' },\n  { name: 'Florence' },\n  { name: 'Florence' },\n  { name: 'Florissant' },\n  { name: 'Flower Mound' },\n  { name: 'Folsom' },\n  { name: 'Fond du Lac' },\n  { name: 'Fontana' },\n  { name: 'Fort Collins' },\n  { name: 'Fort Lauderdale' },\n  { name: 'Fort Myers' },\n  { name: 'Fort Pierce' },\n  { name: 'Fort Smith' },\n  { name: 'Fort Wayne' },\n  { name: 'Fort Worth' },\n  { name: 'Fountain Valley' },\n  { name: 'Franklin' },\n  { name: 'Frederick' },\n  { name: 'Freeport' },\n  { name: 'Fremont' },\n  { name: 'Fresno' },\n  { name: 'Friendswood' },\n  { name: 'Frisco' },\n  { name: 'Fullerton' },\n  { name: 'Gainesville' },\n  { name: 'Gaithersburg' },\n  { name: 'Galveston' },\n  { name: 'Garden Grove' },\n  { name: 'Gardena' },\n  { name: 'Garland' },\n  { name: 'Gary' },\n  { name: 'Gastonia' },\n  { name: 'Georgetown' },\n  { name: 'Germantown' },\n  { name: 'Gilbert' },\n  { name: 'Gilroy' },\n  { name: 'Glendale' },\n  { name: 'Glendale' },\n  { name: 'Glendora' },\n  { name: 'Glenview' },\n  { name: 'Goodyear' },\n  { name: 'Goose Creek' },\n  { name: 'Grand Forks' },\n  { name: 'Grand Island' },\n  { name: 'Grand Junction' },\n  { name: 'Grand Prairie' },\n  { name: 'Grand Rapids' },\n  { name: 'Grapevine' },\n  { name: 'Great Falls' },\n  { name: 'Greeley' },\n  { name: 'Green Bay' },\n  { name: 'Greenacres' },\n  { name: 'Greenfield' },\n  { name: 'Greensboro' },\n  { name: 'Greenville' },\n  { name: 'Greenville' },\n  { name: 'Greenwood' },\n  { name: 'Gresham' },\n  { name: 'Grove City' },\n  { name: 'Gulfport' },\n  { name: 'Hackensack' },\n  { name: 'Hagerstown' },\n  { name: 'Hallandale Beach' },\n  { name: 'Haltom City' },\n  { name: 'Hamilton' },\n  { name: 'Hammond' },\n  { name: 'Hampton' },\n  { name: 'Hanford' },\n  { name: 'Hanover Park' },\n  { name: 'Harlingen' },\n  { name: 'Harrisburg' },\n  { name: 'Harrisonburg' },\n  { name: 'Hartford' },\n  { name: 'Hattiesburg' },\n  { name: 'Haverhill' },\n  { name: 'Hawthorne' },\n  { name: 'Hayward' },\n  { name: 'Hemet' },\n  { name: 'Hempstead' },\n  { name: 'Henderson' },\n  { name: 'Hendersonville' },\n  { name: 'Hesperia' },\n  { name: 'Hialeah' },\n  { name: 'Hickory' },\n  { name: 'High Point' },\n  { name: 'Highland' },\n  { name: 'Hillsboro' },\n  { name: 'Hilton Head Island' },\n  { name: 'Hoboken' },\n  { name: 'Hoffman Estates' },\n  { name: 'Hollywood' },\n  { name: 'Holyoke' },\n  { name: 'Homestead' },\n  { name: 'Honolulu' },\n  { name: 'Hoover' },\n  { name: 'Houston' },\n  { name: 'Huber Heights' },\n  { name: 'Huntersville' },\n  { name: 'Huntington' },\n  { name: 'Huntington Beach' },\n  { name: 'Huntington Park' },\n  { name: 'Huntsville' },\n  { name: 'Huntsville' },\n  { name: 'Hurst' },\n  { name: 'Hutchinson' },\n  { name: 'Idaho Falls' },\n  { name: 'Independence' },\n  { name: 'Indianapolis' },\n  { name: 'Indio' },\n  { name: 'Inglewood' },\n  { name: 'Iowa City' },\n  { name: 'Irvine' },\n  { name: 'Irving' },\n  { name: 'Jackson' },\n  { name: 'Jackson' },\n  { name: 'Jacksonville' },\n  { name: 'Jacksonville' },\n  { name: 'Janesville' },\n  { name: 'Jefferson City' },\n  { name: 'Jeffersonville' },\n  { name: 'Jersey City' },\n  { name: 'Johns Creek' },\n  { name: 'Johnson City' },\n  { name: 'Joliet' },\n  { name: 'Jonesboro' },\n  { name: 'Joplin' },\n  { name: 'Jupiter' },\n  { name: 'Jurupa Valley' },\n  { name: 'Kalamazoo' },\n  { name: 'Kannapolis' },\n  { name: 'Kansas City' },\n  { name: 'Kansas City' },\n  { name: 'Kearny' },\n  { name: 'Keizer' },\n  { name: 'Keller' },\n  { name: 'Kenner' },\n  { name: 'Kennewick' },\n  { name: 'Kenosha' },\n  { name: 'Kent' },\n  { name: 'Kentwood' },\n  { name: 'Kettering' },\n  { name: 'Killeen' },\n  { name: 'Kingsport' },\n  { name: 'Kirkland' },\n  { name: 'Kissimmee' },\n  { name: 'Knoxville' },\n  { name: 'Kokomo' },\n  { name: 'La Crosse' },\n  { name: 'La Habra' },\n  { name: 'La Mesa' },\n  { name: 'La Mirada' },\n  { name: 'La Puente' },\n  { name: 'La Quinta' },\n  { name: 'Lacey' },\n  { name: 'Lafayette' },\n  { name: 'Lafayette' },\n  { name: 'Laguna Niguel' },\n  { name: 'Lake Charles' },\n  { name: 'Lake Elsinore' },\n  { name: 'Lake Forest' },\n  { name: 'Lake Havasu City' },\n  { name: 'Lake Oswego' },\n  { name: 'Lakeland' },\n  { name: 'Lakeville' },\n  { name: 'Lakewood' },\n  { name: 'Lakewood' },\n  { name: 'Lakewood' },\n  { name: 'Lakewood' },\n  { name: 'Lancaster' },\n  { name: 'Lancaster' },\n  { name: 'Lancaster' },\n  { name: 'Lancaster' },\n  { name: 'Lansing' },\n  { name: 'Laredo' },\n  { name: 'Largo' },\n  { name: 'Las Cruces' },\n  { name: 'Las Vegas' },\n  { name: 'Lauderhill' },\n  { name: 'Lawrence' },\n  { name: 'Lawrence' },\n  { name: 'Lawrence' },\n  { name: 'Lawton' },\n  { name: 'Layton' },\n  { name: 'League City' },\n  { name: 'Lee\\'s Summit' },\n  { name: 'Leesburg' },\n  { name: 'Lehi' },\n  { name: 'Lenexa' },\n  { name: 'Leominster' },\n  { name: 'Lewisville' },\n  { name: 'Lexington-Fayette' },\n  { name: 'Lima' },\n  { name: 'Lincoln' },\n  { name: 'Lincoln' },\n  { name: 'Lincoln Park' },\n  { name: 'Linden' },\n  { name: 'Little Rock' },\n  { name: 'Littleton' },\n  { name: 'Livermore' },\n  { name: 'Livonia' },\n  { name: 'Lodi' },\n  { name: 'Logan' },\n  { name: 'Lombard' },\n  { name: 'Lompoc' },\n  { name: 'Long Beach' },\n  { name: 'Longmont' },\n  { name: 'Longview' },\n  { name: 'Lorain' },\n  { name: 'Los Angeles' },\n  { name: 'Louisville/Jefferson County' },\n  { name: 'Loveland' },\n  { name: 'Lowell' },\n  { name: 'Lubbock' },\n  { name: 'Lynchburg' },\n  { name: 'Lynn' },\n  { name: 'Lynwood' },\n  { name: 'Macon' },\n  { name: 'Madera' },\n  { name: 'Madison' },\n  { name: 'Madison' },\n  { name: 'Malden' },\n  { name: 'Manassas' },\n  { name: 'Manchester' },\n  { name: 'Manhattan' },\n  { name: 'Mankato' },\n  { name: 'Mansfield' },\n  { name: 'Mansfield' },\n  { name: 'Manteca' },\n  { name: 'Maple Grove' },\n  { name: 'Maplewood' },\n  { name: 'Marana' },\n  { name: 'Margate' },\n  { name: 'Maricopa' },\n  { name: 'Marietta' },\n  { name: 'Marlborough' },\n  { name: 'Martinez' },\n  { name: 'Marysville' },\n  { name: 'McAllen' },\n  { name: 'McKinney' },\n  { name: 'Medford' },\n  { name: 'Medford' },\n  { name: 'Melbourne' },\n  { name: 'Memphis' },\n  { name: 'Menifee' },\n  { name: 'Mentor' },\n  { name: 'Merced' },\n  { name: 'Meriden' },\n  { name: 'Meridian' },\n  { name: 'Meridian' },\n  { name: 'Mesa' },\n  { name: 'Mesquite' },\n  { name: 'Methuen' },\n  { name: 'Miami' },\n  { name: 'Miami Beach' },\n  { name: 'Miami Gardens' },\n  { name: 'Middletown' },\n  { name: 'Middletown' },\n  { name: 'Midland' },\n  { name: 'Midland' },\n  { name: 'Midwest City' },\n  { name: 'Milford' },\n  { name: 'Milpitas' },\n  { name: 'Milwaukee' },\n  { name: 'Minneapolis' },\n  { name: 'Minnetonka' },\n  { name: 'Minot' },\n  { name: 'Miramar' },\n  { name: 'Mishawaka' },\n  { name: 'Mission' },\n  { name: 'Mission Viejo' },\n  { name: 'Missoula' },\n  { name: 'Missouri City' },\n  { name: 'Mobile' },\n  { name: 'Modesto' },\n  { name: 'Moline' },\n  { name: 'Monroe' },\n  { name: 'Monrovia' },\n  { name: 'Montclair' },\n  { name: 'Montebello' },\n  { name: 'Monterey Park' },\n  { name: 'Montgomery' },\n  { name: 'Moore' },\n  { name: 'Moorhead' },\n  { name: 'Moreno Valley' },\n  { name: 'Morgan Hill' },\n  { name: 'Mount Pleasant' },\n  { name: 'Mount Prospect' },\n  { name: 'Mount Vernon' },\n  { name: 'Mountain View' },\n  { name: 'Muncie' },\n  { name: 'Murfreesboro' },\n  { name: 'Murray' },\n  { name: 'Murrieta' },\n  { name: 'Muskegon' },\n  { name: 'Muskogee' },\n  { name: 'Nampa' },\n  { name: 'Napa' },\n  { name: 'Naperville' },\n  { name: 'Nashua' },\n  { name: 'Nashville-Davidson' },\n  { name: 'National City' },\n  { name: 'New Bedford' },\n  { name: 'New Berlin' },\n  { name: 'New Braunfels' },\n  { name: 'New Britain' },\n  { name: 'New Brunswick' },\n  { name: 'New Haven' },\n  { name: 'New Orleans' },\n  { name: 'New Rochelle' },\n  { name: 'New York' },\n  { name: 'Newark' },\n  { name: 'Newark' },\n  { name: 'Newark' },\n  { name: 'Newport Beach' },\n  { name: 'Newport News' },\n  { name: 'Newton' },\n  { name: 'Niagara Falls' },\n  { name: 'Noblesville' },\n  { name: 'Norfolk' },\n  { name: 'Normal' },\n  { name: 'Norman' },\n  { name: 'North Charleston' },\n  { name: 'North Las Vegas' },\n  { name: 'North Lauderdale' },\n  { name: 'North Little Rock' },\n  { name: 'North Miami' },\n  { name: 'North Miami Beach' },\n  { name: 'North Port' },\n  { name: 'North Richland Hills' },\n  { name: 'Northglenn' },\n  { name: 'Norwalk' },\n  { name: 'Norwalk' },\n  { name: 'Norwich' },\n  { name: 'Novato' },\n  { name: 'Novi' },\n  { name: 'O\\'Fallon' },\n  { name: 'Oak Lawn' },\n  { name: 'Oak Park' },\n  { name: 'Oakland' },\n  { name: 'Oakland Park' },\n  { name: 'Oakley' },\n  { name: 'Ocala' },\n  { name: 'Oceanside' },\n  { name: 'Ocoee' },\n  { name: 'Odessa' },\n  { name: 'Ogden' },\n  { name: 'Oklahoma City' },\n  { name: 'Olathe' },\n  { name: 'Olympia' },\n  { name: 'Omaha' },\n  { name: 'Ontario' },\n  { name: 'Orange' },\n  { name: 'Orem' },\n  { name: 'Orland Park' },\n  { name: 'Orlando' },\n  { name: 'Ormond Beach' },\n  { name: 'Oro Valley' },\n  { name: 'Oshkosh' },\n  { name: 'Overland Park' },\n  { name: 'Owensboro' },\n  { name: 'Oxnard' },\n  { name: 'Pacifica' },\n  { name: 'Palatine' },\n  { name: 'Palm Bay' },\n  { name: 'Palm Beach Gardens' },\n  { name: 'Palm Coast' },\n  { name: 'Palm Desert' },\n  { name: 'Palm Springs' },\n  { name: 'Palmdale' },\n  { name: 'Palo Alto' },\n  { name: 'Panama City' },\n  { name: 'Paramount' },\n  { name: 'Park Ridge' },\n  { name: 'Parker' },\n  { name: 'Parma' },\n  { name: 'Pasadena' },\n  { name: 'Pasadena' },\n  { name: 'Pasco' },\n  { name: 'Passaic' },\n  { name: 'Paterson' },\n  { name: 'Pawtucket' },\n  { name: 'Peabody' },\n  { name: 'Peachtree Corners' },\n  { name: 'Pearland' },\n  { name: 'Pembroke Pines' },\n  { name: 'Pensacola' },\n  { name: 'Peoria' },\n  { name: 'Peoria' },\n  { name: 'Perris' },\n  { name: 'Perth Amboy' },\n  { name: 'Petaluma' },\n  { name: 'Pflugerville' },\n  { name: 'Pharr' },\n  { name: 'Phenix City' },\n  { name: 'Philadelphia' },\n  { name: 'Phoenix' },\n  { name: 'Pico Rivera' },\n  { name: 'Pine Bluff' },\n  { name: 'Pinellas Park' },\n  { name: 'Pittsburg' },\n  { name: 'Pittsburgh' },\n  { name: 'Pittsfield' },\n  { name: 'Placentia' },\n  { name: 'Plainfield' },\n  { name: 'Plainfield' },\n  { name: 'Plano' },\n  { name: 'Plantation' },\n  { name: 'Pleasanton' },\n  { name: 'Plymouth' },\n  { name: 'Pocatello' },\n  { name: 'Pomona' },\n  { name: 'Pompano Beach' },\n  { name: 'Pontiac' },\n  { name: 'Port Arthur' },\n  { name: 'Port Orange' },\n  { name: 'Port St. Lucie' },\n  { name: 'Portage' },\n  { name: 'Porterville' },\n  { name: 'Portland' },\n  { name: 'Portland' },\n  { name: 'Portsmouth' },\n  { name: 'Poway' },\n  { name: 'Prescott' },\n  { name: 'Prescott Valley' },\n  { name: 'Providence' },\n  { name: 'Provo' },\n  { name: 'Pueblo' },\n  { name: 'Puyallup' },\n  { name: 'Quincy' },\n  { name: 'Quincy' },\n  { name: 'Racine' },\n  { name: 'Raleigh' },\n  { name: 'Rancho Cordova' },\n  { name: 'Rancho Cucamonga' },\n  { name: 'Rancho Palos Verdes' },\n  { name: 'Rancho Santa Margarita' },\n  { name: 'Rapid City' },\n  { name: 'Reading' },\n  { name: 'Redding' },\n  { name: 'Redlands' },\n  { name: 'Redmond' },\n  { name: 'Redondo Beach' },\n  { name: 'Redwood City' },\n  { name: 'Reno' },\n  { name: 'Renton' },\n  { name: 'Revere' },\n  { name: 'Rialto' },\n  { name: 'Richardson' },\n  { name: 'Richland' },\n  { name: 'Richmond' },\n  { name: 'Richmond' },\n  { name: 'Rio Rancho' },\n  { name: 'Riverside' },\n  { name: 'Riverton' },\n  { name: 'Roanoke' },\n  { name: 'Rochester' },\n  { name: 'Rochester' },\n  { name: 'Rochester Hills' },\n  { name: 'Rock Hill' },\n  { name: 'Rock Island' },\n  { name: 'Rockford' },\n  { name: 'Rocklin' },\n  { name: 'Rockville' },\n  { name: 'Rockwall' },\n  { name: 'Rocky Mount' },\n  { name: 'Rogers' },\n  { name: 'Rohnert Park' },\n  { name: 'Romeoville' },\n  { name: 'Rosemead' },\n  { name: 'Roseville' },\n  { name: 'Roseville' },\n  { name: 'Roswell' },\n  { name: 'Roswell' },\n  { name: 'Round Rock' },\n  { name: 'Rowlett' },\n  { name: 'Roy' },\n  { name: 'Royal Oak' },\n  { name: 'Sacramento' },\n  { name: 'Saginaw' },\n  { name: 'Salem' },\n  { name: 'Salem' },\n  { name: 'Salina' },\n  { name: 'Salinas' },\n  { name: 'Salt Lake City' },\n  { name: 'Sammamish' },\n  { name: 'San Angelo' },\n  { name: 'San Antonio' },\n  { name: 'San Bernardino' },\n  { name: 'San Bruno' },\n  { name: 'San Buenaventura (Ventura)' },\n  { name: 'San Clemente' },\n  { name: 'San Diego' },\n  { name: 'San Francisco' },\n  { name: 'San Gabriel' },\n  { name: 'San Jacinto' },\n  { name: 'San Jose' },\n  { name: 'San Leandro' },\n  { name: 'San Luis Obispo' },\n  { name: 'San Marcos' },\n  { name: 'San Marcos' },\n  { name: 'San Mateo' },\n  { name: 'San Rafael' },\n  { name: 'San Ramon' },\n  { name: 'Sandy' },\n  { name: 'Sandy Springs' },\n  { name: 'Sanford' },\n  { name: 'Santa Ana' },\n  { name: 'Santa Barbara' },\n  { name: 'Santa Clara' },\n  { name: 'Santa Clarita' },\n  { name: 'Santa Cruz' },\n  { name: 'Santa Fe' },\n  { name: 'Santa Maria' },\n  { name: 'Santa Monica' },\n  { name: 'Santa Rosa' },\n  { name: 'Santee' },\n  { name: 'Sarasota' },\n  { name: 'Savannah' },\n  { name: 'Sayreville' },\n  { name: 'Schaumburg' },\n  { name: 'Schenectady' },\n  { name: 'Scottsdale' },\n  { name: 'Scranton' },\n  { name: 'Seattle' },\n  { name: 'Shakopee' },\n  { name: 'Shawnee' },\n  { name: 'Sheboygan' },\n  { name: 'Shelton' },\n  { name: 'Sherman' },\n  { name: 'Shoreline' },\n  { name: 'Shreveport' },\n  { name: 'Sierra Vista' },\n  { name: 'Simi Valley' },\n  { name: 'Sioux City' },\n  { name: 'Sioux Falls' },\n  { name: 'Skokie' },\n  { name: 'Smyrna' },\n  { name: 'Smyrna' },\n  { name: 'Somerville' },\n  { name: 'South Bend' },\n  { name: 'South Gate' },\n  { name: 'South Jordan' },\n  { name: 'South San Francisco' },\n  { name: 'Southaven' },\n  { name: 'Southfield' },\n  { name: 'Spanish Fork' },\n  { name: 'Sparks' },\n  { name: 'Spartanburg' },\n  { name: 'Spokane' },\n  { name: 'Spokane Valley' },\n  { name: 'Springdale' },\n  { name: 'Springfield' },\n  { name: 'Springfield' },\n  { name: 'Springfield' },\n  { name: 'Springfield' },\n  { name: 'Springfield' },\n  { name: 'St. Charles' },\n  { name: 'St. Clair Shores' },\n  { name: 'St. Cloud' },\n  { name: 'St. Cloud' },\n  { name: 'St. George' },\n  { name: 'St. Joseph' },\n  { name: 'St. Louis' },\n  { name: 'St. Louis Park' },\n  { name: 'St. Paul' },\n  { name: 'St. Peters' },\n  { name: 'St. Petersburg' },\n  { name: 'Stamford' },\n  { name: 'Stanton' },\n  { name: 'State College' },\n  { name: 'Sterling Heights' },\n  { name: 'Stillwater' },\n  { name: 'Stockton' },\n  { name: 'Streamwood' },\n  { name: 'Strongsville' },\n  { name: 'Suffolk' },\n  { name: 'Sugar Land' },\n  { name: 'Summerville' },\n  { name: 'Sumter' },\n  { name: 'Sunnyvale' },\n  { name: 'Sunrise' },\n  { name: 'Surprise' },\n  { name: 'Syracuse' },\n  { name: 'Tacoma' },\n  { name: 'Tallahassee' },\n  { name: 'Tamarac' },\n  { name: 'Tampa' },\n  { name: 'Taunton' },\n  { name: 'Taylor' },\n  { name: 'Taylorsville' },\n  { name: 'Temecula' },\n  { name: 'Tempe' },\n  { name: 'Temple' },\n  { name: 'Terre Haute' },\n  { name: 'Texarkana' },\n  { name: 'Texas City' },\n  { name: 'The Colony' },\n  { name: 'Thornton' },\n  { name: 'Thousand Oaks' },\n  { name: 'Tigard' },\n  { name: 'Tinley Park' },\n  { name: 'Titusville' },\n  { name: 'Toledo' },\n  { name: 'Topeka' },\n  { name: 'Torrance' },\n  { name: 'Tracy' },\n  { name: 'Trenton' },\n  { name: 'Troy' },\n  { name: 'Troy' },\n  { name: 'Tucson' },\n  { name: 'Tulare' },\n  { name: 'Tulsa' },\n  { name: 'Turlock' },\n  { name: 'Tuscaloosa' },\n  { name: 'Tustin' },\n  { name: 'Twin Falls' },\n  { name: 'Tyler' },\n  { name: 'Union City' },\n  { name: 'Union City' },\n  { name: 'Upland' },\n  { name: 'Urbana' },\n  { name: 'Urbandale' },\n  { name: 'Utica' },\n  { name: 'Vacaville' },\n  { name: 'Valdosta' },\n  { name: 'Vallejo' },\n  { name: 'Valley Stream' },\n  { name: 'Vancouver' },\n  { name: 'Victoria' },\n  { name: 'Victorville' },\n  { name: 'Vineland' },\n  { name: 'Virginia Beach' },\n  { name: 'Visalia' },\n  { name: 'Vista' },\n  { name: 'Waco' },\n  { name: 'Walnut Creek' },\n  { name: 'Waltham' },\n  { name: 'Warner Robins' },\n  { name: 'Warren' },\n  { name: 'Warren' },\n  { name: 'Warwick' },\n  { name: 'Washington' },\n  { name: 'Waterbury' },\n  { name: 'Waterloo' },\n  { name: 'Watsonville' },\n  { name: 'Waukegan' },\n  { name: 'Waukesha' },\n  { name: 'Wausau' },\n  { name: 'Wauwatosa' },\n  { name: 'Wellington' },\n  { name: 'Weslaco' },\n  { name: 'West Allis' },\n  { name: 'West Covina' },\n  { name: 'West Des Moines' },\n  { name: 'West Haven' },\n  { name: 'West Jordan' },\n  { name: 'West New York' },\n  { name: 'West Palm Beach' },\n  { name: 'West Sacramento' },\n  { name: 'West Valley City' },\n  { name: 'Westerville' },\n  { name: 'Westfield' },\n  { name: 'Westland' },\n  { name: 'Westminster' },\n  { name: 'Westminster' },\n  { name: 'Weston' },\n  { name: 'Weymouth Town' },\n  { name: 'Wheaton' },\n  { name: 'Wheeling' },\n  { name: 'White Plains' },\n  { name: 'Whittier' },\n  { name: 'Wichita' },\n  { name: 'Wichita Falls' },\n  { name: 'Wilkes-Barre' },\n  { name: 'Wilmington' },\n  { name: 'Wilmington' },\n  { name: 'Wilson' },\n  { name: 'Winston-Salem' },\n  { name: 'Winter Garden' },\n  { name: 'Woburn' },\n  { name: 'Woodbury' },\n  { name: 'Woodland' },\n  { name: 'Woonsocket' },\n  { name: 'Worcester' },\n  { name: 'Wylie' },\n  { name: 'Wyoming' },\n  { name: 'Yakima' },\n  { name: 'Yonkers' },\n  { name: 'Yorba Linda' },\n  { name: 'York' },\n  { name: 'Youngstown' },\n  { name: 'Yuba City' },\n  { name: 'Yucaipa' },\n  { name: 'Yuma' }\n];\n","module.exports = [\n\t{ github: 'jedwatson', name: 'Jed Watson' },\n\t{ github: 'bruderstein', name: 'Dave Brotherstone' },\n\t{ github: 'jossmac', name: 'Joss Mackison' },\n\t{ github: 'jniechcial', name: 'Jakub Niechciał' },\n\t{ github: 'craigdallimore', name: 'Craig Dallimore' },\n\t{ github: 'julen', name: 'Julen Ruiz Aizpuru' },\n\t{ github: 'dcousens', name: 'Daniel Cousens' },\n\t{ github: 'jgautsch', name: 'Jon Gautsch' },\n\t{ github: 'dmitry-smirnov', name: 'Dmitry Smirnov' },\n];\n","exports.AU = [\n\t{ value: 'australian-capital-territory', label: 'Australian Capital Territory', className: 'State-ACT' },\n\t{ value: 'new-south-wales', label: 'New South Wales', className: 'State-NSW' },\n\t{ value: 'victoria', label: 'Victoria', className: 'State-Vic' },\n\t{ value: 'queensland', label: 'Queensland', className: 'State-Qld' },\n\t{ value: 'western-australia', label: 'Western Australia', className: 'State-WA' },\n\t{ value: 'south-australia', label: 'South Australia', className: 'State-SA' },\n\t{ value: 'tasmania', label: 'Tasmania', className: 'State-Tas' },\n\t{ value: 'northern-territory', label: 'Northern Territory', className: 'State-NT' },\n];\n\nexports.US = [\n    { value: 'AL', label: 'Alabama', disabled: true },\n    { value: 'AK', label: 'Alaska' },\n    { value: 'AS', label: 'American Samoa' },\n    { value: 'AZ', label: 'Arizona' },\n    { value: 'AR', label: 'Arkansas' },\n    { value: 'CA', label: 'California' },\n    { value: 'CO', label: 'Colorado' },\n    { value: 'CT', label: 'Connecticut' },\n    { value: 'DE', label: 'Delaware' },\n    { value: 'DC', label: 'District Of Columbia' },\n    { value: 'FM', label: 'Federated States Of Micronesia' },\n    { value: 'FL', label: 'Florida' },\n    { value: 'GA', label: 'Georgia' },\n    { value: 'GU', label: 'Guam' },\n    { value: 'HI', label: 'Hawaii' },\n    { value: 'ID', label: 'Idaho' },\n    { value: 'IL', label: 'Illinois' },\n    { value: 'IN', label: 'Indiana' },\n    { value: 'IA', label: 'Iowa' },\n    { value: 'KS', label: 'Kansas' },\n    { value: 'KY', label: 'Kentucky' },\n    { value: 'LA', label: 'Louisiana' },\n    { value: 'ME', label: 'Maine' },\n    { value: 'MH', label: 'Marshall Islands' },\n    { value: 'MD', label: 'Maryland' },\n    { value: 'MA', label: 'Massachusetts' },\n    { value: 'MI', label: 'Michigan' },\n    { value: 'MN', label: 'Minnesota' },\n    { value: 'MS', label: 'Mississippi' },\n    { value: 'MO', label: 'Missouri' },\n    { value: 'MT', label: 'Montana' },\n    { value: 'NE', label: 'Nebraska' },\n    { value: 'NV', label: 'Nevada' },\n    { value: 'NH', label: 'New Hampshire' },\n    { value: 'NJ', label: 'New Jersey' },\n    { value: 'NM', label: 'New Mexico' },\n    { value: 'NY', label: 'New York' },\n    { value: 'NC', label: 'North Carolina' },\n    { value: 'ND', label: 'North Dakota' },\n    { value: 'MP', label: 'Northern Mariana Islands' },\n    { value: 'OH', label: 'Ohio' },\n    { value: 'OK', label: 'Oklahoma' },\n    { value: 'OR', label: 'Oregon' },\n    { value: 'PW', label: 'Palau' },\n    { value: 'PA', label: 'Pennsylvania' },\n    { value: 'PR', label: 'Puerto Rico' },\n    { value: 'RI', label: 'Rhode Island' },\n    { value: 'SC', label: 'South Carolina' },\n    { value: 'SD', label: 'South Dakota' },\n    { value: 'TN', label: 'Tennessee' },\n    { value: 'TX', label: 'Texas' },\n    { value: 'UT', label: 'Utah' },\n    { value: 'VT', label: 'Vermont' },\n    { value: 'VI', label: 'Virgin Islands' },\n    { value: 'VA', label: 'Virginia' },\n    { value: 'WA', label: 'Washington' },\n    { value: 'WV', label: 'West Virginia' },\n    { value: 'WI', label: 'Wisconsin' },\n    { value: 'WY', label: 'Wyoming' },\n];\n","module.exports = [\n\t{ value: 'John Smith', label: 'John Smith', email: 'john@smith.com' },\n\t{ value: 'Merry Jane', label: 'Merry Jane', email: 'merry@jane.com' },\n\t{ value: 'Stan Hoper', label: 'Stan Hoper', email: 'stan@hoper.com' }\n];\n","var charenc = {\n  // UTF-8 encoding\n  utf8: {\n    // Convert a string to a byte array\n    stringToBytes: function(str) {\n      return charenc.bin.stringToBytes(unescape(encodeURIComponent(str)));\n    },\n\n    // Convert a byte array to a string\n    bytesToString: function(bytes) {\n      return decodeURIComponent(escape(charenc.bin.bytesToString(bytes)));\n    }\n  },\n\n  // Binary encoding\n  bin: {\n    // Convert a string to a byte array\n    stringToBytes: function(str) {\n      for (var bytes = [], i = 0; i < str.length; i++)\n        bytes.push(str.charCodeAt(i) & 0xFF);\n      return bytes;\n    },\n\n    // Convert a byte array to a string\n    bytesToString: function(bytes) {\n      for (var str = [], i = 0; i < bytes.length; i++)\n        str.push(String.fromCharCode(bytes[i]));\n      return str.join('');\n    }\n  }\n};\n\nmodule.exports = charenc;\n","(function() {\n  var base64map\n      = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/',\n\n  crypt = {\n    // Bit-wise rotation left\n    rotl: function(n, b) {\n      return (n << b) | (n >>> (32 - b));\n    },\n\n    // Bit-wise rotation right\n    rotr: function(n, b) {\n      return (n << (32 - b)) | (n >>> b);\n    },\n\n    // Swap big-endian to little-endian and vice versa\n    endian: function(n) {\n      // If number given, swap endian\n      if (n.constructor == Number) {\n        return crypt.rotl(n, 8) & 0x00FF00FF | crypt.rotl(n, 24) & 0xFF00FF00;\n      }\n\n      // Else, assume array and swap all items\n      for (var i = 0; i < n.length; i++)\n        n[i] = crypt.endian(n[i]);\n      return n;\n    },\n\n    // Generate an array of any length of random bytes\n    randomBytes: function(n) {\n      for (var bytes = []; n > 0; n--)\n        bytes.push(Math.floor(Math.random() * 256));\n      return bytes;\n    },\n\n    // Convert a byte array to big-endian 32-bit words\n    bytesToWords: function(bytes) {\n      for (var words = [], i = 0, b = 0; i < bytes.length; i++, b += 8)\n        words[b >>> 5] |= bytes[i] << (24 - b % 32);\n      return words;\n    },\n\n    // Convert big-endian 32-bit words to a byte array\n    wordsToBytes: function(words) {\n      for (var bytes = [], b = 0; b < words.length * 32; b += 8)\n        bytes.push((words[b >>> 5] >>> (24 - b % 32)) & 0xFF);\n      return bytes;\n    },\n\n    // Convert a byte array to a hex string\n    bytesToHex: function(bytes) {\n      for (var hex = [], i = 0; i < bytes.length; i++) {\n        hex.push((bytes[i] >>> 4).toString(16));\n        hex.push((bytes[i] & 0xF).toString(16));\n      }\n      return hex.join('');\n    },\n\n    // Convert a hex string to a byte array\n    hexToBytes: function(hex) {\n      for (var bytes = [], c = 0; c < hex.length; c += 2)\n        bytes.push(parseInt(hex.substr(c, 2), 16));\n      return bytes;\n    },\n\n    // Convert a byte array to a base-64 string\n    bytesToBase64: function(bytes) {\n      for (var base64 = [], i = 0; i < bytes.length; i += 3) {\n        var triplet = (bytes[i] << 16) | (bytes[i + 1] << 8) | bytes[i + 2];\n        for (var j = 0; j < 4; j++)\n          if (i * 8 + j * 6 <= bytes.length * 8)\n            base64.push(base64map.charAt((triplet >>> 6 * (3 - j)) & 0x3F));\n          else\n            base64.push('=');\n      }\n      return base64.join('');\n    },\n\n    // Convert a base-64 string to a byte array\n    base64ToBytes: function(base64) {\n      // Remove non-base-64 characters\n      base64 = base64.replace(/[^A-Z0-9+\\/]/ig, '');\n\n      for (var bytes = [], i = 0, imod4 = 0; i < base64.length;\n          imod4 = ++i % 4) {\n        if (imod4 == 0) continue;\n        bytes.push(((base64map.indexOf(base64.charAt(i - 1))\n            & (Math.pow(2, -2 * imod4 + 8) - 1)) << (imod4 * 2))\n            | (base64map.indexOf(base64.charAt(i)) >>> (6 - imod4 * 2)));\n      }\n      return bytes;\n    }\n  };\n\n  module.exports = crypt;\n})();\n","'use strict';\nmodule.exports = !!(typeof window !== 'undefined' && window.document && window.document.createElement);","'use strict';\n\nvar canUseDOM = require('./inDOM');\n\nvar size;\n\nmodule.exports = function (recalc) {\n  if (!size || recalc) {\n    if (canUseDOM) {\n      var scrollDiv = document.createElement('div');\n\n      scrollDiv.style.position = 'absolute';\n      scrollDiv.style.top = '-9999px';\n      scrollDiv.style.width = '50px';\n      scrollDiv.style.height = '50px';\n      scrollDiv.style.overflow = 'scroll';\n\n      document.body.appendChild(scrollDiv);\n      size = scrollDiv.offsetWidth - scrollDiv.clientWidth;\n      document.body.removeChild(scrollDiv);\n    }\n  }\n\n  return size;\n};","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n *\n * @typechecks\n * \n */\n\n/*eslint-disable no-self-compare */\n\n'use strict';\n\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\n/**\n * inlined Object.is polyfill to avoid requiring consumers ship their own\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\n */\nfunction is(x, y) {\n  // SameValue algorithm\n  if (x === y) {\n    // Steps 1-5, 7-10\n    // Steps 6.b-6.e: +0 != -0\n    // Added the nonzero y check to make Flow happy, but it is redundant\n    return x !== 0 || y !== 0 || 1 / x === 1 / y;\n  } else {\n    // Step 6.a: NaN == NaN\n    return x !== x && y !== y;\n  }\n}\n\n/**\n * Performs equality by iterating through keys on an object and returning false\n * when any key has values which are not strictly equal between the arguments.\n * Returns true when the values of all keys are strictly equal.\n */\nfunction shallowEqual(objA, objB) {\n  if (is(objA, objB)) {\n    return true;\n  }\n\n  if (typeof objA !== 'object' || objA === null || typeof objB !== 'object' || objB === null) {\n    return false;\n  }\n\n  var keysA = Object.keys(objA);\n  var keysB = Object.keys(objB);\n\n  if (keysA.length !== keysB.length) {\n    return false;\n  }\n\n  // Test for A's keys different from B.\n  for (var i = 0; i < keysA.length; i++) {\n    if (!hasOwnProperty.call(objB, keysA[i]) || !is(objA[keysA[i]], objB[keysA[i]])) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nmodule.exports = shallowEqual;","/*!\n * Determine if an object is a Buffer\n *\n * @author   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license  MIT\n */\n\n// The _isBuffer check is for Safari 5-7 support, because it's missing\n// Object.prototype.constructor. Remove this eventually\nmodule.exports = function (obj) {\n  return obj != null && (isBuffer(obj) || isSlowBuffer(obj) || !!obj._isBuffer)\n}\n\nfunction isBuffer (obj) {\n  return !!obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj)\n}\n\n// For Node v0.10 support. Remove this eventually.\nfunction isSlowBuffer (obj) {\n  return typeof obj.readFloatLE === 'function' && typeof obj.slice === 'function' && isBuffer(obj.slice(0, 0))\n}\n","module.exports = function() {\n  var mediaQuery;\n  if (typeof window !== \"undefined\" && window !== null) {\n    mediaQuery = \"(-webkit-min-device-pixel-ratio: 1.25), (min--moz-device-pixel-ratio: 1.25), (-o-min-device-pixel-ratio: 5/4), (min-resolution: 1.25dppx)\";\n    if (window.devicePixelRatio > 1.25) {\n      return true;\n    }\n    if (window.matchMedia && window.matchMedia(mediaQuery).matches) {\n      return true;\n    }\n  }\n  return false;\n};\n","// the whatwg-fetch polyfill installs the fetch() function\n// on the global object (window or self)\n//\n// Return that as the export for use in Webpack, Browserify etc.\nrequire('whatwg-fetch');\nmodule.exports = self.fetch.bind(self);\n","(function(){\r\n  var crypt = require('crypt'),\r\n      utf8 = require('charenc').utf8,\r\n      isBuffer = require('is-buffer'),\r\n      bin = require('charenc').bin,\r\n\r\n  // The core\r\n  md5 = function (message, options) {\r\n    // Convert to byte array\r\n    if (message.constructor == String)\r\n      if (options && options.encoding === 'binary')\r\n        message = bin.stringToBytes(message);\r\n      else\r\n        message = utf8.stringToBytes(message);\r\n    else if (isBuffer(message))\r\n      message = Array.prototype.slice.call(message, 0);\r\n    else if (!Array.isArray(message))\r\n      message = message.toString();\r\n    // else, assume byte array already\r\n\r\n    var m = crypt.bytesToWords(message),\r\n        l = message.length * 8,\r\n        a =  1732584193,\r\n        b = -271733879,\r\n        c = -1732584194,\r\n        d =  271733878;\r\n\r\n    // Swap endian\r\n    for (var i = 0; i < m.length; i++) {\r\n      m[i] = ((m[i] <<  8) | (m[i] >>> 24)) & 0x00FF00FF |\r\n             ((m[i] << 24) | (m[i] >>>  8)) & 0xFF00FF00;\r\n    }\r\n\r\n    // Padding\r\n    m[l >>> 5] |= 0x80 << (l % 32);\r\n    m[(((l + 64) >>> 9) << 4) + 14] = l;\r\n\r\n    // Method shortcuts\r\n    var FF = md5._ff,\r\n        GG = md5._gg,\r\n        HH = md5._hh,\r\n        II = md5._ii;\r\n\r\n    for (var i = 0; i < m.length; i += 16) {\r\n\r\n      var aa = a,\r\n          bb = b,\r\n          cc = c,\r\n          dd = d;\r\n\r\n      a = FF(a, b, c, d, m[i+ 0],  7, -680876936);\r\n      d = FF(d, a, b, c, m[i+ 1], 12, -389564586);\r\n      c = FF(c, d, a, b, m[i+ 2], 17,  606105819);\r\n      b = FF(b, c, d, a, m[i+ 3], 22, -1044525330);\r\n      a = FF(a, b, c, d, m[i+ 4],  7, -176418897);\r\n      d = FF(d, a, b, c, m[i+ 5], 12,  1200080426);\r\n      c = FF(c, d, a, b, m[i+ 6], 17, -1473231341);\r\n      b = FF(b, c, d, a, m[i+ 7], 22, -45705983);\r\n      a = FF(a, b, c, d, m[i+ 8],  7,  1770035416);\r\n      d = FF(d, a, b, c, m[i+ 9], 12, -1958414417);\r\n      c = FF(c, d, a, b, m[i+10], 17, -42063);\r\n      b = FF(b, c, d, a, m[i+11], 22, -1990404162);\r\n      a = FF(a, b, c, d, m[i+12],  7,  1804603682);\r\n      d = FF(d, a, b, c, m[i+13], 12, -40341101);\r\n      c = FF(c, d, a, b, m[i+14], 17, -1502002290);\r\n      b = FF(b, c, d, a, m[i+15], 22,  1236535329);\r\n\r\n      a = GG(a, b, c, d, m[i+ 1],  5, -165796510);\r\n      d = GG(d, a, b, c, m[i+ 6],  9, -1069501632);\r\n      c = GG(c, d, a, b, m[i+11], 14,  643717713);\r\n      b = GG(b, c, d, a, m[i+ 0], 20, -373897302);\r\n      a = GG(a, b, c, d, m[i+ 5],  5, -701558691);\r\n      d = GG(d, a, b, c, m[i+10],  9,  38016083);\r\n      c = GG(c, d, a, b, m[i+15], 14, -660478335);\r\n      b = GG(b, c, d, a, m[i+ 4], 20, -405537848);\r\n      a = GG(a, b, c, d, m[i+ 9],  5,  568446438);\r\n      d = GG(d, a, b, c, m[i+14],  9, -1019803690);\r\n      c = GG(c, d, a, b, m[i+ 3], 14, -187363961);\r\n      b = GG(b, c, d, a, m[i+ 8], 20,  1163531501);\r\n      a = GG(a, b, c, d, m[i+13],  5, -1444681467);\r\n      d = GG(d, a, b, c, m[i+ 2],  9, -51403784);\r\n      c = GG(c, d, a, b, m[i+ 7], 14,  1735328473);\r\n      b = GG(b, c, d, a, m[i+12], 20, -1926607734);\r\n\r\n      a = HH(a, b, c, d, m[i+ 5],  4, -378558);\r\n      d = HH(d, a, b, c, m[i+ 8], 11, -2022574463);\r\n      c = HH(c, d, a, b, m[i+11], 16,  1839030562);\r\n      b = HH(b, c, d, a, m[i+14], 23, -35309556);\r\n      a = HH(a, b, c, d, m[i+ 1],  4, -1530992060);\r\n      d = HH(d, a, b, c, m[i+ 4], 11,  1272893353);\r\n      c = HH(c, d, a, b, m[i+ 7], 16, -155497632);\r\n      b = HH(b, c, d, a, m[i+10], 23, -1094730640);\r\n      a = HH(a, b, c, d, m[i+13],  4,  681279174);\r\n      d = HH(d, a, b, c, m[i+ 0], 11, -358537222);\r\n      c = HH(c, d, a, b, m[i+ 3], 16, -722521979);\r\n      b = HH(b, c, d, a, m[i+ 6], 23,  76029189);\r\n      a = HH(a, b, c, d, m[i+ 9],  4, -640364487);\r\n      d = HH(d, a, b, c, m[i+12], 11, -421815835);\r\n      c = HH(c, d, a, b, m[i+15], 16,  530742520);\r\n      b = HH(b, c, d, a, m[i+ 2], 23, -995338651);\r\n\r\n      a = II(a, b, c, d, m[i+ 0],  6, -198630844);\r\n      d = II(d, a, b, c, m[i+ 7], 10,  1126891415);\r\n      c = II(c, d, a, b, m[i+14], 15, -1416354905);\r\n      b = II(b, c, d, a, m[i+ 5], 21, -57434055);\r\n      a = II(a, b, c, d, m[i+12],  6,  1700485571);\r\n      d = II(d, a, b, c, m[i+ 3], 10, -1894986606);\r\n      c = II(c, d, a, b, m[i+10], 15, -1051523);\r\n      b = II(b, c, d, a, m[i+ 1], 21, -2054922799);\r\n      a = II(a, b, c, d, m[i+ 8],  6,  1873313359);\r\n      d = II(d, a, b, c, m[i+15], 10, -30611744);\r\n      c = II(c, d, a, b, m[i+ 6], 15, -1560198380);\r\n      b = II(b, c, d, a, m[i+13], 21,  1309151649);\r\n      a = II(a, b, c, d, m[i+ 4],  6, -145523070);\r\n      d = II(d, a, b, c, m[i+11], 10, -1120210379);\r\n      c = II(c, d, a, b, m[i+ 2], 15,  718787259);\r\n      b = II(b, c, d, a, m[i+ 9], 21, -343485551);\r\n\r\n      a = (a + aa) >>> 0;\r\n      b = (b + bb) >>> 0;\r\n      c = (c + cc) >>> 0;\r\n      d = (d + dd) >>> 0;\r\n    }\r\n\r\n    return crypt.endian([a, b, c, d]);\r\n  };\r\n\r\n  // Auxiliary functions\r\n  md5._ff  = function (a, b, c, d, x, s, t) {\r\n    var n = a + (b & c | ~b & d) + (x >>> 0) + t;\r\n    return ((n << s) | (n >>> (32 - s))) + b;\r\n  };\r\n  md5._gg  = function (a, b, c, d, x, s, t) {\r\n    var n = a + (b & d | c & ~d) + (x >>> 0) + t;\r\n    return ((n << s) | (n >>> (32 - s))) + b;\r\n  };\r\n  md5._hh  = function (a, b, c, d, x, s, t) {\r\n    var n = a + (b ^ c ^ d) + (x >>> 0) + t;\r\n    return ((n << s) | (n >>> (32 - s))) + b;\r\n  };\r\n  md5._ii  = function (a, b, c, d, x, s, t) {\r\n    var n = a + (c ^ (b | ~d)) + (x >>> 0) + t;\r\n    return ((n << s) | (n >>> (32 - s))) + b;\r\n  };\r\n\r\n  // Package private blocksize\r\n  md5._blocksize = 16;\r\n  md5._digestsize = 16;\r\n\r\n  module.exports = function (message, options) {\r\n    if (message === undefined || message === null)\r\n      throw new Error('Illegal argument ' + message);\r\n\r\n    var digestbytes = crypt.wordsToBytes(md5(message, options));\r\n    return options && options.asBytes ? digestbytes :\r\n        options && options.asString ? bin.bytesToString(digestbytes) :\r\n        crypt.bytesToHex(digestbytes);\r\n  };\r\n\r\n})();\r\n","'use strict';\n/* eslint-disable no-unused-vars */\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc');  // eslint-disable-line\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (e) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (Object.getOwnPropertySymbols) {\n\t\t\tsymbols = Object.getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","// Generated by CoffeeScript 1.7.1\n(function() {\n  var getNanoSeconds, hrtime, loadTime;\n\n  if ((typeof performance !== \"undefined\" && performance !== null) && performance.now) {\n    module.exports = function() {\n      return performance.now();\n    };\n  } else if ((typeof process !== \"undefined\" && process !== null) && process.hrtime) {\n    module.exports = function() {\n      return (getNanoSeconds() - loadTime) / 1e6;\n    };\n    hrtime = process.hrtime;\n    getNanoSeconds = function() {\n      var hr;\n      hr = hrtime();\n      return hr[0] * 1e9 + hr[1];\n    };\n    loadTime = getNanoSeconds();\n  } else if (Date.now) {\n    module.exports = function() {\n      return Date.now() - loadTime;\n    };\n    loadTime = Date.now();\n  } else {\n    module.exports = function() {\n      return new Date().getTime() - loadTime;\n    };\n    loadTime = new Date().getTime();\n  }\n\n}).call(this);\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things.  But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals.  It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n    throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n    throw new Error('clearTimeout has not been defined');\n}\n(function () {\n    try {\n        if (typeof setTimeout === 'function') {\n            cachedSetTimeout = setTimeout;\n        } else {\n            cachedSetTimeout = defaultSetTimout;\n        }\n    } catch (e) {\n        cachedSetTimeout = defaultSetTimout;\n    }\n    try {\n        if (typeof clearTimeout === 'function') {\n            cachedClearTimeout = clearTimeout;\n        } else {\n            cachedClearTimeout = defaultClearTimeout;\n        }\n    } catch (e) {\n        cachedClearTimeout = defaultClearTimeout;\n    }\n} ())\nfunction runTimeout(fun) {\n    if (cachedSetTimeout === setTimeout) {\n        //normal enviroments in sane situations\n        return setTimeout(fun, 0);\n    }\n    // if setTimeout wasn't available but was latter defined\n    if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n        cachedSetTimeout = setTimeout;\n        return setTimeout(fun, 0);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedSetTimeout(fun, 0);\n    } catch(e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n            return cachedSetTimeout.call(null, fun, 0);\n        } catch(e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n            return cachedSetTimeout.call(this, fun, 0);\n        }\n    }\n\n\n}\nfunction runClearTimeout(marker) {\n    if (cachedClearTimeout === clearTimeout) {\n        //normal enviroments in sane situations\n        return clearTimeout(marker);\n    }\n    // if clearTimeout wasn't available but was latter defined\n    if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n        cachedClearTimeout = clearTimeout;\n        return clearTimeout(marker);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedClearTimeout(marker);\n    } catch (e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't  trust the global object when called normally\n            return cachedClearTimeout.call(null, marker);\n        } catch (e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n            // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n            return cachedClearTimeout.call(this, marker);\n        }\n    }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = runTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        runTimeout(drainQueue);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","'use strict';\nvar strictUriEncode = require('strict-uri-encode');\nvar objectAssign = require('object-assign');\n\nfunction encode(value, opts) {\n\tif (opts.encode) {\n\t\treturn opts.strict ? strictUriEncode(value) : encodeURIComponent(value);\n\t}\n\n\treturn value;\n}\n\nexports.extract = function (str) {\n\treturn str.split('?')[1] || '';\n};\n\nexports.parse = function (str) {\n\t// Create an object with no prototype\n\t// https://github.com/sindresorhus/query-string/issues/47\n\tvar ret = Object.create(null);\n\n\tif (typeof str !== 'string') {\n\t\treturn ret;\n\t}\n\n\tstr = str.trim().replace(/^(\\?|#|&)/, '');\n\n\tif (!str) {\n\t\treturn ret;\n\t}\n\n\tstr.split('&').forEach(function (param) {\n\t\tvar parts = param.replace(/\\+/g, ' ').split('=');\n\t\t// Firefox (pre 40) decodes `%3D` to `=`\n\t\t// https://github.com/sindresorhus/query-string/pull/37\n\t\tvar key = parts.shift();\n\t\tvar val = parts.length > 0 ? parts.join('=') : undefined;\n\n\t\tkey = decodeURIComponent(key);\n\n\t\t// missing `=` should be `null`:\n\t\t// http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n\t\tval = val === undefined ? null : decodeURIComponent(val);\n\n\t\tif (ret[key] === undefined) {\n\t\t\tret[key] = val;\n\t\t} else if (Array.isArray(ret[key])) {\n\t\t\tret[key].push(val);\n\t\t} else {\n\t\t\tret[key] = [ret[key], val];\n\t\t}\n\t});\n\n\treturn ret;\n};\n\nexports.stringify = function (obj, opts) {\n\tvar defaults = {\n\t\tencode: true,\n\t\tstrict: true\n\t};\n\n\topts = objectAssign(defaults, opts);\n\n\treturn obj ? Object.keys(obj).sort().map(function (key) {\n\t\tvar val = obj[key];\n\n\t\tif (val === undefined) {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (val === null) {\n\t\t\treturn encode(key, opts);\n\t\t}\n\n\t\tif (Array.isArray(val)) {\n\t\t\tvar result = [];\n\n\t\t\tval.slice().forEach(function (val2) {\n\t\t\t\tif (val2 === undefined) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (val2 === null) {\n\t\t\t\t\tresult.push(encode(key, opts));\n\t\t\t\t} else {\n\t\t\t\t\tresult.push(encode(key, opts) + '=' + encode(val2, opts));\n\t\t\t\t}\n\t\t\t});\n\n\t\t\treturn result.join('&');\n\t\t}\n\n\t\treturn encode(key, opts) + '=' + encode(val, opts);\n\t}).filter(function (x) {\n\t\treturn x.length > 0;\n\t}).join('&') : '';\n};\n","var now = require('performance-now')\n  , root = typeof window === 'undefined' ? global : window\n  , vendors = ['moz', 'webkit']\n  , suffix = 'AnimationFrame'\n  , raf = root['request' + suffix]\n  , caf = root['cancel' + suffix] || root['cancelRequest' + suffix]\n\nfor(var i = 0; !raf && i < vendors.length; i++) {\n  raf = root[vendors[i] + 'Request' + suffix]\n  caf = root[vendors[i] + 'Cancel' + suffix]\n      || root[vendors[i] + 'CancelRequest' + suffix]\n}\n\n// Some versions of FF have rAF but not cAF\nif(!raf || !caf) {\n  var last = 0\n    , id = 0\n    , queue = []\n    , frameDuration = 1000 / 60\n\n  raf = function(callback) {\n    if(queue.length === 0) {\n      var _now = now()\n        , next = Math.max(0, frameDuration - (_now - last))\n      last = next + _now\n      setTimeout(function() {\n        var cp = queue.slice(0)\n        // Clear queue here to prevent\n        // callbacks from appending listeners\n        // to the current frame's queue\n        queue.length = 0\n        for(var i = 0; i < cp.length; i++) {\n          if(!cp[i].cancelled) {\n            try{\n              cp[i].callback(last)\n            } catch(e) {\n              setTimeout(function() { throw e }, 0)\n            }\n          }\n        }\n      }, Math.round(next))\n    }\n    queue.push({\n      handle: ++id,\n      callback: callback,\n      cancelled: false\n    })\n    return id\n  }\n\n  caf = function(handle) {\n    for(var i = 0; i < queue.length; i++) {\n      if(queue[i].handle === handle) {\n        queue[i].cancelled = true\n      }\n    }\n  }\n}\n\nmodule.exports = function(fn) {\n  // Wrap in a new function to prevent\n  // `cancel` potentially being assigned\n  // to the native rAF function\n  return raf.call(root, fn)\n}\nmodule.exports.cancel = function() {\n  caf.apply(root, arguments)\n}\nmodule.exports.polyfill = function() {\n  root.requestAnimationFrame = raf\n  root.cancelAnimationFrame = caf\n}\n","module.exports = require('react/lib/shallowCompare');","'use strict';\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _md = require('md5');\n\nvar _md2 = _interopRequireDefault(_md);\n\nvar _queryString = require('query-string');\n\nvar _queryString2 = _interopRequireDefault(_queryString);\n\nvar _isRetina = require('is-retina');\n\nvar _isRetina2 = _interopRequireDefault(_isRetina);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Gravatar = function (_React$Component) {\n  _inherits(Gravatar, _React$Component);\n\n  function Gravatar() {\n    _classCallCheck(this, Gravatar);\n\n    return _possibleConstructorReturn(this, Object.getPrototypeOf(Gravatar).apply(this, arguments));\n  }\n\n  _createClass(Gravatar, [{\n    key: 'render',\n    value: function render() {\n      var base = this.props.protocol + 'www.gravatar.com/avatar/';\n\n      var query = _queryString2.default.stringify({\n        s: this.props.size,\n        r: this.props.rating,\n        d: this.props.default\n      });\n\n      var retinaQuery = _queryString2.default.stringify({\n        s: this.props.size * 2,\n        r: this.props.rating,\n        d: this.props.default\n      });\n\n      // Gravatar service currently trims and lowercases all registered emails\n      var formattedEmail = ('' + this.props.email).trim().toLowerCase();\n\n      var hash = void 0;\n      if (this.props.md5) {\n        hash = this.props.md5;\n      } else if (typeof this.props.email === 'string') {\n        hash = (0, _md2.default)(formattedEmail);\n      } else {\n        console.warn('Gravatar image can not be fetched. Either the \"email\" or \"md5\" prop must be specified.');\n        return _react2.default.createElement('script', null);\n      }\n\n      var src = '' + base + hash + '?' + query;\n      var retinaSrc = '' + base + hash + '?' + retinaQuery;\n\n      var modernBrowser = true; // server-side, we render for modern browsers\n\n      if (typeof window !== 'undefined') {\n        // this is not NodeJS\n        modernBrowser = 'srcset' in document.createElement('img');\n      }\n\n      var className = 'react-gravatar';\n      if (this.props.className) {\n        className = className + ' ' + this.props.className;\n      }\n\n      // Clone this.props and then delete Component specific props so we can\n      // spread the rest into the img.\n\n      var rest = _objectWithoutProperties(this.props, []);\n\n      delete rest.md5;\n      delete rest.email;\n      delete rest.protocol;\n      delete rest.rating;\n      delete rest.size;\n      delete rest.style;\n      delete rest.className;\n      delete rest.default;\n      if (!modernBrowser && (0, _isRetina2.default)()) {\n        return _react2.default.createElement('img', _extends({\n          alt: 'Gravatar for ' + formattedEmail,\n          style: this.props.style,\n          src: retinaSrc,\n          height: this.props.size,\n          width: this.props.size\n        }, rest, {\n          className: className\n        }));\n      }\n      return _react2.default.createElement('img', _extends({\n        alt: 'Gravatar for ' + formattedEmail,\n        style: this.props.style,\n        src: src,\n        srcSet: retinaSrc + ' 2x',\n        height: this.props.size,\n        width: this.props.size\n      }, rest, {\n        className: className\n      }));\n    }\n  }]);\n\n  return Gravatar;\n}(_react2.default.Component);\n\nGravatar.displayName = 'Gravatar';\nGravatar.propTypes = {\n  email: _react2.default.PropTypes.string,\n  md5: _react2.default.PropTypes.string,\n  size: _react2.default.PropTypes.number,\n  rating: _react2.default.PropTypes.string,\n  default: _react2.default.PropTypes.string,\n  className: _react2.default.PropTypes.string,\n  protocol: _react2.default.PropTypes.string,\n  style: _react2.default.PropTypes.object\n};\nGravatar.defaultProps = {\n  size: 50,\n  rating: 'g',\n  default: 'retro',\n  protocol: '//'\n};\n\n\nmodule.exports = Gravatar;","module.exports =\n/******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId])\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\texports: {},\n/******/ \t\t\tid: moduleId,\n/******/ \t\t\tloaded: false\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.loaded = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(0);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ function(module, exports, __webpack_require__) {\n\n\tmodule.exports = __webpack_require__(1);\n\n\n/***/ },\n/* 1 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, '__esModule', {\n\t  value: true\n\t});\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\t\n\tvar _Highlighter = __webpack_require__(2);\n\t\n\tvar _Highlighter2 = _interopRequireDefault(_Highlighter);\n\t\n\tvar _utils = __webpack_require__(4);\n\t\n\texports['default'] = _Highlighter2['default'];\n\texports.combineChunks = _utils.combineChunks;\n\texports.fillInChunks = _utils.fillInChunks;\n\texports.findAll = _utils.findAll;\n\texports.findChunks = _utils.findChunks;\n\n/***/ },\n/* 2 */\n/***/ function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, '__esModule', {\n\t  value: true\n\t});\n\texports['default'] = Highlighter;\n\t\n\tfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj['default'] = obj; return newObj; } }\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\t\n\tvar _react = __webpack_require__(3);\n\t\n\tvar _react2 = _interopRequireDefault(_react);\n\t\n\tvar _utilsJs = __webpack_require__(4);\n\t\n\tvar Chunks = _interopRequireWildcard(_utilsJs);\n\t\n\tHighlighter.propTypes = {\n\t  highlightClassName: _react.PropTypes.string,\n\t  highlightStyle: _react.PropTypes.object,\n\t  searchWords: _react.PropTypes.arrayOf(_react.PropTypes.string).isRequired,\n\t  textToHighlight: _react.PropTypes.string.isRequired,\n\t  sanitize: _react.PropTypes.func\n\t};\n\t\n\t/**\n\t * Highlights all occurrences of search terms (searchText) within a string (textToHighlight).\n\t * This function returns an array of strings and <span>s (wrapping highlighted words).\n\t */\n\t\n\tfunction Highlighter(_ref) {\n\t  var _ref$highlightClassName = _ref.highlightClassName;\n\t  var highlightClassName = _ref$highlightClassName === undefined ? '' : _ref$highlightClassName;\n\t  var _ref$highlightStyle = _ref.highlightStyle;\n\t  var highlightStyle = _ref$highlightStyle === undefined ? {} : _ref$highlightStyle;\n\t  var searchWords = _ref.searchWords;\n\t  var textToHighlight = _ref.textToHighlight;\n\t  var sanitize = _ref.sanitize;\n\t\n\t  var chunks = Chunks.findAll(textToHighlight, searchWords, sanitize);\n\t\n\t  return _react2['default'].createElement(\n\t    'span',\n\t    null,\n\t    chunks.map(function (chunk, index) {\n\t      var text = textToHighlight.substr(chunk.start, chunk.end - chunk.start);\n\t\n\t      if (chunk.highlight) {\n\t        return _react2['default'].createElement(\n\t          'mark',\n\t          {\n\t            className: highlightClassName,\n\t            key: index,\n\t            style: highlightStyle\n\t          },\n\t          text\n\t        );\n\t      } else {\n\t        return _react2['default'].createElement(\n\t          'span',\n\t          { key: index },\n\t          text\n\t        );\n\t      }\n\t    })\n\t  );\n\t}\n\t\n\tmodule.exports = exports['default'];\n\n/***/ },\n/* 3 */\n/***/ function(module, exports) {\n\n\tmodule.exports = require(\"react\");\n\n/***/ },\n/* 4 */\n/***/ function(module, exports) {\n\n\t/**\n\t * Creates an array of chunk objects representing both higlightable and non highlightable pieces of text that match each search word.\n\t * @param searchWords string[]\n\t * @param textToSearch string\n\t * @return {start:number, end:number, highlight:boolean}[]\n\t */\n\t'use strict';\n\t\n\tObject.defineProperty(exports, '__esModule', {\n\t  value: true\n\t});\n\tvar findAll = function findAll(textToSearch, wordsToFind, sanitize) {\n\t  return fillInChunks(combineChunks(findChunks(textToSearch, wordsToFind, sanitize)), textToSearch.length);\n\t};\n\t\n\texports.findAll = findAll;\n\t/**\n\t * Takes an array of {start:number, end:number} objects and combines chunks that overlap into single chunks.\n\t * @param chunks {start:number, end:number}[]\n\t * @return {start:number, end:number}[]\n\t */\n\tvar combineChunks = function combineChunks(chunks) {\n\t  chunks = chunks.sort(function (first, second) {\n\t    return first.start - second.start;\n\t  }).reduce(function (processedChunks, nextChunk) {\n\t    // First chunk just goes straight in the array...\n\t    if (processedChunks.length === 0) {\n\t      return [nextChunk];\n\t    } else {\n\t      // ... subsequent chunks get checked to see if they overlap...\n\t      var prevChunk = processedChunks.pop();\n\t      if (nextChunk.start <= prevChunk.end) {\n\t        // It may be the case that prevChunk completely surrounds nextChunk, so take the\n\t        // largest of the end indeces.\n\t        var endIndex = Math.max(prevChunk.end, nextChunk.end);\n\t        processedChunks.push({ start: prevChunk.start, end: endIndex });\n\t      } else {\n\t        processedChunks.push(prevChunk, nextChunk);\n\t      }\n\t      return processedChunks;\n\t    }\n\t  }, []);\n\t\n\t  return chunks;\n\t};\n\t\n\texports.combineChunks = combineChunks;\n\t/**\n\t * Examine textToSearch for any matches.\n\t * If we find matches, add them to the returned array as a \"chunk\" object ({start:number, end:number}).\n\t * @param textToSearch string\n\t * @param wordsToFind string[]\n\t * @param sanitize Process and optionally modify textToSearch and wordsToFind before comparison; this can be used to eg. remove accents\n\t * @return {start:number, end:number}[]\n\t */\n\tvar findChunks = function findChunks(textToSearch, wordsToFind) {\n\t  var sanitize = arguments.length <= 2 || arguments[2] === undefined ? identity : arguments[2];\n\t  return wordsToFind.filter(function (searchWord) {\n\t    return searchWord;\n\t  }) // Remove empty words\n\t  .reduce(function (chunks, searchWord) {\n\t    var normalizedWord = sanitize(searchWord);\n\t    var normalizedText = sanitize(textToSearch);\n\t    var regex = new RegExp(normalizedWord, 'gi');\n\t    var match = undefined;\n\t    while ((match = regex.exec(normalizedText)) != null) {\n\t      chunks.push({ start: match.index, end: regex.lastIndex });\n\t    }\n\t    return chunks;\n\t  }, []);\n\t};\n\t\n\texports.findChunks = findChunks;\n\t/**\n\t * Given a set of chunks to highlight, create an additional set of chunks\n\t * to represent the bits of text between the highlighted text.\n\t * @param chunksToHighlight {start:number, end:number}[]\n\t * @param totalLength number\n\t * @return {start:number, end:number, highlight:boolean}[]\n\t */\n\tvar fillInChunks = function fillInChunks(chunksToHighlight, totalLength) {\n\t  var allChunks = [];\n\t  var append = function append(start, end, highlight) {\n\t    if (end - start > 0) {\n\t      allChunks.push({ start: start, end: end, highlight: highlight });\n\t    }\n\t  };\n\t\n\t  if (chunksToHighlight.length === 0) {\n\t    append(0, totalLength, false);\n\t  } else {\n\t    (function () {\n\t      var lastIndex = 0;\n\t      chunksToHighlight.forEach(function (chunk) {\n\t        append(lastIndex, chunk.start, false);\n\t        append(chunk.start, chunk.end, true);\n\t        lastIndex = chunk.end;\n\t      });\n\t      append(lastIndex, totalLength, false);\n\t    })();\n\t  }\n\t  return allChunks;\n\t};\n\t\n\texports.fillInChunks = fillInChunks;\n\tfunction identity(value) {\n\t  return value;\n\t}\n\n/***/ }\n/******/ ]);\n//# sourceMappingURL=main.js.map","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactSelect = require('react-select');\n\nvar _reactSelect2 = _interopRequireDefault(_reactSelect);\n\nvar _reactVirtualized = require('react-virtualized');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar VirtualizedSelect = function (_Component) {\n  _inherits(VirtualizedSelect, _Component);\n\n  function VirtualizedSelect(props, context) {\n    _classCallCheck(this, VirtualizedSelect);\n\n    var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(VirtualizedSelect).call(this, props, context));\n\n    _this._renderMenu = _this._renderMenu.bind(_this);\n    _this._optionRenderer = _this._optionRenderer.bind(_this);\n    return _this;\n  }\n\n  /** See VirtualScroll#recomputeRowHeights */\n\n\n  _createClass(VirtualizedSelect, [{\n    key: 'recomputeOptionHeights',\n    value: function recomputeOptionHeights() {\n      var index = arguments.length <= 0 || arguments[0] === undefined ? 0 : arguments[0];\n\n      if (this._virtualScroll) {\n        this._virtualScroll.recomputeRowHeights(index);\n      }\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var SelectComponent = this._getSelectComponent();\n\n      return _react2.default.createElement(SelectComponent, _extends({}, this.props, {\n        menuRenderer: this._renderMenu,\n        menuStyle: { overflow: 'hidden' }\n      }));\n    }\n\n    // See https://github.com/JedWatson/react-select/#effeciently-rendering-large-lists-with-windowing\n\n  }, {\n    key: '_renderMenu',\n    value: function _renderMenu(_ref) {\n      var _this2 = this;\n\n      var focusedOption = _ref.focusedOption;\n      var focusOption = _ref.focusOption;\n      var labelKey = _ref.labelKey;\n      var options = _ref.options;\n      var selectValue = _ref.selectValue;\n      var valueArray = _ref.valueArray;\n      var optionRenderer = this.props.optionRenderer;\n\n      var focusedOptionIndex = options.indexOf(focusedOption);\n      var height = this._calculateVirtualScrollHeight({ options: options });\n      var innerRowRenderer = optionRenderer || this._optionRenderer;\n\n      function wrappedRowRenderer(_ref2) {\n        var index = _ref2.index;\n\n        var option = options[index];\n\n        return innerRowRenderer({\n          focusedOption: focusedOption,\n          focusedOptionIndex: focusedOptionIndex,\n          focusOption: focusOption,\n          labelKey: labelKey,\n          option: option,\n          optionIndex: index,\n          options: options,\n          selectValue: selectValue,\n          valueArray: valueArray\n        });\n      }\n\n      return _react2.default.createElement(\n        _reactVirtualized.AutoSizer,\n        { disableHeight: true },\n        function (_ref3) {\n          var width = _ref3.width;\n          return _react2.default.createElement(_reactVirtualized.VirtualScroll, {\n            className: 'VirtualSelectGrid',\n            height: height,\n            ref: function ref(_ref5) {\n              return _this2._virtualScroll = _ref5;\n            },\n            rowCount: options.length,\n            rowHeight: function rowHeight(_ref4) {\n              var index = _ref4.index;\n              return _this2._getOptionHeight({\n                option: options[index]\n              });\n            },\n            rowRenderer: wrappedRowRenderer,\n            scrollToIndex: focusedOptionIndex,\n            width: width\n          });\n        }\n      );\n    }\n  }, {\n    key: '_calculateVirtualScrollHeight',\n    value: function _calculateVirtualScrollHeight(_ref6) {\n      var options = _ref6.options;\n      var maxHeight = this.props.maxHeight;\n\n\n      var height = 0;\n\n      for (var optionIndex = 0; optionIndex < options.length; optionIndex++) {\n        var option = options[optionIndex];\n\n        height += this._getOptionHeight({ option: option });\n\n        if (height > maxHeight) {\n          return maxHeight;\n        }\n      }\n\n      return height;\n    }\n  }, {\n    key: '_getOptionHeight',\n    value: function _getOptionHeight(_ref7) {\n      var option = _ref7.option;\n      var optionHeight = this.props.optionHeight;\n\n\n      return optionHeight instanceof Function ? optionHeight({ option: option }) : optionHeight;\n    }\n  }, {\n    key: '_getSelectComponent',\n    value: function _getSelectComponent() {\n      var _props = this.props;\n      var async = _props.async;\n      var selectComponent = _props.selectComponent;\n\n\n      if (selectComponent) {\n        return selectComponent;\n      } else if (async) {\n        return _reactSelect2.default.Async;\n      } else {\n        return _reactSelect2.default;\n      }\n    }\n  }, {\n    key: '_optionRenderer',\n    value: function _optionRenderer(_ref8) {\n      var focusedOption = _ref8.focusedOption;\n      var focusOption = _ref8.focusOption;\n      var labelKey = _ref8.labelKey;\n      var option = _ref8.option;\n      var selectValue = _ref8.selectValue;\n\n      var height = this._getOptionHeight({ option: option });\n\n      var className = ['VirtualizedSelectOption'];\n\n      if (option === focusedOption) {\n        className.push('VirtualizedSelectFocusedOption');\n      }\n\n      if (option.disabled) {\n        className.push('VirtualizedSelectDisabledOption');\n      }\n\n      var events = option.disabled ? {} : {\n        onClick: function onClick() {\n          return selectValue(option);\n        },\n        onMouseOver: function onMouseOver() {\n          return focusOption(option);\n        }\n      };\n\n      return _react2.default.createElement(\n        'div',\n        _extends({\n          className: className.join(' '),\n          style: { height: height }\n        }, events),\n        option[labelKey]\n      );\n    }\n  }]);\n\n  return VirtualizedSelect;\n}(_react.Component);\n\nVirtualizedSelect.propTypes = {\n  async: _react.PropTypes.bool,\n  maxHeight: _react.PropTypes.number.isRequired,\n  optionHeight: _react.PropTypes.oneOfType([_react.PropTypes.number, _react.PropTypes.func]).isRequired,\n  optionRenderer: _react.PropTypes.func,\n  selectComponent: _react.PropTypes.func\n};\nVirtualizedSelect.defaultProps = {\n  async: false,\n  maxHeight: 200,\n  optionHeight: 35\n};\nexports.default = VirtualizedSelect;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = undefined;\n\nvar _VirtualizedSelect = require('./VirtualizedSelect');\n\nvar _VirtualizedSelect2 = _interopRequireDefault(_VirtualizedSelect);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _VirtualizedSelect2.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * This HOC decorates a virtualized component and responds to arrow-key events by scrolling one row or column at a time.\n */\nvar ArrowKeyStepper = function (_Component) {\n  _inherits(ArrowKeyStepper, _Component);\n\n  function ArrowKeyStepper(props, context) {\n    _classCallCheck(this, ArrowKeyStepper);\n\n    var _this = _possibleConstructorReturn(this, (ArrowKeyStepper.__proto__ || Object.getPrototypeOf(ArrowKeyStepper)).call(this, props, context));\n\n    _this.state = {\n      scrollToColumn: 0,\n      scrollToRow: 0\n    };\n\n    _this._columnStartIndex = 0;\n    _this._columnStopIndex = 0;\n    _this._rowStartIndex = 0;\n    _this._rowStopIndex = 0;\n\n    _this._onKeyDown = _this._onKeyDown.bind(_this);\n    _this._onSectionRendered = _this._onSectionRendered.bind(_this);\n    return _this;\n  }\n\n  _createClass(ArrowKeyStepper, [{\n    key: 'render',\n    value: function render() {\n      var _props = this.props;\n      var className = _props.className;\n      var children = _props.children;\n      var _state = this.state;\n      var scrollToColumn = _state.scrollToColumn;\n      var scrollToRow = _state.scrollToRow;\n\n\n      return _react2.default.createElement(\n        'div',\n        {\n          className: className,\n          onKeyDown: this._onKeyDown\n        },\n        children({\n          onSectionRendered: this._onSectionRendered,\n          scrollToColumn: scrollToColumn,\n          scrollToRow: scrollToRow\n        })\n      );\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_onKeyDown',\n    value: function _onKeyDown(event) {\n      var _props2 = this.props;\n      var columnCount = _props2.columnCount;\n      var rowCount = _props2.rowCount;\n\n      // The above cases all prevent default event event behavior.\n      // This is to keep the grid from scrolling after the snap-to update.\n\n      switch (event.key) {\n        case 'ArrowDown':\n          event.preventDefault();\n          this.setState({\n            scrollToRow: Math.min(this._rowStopIndex + 1, rowCount - 1)\n          });\n          break;\n        case 'ArrowLeft':\n          event.preventDefault();\n          this.setState({\n            scrollToColumn: Math.max(this._columnStartIndex - 1, 0)\n          });\n          break;\n        case 'ArrowRight':\n          event.preventDefault();\n          this.setState({\n            scrollToColumn: Math.min(this._columnStopIndex + 1, columnCount - 1)\n          });\n          break;\n        case 'ArrowUp':\n          event.preventDefault();\n          this.setState({\n            scrollToRow: Math.max(this._rowStartIndex - 1, 0)\n          });\n          break;\n      }\n    }\n  }, {\n    key: '_onSectionRendered',\n    value: function _onSectionRendered(_ref) {\n      var columnStartIndex = _ref.columnStartIndex;\n      var columnStopIndex = _ref.columnStopIndex;\n      var rowStartIndex = _ref.rowStartIndex;\n      var rowStopIndex = _ref.rowStopIndex;\n\n      this._columnStartIndex = columnStartIndex;\n      this._columnStopIndex = columnStopIndex;\n      this._rowStartIndex = rowStartIndex;\n      this._rowStopIndex = rowStopIndex;\n    }\n  }]);\n\n  return ArrowKeyStepper;\n}(_react.Component);\n\nArrowKeyStepper.propTypes = {\n  children: _react.PropTypes.func.isRequired,\n  className: _react.PropTypes.string,\n  columnCount: _react.PropTypes.number.isRequired,\n  rowCount: _react.PropTypes.number.isRequired\n};\nexports.default = ArrowKeyStepper;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.ArrowKeyStepper = exports.default = undefined;\n\nvar _ArrowKeyStepper2 = require('./ArrowKeyStepper');\n\nvar _ArrowKeyStepper3 = _interopRequireDefault(_ArrowKeyStepper2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _ArrowKeyStepper3.default;\nexports.ArrowKeyStepper = _ArrowKeyStepper3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * Decorator component that automatically adjusts the width and height of a single child.\n * Child component should not be declared as a child but should rather be specified by a `ChildComponent` property.\n * All other properties will be passed through to the child component.\n */\nvar AutoSizer = function (_Component) {\n  _inherits(AutoSizer, _Component);\n\n  function AutoSizer(props) {\n    _classCallCheck(this, AutoSizer);\n\n    var _this = _possibleConstructorReturn(this, (AutoSizer.__proto__ || Object.getPrototypeOf(AutoSizer)).call(this, props));\n\n    _this.state = {\n      height: 0,\n      width: 0\n    };\n\n    _this._onResize = _this._onResize.bind(_this);\n    _this._onScroll = _this._onScroll.bind(_this);\n    _this._setRef = _this._setRef.bind(_this);\n    return _this;\n  }\n\n  _createClass(AutoSizer, [{\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      // Delay access of parentNode until mount.\n      // This handles edge-cases where the component has already been unmounted before its ref has been set,\n      // As well as libraries like react-lite which have a slightly different lifecycle.\n      this._parentNode = this._autoSizer.parentNode;\n\n      // Defer requiring resize handler in order to support server-side rendering.\n      // See issue #41\n      this._detectElementResize = require('../vendor/detectElementResize');\n      this._detectElementResize.addResizeListener(this._parentNode, this._onResize);\n\n      this._onResize();\n    }\n  }, {\n    key: 'componentWillUnmount',\n    value: function componentWillUnmount() {\n      if (this._detectElementResize) {\n        this._detectElementResize.removeResizeListener(this._parentNode, this._onResize);\n      }\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _props = this.props;\n      var children = _props.children;\n      var disableHeight = _props.disableHeight;\n      var disableWidth = _props.disableWidth;\n      var _state = this.state;\n      var height = _state.height;\n      var width = _state.width;\n\n      // Outer div should not force width/height since that may prevent containers from shrinking.\n      // Inner component should overflow and use calculated width/height.\n      // See issue #68 for more information.\n\n      var outerStyle = { overflow: 'visible' };\n\n      if (!disableHeight) {\n        outerStyle.height = 0;\n      }\n\n      if (!disableWidth) {\n        outerStyle.width = 0;\n      }\n\n      return _react2.default.createElement(\n        'div',\n        {\n          ref: this._setRef,\n          onScroll: this._onScroll,\n          style: outerStyle\n        },\n        children({ height: height, width: width })\n      );\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_onResize',\n    value: function _onResize() {\n      var onResize = this.props.onResize;\n\n      // Gaurd against AutoSizer component being removed from the DOM immediately after being added.\n      // This can result in invalid style values which can result in NaN values if we don't handle them.\n      // See issue #150 for more context.\n\n      var boundingRect = this._parentNode.getBoundingClientRect();\n      var height = boundingRect.height || 0;\n      var width = boundingRect.width || 0;\n\n      var style = getComputedStyle(this._parentNode);\n      var paddingLeft = parseInt(style.paddingLeft, 10) || 0;\n      var paddingRight = parseInt(style.paddingRight, 10) || 0;\n      var paddingTop = parseInt(style.paddingTop, 10) || 0;\n      var paddingBottom = parseInt(style.paddingBottom, 10) || 0;\n\n      this.setState({\n        height: height - paddingTop - paddingBottom,\n        width: width - paddingLeft - paddingRight\n      });\n\n      onResize({ height: height, width: width });\n    }\n  }, {\n    key: '_onScroll',\n    value: function _onScroll(event) {\n      // Prevent detectElementResize library from being triggered by this scroll event.\n      event.stopPropagation();\n    }\n  }, {\n    key: '_setRef',\n    value: function _setRef(autoSizer) {\n      this._autoSizer = autoSizer;\n    }\n  }]);\n\n  return AutoSizer;\n}(_react.Component);\n\nAutoSizer.propTypes = {\n  /**\n   * Function respondible for rendering children.\n   * This function should implement the following signature:\n   * ({ height, width }) => PropTypes.element\n   */\n  children: _react.PropTypes.func.isRequired,\n\n  /** Disable dynamic :height property */\n  disableHeight: _react.PropTypes.bool,\n\n  /** Disable dynamic :width property */\n  disableWidth: _react.PropTypes.bool,\n\n  /** Callback to be invoked on-resize: ({ height, width }) */\n  onResize: _react.PropTypes.func.isRequired\n};\nAutoSizer.defaultProps = {\n  onResize: function onResize() {}\n};\nexports.default = AutoSizer;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.AutoSizer = exports.default = undefined;\n\nvar _AutoSizer2 = require('./AutoSizer');\n\nvar _AutoSizer3 = _interopRequireDefault(_AutoSizer2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _AutoSizer3.default;\nexports.AutoSizer = _AutoSizer3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nvar _reactDom = require('react-dom');\n\nvar _reactDom2 = _interopRequireDefault(_reactDom);\n\nvar _defaultCellSizeCache = require('./defaultCellSizeCache');\n\nvar _defaultCellSizeCache2 = _interopRequireDefault(_defaultCellSizeCache);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * Measures a Grid cell's contents by rendering them in a way that is not visible to the user.\n * Either a fixed width or height may be provided if it is desirable to measure only in one direction.\n */\nvar CellMeasurer = function (_Component) {\n  _inherits(CellMeasurer, _Component);\n\n  function CellMeasurer(props, state) {\n    _classCallCheck(this, CellMeasurer);\n\n    var _this = _possibleConstructorReturn(this, (CellMeasurer.__proto__ || Object.getPrototypeOf(CellMeasurer)).call(this, props, state));\n\n    _this._cellSizeCache = props.cellSizeCache || new _defaultCellSizeCache2.default();\n\n    _this.getColumnWidth = _this.getColumnWidth.bind(_this);\n    _this.getRowHeight = _this.getRowHeight.bind(_this);\n    _this.resetMeasurements = _this.resetMeasurements.bind(_this);\n    _this.resetMeasurementForColumn = _this.resetMeasurementForColumn.bind(_this);\n    _this.resetMeasurementForRow = _this.resetMeasurementForRow.bind(_this);\n    return _this;\n  }\n\n  _createClass(CellMeasurer, [{\n    key: 'getColumnWidth',\n    value: function getColumnWidth(_ref) {\n      var index = _ref.index;\n\n      if (this._cellSizeCache.hasColumnWidth(index)) {\n        return this._cellSizeCache.getColumnWidth(index);\n      }\n\n      var rowCount = this.props.rowCount;\n\n\n      var maxWidth = 0;\n\n      for (var rowIndex = 0; rowIndex < rowCount; rowIndex++) {\n        var _measureCell2 = this._measureCell({\n          clientWidth: true,\n          columnIndex: index,\n          rowIndex: rowIndex\n        });\n\n        var width = _measureCell2.width;\n\n\n        maxWidth = Math.max(maxWidth, width);\n      }\n\n      this._cellSizeCache.setColumnWidth(index, maxWidth);\n\n      return maxWidth;\n    }\n  }, {\n    key: 'getRowHeight',\n    value: function getRowHeight(_ref2) {\n      var index = _ref2.index;\n\n      if (this._cellSizeCache.hasRowHeight(index)) {\n        return this._cellSizeCache.getRowHeight(index);\n      }\n\n      var columnCount = this.props.columnCount;\n\n\n      var maxHeight = 0;\n\n      for (var columnIndex = 0; columnIndex < columnCount; columnIndex++) {\n        var _measureCell3 = this._measureCell({\n          clientHeight: true,\n          columnIndex: columnIndex,\n          rowIndex: index\n        });\n\n        var height = _measureCell3.height;\n\n\n        maxHeight = Math.max(maxHeight, height);\n      }\n\n      this._cellSizeCache.setRowHeight(index, maxHeight);\n\n      return maxHeight;\n    }\n  }, {\n    key: 'resetMeasurementForColumn',\n    value: function resetMeasurementForColumn(columnIndex) {\n      this._cellSizeCache.clearColumnWidth(columnIndex);\n    }\n  }, {\n    key: 'resetMeasurementForRow',\n    value: function resetMeasurementForRow(rowIndex) {\n      this._cellSizeCache.clearRowHeight(rowIndex);\n    }\n  }, {\n    key: 'resetMeasurements',\n    value: function resetMeasurements() {\n      this._cellSizeCache.clearAllColumnWidths();\n      this._cellSizeCache.clearAllRowHeights();\n    }\n  }, {\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      this._renderAndMount();\n    }\n  }, {\n    key: 'componentWillReceiveProps',\n    value: function componentWillReceiveProps(nextProps) {\n      var cellSizeCache = this.props.cellSizeCache;\n\n\n      if (cellSizeCache !== nextProps.cellSizeCache) {\n        this._cellSizeCache = nextProps.cellSizeCache;\n      }\n\n      this._updateDivDimensions(nextProps);\n    }\n  }, {\n    key: 'componentWillUnmount',\n    value: function componentWillUnmount() {\n      this._unmountContainer();\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var children = this.props.children;\n\n\n      return children({\n        getColumnWidth: this.getColumnWidth,\n        getRowHeight: this.getRowHeight,\n        resetMeasurements: this.resetMeasurements,\n        resetMeasurementForColumn: this.resetMeasurementForColumn,\n        resetMeasurementForRow: this.resetMeasurementForRow\n      });\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_getContainerNode',\n    value: function _getContainerNode(props) {\n      var container = props.container;\n\n\n      if (container) {\n        return _reactDom2.default.findDOMNode(typeof container === 'function' ? container() : container);\n      } else {\n        return document.body;\n      }\n    }\n  }, {\n    key: '_measureCell',\n    value: function _measureCell(_ref3) {\n      var _ref3$clientHeight = _ref3.clientHeight;\n      var clientHeight = _ref3$clientHeight === undefined ? false : _ref3$clientHeight;\n      var _ref3$clientWidth = _ref3.clientWidth;\n      var clientWidth = _ref3$clientWidth === undefined ? true : _ref3$clientWidth;\n      var columnIndex = _ref3.columnIndex;\n      var rowIndex = _ref3.rowIndex;\n      var cellRenderer = this.props.cellRenderer;\n\n\n      var rendered = cellRenderer({\n        columnIndex: columnIndex,\n        rowIndex: rowIndex\n      });\n\n      // Handle edge case where this method is called before the CellMeasurer has completed its initial render (and mounted).\n      this._renderAndMount();\n\n      // @TODO Keep an eye on this for future React updates as the interface may change:\n      // https://twitter.com/soprano/status/737316379712331776\n      _reactDom2.default.unstable_renderSubtreeIntoContainer(this, rendered, this._div);\n\n      var measurements = {\n        height: clientHeight && this._div.clientHeight,\n        width: clientWidth && this._div.clientWidth\n      };\n\n      _reactDom2.default.unmountComponentAtNode(this._div);\n\n      return measurements;\n    }\n  }, {\n    key: '_renderAndMount',\n    value: function _renderAndMount() {\n      if (!this._div) {\n        this._div = document.createElement('div');\n        this._div.style.display = 'inline-block';\n        this._div.style.position = 'absolute';\n        this._div.style.visibility = 'hidden';\n        this._div.style.zIndex = -1;\n\n        this._updateDivDimensions(this.props);\n\n        this._containerNode = this._getContainerNode(this.props);\n        this._containerNode.appendChild(this._div);\n      }\n    }\n  }, {\n    key: '_unmountContainer',\n    value: function _unmountContainer() {\n      if (this._div) {\n        this._containerNode.removeChild(this._div);\n\n        this._div = null;\n      }\n\n      this._containerNode = null;\n    }\n  }, {\n    key: '_updateDivDimensions',\n    value: function _updateDivDimensions(props) {\n      var height = props.height;\n      var width = props.width;\n\n\n      if (height && height !== this._divHeight) {\n        this._divHeight = height;\n        this._div.style.height = height + 'px';\n      }\n\n      if (width && width !== this._divWidth) {\n        this._divWidth = width;\n        this._div.style.width = width + 'px';\n      }\n    }\n  }]);\n\n  return CellMeasurer;\n}(_react.Component);\n\nCellMeasurer.propTypes = {\n  /**\n   * Renders a cell given its indices.\n   * Should implement the following interface: ({ columnIndex: number, rowIndex: number }): PropTypes.node\n   */\n  cellRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Optional, custom caching strategy for cell sizes.\n   */\n  cellSizeCache: _react.PropTypes.object,\n\n  /**\n   * Function respondible for rendering a virtualized component.\n   * This function should implement the following signature:\n   * ({ getColumnWidth, getRowHeight, resetMeasurements }) => PropTypes.element\n   */\n  children: _react.PropTypes.func.isRequired,\n\n  /**\n   * Number of columns in grid.\n   */\n  columnCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * A Node, Component instance, or function that returns either.\n   * If this property is not specified the document body will be used.\n   */\n  container: _react2.default.PropTypes.oneOfType([_react2.default.PropTypes.func, _react2.default.PropTypes.node]),\n\n  /**\n   * Assign a fixed :height in order to measure dynamic text :width only.\n   */\n  height: _react.PropTypes.number,\n\n  /**\n   * Number of rows in grid.\n   */\n  rowCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Assign a fixed :width in order to measure dynamic text :height only.\n   */\n  width: _react.PropTypes.number\n};\nexports.default = CellMeasurer;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\n * Default CellMeasurer `cellSizeCache` implementation.\n * Permanently caches all cell sizes (identified by column and row index) unless explicitly cleared.\n * Can be configured to handle uniform cell widths and/or heights as a way of optimizing certain use cases.\n */\nvar CellSizeCache = function () {\n  function CellSizeCache() {\n    var _ref = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n    var _ref$uniformRowHeight = _ref.uniformRowHeight;\n    var uniformRowHeight = _ref$uniformRowHeight === undefined ? false : _ref$uniformRowHeight;\n    var _ref$uniformColumnWid = _ref.uniformColumnWidth;\n    var uniformColumnWidth = _ref$uniformColumnWid === undefined ? false : _ref$uniformColumnWid;\n\n    _classCallCheck(this, CellSizeCache);\n\n    this._uniformRowHeight = uniformRowHeight;\n    this._uniformColumnWidth = uniformColumnWidth;\n\n    this._cachedColumnWidths = {};\n    this._cachedRowHeights = {};\n  }\n\n  _createClass(CellSizeCache, [{\n    key: \"clearAllColumnWidths\",\n    value: function clearAllColumnWidths() {\n      this._cachedColumnWidth = undefined;\n      this._cachedColumnWidths = {};\n    }\n  }, {\n    key: \"clearAllRowHeights\",\n    value: function clearAllRowHeights() {\n      this._cachedRowHeight = undefined;\n      this._cachedRowHeights = {};\n    }\n  }, {\n    key: \"clearColumnWidth\",\n    value: function clearColumnWidth(index) {\n      this._cachedColumnWidth = undefined;\n\n      delete this._cachedColumnWidths[index];\n    }\n  }, {\n    key: \"clearRowHeight\",\n    value: function clearRowHeight(index) {\n      this._cachedRowHeight = undefined;\n\n      delete this._cachedRowHeights[index];\n    }\n  }, {\n    key: \"getColumnWidth\",\n    value: function getColumnWidth(index) {\n      return this._uniformColumnWidth ? this._cachedColumnWidth : this._cachedColumnWidths[index];\n    }\n  }, {\n    key: \"getRowHeight\",\n    value: function getRowHeight(index) {\n      return this._uniformRowHeight ? this._cachedRowHeight : this._cachedRowHeights[index];\n    }\n  }, {\n    key: \"hasColumnWidth\",\n    value: function hasColumnWidth(index) {\n      return this._uniformColumnWidth ? !!this._cachedColumnWidth : !!this._cachedColumnWidths[index];\n    }\n  }, {\n    key: \"hasRowHeight\",\n    value: function hasRowHeight(index) {\n      return this._uniformRowHeight ? !!this._cachedRowHeight : !!this._cachedRowHeights[index];\n    }\n  }, {\n    key: \"setColumnWidth\",\n    value: function setColumnWidth(index, width) {\n      this._cachedColumnWidth = width;\n      this._cachedColumnWidths[index] = width;\n    }\n  }, {\n    key: \"setRowHeight\",\n    value: function setRowHeight(index, height) {\n      this._cachedRowHeight = height;\n      this._cachedRowHeights[index] = height;\n    }\n  }]);\n\n  return CellSizeCache;\n}();\n\nexports.default = CellSizeCache;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.defaultCellSizeCache = exports.CellMeasurer = exports.default = undefined;\n\nvar _CellMeasurer2 = require('./CellMeasurer');\n\nvar _CellMeasurer3 = _interopRequireDefault(_CellMeasurer2);\n\nvar _defaultCellSizeCache2 = require('./defaultCellSizeCache');\n\nvar _defaultCellSizeCache3 = _interopRequireDefault(_defaultCellSizeCache2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _CellMeasurer3.default;\nexports.CellMeasurer = _CellMeasurer3.default;\nexports.defaultCellSizeCache = _defaultCellSizeCache3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _CollectionView = require('./CollectionView');\n\nvar _CollectionView2 = _interopRequireDefault(_CollectionView);\n\nvar _calculateSizeAndPositionData2 = require('./utils/calculateSizeAndPositionData');\n\nvar _calculateSizeAndPositionData3 = _interopRequireDefault(_calculateSizeAndPositionData2);\n\nvar _getUpdatedOffsetForIndex = require('../utils/getUpdatedOffsetForIndex');\n\nvar _getUpdatedOffsetForIndex2 = _interopRequireDefault(_getUpdatedOffsetForIndex);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * Renders scattered or non-linear data.\n * Unlike Grid, which renders checkerboard data, Collection can render arbitrarily positioned- even overlapping- data.\n */\nvar Collection = function (_Component) {\n  _inherits(Collection, _Component);\n\n  function Collection(props, context) {\n    _classCallCheck(this, Collection);\n\n    var _this = _possibleConstructorReturn(this, (Collection.__proto__ || Object.getPrototypeOf(Collection)).call(this, props, context));\n\n    _this._cellMetadata = [];\n    _this._lastRenderedCellIndices = [];\n\n    // Cell cache during scroll (for perforamnce)\n    _this._cellCache = [];\n\n    _this._isScrollingChange = _this._isScrollingChange.bind(_this);\n    return _this;\n  }\n\n  /** See Collection#recomputeCellSizesAndPositions */\n\n\n  _createClass(Collection, [{\n    key: 'recomputeCellSizesAndPositions',\n    value: function recomputeCellSizesAndPositions() {\n      this._cellCache = [];\n      this._collectionView.recomputeCellSizesAndPositions();\n    }\n\n    /** React lifecycle methods */\n\n  }, {\n    key: 'render',\n    value: function render() {\n      var _this2 = this;\n\n      var props = _objectWithoutProperties(this.props, []);\n\n      return _react2.default.createElement(_CollectionView2.default, _extends({\n        cellLayoutManager: this,\n        isScrollingChange: this._isScrollingChange,\n        ref: function ref(_ref) {\n          _this2._collectionView = _ref;\n        }\n      }, props));\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n\n    /** CellLayoutManager interface */\n\n  }, {\n    key: 'calculateSizeAndPositionData',\n    value: function calculateSizeAndPositionData() {\n      var _props = this.props;\n      var cellCount = _props.cellCount;\n      var cellSizeAndPositionGetter = _props.cellSizeAndPositionGetter;\n      var sectionSize = _props.sectionSize;\n\n\n      var data = (0, _calculateSizeAndPositionData3.default)({\n        cellCount: cellCount,\n        cellSizeAndPositionGetter: cellSizeAndPositionGetter,\n        sectionSize: sectionSize\n      });\n\n      this._cellMetadata = data.cellMetadata;\n      this._sectionManager = data.sectionManager;\n      this._height = data.height;\n      this._width = data.width;\n    }\n\n    /**\n     * Returns the most recently rendered set of cell indices.\n     */\n\n  }, {\n    key: 'getLastRenderedIndices',\n    value: function getLastRenderedIndices() {\n      return this._lastRenderedCellIndices;\n    }\n\n    /**\n     * Calculates the minimum amount of change from the current scroll position to ensure the specified cell is (fully) visible.\n     */\n\n  }, {\n    key: 'getScrollPositionForCell',\n    value: function getScrollPositionForCell(_ref2) {\n      var align = _ref2.align;\n      var cellIndex = _ref2.cellIndex;\n      var height = _ref2.height;\n      var scrollLeft = _ref2.scrollLeft;\n      var scrollTop = _ref2.scrollTop;\n      var width = _ref2.width;\n      var cellCount = this.props.cellCount;\n\n\n      if (cellIndex >= 0 && cellIndex < cellCount) {\n        var cellMetadata = this._cellMetadata[cellIndex];\n\n        scrollLeft = (0, _getUpdatedOffsetForIndex2.default)({\n          align: align,\n          cellOffset: cellMetadata.x,\n          cellSize: cellMetadata.width,\n          containerSize: width,\n          currentOffset: scrollLeft,\n          targetIndex: cellIndex\n        });\n\n        scrollTop = (0, _getUpdatedOffsetForIndex2.default)({\n          align: align,\n          cellOffset: cellMetadata.y,\n          cellSize: cellMetadata.height,\n          containerSize: height,\n          currentOffset: scrollTop,\n          targetIndex: cellIndex\n        });\n      }\n\n      return {\n        scrollLeft: scrollLeft,\n        scrollTop: scrollTop\n      };\n    }\n  }, {\n    key: 'getTotalSize',\n    value: function getTotalSize() {\n      return {\n        height: this._height,\n        width: this._width\n      };\n    }\n  }, {\n    key: 'cellRenderers',\n    value: function cellRenderers(_ref3) {\n      var _this3 = this;\n\n      var height = _ref3.height;\n      var isScrolling = _ref3.isScrolling;\n      var width = _ref3.width;\n      var x = _ref3.x;\n      var y = _ref3.y;\n      var _props2 = this.props;\n      var cellGroupRenderer = _props2.cellGroupRenderer;\n      var cellRenderer = _props2.cellRenderer;\n\n      // Store for later calls to getLastRenderedIndices()\n\n      this._lastRenderedCellIndices = this._sectionManager.getCellIndices({\n        height: height,\n        width: width,\n        x: x,\n        y: y\n      });\n\n      return cellGroupRenderer({\n        cellCache: this._cellCache,\n        cellRenderer: cellRenderer,\n        cellSizeAndPositionGetter: function cellSizeAndPositionGetter(_ref4) {\n          var index = _ref4.index;\n          return _this3._sectionManager.getCellMetadata({ index: index });\n        },\n        indices: this._lastRenderedCellIndices,\n        isScrolling: isScrolling\n      });\n    }\n  }, {\n    key: '_isScrollingChange',\n    value: function _isScrollingChange(isScrolling) {\n      if (!isScrolling) {\n        this._cellCache = [];\n      }\n    }\n  }]);\n\n  return Collection;\n}(_react.Component);\n\nCollection.propTypes = {\n  'aria-label': _react.PropTypes.string,\n\n  /**\n   * Number of cells in Collection.\n   */\n  cellCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Responsible for rendering a group of cells given their indices.\n   * Should implement the following interface: ({\n   *   cellSizeAndPositionGetter:Function,\n   *   indices: Array<number>,\n   *   cellRenderer: Function\n   * }): Array<PropTypes.node>\n   */\n  cellGroupRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Responsible for rendering a cell given an row and column index.\n   * Should implement the following interface: ({ index: number }): PropTypes.element\n   */\n  cellRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Callback responsible for returning size and offset/position information for a given cell (index).\n   * ({ index: number }): { height: number, width: number, x: number, y: number }\n   */\n  cellSizeAndPositionGetter: _react.PropTypes.func.isRequired,\n\n  /**\n   * Optionally override the size of the sections a Collection's cells are split into.\n   */\n  sectionSize: _react.PropTypes.number\n};\nCollection.defaultProps = {\n  'aria-label': 'grid',\n  cellGroupRenderer: defaultCellGroupRenderer\n};\nexports.default = Collection;\n\n\nfunction defaultCellGroupRenderer(_ref5) {\n  var cellCache = _ref5.cellCache;\n  var cellRenderer = _ref5.cellRenderer;\n  var cellSizeAndPositionGetter = _ref5.cellSizeAndPositionGetter;\n  var indices = _ref5.indices;\n  var isScrolling = _ref5.isScrolling;\n\n  return indices.map(function (index) {\n    var cellMetadata = cellSizeAndPositionGetter({ index: index });\n\n    // Avoid re-creating cells while scrolling.\n    // This can lead to the same cell being created many times and can cause performance issues for \"heavy\" cells.\n    // If a scroll is in progress- cache and reuse cells.\n    // This cache will be thrown away once scrolling complets.\n    var renderedCell = void 0;\n\n    if (isScrolling) {\n      if (!(index in cellCache)) {\n        cellCache[index] = cellRenderer({\n          index: index,\n          isScrolling: isScrolling\n        });\n      }\n\n      renderedCell = cellCache[index];\n    } else {\n      renderedCell = cellRenderer({\n        index: index,\n        isScrolling: isScrolling\n      });\n    }\n\n    if (renderedCell == null || renderedCell === false) {\n      return null;\n    }\n\n    return _react2.default.createElement(\n      'div',\n      {\n        className: 'Collection__cell',\n        key: index,\n        style: {\n          height: cellMetadata.height,\n          left: cellMetadata.x,\n          top: cellMetadata.y,\n          width: cellMetadata.width\n        }\n      },\n      renderedCell\n    );\n  }).filter(function (renderedCell) {\n    return !!renderedCell;\n  });\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _classnames = require('classnames');\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nvar _createCallbackMemoizer = require('../utils/createCallbackMemoizer');\n\nvar _createCallbackMemoizer2 = _interopRequireDefault(_createCallbackMemoizer);\n\nvar _scrollbarSize = require('dom-helpers/util/scrollbarSize');\n\nvar _scrollbarSize2 = _interopRequireDefault(_scrollbarSize);\n\nvar _raf = require('raf');\n\nvar _raf2 = _interopRequireDefault(_raf);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n// @TODO It would be nice to refactor Grid to use this code as well.\n\n/**\n * Specifies the number of miliseconds during which to disable pointer events while a scroll is in progress.\n * This improves performance and makes scrolling smoother.\n */\nvar IS_SCROLLING_TIMEOUT = 150;\n\n/**\n * Controls whether the Grid updates the DOM element's scrollLeft/scrollTop based on the current state or just observes it.\n * This prevents Grid from interrupting mouse-wheel animations (see issue #2).\n */\nvar SCROLL_POSITION_CHANGE_REASONS = {\n  OBSERVED: 'observed',\n  REQUESTED: 'requested'\n};\n\n/**\n * Monitors changes in properties (eg. cellCount) and state (eg. scroll offsets) to determine when rendering needs to occur.\n * This component does not render any visible content itself; it defers to the specified :cellLayoutManager.\n */\n\nvar CollectionView = function (_Component) {\n  _inherits(CollectionView, _Component);\n\n  function CollectionView(props, context) {\n    _classCallCheck(this, CollectionView);\n\n    var _this = _possibleConstructorReturn(this, (CollectionView.__proto__ || Object.getPrototypeOf(CollectionView)).call(this, props, context));\n\n    _this.state = {\n      calculateSizeAndPositionDataOnNextUpdate: false,\n      isScrolling: false,\n      scrollLeft: 0,\n      scrollTop: 0\n    };\n\n    // Invokes callbacks only when their values have changed.\n    _this._onSectionRenderedMemoizer = (0, _createCallbackMemoizer2.default)();\n    _this._onScrollMemoizer = (0, _createCallbackMemoizer2.default)(false);\n\n    // Bind functions to instance so they don't lose context when passed around.\n    _this._invokeOnSectionRenderedHelper = _this._invokeOnSectionRenderedHelper.bind(_this);\n    _this._onScroll = _this._onScroll.bind(_this);\n    _this._updateScrollPositionForScrollToCell = _this._updateScrollPositionForScrollToCell.bind(_this);\n    return _this;\n  }\n\n  /**\n   * Forced recompute of cell sizes and positions.\n   * This function should be called if cell sizes have changed but nothing else has.\n   * Since cell positions are calculated by callbacks, the collection view has no way of detecting when the underlying data has changed.\n   */\n\n\n  _createClass(CollectionView, [{\n    key: 'recomputeCellSizesAndPositions',\n    value: function recomputeCellSizesAndPositions() {\n      this.setState({\n        calculateSizeAndPositionDataOnNextUpdate: true\n      });\n    }\n\n    /* ---------------------------- Component lifecycle methods ---------------------------- */\n\n  }, {\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      var _props = this.props;\n      var cellLayoutManager = _props.cellLayoutManager;\n      var scrollLeft = _props.scrollLeft;\n      var scrollToCell = _props.scrollToCell;\n      var scrollTop = _props.scrollTop;\n\n      // If this component was first rendered server-side, scrollbar size will be undefined.\n      // In that event we need to remeasure.\n\n      if (!this._scrollbarSizeMeasured) {\n        this._scrollbarSize = (0, _scrollbarSize2.default)();\n        this._scrollbarSizeMeasured = true;\n        this.setState({});\n      }\n\n      if (scrollToCell >= 0) {\n        this._updateScrollPositionForScrollToCell();\n      } else if (scrollLeft >= 0 || scrollTop >= 0) {\n        this._setScrollPosition({ scrollLeft: scrollLeft, scrollTop: scrollTop });\n      }\n\n      // Update onSectionRendered callback.\n      this._invokeOnSectionRenderedHelper();\n\n      var _cellLayoutManager$ge = cellLayoutManager.getTotalSize();\n\n      var totalHeight = _cellLayoutManager$ge.height;\n      var totalWidth = _cellLayoutManager$ge.width;\n\n      // Initialize onScroll callback.\n\n      this._invokeOnScrollMemoizer({\n        scrollLeft: scrollLeft || 0,\n        scrollTop: scrollTop || 0,\n        totalHeight: totalHeight,\n        totalWidth: totalWidth\n      });\n    }\n  }, {\n    key: 'componentDidUpdate',\n    value: function componentDidUpdate(prevProps, prevState) {\n      var _props2 = this.props;\n      var height = _props2.height;\n      var scrollToCell = _props2.scrollToCell;\n      var width = _props2.width;\n      var _state = this.state;\n      var scrollLeft = _state.scrollLeft;\n      var scrollPositionChangeReason = _state.scrollPositionChangeReason;\n      var scrollToAlignment = _state.scrollToAlignment;\n      var scrollTop = _state.scrollTop;\n\n      // Make sure requested changes to :scrollLeft or :scrollTop get applied.\n      // Assigning to scrollLeft/scrollTop tells the browser to interrupt any running scroll animations,\n      // And to discard any pending async changes to the scroll position that may have happened in the meantime (e.g. on a separate scrolling thread).\n      // So we only set these when we require an adjustment of the scroll position.\n      // See issue #2 for more information.\n\n      if (scrollPositionChangeReason === SCROLL_POSITION_CHANGE_REASONS.REQUESTED) {\n        if (scrollLeft >= 0 && scrollLeft !== prevState.scrollLeft && scrollLeft !== this._scrollingContainer.scrollLeft) {\n          this._scrollingContainer.scrollLeft = scrollLeft;\n        }\n        if (scrollTop >= 0 && scrollTop !== prevState.scrollTop && scrollTop !== this._scrollingContainer.scrollTop) {\n          this._scrollingContainer.scrollTop = scrollTop;\n        }\n      }\n\n      // Update scroll offsets if the current :scrollToCell values requires it\n      if (height !== prevProps.height || scrollToAlignment !== prevProps.scrollToAlignment || scrollToCell !== prevProps.scrollToCell || width !== prevProps.width) {\n        this._updateScrollPositionForScrollToCell();\n      }\n\n      // Update onRowsRendered callback if start/stop indices have changed\n      this._invokeOnSectionRenderedHelper();\n    }\n  }, {\n    key: 'componentWillMount',\n    value: function componentWillMount() {\n      var cellLayoutManager = this.props.cellLayoutManager;\n\n\n      cellLayoutManager.calculateSizeAndPositionData();\n\n      // If this component is being rendered server-side, getScrollbarSize() will return undefined.\n      // We handle this case in componentDidMount()\n      this._scrollbarSize = (0, _scrollbarSize2.default)();\n      if (this._scrollbarSize === undefined) {\n        this._scrollbarSizeMeasured = false;\n        this._scrollbarSize = 0;\n      } else {\n        this._scrollbarSizeMeasured = true;\n      }\n    }\n  }, {\n    key: 'componentWillUnmount',\n    value: function componentWillUnmount() {\n      if (this._disablePointerEventsTimeoutId) {\n        clearTimeout(this._disablePointerEventsTimeoutId);\n      }\n\n      if (this._setNextStateAnimationFrameId) {\n        _raf2.default.cancel(this._setNextStateAnimationFrameId);\n      }\n    }\n\n    /**\n     * @private\n     * This method updates scrollLeft/scrollTop in state for the following conditions:\n     * 1) Empty content (0 rows or columns)\n     * 2) New scroll props overriding the current state\n     * 3) Cells-count or cells-size has changed, making previous scroll offsets invalid\n     */\n\n  }, {\n    key: 'componentWillUpdate',\n    value: function componentWillUpdate(nextProps, nextState) {\n      if (nextProps.cellCount === 0 && (nextState.scrollLeft !== 0 || nextState.scrollTop !== 0)) {\n        this._setScrollPosition({\n          scrollLeft: 0,\n          scrollTop: 0\n        });\n      } else if (nextProps.scrollLeft !== this.props.scrollLeft || nextProps.scrollTop !== this.props.scrollTop) {\n        this._setScrollPosition({\n          scrollLeft: nextProps.scrollLeft,\n          scrollTop: nextProps.scrollTop\n        });\n      }\n\n      if (nextProps.cellCount !== this.props.cellCount || nextProps.cellLayoutManager !== this.props.cellLayoutManager || nextState.calculateSizeAndPositionDataOnNextUpdate) {\n        nextProps.cellLayoutManager.calculateSizeAndPositionData();\n      }\n\n      if (nextState.calculateSizeAndPositionDataOnNextUpdate) {\n        this.setState({\n          calculateSizeAndPositionDataOnNextUpdate: false\n        });\n      }\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _this2 = this;\n\n      var _props3 = this.props;\n      var autoHeight = _props3.autoHeight;\n      var cellCount = _props3.cellCount;\n      var cellLayoutManager = _props3.cellLayoutManager;\n      var className = _props3.className;\n      var height = _props3.height;\n      var horizontalOverscanSize = _props3.horizontalOverscanSize;\n      var noContentRenderer = _props3.noContentRenderer;\n      var style = _props3.style;\n      var verticalOverscanSize = _props3.verticalOverscanSize;\n      var width = _props3.width;\n      var _state2 = this.state;\n      var isScrolling = _state2.isScrolling;\n      var scrollLeft = _state2.scrollLeft;\n      var scrollTop = _state2.scrollTop;\n\n      var _cellLayoutManager$ge2 = cellLayoutManager.getTotalSize();\n\n      var totalHeight = _cellLayoutManager$ge2.height;\n      var totalWidth = _cellLayoutManager$ge2.width;\n\n      // Safely expand the rendered area by the specified overscan amount\n\n      var left = Math.max(0, scrollLeft - horizontalOverscanSize);\n      var top = Math.max(0, scrollTop - verticalOverscanSize);\n      var right = Math.min(totalWidth, scrollLeft + width + horizontalOverscanSize);\n      var bottom = Math.min(totalHeight, scrollTop + height + verticalOverscanSize);\n\n      var childrenToDisplay = height > 0 && width > 0 ? cellLayoutManager.cellRenderers({\n        height: bottom - top,\n        isScrolling: isScrolling,\n        width: right - left,\n        x: left,\n        y: top\n      }) : [];\n\n      var collectionStyle = {\n        height: autoHeight ? 'auto' : height,\n        width: width\n      };\n\n      // Force browser to hide scrollbars when we know they aren't necessary.\n      // Otherwise once scrollbars appear they may not disappear again.\n      // For more info see issue #116\n      var verticalScrollBarSize = totalHeight > height ? this._scrollbarSize : 0;\n      var horizontalScrollBarSize = totalWidth > width ? this._scrollbarSize : 0;\n      if (totalWidth + verticalScrollBarSize <= width) {\n        collectionStyle.overflowX = 'hidden';\n      }\n      if (totalHeight + horizontalScrollBarSize <= height) {\n        collectionStyle.overflowY = 'hidden';\n      }\n\n      return _react2.default.createElement(\n        'div',\n        {\n          ref: function ref(_ref) {\n            _this2._scrollingContainer = _ref;\n          },\n          'aria-label': this.props['aria-label'],\n          className: (0, _classnames2.default)('Collection', className),\n          onScroll: this._onScroll,\n          role: 'grid',\n          style: _extends({}, collectionStyle, style),\n          tabIndex: 0\n        },\n        cellCount > 0 && _react2.default.createElement(\n          'div',\n          {\n            className: 'Collection__innerScrollContainer',\n            style: {\n              height: totalHeight,\n              maxHeight: totalHeight,\n              maxWidth: totalWidth,\n              pointerEvents: isScrolling ? 'none' : '',\n              width: totalWidth\n            }\n          },\n          childrenToDisplay\n        ),\n        cellCount === 0 && noContentRenderer()\n      );\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n\n    /* ---------------------------- Helper methods ---------------------------- */\n\n    /**\n     * Sets an :isScrolling flag for a small window of time.\n     * This flag is used to disable pointer events on the scrollable portion of the Collection.\n     * This prevents jerky/stuttery mouse-wheel scrolling.\n     */\n\n  }, {\n    key: '_enablePointerEventsAfterDelay',\n    value: function _enablePointerEventsAfterDelay() {\n      var _this3 = this;\n\n      if (this._disablePointerEventsTimeoutId) {\n        clearTimeout(this._disablePointerEventsTimeoutId);\n      }\n\n      this._disablePointerEventsTimeoutId = setTimeout(function () {\n        var isScrollingChange = _this3.props.isScrollingChange;\n\n\n        isScrollingChange(false);\n\n        _this3._disablePointerEventsTimeoutId = null;\n        _this3.setState({\n          isScrolling: false\n        });\n      }, IS_SCROLLING_TIMEOUT);\n    }\n  }, {\n    key: '_invokeOnSectionRenderedHelper',\n    value: function _invokeOnSectionRenderedHelper() {\n      var _props4 = this.props;\n      var cellLayoutManager = _props4.cellLayoutManager;\n      var onSectionRendered = _props4.onSectionRendered;\n\n\n      this._onSectionRenderedMemoizer({\n        callback: onSectionRendered,\n        indices: {\n          indices: cellLayoutManager.getLastRenderedIndices()\n        }\n      });\n    }\n  }, {\n    key: '_invokeOnScrollMemoizer',\n    value: function _invokeOnScrollMemoizer(_ref2) {\n      var _this4 = this;\n\n      var scrollLeft = _ref2.scrollLeft;\n      var scrollTop = _ref2.scrollTop;\n      var totalHeight = _ref2.totalHeight;\n      var totalWidth = _ref2.totalWidth;\n\n      this._onScrollMemoizer({\n        callback: function callback(_ref3) {\n          var scrollLeft = _ref3.scrollLeft;\n          var scrollTop = _ref3.scrollTop;\n          var _props5 = _this4.props;\n          var height = _props5.height;\n          var onScroll = _props5.onScroll;\n          var width = _props5.width;\n\n\n          onScroll({\n            clientHeight: height,\n            clientWidth: width,\n            scrollHeight: totalHeight,\n            scrollLeft: scrollLeft,\n            scrollTop: scrollTop,\n            scrollWidth: totalWidth\n          });\n        },\n        indices: {\n          scrollLeft: scrollLeft,\n          scrollTop: scrollTop\n        }\n      });\n    }\n\n    /**\n     * Updates the state during the next animation frame.\n     * Use this method to avoid multiple renders in a small span of time.\n     * This helps performance for bursty events (like onScroll).\n     */\n\n  }, {\n    key: '_setNextState',\n    value: function _setNextState(state) {\n      var _this5 = this;\n\n      if (this._setNextStateAnimationFrameId) {\n        _raf2.default.cancel(this._setNextStateAnimationFrameId);\n      }\n\n      this._setNextStateAnimationFrameId = (0, _raf2.default)(function () {\n        _this5._setNextStateAnimationFrameId = null;\n        _this5.setState(state);\n      });\n    }\n  }, {\n    key: '_setScrollPosition',\n    value: function _setScrollPosition(_ref4) {\n      var scrollLeft = _ref4.scrollLeft;\n      var scrollTop = _ref4.scrollTop;\n\n      var newState = {\n        scrollPositionChangeReason: SCROLL_POSITION_CHANGE_REASONS.REQUESTED\n      };\n\n      if (scrollLeft >= 0) {\n        newState.scrollLeft = scrollLeft;\n      }\n\n      if (scrollTop >= 0) {\n        newState.scrollTop = scrollTop;\n      }\n\n      if (scrollLeft >= 0 && scrollLeft !== this.state.scrollLeft || scrollTop >= 0 && scrollTop !== this.state.scrollTop) {\n        this.setState(newState);\n      }\n    }\n  }, {\n    key: '_updateScrollPositionForScrollToCell',\n    value: function _updateScrollPositionForScrollToCell() {\n      var _props6 = this.props;\n      var cellLayoutManager = _props6.cellLayoutManager;\n      var height = _props6.height;\n      var scrollToAlignment = _props6.scrollToAlignment;\n      var scrollToCell = _props6.scrollToCell;\n      var width = _props6.width;\n      var _state3 = this.state;\n      var scrollLeft = _state3.scrollLeft;\n      var scrollTop = _state3.scrollTop;\n\n\n      if (scrollToCell >= 0) {\n        var scrollPosition = cellLayoutManager.getScrollPositionForCell({\n          align: scrollToAlignment,\n          cellIndex: scrollToCell,\n          height: height,\n          scrollLeft: scrollLeft,\n          scrollTop: scrollTop,\n          width: width\n        });\n\n        if (scrollPosition.scrollLeft !== scrollLeft || scrollPosition.scrollTop !== scrollTop) {\n          this._setScrollPosition(scrollPosition);\n        }\n      }\n    }\n  }, {\n    key: '_onScroll',\n    value: function _onScroll(event) {\n      // In certain edge-cases React dispatches an onScroll event with an invalid target.scrollLeft / target.scrollTop.\n      // This invalid event can be detected by comparing event.target to this component's scrollable DOM element.\n      // See issue #404 for more information.\n      if (event.target !== this._scrollingContainer) {\n        return;\n      }\n\n      // Prevent pointer events from interrupting a smooth scroll\n      this._enablePointerEventsAfterDelay();\n\n      // When this component is shrunk drastically, React dispatches a series of back-to-back scroll events,\n      // Gradually converging on a scrollTop that is within the bounds of the new, smaller height.\n      // This causes a series of rapid renders that is slow for long lists.\n      // We can avoid that by doing some simple bounds checking to ensure that scrollTop never exceeds the total height.\n      var _props7 = this.props;\n      var cellLayoutManager = _props7.cellLayoutManager;\n      var height = _props7.height;\n      var isScrollingChange = _props7.isScrollingChange;\n      var width = _props7.width;\n\n      var scrollbarSize = this._scrollbarSize;\n\n      var _cellLayoutManager$ge3 = cellLayoutManager.getTotalSize();\n\n      var totalHeight = _cellLayoutManager$ge3.height;\n      var totalWidth = _cellLayoutManager$ge3.width;\n\n      var scrollLeft = Math.max(0, Math.min(totalWidth - width + scrollbarSize, event.target.scrollLeft));\n      var scrollTop = Math.max(0, Math.min(totalHeight - height + scrollbarSize, event.target.scrollTop));\n\n      // Certain devices (like Apple touchpad) rapid-fire duplicate events.\n      // Don't force a re-render if this is the case.\n      // The mouse may move faster then the animation frame does.\n      // Use requestAnimationFrame to avoid over-updating.\n      if (this.state.scrollLeft !== scrollLeft || this.state.scrollTop !== scrollTop) {\n        // Browsers with cancelable scroll events (eg. Firefox) interrupt scrolling animations if scrollTop/scrollLeft is set.\n        // Other browsers (eg. Safari) don't scroll as well without the help under certain conditions (DOM or style changes during scrolling).\n        // All things considered, this seems to be the best current work around that I'm aware of.\n        // For more information see https://github.com/bvaughn/react-virtualized/pull/124\n        var scrollPositionChangeReason = event.cancelable ? SCROLL_POSITION_CHANGE_REASONS.OBSERVED : SCROLL_POSITION_CHANGE_REASONS.REQUESTED;\n\n        // Synchronously set :isScrolling the first time (since _setNextState will reschedule its animation frame each time it's called)\n        if (!this.state.isScrolling) {\n          isScrollingChange(true);\n\n          this.setState({\n            isScrolling: true\n          });\n        }\n\n        this._setNextState({\n          isScrolling: true,\n          scrollLeft: scrollLeft,\n          scrollPositionChangeReason: scrollPositionChangeReason,\n          scrollTop: scrollTop\n        });\n      }\n\n      this._invokeOnScrollMemoizer({\n        scrollLeft: scrollLeft,\n        scrollTop: scrollTop,\n        totalWidth: totalWidth,\n        totalHeight: totalHeight\n      });\n    }\n  }]);\n\n  return CollectionView;\n}(_react.Component);\n\nCollectionView.propTypes = {\n  'aria-label': _react.PropTypes.string,\n\n  /**\n   * Removes fixed height from the scrollingContainer so that the total height\n   * of rows can stretch the window. Intended for use with WindowScroller\n   */\n  autoHeight: _react.PropTypes.bool,\n\n  /**\n   * Number of cells in collection.\n   */\n  cellCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Calculates cell sizes and positions and manages rendering the appropriate cells given a specified window.\n   */\n  cellLayoutManager: _react.PropTypes.object.isRequired,\n\n  /**\n   * Optional custom CSS class name to attach to root Collection element.\n   */\n  className: _react.PropTypes.string,\n\n  /**\n   * Height of Collection; this property determines the number of visible (vs virtualized) rows.\n   */\n  height: _react.PropTypes.number.isRequired,\n\n  /**\n   * Enables the `Collection` to horiontally \"overscan\" its content similar to how `Grid` does.\n   * This can reduce flicker around the edges when a user scrolls quickly.\n   */\n  horizontalOverscanSize: _react.PropTypes.number.isRequired,\n\n  isScrollingChange: _react.PropTypes.func,\n\n  /**\n   * Optional renderer to be used in place of rows when either :rowCount or :cellCount is 0.\n   */\n  noContentRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Callback invoked whenever the scroll offset changes within the inner scrollable region.\n   * This callback can be used to sync scrolling between lists, tables, or grids.\n   * ({ clientHeight, clientWidth, scrollHeight, scrollLeft, scrollTop, scrollWidth }): void\n   */\n  onScroll: _react.PropTypes.func.isRequired,\n\n  /**\n   * Callback invoked with information about the section of the Collection that was just rendered.\n   * This callback is passed a named :indices parameter which is an Array of the most recently rendered section indices.\n   */\n  onSectionRendered: _react.PropTypes.func.isRequired,\n\n  /**\n   * Horizontal offset.\n   */\n  scrollLeft: _react.PropTypes.number,\n\n  /**\n   * Controls scroll-to-cell behavior of the Grid.\n   * The default (\"auto\") scrolls the least amount possible to ensure that the specified cell is fully visible.\n   * Use \"start\" to align cells to the top/left of the Grid and \"end\" to align bottom/right.\n   */\n  scrollToAlignment: _react.PropTypes.oneOf(['auto', 'end', 'start', 'center']).isRequired,\n\n  /**\n   * Cell index to ensure visible (by forcefully scrolling if necessary).\n   */\n  scrollToCell: _react.PropTypes.number,\n\n  /**\n   * Vertical offset.\n   */\n  scrollTop: _react.PropTypes.number,\n\n  /**\n   * Optional custom inline style to attach to root Collection element.\n   */\n  style: _react.PropTypes.object,\n\n  /**\n   * Enables the `Collection` to vertically \"overscan\" its content similar to how `Grid` does.\n   * This can reduce flicker around the edges when a user scrolls quickly.\n   */\n  verticalOverscanSize: _react.PropTypes.number.isRequired,\n\n  /**\n   * Width of Collection; this property determines the number of visible (vs virtualized) columns.\n   */\n  width: _react.PropTypes.number.isRequired\n};\nCollectionView.defaultProps = {\n  'aria-label': 'grid',\n  horizontalOverscanSize: 0,\n  noContentRenderer: function noContentRenderer() {\n    return null;\n  },\n  onScroll: function onScroll() {\n    return null;\n  },\n  onSectionRendered: function onSectionRendered() {\n    return null;\n  },\n  scrollToAlignment: 'auto',\n  style: {},\n  verticalOverscanSize: 0\n};\nexports.default = CollectionView;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\n * A section of the Window.\n * Window Sections are used to group nearby cells.\n * This enables us to more quickly determine which cells to display in a given region of the Window.\n * Sections have a fixed size and contain 0 to many cells (tracked by their indices).\n */\nvar Section = function () {\n  function Section(_ref) {\n    var height = _ref.height;\n    var width = _ref.width;\n    var x = _ref.x;\n    var y = _ref.y;\n\n    _classCallCheck(this, Section);\n\n    this.height = height;\n    this.width = width;\n    this.x = x;\n    this.y = y;\n\n    this._indexMap = {};\n    this._indices = [];\n  }\n\n  /** Add a cell to this section. */\n\n\n  _createClass(Section, [{\n    key: 'addCellIndex',\n    value: function addCellIndex(_ref2) {\n      var index = _ref2.index;\n\n      if (!this._indexMap[index]) {\n        this._indexMap[index] = true;\n        this._indices.push(index);\n      }\n    }\n\n    /** Get all cell indices that have been added to this section. */\n\n  }, {\n    key: 'getCellIndices',\n    value: function getCellIndices() {\n      return this._indices;\n    }\n\n    /** Intended for debugger/test purposes only */\n\n  }, {\n    key: 'toString',\n    value: function toString() {\n      return this.x + ',' + this.y + ' ' + this.width + 'x' + this.height;\n    }\n  }]);\n\n  return Section;\n}(); /** @rlow */\n\n\nexports.default = Section;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); /**\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      * Window Sections are used to group nearby cells.\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      * This enables us to more quickly determine which cells to display in a given region of the Window.\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      * \n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      */\n\n\nvar _Section = require('./Section');\n\nvar _Section2 = _interopRequireDefault(_Section);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar SECTION_SIZE = 100;\n\n/**\n * Contains 0 to many Sections.\n * Grows (and adds Sections) dynamically as cells are registered.\n * Automatically adds cells to the appropriate Section(s).\n */\nvar SectionManager = function () {\n  function SectionManager() {\n    var sectionSize = arguments.length <= 0 || arguments[0] === undefined ? SECTION_SIZE : arguments[0];\n\n    _classCallCheck(this, SectionManager);\n\n    this._sectionSize = sectionSize;\n\n    this._cellMetadata = [];\n    this._sections = {};\n  }\n\n  /**\n   * Gets all cell indices contained in the specified region.\n   * A region may encompass 1 or more Sections.\n   */\n\n\n  _createClass(SectionManager, [{\n    key: 'getCellIndices',\n    value: function getCellIndices(_ref) {\n      var height = _ref.height;\n      var width = _ref.width;\n      var x = _ref.x;\n      var y = _ref.y;\n\n      var indices = {};\n\n      this.getSections({ height: height, width: width, x: x, y: y }).forEach(function (section) {\n        return section.getCellIndices().forEach(function (index) {\n          indices[index] = index;\n        });\n      });\n\n      // Object keys are strings; this function returns numbers\n      return Object.keys(indices).map(function (index) {\n        return indices[index];\n      });\n    }\n\n    /** Get size and position information for the cell specified. */\n\n  }, {\n    key: 'getCellMetadata',\n    value: function getCellMetadata(_ref2) {\n      var index = _ref2.index;\n\n      return this._cellMetadata[index];\n    }\n\n    /** Get all Sections overlapping the specified region. */\n\n  }, {\n    key: 'getSections',\n    value: function getSections(_ref3) {\n      var height = _ref3.height;\n      var width = _ref3.width;\n      var x = _ref3.x;\n      var y = _ref3.y;\n\n      var sectionXStart = Math.floor(x / this._sectionSize);\n      var sectionXStop = Math.floor((x + width - 1) / this._sectionSize);\n      var sectionYStart = Math.floor(y / this._sectionSize);\n      var sectionYStop = Math.floor((y + height - 1) / this._sectionSize);\n\n      var sections = [];\n\n      for (var sectionX = sectionXStart; sectionX <= sectionXStop; sectionX++) {\n        for (var sectionY = sectionYStart; sectionY <= sectionYStop; sectionY++) {\n          var key = sectionX + '.' + sectionY;\n\n          if (!this._sections[key]) {\n            this._sections[key] = new _Section2.default({\n              height: this._sectionSize,\n              width: this._sectionSize,\n              x: sectionX * this._sectionSize,\n              y: sectionY * this._sectionSize\n            });\n          }\n\n          sections.push(this._sections[key]);\n        }\n      }\n\n      return sections;\n    }\n\n    /** Total number of Sections based on the currently registered cells. */\n\n  }, {\n    key: 'getTotalSectionCount',\n    value: function getTotalSectionCount() {\n      return Object.keys(this._sections).length;\n    }\n\n    /** Intended for debugger/test purposes only */\n\n  }, {\n    key: 'toString',\n    value: function toString() {\n      var _this = this;\n\n      return Object.keys(this._sections).map(function (index) {\n        return _this._sections[index].toString();\n      });\n    }\n\n    /** Adds a cell to the appropriate Sections and registers it metadata for later retrievable. */\n\n  }, {\n    key: 'registerCell',\n    value: function registerCell(_ref4) {\n      var cellMetadatum = _ref4.cellMetadatum;\n      var index = _ref4.index;\n\n      this._cellMetadata[index] = cellMetadatum;\n\n      this.getSections(cellMetadatum).forEach(function (section) {\n        return section.addCellIndex({ index: index });\n      });\n    }\n  }]);\n\n  return SectionManager;\n}();\n\nexports.default = SectionManager;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.Collection = exports.default = undefined;\n\nvar _Collection2 = require('./Collection');\n\nvar _Collection3 = _interopRequireDefault(_Collection2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _Collection3.default;\nexports.Collection = _Collection3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = calculateSizeAndPositionData;\n\nvar _SectionManager = require('../SectionManager');\n\nvar _SectionManager2 = _interopRequireDefault(_SectionManager);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction calculateSizeAndPositionData(_ref) {\n  var cellCount = _ref.cellCount;\n  var cellSizeAndPositionGetter = _ref.cellSizeAndPositionGetter;\n  var sectionSize = _ref.sectionSize;\n\n  var cellMetadata = [];\n  var sectionManager = new _SectionManager2.default(sectionSize);\n  var height = 0;\n  var width = 0;\n\n  for (var index = 0; index < cellCount; index++) {\n    var cellMetadatum = cellSizeAndPositionGetter({ index: index });\n\n    if (cellMetadatum.height == null || isNaN(cellMetadatum.height) || cellMetadatum.width == null || isNaN(cellMetadatum.width) || cellMetadatum.x == null || isNaN(cellMetadatum.x) || cellMetadatum.y == null || isNaN(cellMetadatum.y)) {\n      throw Error('Invalid metadata returned for cell ' + index + ':\\n        x:' + cellMetadatum.x + ', y:' + cellMetadatum.y + ', width:' + cellMetadatum.width + ', height:' + cellMetadatum.height);\n    }\n\n    height = Math.max(height, cellMetadatum.y + cellMetadatum.height);\n    width = Math.max(width, cellMetadatum.x + cellMetadatum.width);\n\n    cellMetadata[index] = cellMetadatum;\n    sectionManager.registerCell({\n      cellMetadatum: cellMetadatum,\n      index: index\n    });\n  }\n\n  return {\n    cellMetadata: cellMetadata,\n    height: height,\n    sectionManager: sectionManager,\n    width: width\n  };\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nvar _Grid = require('../Grid');\n\nvar _Grid2 = _interopRequireDefault(_Grid);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * High-order component that auto-calculates column-widths for `Grid` cells.\n */\nvar ColumnSizer = function (_Component) {\n  _inherits(ColumnSizer, _Component);\n\n  function ColumnSizer(props, context) {\n    _classCallCheck(this, ColumnSizer);\n\n    var _this = _possibleConstructorReturn(this, (ColumnSizer.__proto__ || Object.getPrototypeOf(ColumnSizer)).call(this, props, context));\n\n    _this._registerChild = _this._registerChild.bind(_this);\n    return _this;\n  }\n\n  _createClass(ColumnSizer, [{\n    key: 'componentDidUpdate',\n    value: function componentDidUpdate(prevProps, prevState) {\n      var _props = this.props;\n      var columnMaxWidth = _props.columnMaxWidth;\n      var columnMinWidth = _props.columnMinWidth;\n      var columnCount = _props.columnCount;\n      var width = _props.width;\n\n\n      if (columnMaxWidth !== prevProps.columnMaxWidth || columnMinWidth !== prevProps.columnMinWidth || columnCount !== prevProps.columnCount || width !== prevProps.width) {\n        if (this._registeredChild) {\n          this._registeredChild.recomputeGridSize();\n        }\n      }\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _props2 = this.props;\n      var children = _props2.children;\n      var columnMaxWidth = _props2.columnMaxWidth;\n      var columnMinWidth = _props2.columnMinWidth;\n      var columnCount = _props2.columnCount;\n      var width = _props2.width;\n\n\n      var safeColumnMinWidth = columnMinWidth || 1;\n\n      var safeColumnMaxWidth = columnMaxWidth ? Math.min(columnMaxWidth, width) : width;\n\n      var columnWidth = width / columnCount;\n      columnWidth = Math.max(safeColumnMinWidth, columnWidth);\n      columnWidth = Math.min(safeColumnMaxWidth, columnWidth);\n      columnWidth = Math.floor(columnWidth);\n\n      var adjustedWidth = Math.min(width, columnWidth * columnCount);\n\n      return children({\n        adjustedWidth: adjustedWidth,\n        getColumnWidth: function getColumnWidth() {\n          return columnWidth;\n        },\n        registerChild: this._registerChild\n      });\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_registerChild',\n    value: function _registerChild(child) {\n      if (child !== null && !(child instanceof _Grid2.default)) {\n        throw Error('Unexpected child type registered; only Grid children are supported.');\n      }\n\n      this._registeredChild = child;\n\n      if (this._registeredChild) {\n        this._registeredChild.recomputeGridSize();\n      }\n    }\n  }]);\n\n  return ColumnSizer;\n}(_react.Component);\n\nColumnSizer.propTypes = {\n  /**\n   * Function respondible for rendering a virtualized Grid.\n   * This function should implement the following signature:\n   * ({ adjustedWidth, getColumnWidth, registerChild }) => PropTypes.element\n   *\n   * The specified :getColumnWidth function should be passed to the Grid's :columnWidth property.\n   * The :registerChild should be passed to the Grid's :ref property.\n   * The :adjustedWidth property is optional; it reflects the lesser of the overall width or the width of all columns.\n   */\n  children: _react.PropTypes.func.isRequired,\n\n  /** Optional maximum allowed column width */\n  columnMaxWidth: _react.PropTypes.number,\n\n  /** Optional minimum allowed column width */\n  columnMinWidth: _react.PropTypes.number,\n\n  /** Number of columns in Grid or FlexTable child */\n  columnCount: _react.PropTypes.number.isRequired,\n\n  /** Width of Grid or FlexTable child */\n  width: _react.PropTypes.number.isRequired\n};\nexports.default = ColumnSizer;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.ColumnSizer = exports.default = undefined;\n\nvar _ColumnSizer2 = require('./ColumnSizer');\n\nvar _ColumnSizer3 = _interopRequireDefault(_ColumnSizer2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _ColumnSizer3.default;\nexports.ColumnSizer = _ColumnSizer3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _react = require('react');\n\nvar _defaultHeaderRenderer = require('./defaultHeaderRenderer');\n\nvar _defaultHeaderRenderer2 = _interopRequireDefault(_defaultHeaderRenderer);\n\nvar _defaultCellRenderer = require('./defaultCellRenderer');\n\nvar _defaultCellRenderer2 = _interopRequireDefault(_defaultCellRenderer);\n\nvar _defaultCellDataGetter = require('./defaultCellDataGetter');\n\nvar _defaultCellDataGetter2 = _interopRequireDefault(_defaultCellDataGetter);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * Describes the header and cell contents of a table column.\n */\nvar Column = function (_Component) {\n  _inherits(Column, _Component);\n\n  function Column() {\n    _classCallCheck(this, Column);\n\n    return _possibleConstructorReturn(this, (Column.__proto__ || Object.getPrototypeOf(Column)).apply(this, arguments));\n  }\n\n  return Column;\n}(_react.Component);\n\nColumn.defaultProps = {\n  cellDataGetter: _defaultCellDataGetter2.default,\n  cellRenderer: _defaultCellRenderer2.default,\n  flexGrow: 0,\n  flexShrink: 1,\n  headerRenderer: _defaultHeaderRenderer2.default,\n  style: {}\n};\nColumn.propTypes = {\n  /** Optional aria-label value to set on the column header */\n  'aria-label': _react.PropTypes.string,\n\n  /**\n   * Callback responsible for returning a cell's data, given its :dataKey\n   * ({ columnData: any, dataKey: string, rowData: any }): any\n   */\n  cellDataGetter: _react.PropTypes.func,\n\n  /**\n   * Callback responsible for rendering a cell's contents.\n   * ({ cellData: any, columnData: any, dataKey: string, rowData: any, rowIndex: number }): node\n   */\n  cellRenderer: _react.PropTypes.func,\n\n  /** Optional CSS class to apply to cell */\n  className: _react.PropTypes.string,\n\n  /** Optional additional data passed to this column's :cellDataGetter */\n  columnData: _react.PropTypes.object,\n\n  /** Uniquely identifies the row-data attribute correspnding to this cell */\n  dataKey: _react.PropTypes.any.isRequired,\n\n  /** If sort is enabled for the table at large, disable it for this column */\n  disableSort: _react.PropTypes.bool,\n\n  /** Flex grow style; defaults to 0 */\n  flexGrow: _react.PropTypes.number,\n\n  /** Flex shrink style; defaults to 1 */\n  flexShrink: _react.PropTypes.number,\n\n  /** Optional CSS class to apply to this column's header */\n  headerClassName: _react.PropTypes.string,\n\n  /**\n   * Optional callback responsible for rendering a column header contents.\n   * ({ columnData: object, dataKey: string, disableSort: boolean, label: string, sortBy: string, sortDirection: string }): PropTypes.node\n   */\n  headerRenderer: _react.PropTypes.func.isRequired,\n\n  /** Header label for this column */\n  label: _react.PropTypes.string,\n\n  /** Maximum width of column; this property will only be used if :flexGrow is > 0. */\n  maxWidth: _react.PropTypes.number,\n\n  /** Minimum width of column. */\n  minWidth: _react.PropTypes.number,\n\n  /** Optional inline style to apply to cell */\n  style: _react.PropTypes.object,\n\n  /** Flex basis (width) for this column; This value can grow or shrink based on :flexGrow and :flexShrink properties. */\n  width: _react.PropTypes.number.isRequired\n};\nexports.default = Column;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _classnames = require('classnames');\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nvar _FlexColumn = require('./FlexColumn');\n\nvar _FlexColumn2 = _interopRequireDefault(_FlexColumn);\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactDom = require('react-dom');\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nvar _Grid = require('../Grid');\n\nvar _Grid2 = _interopRequireDefault(_Grid);\n\nvar _defaultRowRenderer = require('./defaultRowRenderer');\n\nvar _defaultRowRenderer2 = _interopRequireDefault(_defaultRowRenderer);\n\nvar _SortDirection = require('./SortDirection');\n\nvar _SortDirection2 = _interopRequireDefault(_SortDirection);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * Table component with fixed headers and virtualized rows for improved performance with large data sets.\n * This component expects explicit width, height, and padding parameters.\n */\nvar FlexTable = function (_Component) {\n  _inherits(FlexTable, _Component);\n\n  function FlexTable(props) {\n    _classCallCheck(this, FlexTable);\n\n    var _this = _possibleConstructorReturn(this, (FlexTable.__proto__ || Object.getPrototypeOf(FlexTable)).call(this, props));\n\n    _this.state = {\n      scrollbarWidth: 0\n    };\n\n    _this._cellClassName = _this._cellClassName.bind(_this);\n    _this._cellStyle = _this._cellStyle.bind(_this);\n    _this._createColumn = _this._createColumn.bind(_this);\n    _this._createRow = _this._createRow.bind(_this);\n    _this._onScroll = _this._onScroll.bind(_this);\n    _this._onSectionRendered = _this._onSectionRendered.bind(_this);\n    return _this;\n  }\n\n  _createClass(FlexTable, [{\n    key: 'forceUpdateGrid',\n    value: function forceUpdateGrid() {\n      this.Grid.forceUpdate();\n    }\n\n    /** See Grid#measureAllCells */\n\n  }, {\n    key: 'measureAllRows',\n    value: function measureAllRows() {\n      this.Grid.measureAllCells();\n    }\n\n    /** See Grid#recomputeGridSize */\n\n  }, {\n    key: 'recomputeRowHeights',\n    value: function recomputeRowHeights() {\n      var index = arguments.length <= 0 || arguments[0] === undefined ? 0 : arguments[0];\n\n      this.Grid.recomputeGridSize({\n        rowIndex: index\n      });\n      this.forceUpdateGrid();\n    }\n  }, {\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      this._setScrollbarWidth();\n    }\n  }, {\n    key: 'componentDidUpdate',\n    value: function componentDidUpdate() {\n      this._setScrollbarWidth();\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _this2 = this;\n\n      var _props = this.props;\n      var children = _props.children;\n      var className = _props.className;\n      var disableHeader = _props.disableHeader;\n      var gridClassName = _props.gridClassName;\n      var gridStyle = _props.gridStyle;\n      var headerHeight = _props.headerHeight;\n      var height = _props.height;\n      var noRowsRenderer = _props.noRowsRenderer;\n      var rowClassName = _props.rowClassName;\n      var rowStyle = _props.rowStyle;\n      var scrollToIndex = _props.scrollToIndex;\n      var style = _props.style;\n      var width = _props.width;\n      var scrollbarWidth = this.state.scrollbarWidth;\n\n\n      var availableRowsHeight = height - headerHeight;\n\n      var rowClass = rowClassName instanceof Function ? rowClassName({ index: -1 }) : rowClassName;\n      var rowStyleObject = rowStyle instanceof Function ? rowStyle({ index: -1 }) : rowStyle;\n\n      // Precompute and cache column styles before rendering rows and columns to speed things up\n      this._cachedColumnStyles = [];\n      _react2.default.Children.toArray(children).forEach(function (column, index) {\n        _this2._cachedColumnStyles[index] = _this2._getFlexStyleForColumn(column, column.props.style);\n      });\n\n      // Note that we specify :numChildren, :scrollbarWidth, :sortBy, and :sortDirection as properties on Grid even though these have nothing to do with Grid.\n      // This is done because Grid is a pure component and won't update unless its properties or state has changed.\n      // Any property that should trigger a re-render of Grid then is specified here to avoid a stale display.\n      return _react2.default.createElement(\n        'div',\n        {\n          className: (0, _classnames2.default)('FlexTable', className),\n          style: style\n        },\n        !disableHeader && _react2.default.createElement(\n          'div',\n          {\n            className: (0, _classnames2.default)('FlexTable__headerRow', rowClass),\n            style: _extends({}, rowStyleObject, {\n              height: headerHeight,\n              paddingRight: scrollbarWidth,\n              width: width\n            })\n          },\n          this._getRenderedHeaderRow()\n        ),\n        _react2.default.createElement(_Grid2.default, _extends({}, this.props, {\n          autoContainerWidth: true,\n          className: (0, _classnames2.default)('FlexTable__Grid', gridClassName),\n          cellClassName: this._cellClassName,\n          cellRenderer: this._createRow,\n          cellStyle: this._cellStyle,\n          columnWidth: width,\n          columnCount: 1,\n          height: availableRowsHeight,\n          noContentRenderer: noRowsRenderer,\n          onScroll: this._onScroll,\n          onSectionRendered: this._onSectionRendered,\n          ref: function ref(_ref) {\n            _this2.Grid = _ref;\n          },\n          scrollbarWidth: scrollbarWidth,\n          scrollToRow: scrollToIndex,\n          style: gridStyle\n        }))\n      );\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_cellClassName',\n    value: function _cellClassName(_ref2) {\n      var rowIndex = _ref2.rowIndex;\n      var rowWrapperClassName = this.props.rowWrapperClassName;\n\n\n      return rowWrapperClassName instanceof Function ? rowWrapperClassName({ index: rowIndex - 1 }) : rowWrapperClassName;\n    }\n  }, {\n    key: '_cellStyle',\n    value: function _cellStyle(_ref3) {\n      var rowIndex = _ref3.rowIndex;\n      var rowWrapperStyle = this.props.rowWrapperStyle;\n\n\n      return rowWrapperStyle instanceof Function ? rowWrapperStyle({ index: rowIndex - 1 }) : rowWrapperStyle;\n    }\n  }, {\n    key: '_createColumn',\n    value: function _createColumn(_ref4) {\n      var column = _ref4.column;\n      var columnIndex = _ref4.columnIndex;\n      var isScrolling = _ref4.isScrolling;\n      var rowData = _ref4.rowData;\n      var rowIndex = _ref4.rowIndex;\n      var _column$props = column.props;\n      var cellDataGetter = _column$props.cellDataGetter;\n      var cellRenderer = _column$props.cellRenderer;\n      var className = _column$props.className;\n      var columnData = _column$props.columnData;\n      var dataKey = _column$props.dataKey;\n\n\n      var cellData = cellDataGetter({ columnData: columnData, dataKey: dataKey, rowData: rowData });\n      var renderedCell = cellRenderer({ cellData: cellData, columnData: columnData, dataKey: dataKey, isScrolling: isScrolling, rowData: rowData, rowIndex: rowIndex });\n\n      var style = this._cachedColumnStyles[columnIndex];\n\n      var title = typeof renderedCell === 'string' ? renderedCell : null;\n\n      return _react2.default.createElement(\n        'div',\n        {\n          key: 'Row' + rowIndex + '-Col' + columnIndex,\n          className: (0, _classnames2.default)('FlexTable__rowColumn', className),\n          style: style,\n          title: title\n        },\n        renderedCell\n      );\n    }\n  }, {\n    key: '_createHeader',\n    value: function _createHeader(_ref5) {\n      var column = _ref5.column;\n      var index = _ref5.index;\n      var _props2 = this.props;\n      var headerClassName = _props2.headerClassName;\n      var headerStyle = _props2.headerStyle;\n      var onHeaderClick = _props2.onHeaderClick;\n      var sort = _props2.sort;\n      var sortBy = _props2.sortBy;\n      var sortDirection = _props2.sortDirection;\n      var _column$props2 = column.props;\n      var dataKey = _column$props2.dataKey;\n      var disableSort = _column$props2.disableSort;\n      var headerRenderer = _column$props2.headerRenderer;\n      var label = _column$props2.label;\n      var columnData = _column$props2.columnData;\n\n      var sortEnabled = !disableSort && sort;\n\n      var classNames = (0, _classnames2.default)('FlexTable__headerColumn', headerClassName, column.props.headerClassName, {\n        'FlexTable__sortableHeaderColumn': sortEnabled\n      });\n      var style = this._getFlexStyleForColumn(column, headerStyle);\n\n      var renderedHeader = headerRenderer({\n        columnData: columnData,\n        dataKey: dataKey,\n        disableSort: disableSort,\n        label: label,\n        sortBy: sortBy,\n        sortDirection: sortDirection\n      });\n\n      var a11yProps = {};\n\n      if (sortEnabled || onHeaderClick) {\n        (function () {\n          // If this is a sortable header, clicking it should update the table data's sorting.\n          var newSortDirection = sortBy !== dataKey || sortDirection === _SortDirection2.default.DESC ? _SortDirection2.default.ASC : _SortDirection2.default.DESC;\n\n          var onClick = function onClick() {\n            sortEnabled && sort({\n              sortBy: dataKey,\n              sortDirection: newSortDirection\n            });\n            onHeaderClick && onHeaderClick({ columnData: columnData, dataKey: dataKey });\n          };\n\n          var onKeyDown = function onKeyDown(event) {\n            if (event.key === 'Enter' || event.key === ' ') {\n              onClick();\n            }\n          };\n\n          a11yProps['aria-label'] = column.props['aria-label'] || label || dataKey;\n          a11yProps.role = 'rowheader';\n          a11yProps.tabIndex = 0;\n          a11yProps.onClick = onClick;\n          a11yProps.onKeyDown = onKeyDown;\n        })();\n      }\n\n      return _react2.default.createElement(\n        'div',\n        _extends({}, a11yProps, {\n          key: 'Header-Col' + index,\n          className: classNames,\n          style: style\n        }),\n        renderedHeader\n      );\n    }\n  }, {\n    key: '_createRow',\n    value: function _createRow(_ref6) {\n      var _this3 = this;\n\n      var index = _ref6.rowIndex;\n      var isScrolling = _ref6.isScrolling;\n      var _props3 = this.props;\n      var children = _props3.children;\n      var onRowClick = _props3.onRowClick;\n      var onRowDoubleClick = _props3.onRowDoubleClick;\n      var onRowMouseOver = _props3.onRowMouseOver;\n      var onRowMouseOut = _props3.onRowMouseOut;\n      var rowClassName = _props3.rowClassName;\n      var rowGetter = _props3.rowGetter;\n      var rowRenderer = _props3.rowRenderer;\n      var rowStyle = _props3.rowStyle;\n      var scrollbarWidth = this.state.scrollbarWidth;\n\n\n      var rowClass = rowClassName instanceof Function ? rowClassName({ index: index }) : rowClassName;\n      var rowStyleObject = rowStyle instanceof Function ? rowStyle({ index: index }) : rowStyle;\n      var rowData = rowGetter({ index: index });\n\n      var columns = _react2.default.Children.toArray(children).map(function (column, columnIndex) {\n        return _this3._createColumn({\n          column: column,\n          columnIndex: columnIndex,\n          isScrolling: isScrolling,\n          rowData: rowData,\n          rowIndex: index,\n          scrollbarWidth: scrollbarWidth\n        });\n      });\n\n      var className = (0, _classnames2.default)('FlexTable__row', rowClass);\n      var style = _extends({}, rowStyleObject, {\n        height: this._getRowHeight(index),\n        paddingRight: scrollbarWidth\n      });\n\n      return rowRenderer({\n        className: className,\n        columns: columns,\n        index: index,\n        isScrolling: isScrolling,\n        onRowClick: onRowClick,\n        onRowDoubleClick: onRowDoubleClick,\n        onRowMouseOver: onRowMouseOver,\n        onRowMouseOut: onRowMouseOut,\n        rowData: rowData,\n        style: style\n      });\n    }\n\n    /**\n     * Determines the flex-shrink, flex-grow, and width values for a cell (header or column).\n     */\n\n  }, {\n    key: '_getFlexStyleForColumn',\n    value: function _getFlexStyleForColumn(column) {\n      var customStyle = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1];\n\n      var flexValue = column.props.flexGrow + ' ' + column.props.flexShrink + ' ' + column.props.width + 'px';\n\n      var style = _extends({}, customStyle, {\n        flex: flexValue,\n        msFlex: flexValue,\n        WebkitFlex: flexValue\n      });\n\n      if (column.props.maxWidth) {\n        style.maxWidth = column.props.maxWidth;\n      }\n\n      if (column.props.minWidth) {\n        style.minWidth = column.props.minWidth;\n      }\n\n      return style;\n    }\n  }, {\n    key: '_getRenderedHeaderRow',\n    value: function _getRenderedHeaderRow() {\n      var _this4 = this;\n\n      var _props4 = this.props;\n      var children = _props4.children;\n      var disableHeader = _props4.disableHeader;\n\n      var items = disableHeader ? [] : _react2.default.Children.toArray(children);\n\n      return items.map(function (column, index) {\n        return _this4._createHeader({ column: column, index: index });\n      });\n    }\n  }, {\n    key: '_getRowHeight',\n    value: function _getRowHeight(rowIndex) {\n      var rowHeight = this.props.rowHeight;\n\n\n      return rowHeight instanceof Function ? rowHeight({ index: rowIndex }) : rowHeight;\n    }\n  }, {\n    key: '_onScroll',\n    value: function _onScroll(_ref7) {\n      var clientHeight = _ref7.clientHeight;\n      var scrollHeight = _ref7.scrollHeight;\n      var scrollTop = _ref7.scrollTop;\n      var onScroll = this.props.onScroll;\n\n\n      onScroll({ clientHeight: clientHeight, scrollHeight: scrollHeight, scrollTop: scrollTop });\n    }\n  }, {\n    key: '_onSectionRendered',\n    value: function _onSectionRendered(_ref8) {\n      var rowOverscanStartIndex = _ref8.rowOverscanStartIndex;\n      var rowOverscanStopIndex = _ref8.rowOverscanStopIndex;\n      var rowStartIndex = _ref8.rowStartIndex;\n      var rowStopIndex = _ref8.rowStopIndex;\n      var onRowsRendered = this.props.onRowsRendered;\n\n\n      onRowsRendered({\n        overscanStartIndex: rowOverscanStartIndex,\n        overscanStopIndex: rowOverscanStopIndex,\n        startIndex: rowStartIndex,\n        stopIndex: rowStopIndex\n      });\n    }\n  }, {\n    key: '_setScrollbarWidth',\n    value: function _setScrollbarWidth() {\n      var Grid = (0, _reactDom.findDOMNode)(this.Grid);\n      var clientWidth = Grid.clientWidth || 0;\n      var offsetWidth = Grid.offsetWidth || 0;\n      var scrollbarWidth = offsetWidth - clientWidth;\n\n      this.setState({ scrollbarWidth: scrollbarWidth });\n    }\n  }]);\n\n  return FlexTable;\n}(_react.Component);\n\nFlexTable.propTypes = {\n  'aria-label': _react.PropTypes.string,\n\n  /**\n   * Removes fixed height from the scrollingContainer so that the total height\n   * of rows can stretch the window. Intended for use with WindowScroller\n   */\n  autoHeight: _react.PropTypes.bool,\n\n  /** One or more FlexColumns describing the data displayed in this row */\n  children: function children(props, propName, componentName) {\n    var children = _react2.default.Children.toArray(props.children);\n    for (var i = 0; i < children.length; i++) {\n      if (children[i].type !== _FlexColumn2.default) {\n        return new Error('FlexTable only accepts children of type FlexColumn');\n      }\n    }\n  },\n\n  /** Optional CSS class name */\n  className: _react.PropTypes.string,\n\n  /** Disable rendering the header at all */\n  disableHeader: _react.PropTypes.bool,\n\n  /**\n   * Used to estimate the total height of a FlexTable before all of its rows have actually been measured.\n   * The estimated total height is adjusted as rows are rendered.\n   */\n  estimatedRowSize: _react.PropTypes.number.isRequired,\n\n  /** Optional custom CSS class name to attach to inner Grid element. */\n  gridClassName: _react.PropTypes.string,\n\n  /** Optional inline style to attach to inner Grid element. */\n  gridStyle: _react.PropTypes.object,\n\n  /** Optional CSS class to apply to all column headers */\n  headerClassName: _react.PropTypes.string,\n\n  /** Fixed height of header row */\n  headerHeight: _react.PropTypes.number.isRequired,\n\n  /** Fixed/available height for out DOM element */\n  height: _react.PropTypes.number.isRequired,\n\n  /** Optional renderer to be used in place of table body rows when rowCount is 0 */\n  noRowsRenderer: _react.PropTypes.func,\n\n  /**\n  * Optional callback when a column's header is clicked.\n  * ({ columnData: any, dataKey: string }): void\n  */\n  onHeaderClick: _react.PropTypes.func,\n\n  /** Optional custom inline style to attach to table header columns. */\n  headerStyle: _react.PropTypes.object,\n\n  /**\n   * Callback invoked when a user clicks on a table row.\n   * ({ index: number }): void\n   */\n  onRowClick: _react.PropTypes.func,\n\n  /**\n   * Callback invoked when a user double-clicks on a table row.\n   * ({ index: number }): void\n   */\n  onRowDoubleClick: _react.PropTypes.func,\n\n  /**\n   * Callback invoked when the mouse leaves a table row.\n   * ({ index: number }): void\n   */\n  onRowMouseOut: _react.PropTypes.func,\n\n  /**\n   * Callback invoked when a user moves the mouse over a table row.\n   * ({ index: number }): void\n   */\n  onRowMouseOver: _react.PropTypes.func,\n\n  /**\n   * Callback invoked with information about the slice of rows that were just rendered.\n   * ({ startIndex, stopIndex }): void\n   */\n  onRowsRendered: _react.PropTypes.func,\n\n  /**\n   * Callback invoked whenever the scroll offset changes within the inner scrollable region.\n   * This callback can be used to sync scrolling between lists, tables, or grids.\n   * ({ clientHeight, scrollHeight, scrollTop }): void\n   */\n  onScroll: _react.PropTypes.func.isRequired,\n\n  /**\n   * Number of rows to render above/below the visible bounds of the list.\n   * These rows can help for smoother scrolling on touch devices.\n   */\n  overscanRowCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Optional CSS class to apply to all table rows (including the header row).\n   * This property can be a CSS class name (string) or a function that returns a class name.\n   * If a function is provided its signature should be: ({ index: number }): string\n   */\n  rowClassName: _react.PropTypes.oneOfType([_react.PropTypes.string, _react.PropTypes.func]),\n\n  /**\n   * Callback responsible for returning a data row given an index.\n   * ({ index: number }): any\n   */\n  rowGetter: _react.PropTypes.func.isRequired,\n\n  /**\n   * Either a fixed row height (number) or a function that returns the height of a row given its index.\n   * ({ index: number }): number\n   */\n  rowHeight: _react.PropTypes.oneOfType([_react.PropTypes.number, _react.PropTypes.func]).isRequired,\n\n  /** Number of rows in table. */\n  rowCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Responsible for rendering a table row given an array of columns:\n   * Should implement the following interface: ({\n   *   className: string,\n   *   columns: Array,\n   *   index: number,\n   *   isScrolling: boolean,\n   *   onRowClick: ?Function,\n   *   onRowDoubleClick: ?Function,\n   *   onRowMouseOver: ?Function,\n   *   onRowMouseOut: ?Function,\n   *   rowData: any,\n   *   style: any\n   * }): PropTypes.node\n   */\n  rowRenderer: _react.PropTypes.func,\n\n  /** Optional custom inline style to attach to table rows. */\n  rowStyle: _react.PropTypes.oneOfType([_react.PropTypes.object, _react.PropTypes.func]).isRequired,\n\n  /** Optional custom CSS class for individual rows */\n  rowWrapperClassName: _react.PropTypes.oneOfType([_react.PropTypes.string, _react.PropTypes.func]),\n\n  /** Optional custom CSS class for individual rows */\n  rowWrapperStyle: _react.PropTypes.oneOfType([_react.PropTypes.object, _react.PropTypes.func]),\n\n  /** See Grid#scrollToAlignment */\n  scrollToAlignment: _react.PropTypes.oneOf(['auto', 'end', 'start', 'center']).isRequired,\n\n  /** Row index to ensure visible (by forcefully scrolling if necessary) */\n  scrollToIndex: _react.PropTypes.number,\n\n  /** Vertical offset. */\n  scrollTop: _react.PropTypes.number,\n\n  /**\n   * Sort function to be called if a sortable header is clicked.\n   * ({ sortBy: string, sortDirection: SortDirection }): void\n   */\n  sort: _react.PropTypes.func,\n\n  /** FlexTable data is currently sorted by this :dataKey (if it is sorted at all) */\n  sortBy: _react.PropTypes.string,\n\n  /** FlexTable data is currently sorted in this direction (if it is sorted at all) */\n  sortDirection: _react.PropTypes.oneOf([_SortDirection2.default.ASC, _SortDirection2.default.DESC]),\n\n  /** Optional inline style */\n  style: _react.PropTypes.object,\n\n  /** Tab index for focus */\n  tabIndex: _react.PropTypes.number,\n\n  /** Width of list */\n  width: _react.PropTypes.number.isRequired\n};\nFlexTable.defaultProps = {\n  disableHeader: false,\n  estimatedRowSize: 30,\n  headerHeight: 0,\n  headerStyle: {},\n  noRowsRenderer: function noRowsRenderer() {\n    return null;\n  },\n  onRowsRendered: function onRowsRendered() {\n    return null;\n  },\n  onScroll: function onScroll() {\n    return null;\n  },\n  overscanRowCount: 10,\n  rowRenderer: _defaultRowRenderer2.default,\n  rowStyle: {},\n  scrollToAlignment: 'auto',\n  style: {}\n};\nexports.default = FlexTable;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nvar SortDirection = {\n  /**\n   * Sort items in ascending order.\n   * This means arranging from the lowest value to the highest (e.g. a-z, 0-9).\n   */\n  ASC: 'ASC',\n\n  /**\n   * Sort items in descending order.\n   * This means arranging from the highest value to the lowest (e.g. z-a, 9-0).\n   */\n  DESC: 'DESC'\n};\n\nexports.default = SortDirection;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = SortIndicator;\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _classnames = require('classnames');\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nvar _SortDirection = require('./SortDirection');\n\nvar _SortDirection2 = _interopRequireDefault(_SortDirection);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Displayed beside a header to indicate that a FlexTable is currently sorted by this column.\n */\nfunction SortIndicator(_ref) {\n  var sortDirection = _ref.sortDirection;\n\n  var classNames = (0, _classnames2.default)('FlexTable__sortableHeaderIcon', {\n    'FlexTable__sortableHeaderIcon--ASC': sortDirection === _SortDirection2.default.ASC,\n    'FlexTable__sortableHeaderIcon--DESC': sortDirection === _SortDirection2.default.DESC\n  });\n\n  return _react2.default.createElement(\n    'svg',\n    {\n      className: classNames,\n      width: 18,\n      height: 18,\n      viewBox: '0 0 24 24'\n    },\n    sortDirection === _SortDirection2.default.ASC ? _react2.default.createElement('path', { d: 'M7 14l5-5 5 5z' }) : _react2.default.createElement('path', { d: 'M7 10l5 5 5-5z' }),\n    _react2.default.createElement('path', { d: 'M0 0h24v24H0z', fill: 'none' })\n  );\n}\nSortIndicator.propTypes = {\n  sortDirection: _react.PropTypes.oneOf([_SortDirection2.default.ASC, _SortDirection2.default.DESC])\n};","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = defaultCellDataGetter;\n\n\n/**\n * Default accessor for returning a cell value for a given attribute.\n * This function expects to operate on either a vanilla Object or an Immutable Map.\n * You should override the column's cellDataGetter if your data is some other type of object.\n */\nfunction defaultCellDataGetter(_ref) {\n  var columnData = _ref.columnData;\n  var dataKey = _ref.dataKey;\n  var rowData = _ref.rowData;\n\n  if (rowData.get instanceof Function) {\n    return rowData.get(dataKey);\n  } else {\n    return rowData[dataKey];\n  }\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = defaultCellRenderer;\n\n\n/**\n * Default cell renderer that displays an attribute as a simple string\n * You should override the column's cellRenderer if your data is some other type of object.\n */\nfunction defaultCellRenderer(_ref) {\n  var cellData = _ref.cellData;\n  var cellDataKey = _ref.cellDataKey;\n  var columnData = _ref.columnData;\n  var rowData = _ref.rowData;\n  var rowIndex = _ref.rowIndex;\n\n  if (cellData == null) {\n    return '';\n  } else {\n    return String(cellData);\n  }\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = defaultHeaderRenderer;\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _SortIndicator = require('./SortIndicator');\n\nvar _SortIndicator2 = _interopRequireDefault(_SortIndicator);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Default table header renderer.\n */\nfunction defaultHeaderRenderer(_ref) {\n  var columnData = _ref.columnData;\n  var dataKey = _ref.dataKey;\n  var disableSort = _ref.disableSort;\n  var label = _ref.label;\n  var sortBy = _ref.sortBy;\n  var sortDirection = _ref.sortDirection;\n\n  var showSortIndicator = sortBy === dataKey;\n  var children = [_react2.default.createElement(\n    'span',\n    {\n      className: 'FlexTable__headerTruncatedText',\n      key: 'label',\n      title: label\n    },\n    label\n  )];\n\n  if (showSortIndicator) {\n    children.push(_react2.default.createElement(_SortIndicator2.default, {\n      key: 'SortIndicator',\n      sortDirection: sortDirection\n    }));\n  }\n\n  return children;\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nexports.default = defaultRowRenderer;\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Default row renderer for FlexTable.\n */\nfunction defaultRowRenderer(_ref) {\n  var className = _ref.className;\n  var columns = _ref.columns;\n  var index = _ref.index;\n  var isScrolling = _ref.isScrolling;\n  var onRowClick = _ref.onRowClick;\n  var onRowDoubleClick = _ref.onRowDoubleClick;\n  var onRowMouseOver = _ref.onRowMouseOver;\n  var onRowMouseOut = _ref.onRowMouseOut;\n  var rowData = _ref.rowData;\n  var style = _ref.style;\n\n  var a11yProps = {};\n\n  if (onRowClick || onRowDoubleClick || onRowMouseOver || onRowMouseOut) {\n    a11yProps['aria-label'] = 'row';\n    a11yProps.role = 'row';\n    a11yProps.tabIndex = 0;\n\n    if (onRowClick) {\n      a11yProps.onClick = function () {\n        return onRowClick({ index: index });\n      };\n    }\n    if (onRowDoubleClick) {\n      a11yProps.onDoubleClick = function () {\n        return onRowDoubleClick({ index: index });\n      };\n    }\n    if (onRowMouseOut) {\n      a11yProps.onMouseOut = function () {\n        return onRowMouseOut({ index: index });\n      };\n    }\n    if (onRowMouseOver) {\n      a11yProps.onMouseOver = function () {\n        return onRowMouseOver({ index: index });\n      };\n    }\n  }\n\n  return _react2.default.createElement(\n    'div',\n    _extends({}, a11yProps, {\n      className: className,\n      style: style\n    }),\n    columns\n  );\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.SortIndicator = exports.SortDirection = exports.FlexColumn = exports.FlexTable = exports.defaultRowRenderer = exports.defaultHeaderRenderer = exports.defaultCellRenderer = exports.defaultCellDataGetter = exports.default = undefined;\n\nvar _FlexTable2 = require('./FlexTable');\n\nvar _FlexTable3 = _interopRequireDefault(_FlexTable2);\n\nvar _defaultCellDataGetter2 = require('./defaultCellDataGetter');\n\nvar _defaultCellDataGetter3 = _interopRequireDefault(_defaultCellDataGetter2);\n\nvar _defaultCellRenderer2 = require('./defaultCellRenderer');\n\nvar _defaultCellRenderer3 = _interopRequireDefault(_defaultCellRenderer2);\n\nvar _defaultHeaderRenderer2 = require('./defaultHeaderRenderer');\n\nvar _defaultHeaderRenderer3 = _interopRequireDefault(_defaultHeaderRenderer2);\n\nvar _defaultRowRenderer2 = require('./defaultRowRenderer');\n\nvar _defaultRowRenderer3 = _interopRequireDefault(_defaultRowRenderer2);\n\nvar _FlexColumn2 = require('./FlexColumn');\n\nvar _FlexColumn3 = _interopRequireDefault(_FlexColumn2);\n\nvar _SortDirection2 = require('./SortDirection');\n\nvar _SortDirection3 = _interopRequireDefault(_SortDirection2);\n\nvar _SortIndicator2 = require('./SortIndicator');\n\nvar _SortIndicator3 = _interopRequireDefault(_SortIndicator2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _FlexTable3.default;\nexports.defaultCellDataGetter = _defaultCellDataGetter3.default;\nexports.defaultCellRenderer = _defaultCellRenderer3.default;\nexports.defaultHeaderRenderer = _defaultHeaderRenderer3.default;\nexports.defaultRowRenderer = _defaultRowRenderer3.default;\nexports.FlexTable = _FlexTable3.default;\nexports.FlexColumn = _FlexColumn3.default;\nexports.SortDirection = _SortDirection3.default;\nexports.SortIndicator = _SortIndicator3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.DEFAULT_SCROLLING_RESET_TIME_INTERVAL = undefined;\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _classnames = require('classnames');\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nvar _calculateSizeAndPositionDataAndUpdateScrollOffset = require('./utils/calculateSizeAndPositionDataAndUpdateScrollOffset');\n\nvar _calculateSizeAndPositionDataAndUpdateScrollOffset2 = _interopRequireDefault(_calculateSizeAndPositionDataAndUpdateScrollOffset);\n\nvar _ScalingCellSizeAndPositionManager = require('./utils/ScalingCellSizeAndPositionManager');\n\nvar _ScalingCellSizeAndPositionManager2 = _interopRequireDefault(_ScalingCellSizeAndPositionManager);\n\nvar _createCallbackMemoizer = require('../utils/createCallbackMemoizer');\n\nvar _createCallbackMemoizer2 = _interopRequireDefault(_createCallbackMemoizer);\n\nvar _getOverscanIndices = require('./utils/getOverscanIndices');\n\nvar _getOverscanIndices2 = _interopRequireDefault(_getOverscanIndices);\n\nvar _scrollbarSize = require('dom-helpers/util/scrollbarSize');\n\nvar _scrollbarSize2 = _interopRequireDefault(_scrollbarSize);\n\nvar _raf = require('raf');\n\nvar _raf2 = _interopRequireDefault(_raf);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nvar _updateScrollIndexHelper = require('./utils/updateScrollIndexHelper');\n\nvar _updateScrollIndexHelper2 = _interopRequireDefault(_updateScrollIndexHelper);\n\nvar _defaultCellRangeRenderer = require('./defaultCellRangeRenderer');\n\nvar _defaultCellRangeRenderer2 = _interopRequireDefault(_defaultCellRangeRenderer);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * Specifies the number of miliseconds during which to disable pointer events while a scroll is in progress.\n * This improves performance and makes scrolling smoother.\n */\nvar DEFAULT_SCROLLING_RESET_TIME_INTERVAL = exports.DEFAULT_SCROLLING_RESET_TIME_INTERVAL = 150;\n\n/**\n * Controls whether the Grid updates the DOM element's scrollLeft/scrollTop based on the current state or just observes it.\n * This prevents Grid from interrupting mouse-wheel animations (see issue #2).\n */\nvar SCROLL_POSITION_CHANGE_REASONS = {\n  OBSERVED: 'observed',\n  REQUESTED: 'requested'\n};\n\n/**\n * Renders tabular data with virtualization along the vertical and horizontal axes.\n * Row heights and column widths must be known ahead of time and specified as properties.\n */\n\nvar Grid = function (_Component) {\n  _inherits(Grid, _Component);\n\n  function Grid(props, context) {\n    _classCallCheck(this, Grid);\n\n    var _this = _possibleConstructorReturn(this, (Grid.__proto__ || Object.getPrototypeOf(Grid)).call(this, props, context));\n\n    _this.state = {\n      isScrolling: false,\n      scrollDirectionHorizontal: _getOverscanIndices.SCROLL_DIRECTION_FIXED,\n      scrollDirectionVertical: _getOverscanIndices.SCROLL_DIRECTION_FIXED,\n      scrollLeft: 0,\n      scrollTop: 0\n    };\n\n    // Invokes onSectionRendered callback only when start/stop row or column indices change\n    _this._onGridRenderedMemoizer = (0, _createCallbackMemoizer2.default)();\n    _this._onScrollMemoizer = (0, _createCallbackMemoizer2.default)(false);\n\n    // Bind functions to instance so they don't lose context when passed around\n    _this._enablePointerEventsAfterDelayCallback = _this._enablePointerEventsAfterDelayCallback.bind(_this);\n    _this._invokeOnGridRenderedHelper = _this._invokeOnGridRenderedHelper.bind(_this);\n    _this._onScroll = _this._onScroll.bind(_this);\n    _this._setNextStateCallback = _this._setNextStateCallback.bind(_this);\n    _this._updateScrollLeftForScrollToColumn = _this._updateScrollLeftForScrollToColumn.bind(_this);\n    _this._updateScrollTopForScrollToRow = _this._updateScrollTopForScrollToRow.bind(_this);\n\n    _this._columnWidthGetter = _this._wrapSizeGetter(props.columnWidth);\n    _this._rowHeightGetter = _this._wrapSizeGetter(props.rowHeight);\n\n    _this._columnSizeAndPositionManager = new _ScalingCellSizeAndPositionManager2.default({\n      cellCount: props.columnCount,\n      cellSizeGetter: function cellSizeGetter(index) {\n        return _this._columnWidthGetter(index);\n      },\n      estimatedCellSize: _this._getEstimatedColumnSize(props)\n    });\n    _this._rowSizeAndPositionManager = new _ScalingCellSizeAndPositionManager2.default({\n      cellCount: props.rowCount,\n      cellSizeGetter: function cellSizeGetter(index) {\n        return _this._rowHeightGetter(index);\n      },\n      estimatedCellSize: _this._getEstimatedRowSize(props)\n    });\n\n    // See defaultCellRangeRenderer() for more information on the usage of this cache\n    _this._cellCache = {};\n    return _this;\n  }\n\n  /**\n   * Pre-measure all columns and rows in a Grid.\n   * Typically cells are only measured as needed and estimated sizes are used for cells that have not yet been measured.\n   * This method ensures that the next call to getTotalSize() returns an exact size (as opposed to just an estimated one).\n   */\n\n\n  _createClass(Grid, [{\n    key: 'measureAllCells',\n    value: function measureAllCells() {\n      var _props = this.props;\n      var columnCount = _props.columnCount;\n      var rowCount = _props.rowCount;\n\n\n      this._columnSizeAndPositionManager.getSizeAndPositionOfCell(columnCount - 1);\n      this._rowSizeAndPositionManager.getSizeAndPositionOfCell(rowCount - 1);\n    }\n\n    /**\n     * Forced recompute of row heights and column widths.\n     * This function should be called if dynamic column or row sizes have changed but nothing else has.\n     * Since Grid only receives :columnCount and :rowCount it has no way of detecting when the underlying data changes.\n     */\n\n  }, {\n    key: 'recomputeGridSize',\n    value: function recomputeGridSize() {\n      var _ref = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n      var _ref$columnIndex = _ref.columnIndex;\n      var columnIndex = _ref$columnIndex === undefined ? 0 : _ref$columnIndex;\n      var _ref$rowIndex = _ref.rowIndex;\n      var rowIndex = _ref$rowIndex === undefined ? 0 : _ref$rowIndex;\n\n      this._columnSizeAndPositionManager.resetCell(columnIndex);\n      this._rowSizeAndPositionManager.resetCell(rowIndex);\n\n      // Clear cell cache in case we are scrolling;\n      // Invalid row heights likely mean invalid cached content as well.\n      this._cellCache = {};\n\n      this.forceUpdate();\n    }\n  }, {\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      var _props2 = this.props;\n      var scrollLeft = _props2.scrollLeft;\n      var scrollToColumn = _props2.scrollToColumn;\n      var scrollTop = _props2.scrollTop;\n      var scrollToRow = _props2.scrollToRow;\n\n      // If this component was first rendered server-side, scrollbar size will be undefined.\n      // In that event we need to remeasure.\n\n      if (!this._scrollbarSizeMeasured) {\n        this._scrollbarSize = (0, _scrollbarSize2.default)();\n        this._scrollbarSizeMeasured = true;\n        this.setState({});\n      }\n\n      if (scrollLeft >= 0 || scrollTop >= 0) {\n        this._setScrollPosition({ scrollLeft: scrollLeft, scrollTop: scrollTop });\n      }\n\n      if (scrollToColumn >= 0 || scrollToRow >= 0) {\n        this._updateScrollLeftForScrollToColumn();\n        this._updateScrollTopForScrollToRow();\n      }\n\n      // Update onRowsRendered callback\n      this._invokeOnGridRenderedHelper();\n\n      // Initialize onScroll callback\n      this._invokeOnScrollMemoizer({\n        scrollLeft: scrollLeft || 0,\n        scrollTop: scrollTop || 0,\n        totalColumnsWidth: this._columnSizeAndPositionManager.getTotalSize(),\n        totalRowsHeight: this._rowSizeAndPositionManager.getTotalSize()\n      });\n    }\n\n    /**\n     * @private\n     * This method updates scrollLeft/scrollTop in state for the following conditions:\n     * 1) New scroll-to-cell props have been set\n     */\n\n  }, {\n    key: 'componentDidUpdate',\n    value: function componentDidUpdate(prevProps, prevState) {\n      var _this2 = this;\n\n      var _props3 = this.props;\n      var autoHeight = _props3.autoHeight;\n      var columnCount = _props3.columnCount;\n      var height = _props3.height;\n      var rowCount = _props3.rowCount;\n      var scrollToAlignment = _props3.scrollToAlignment;\n      var scrollToColumn = _props3.scrollToColumn;\n      var scrollToRow = _props3.scrollToRow;\n      var width = _props3.width;\n      var _state = this.state;\n      var scrollLeft = _state.scrollLeft;\n      var scrollPositionChangeReason = _state.scrollPositionChangeReason;\n      var scrollTop = _state.scrollTop;\n\n      // Handle edge case where column or row count has only just increased over 0.\n      // In this case we may have to restore a previously-specified scroll offset.\n      // For more info see bvaughn/react-virtualized/issues/218\n\n      var columnOrRowCountJustIncreasedFromZero = columnCount > 0 && prevProps.columnCount === 0 || rowCount > 0 && prevProps.rowCount === 0;\n\n      // Make sure requested changes to :scrollLeft or :scrollTop get applied.\n      // Assigning to scrollLeft/scrollTop tells the browser to interrupt any running scroll animations,\n      // And to discard any pending async changes to the scroll position that may have happened in the meantime (e.g. on a separate scrolling thread).\n      // So we only set these when we require an adjustment of the scroll position.\n      // See issue #2 for more information.\n      if (scrollPositionChangeReason === SCROLL_POSITION_CHANGE_REASONS.REQUESTED) {\n        if (scrollLeft >= 0 && (scrollLeft !== prevState.scrollLeft && scrollLeft !== this._scrollingContainer.scrollLeft || columnOrRowCountJustIncreasedFromZero)) {\n          this._scrollingContainer.scrollLeft = scrollLeft;\n        }\n\n        // @TRICKY :autoHeight property instructs Grid to leave :scrollTop management to an external HOC (eg WindowScroller).\n        // In this case we should avoid checking scrollingContainer.scrollTop since it forces layout/flow.\n        if (!autoHeight && scrollTop >= 0 && (scrollTop !== prevState.scrollTop && scrollTop !== this._scrollingContainer.scrollTop || columnOrRowCountJustIncreasedFromZero)) {\n          this._scrollingContainer.scrollTop = scrollTop;\n        }\n      }\n\n      // Update scroll offsets if the current :scrollToColumn or :scrollToRow values requires it\n      // @TODO Do we also need this check or can the one in componentWillUpdate() suffice?\n      (0, _updateScrollIndexHelper2.default)({\n        cellSizeAndPositionManager: this._columnSizeAndPositionManager,\n        previousCellsCount: prevProps.columnCount,\n        previousCellSize: prevProps.columnWidth,\n        previousScrollToAlignment: prevProps.scrollToAlignment,\n        previousScrollToIndex: prevProps.scrollToColumn,\n        previousSize: prevProps.width,\n        scrollOffset: scrollLeft,\n        scrollToAlignment: scrollToAlignment,\n        scrollToIndex: scrollToColumn,\n        size: width,\n        updateScrollIndexCallback: function updateScrollIndexCallback(scrollToColumn) {\n          return _this2._updateScrollLeftForScrollToColumn(_extends({}, _this2.props, { scrollToColumn: scrollToColumn }));\n        }\n      });\n      (0, _updateScrollIndexHelper2.default)({\n        cellSizeAndPositionManager: this._rowSizeAndPositionManager,\n        previousCellsCount: prevProps.rowCount,\n        previousCellSize: prevProps.rowHeight,\n        previousScrollToAlignment: prevProps.scrollToAlignment,\n        previousScrollToIndex: prevProps.scrollToRow,\n        previousSize: prevProps.height,\n        scrollOffset: scrollTop,\n        scrollToAlignment: scrollToAlignment,\n        scrollToIndex: scrollToRow,\n        size: height,\n        updateScrollIndexCallback: function updateScrollIndexCallback(scrollToRow) {\n          return _this2._updateScrollTopForScrollToRow(_extends({}, _this2.props, { scrollToRow: scrollToRow }));\n        }\n      });\n\n      // Update onRowsRendered callback if start/stop indices have changed\n      this._invokeOnGridRenderedHelper();\n    }\n  }, {\n    key: 'componentWillMount',\n    value: function componentWillMount() {\n      // If this component is being rendered server-side, getScrollbarSize() will return undefined.\n      // We handle this case in componentDidMount()\n      this._scrollbarSize = (0, _scrollbarSize2.default)();\n      if (this._scrollbarSize === undefined) {\n        this._scrollbarSizeMeasured = false;\n        this._scrollbarSize = 0;\n      } else {\n        this._scrollbarSizeMeasured = true;\n      }\n\n      this._calculateChildrenToRender();\n    }\n  }, {\n    key: 'componentWillUnmount',\n    value: function componentWillUnmount() {\n      if (this._disablePointerEventsTimeoutId) {\n        clearTimeout(this._disablePointerEventsTimeoutId);\n      }\n\n      if (this._setNextStateAnimationFrameId) {\n        _raf2.default.cancel(this._setNextStateAnimationFrameId);\n      }\n    }\n\n    /**\n     * @private\n     * This method updates scrollLeft/scrollTop in state for the following conditions:\n     * 1) Empty content (0 rows or columns)\n     * 2) New scroll props overriding the current state\n     * 3) Cells-count or cells-size has changed, making previous scroll offsets invalid\n     */\n\n  }, {\n    key: 'componentWillUpdate',\n    value: function componentWillUpdate(nextProps, nextState) {\n      var _this3 = this;\n\n      if (nextProps.columnCount === 0 && nextState.scrollLeft !== 0 || nextProps.rowCount === 0 && nextState.scrollTop !== 0) {\n        this._setScrollPosition({\n          scrollLeft: 0,\n          scrollTop: 0\n        });\n      } else if (nextProps.scrollLeft !== this.props.scrollLeft || nextProps.scrollTop !== this.props.scrollTop) {\n        this._setScrollPosition({\n          scrollLeft: nextProps.scrollLeft,\n          scrollTop: nextProps.scrollTop\n        });\n      }\n\n      this._columnWidthGetter = this._wrapSizeGetter(nextProps.columnWidth);\n      this._rowHeightGetter = this._wrapSizeGetter(nextProps.rowHeight);\n\n      this._columnSizeAndPositionManager.configure({\n        cellCount: nextProps.columnCount,\n        estimatedCellSize: this._getEstimatedColumnSize(nextProps)\n      });\n      this._rowSizeAndPositionManager.configure({\n        cellCount: nextProps.rowCount,\n        estimatedCellSize: this._getEstimatedRowSize(nextProps)\n      });\n\n      // Update scroll offsets if the size or number of cells have changed, invalidating the previous value\n      (0, _calculateSizeAndPositionDataAndUpdateScrollOffset2.default)({\n        cellCount: this.props.columnCount,\n        cellSize: this.props.columnWidth,\n        computeMetadataCallback: function computeMetadataCallback() {\n          return _this3._columnSizeAndPositionManager.resetCell(0);\n        },\n        computeMetadataCallbackProps: nextProps,\n        nextCellsCount: nextProps.columnCount,\n        nextCellSize: nextProps.columnWidth,\n        nextScrollToIndex: nextProps.scrollToColumn,\n        scrollToIndex: this.props.scrollToColumn,\n        updateScrollOffsetForScrollToIndex: function updateScrollOffsetForScrollToIndex() {\n          return _this3._updateScrollLeftForScrollToColumn(nextProps, nextState);\n        }\n      });\n      (0, _calculateSizeAndPositionDataAndUpdateScrollOffset2.default)({\n        cellCount: this.props.rowCount,\n        cellSize: this.props.rowHeight,\n        computeMetadataCallback: function computeMetadataCallback() {\n          return _this3._rowSizeAndPositionManager.resetCell(0);\n        },\n        computeMetadataCallbackProps: nextProps,\n        nextCellsCount: nextProps.rowCount,\n        nextCellSize: nextProps.rowHeight,\n        nextScrollToIndex: nextProps.scrollToRow,\n        scrollToIndex: this.props.scrollToRow,\n        updateScrollOffsetForScrollToIndex: function updateScrollOffsetForScrollToIndex() {\n          return _this3._updateScrollTopForScrollToRow(nextProps, nextState);\n        }\n      });\n\n      this._calculateChildrenToRender(nextProps, nextState);\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _this4 = this;\n\n      var _props4 = this.props;\n      var autoContainerWidth = _props4.autoContainerWidth;\n      var autoHeight = _props4.autoHeight;\n      var className = _props4.className;\n      var height = _props4.height;\n      var noContentRenderer = _props4.noContentRenderer;\n      var style = _props4.style;\n      var tabIndex = _props4.tabIndex;\n      var width = _props4.width;\n      var isScrolling = this.state.isScrolling;\n\n\n      var gridStyle = {\n        height: autoHeight ? 'auto' : height,\n        width: width\n      };\n\n      var totalColumnsWidth = this._columnSizeAndPositionManager.getTotalSize();\n      var totalRowsHeight = this._rowSizeAndPositionManager.getTotalSize();\n\n      // Force browser to hide scrollbars when we know they aren't necessary.\n      // Otherwise once scrollbars appear they may not disappear again.\n      // For more info see issue #116\n      var verticalScrollBarSize = totalRowsHeight > height ? this._scrollbarSize : 0;\n      var horizontalScrollBarSize = totalColumnsWidth > width ? this._scrollbarSize : 0;\n\n      // Also explicitly init styles to 'auto' if scrollbars are required.\n      // This works around an obscure edge case where external CSS styles have not yet been loaded,\n      // But an initial scroll index of offset is set as an external prop.\n      // Without this style, Grid would render the correct range of cells but would NOT update its internal offset.\n      // This was originally reported via clauderic/react-infinite-calendar/issues/23\n      gridStyle.overflowX = totalColumnsWidth + verticalScrollBarSize <= width ? 'hidden' : 'auto';\n      gridStyle.overflowY = totalRowsHeight + horizontalScrollBarSize <= height ? 'hidden' : 'auto';\n\n      var childrenToDisplay = this._childrenToDisplay;\n\n      var showNoContentRenderer = childrenToDisplay.length === 0 && height > 0 && width > 0;\n\n      return _react2.default.createElement(\n        'div',\n        {\n          ref: function ref(_ref2) {\n            _this4._scrollingContainer = _ref2;\n          },\n          'aria-label': this.props['aria-label'],\n          className: (0, _classnames2.default)('Grid', className),\n          onScroll: this._onScroll,\n          role: 'grid',\n          style: _extends({}, gridStyle, style),\n          tabIndex: tabIndex\n        },\n        childrenToDisplay.length > 0 && _react2.default.createElement(\n          'div',\n          {\n            className: 'Grid__innerScrollContainer',\n            style: {\n              width: autoContainerWidth ? 'auto' : totalColumnsWidth,\n              height: totalRowsHeight,\n              maxWidth: totalColumnsWidth,\n              maxHeight: totalRowsHeight,\n              pointerEvents: isScrolling ? 'none' : ''\n            }\n          },\n          childrenToDisplay\n        ),\n        showNoContentRenderer && noContentRenderer()\n      );\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n\n    /* ---------------------------- Helper methods ---------------------------- */\n\n  }, {\n    key: '_calculateChildrenToRender',\n    value: function _calculateChildrenToRender() {\n      var props = arguments.length <= 0 || arguments[0] === undefined ? this.props : arguments[0];\n      var state = arguments.length <= 1 || arguments[1] === undefined ? this.state : arguments[1];\n      var cellClassName = props.cellClassName;\n      var cellRenderer = props.cellRenderer;\n      var cellRangeRenderer = props.cellRangeRenderer;\n      var cellStyle = props.cellStyle;\n      var columnCount = props.columnCount;\n      var height = props.height;\n      var overscanColumnCount = props.overscanColumnCount;\n      var overscanRowCount = props.overscanRowCount;\n      var rowCount = props.rowCount;\n      var width = props.width;\n      var isScrolling = state.isScrolling;\n      var scrollDirectionHorizontal = state.scrollDirectionHorizontal;\n      var scrollDirectionVertical = state.scrollDirectionVertical;\n      var scrollLeft = state.scrollLeft;\n      var scrollTop = state.scrollTop;\n\n\n      this._childrenToDisplay = [];\n\n      // Render only enough columns and rows to cover the visible area of the grid.\n      if (height > 0 && width > 0) {\n        var visibleColumnIndices = this._columnSizeAndPositionManager.getVisibleCellRange({\n          containerSize: width,\n          offset: scrollLeft\n        });\n        var visibleRowIndices = this._rowSizeAndPositionManager.getVisibleCellRange({\n          containerSize: height,\n          offset: scrollTop\n        });\n\n        var horizontalOffsetAdjustment = this._columnSizeAndPositionManager.getOffsetAdjustment({\n          containerSize: width,\n          offset: scrollLeft\n        });\n        var verticalOffsetAdjustment = this._rowSizeAndPositionManager.getOffsetAdjustment({\n          containerSize: height,\n          offset: scrollTop\n        });\n\n        // Store for _invokeOnGridRenderedHelper()\n        this._renderedColumnStartIndex = visibleColumnIndices.start;\n        this._renderedColumnStopIndex = visibleColumnIndices.stop;\n        this._renderedRowStartIndex = visibleRowIndices.start;\n        this._renderedRowStopIndex = visibleRowIndices.stop;\n\n        var overscanColumnIndices = (0, _getOverscanIndices2.default)({\n          cellCount: columnCount,\n          overscanCellsCount: overscanColumnCount,\n          scrollDirection: scrollDirectionHorizontal,\n          startIndex: this._renderedColumnStartIndex,\n          stopIndex: this._renderedColumnStopIndex\n        });\n\n        var overscanRowIndices = (0, _getOverscanIndices2.default)({\n          cellCount: rowCount,\n          overscanCellsCount: overscanRowCount,\n          scrollDirection: scrollDirectionVertical,\n          startIndex: this._renderedRowStartIndex,\n          stopIndex: this._renderedRowStopIndex\n        });\n\n        // Store for _invokeOnGridRenderedHelper()\n        this._columnStartIndex = overscanColumnIndices.overscanStartIndex;\n        this._columnStopIndex = overscanColumnIndices.overscanStopIndex;\n        this._rowStartIndex = overscanRowIndices.overscanStartIndex;\n        this._rowStopIndex = overscanRowIndices.overscanStopIndex;\n\n        this._childrenToDisplay = cellRangeRenderer({\n          cellCache: this._cellCache,\n          cellClassName: this._wrapCellClassNameGetter(cellClassName),\n          cellRenderer: cellRenderer,\n          cellStyle: this._wrapCellStyleGetter(cellStyle),\n          columnSizeAndPositionManager: this._columnSizeAndPositionManager,\n          columnStartIndex: this._columnStartIndex,\n          columnStopIndex: this._columnStopIndex,\n          horizontalOffsetAdjustment: horizontalOffsetAdjustment,\n          isScrolling: isScrolling,\n          rowSizeAndPositionManager: this._rowSizeAndPositionManager,\n          rowStartIndex: this._rowStartIndex,\n          rowStopIndex: this._rowStopIndex,\n          scrollLeft: scrollLeft,\n          scrollTop: scrollTop,\n          verticalOffsetAdjustment: verticalOffsetAdjustment\n        });\n      }\n    }\n\n    /**\n     * Sets an :isScrolling flag for a small window of time.\n     * This flag is used to disable pointer events on the scrollable portion of the Grid.\n     * This prevents jerky/stuttery mouse-wheel scrolling.\n     */\n\n  }, {\n    key: '_enablePointerEventsAfterDelay',\n    value: function _enablePointerEventsAfterDelay() {\n      var scrollingResetTimeInterval = this.props.scrollingResetTimeInterval;\n\n\n      if (this._disablePointerEventsTimeoutId) {\n        clearTimeout(this._disablePointerEventsTimeoutId);\n      }\n\n      this._disablePointerEventsTimeoutId = setTimeout(this._enablePointerEventsAfterDelayCallback, scrollingResetTimeInterval);\n    }\n  }, {\n    key: '_enablePointerEventsAfterDelayCallback',\n    value: function _enablePointerEventsAfterDelayCallback() {\n      this._disablePointerEventsTimeoutId = null;\n\n      // Throw away cell cache once scrolling is complete\n      this._cellCache = {};\n\n      this.setState({\n        isScrolling: false,\n        scrollDirectionHorizontal: _getOverscanIndices.SCROLL_DIRECTION_FIXED,\n        scrollDirectionVertical: _getOverscanIndices.SCROLL_DIRECTION_FIXED\n      });\n    }\n  }, {\n    key: '_getEstimatedColumnSize',\n    value: function _getEstimatedColumnSize(props) {\n      return typeof props.columnWidth === 'number' ? props.columnWidth : props.estimatedColumnSize;\n    }\n  }, {\n    key: '_getEstimatedRowSize',\n    value: function _getEstimatedRowSize(props) {\n      return typeof props.rowHeight === 'number' ? props.rowHeight : props.estimatedRowSize;\n    }\n  }, {\n    key: '_invokeOnGridRenderedHelper',\n    value: function _invokeOnGridRenderedHelper() {\n      var onSectionRendered = this.props.onSectionRendered;\n\n\n      this._onGridRenderedMemoizer({\n        callback: onSectionRendered,\n        indices: {\n          columnOverscanStartIndex: this._columnStartIndex,\n          columnOverscanStopIndex: this._columnStopIndex,\n          columnStartIndex: this._renderedColumnStartIndex,\n          columnStopIndex: this._renderedColumnStopIndex,\n          rowOverscanStartIndex: this._rowStartIndex,\n          rowOverscanStopIndex: this._rowStopIndex,\n          rowStartIndex: this._renderedRowStartIndex,\n          rowStopIndex: this._renderedRowStopIndex\n        }\n      });\n    }\n  }, {\n    key: '_invokeOnScrollMemoizer',\n    value: function _invokeOnScrollMemoizer(_ref3) {\n      var _this5 = this;\n\n      var scrollLeft = _ref3.scrollLeft;\n      var scrollTop = _ref3.scrollTop;\n      var totalColumnsWidth = _ref3.totalColumnsWidth;\n      var totalRowsHeight = _ref3.totalRowsHeight;\n\n      this._onScrollMemoizer({\n        callback: function callback(_ref4) {\n          var scrollLeft = _ref4.scrollLeft;\n          var scrollTop = _ref4.scrollTop;\n          var _props5 = _this5.props;\n          var height = _props5.height;\n          var onScroll = _props5.onScroll;\n          var width = _props5.width;\n\n\n          onScroll({\n            clientHeight: height,\n            clientWidth: width,\n            scrollHeight: totalRowsHeight,\n            scrollLeft: scrollLeft,\n            scrollTop: scrollTop,\n            scrollWidth: totalColumnsWidth\n          });\n        },\n        indices: {\n          scrollLeft: scrollLeft,\n          scrollTop: scrollTop\n        }\n      });\n    }\n\n    /**\n     * Updates the state during the next animation frame.\n     * Use this method to avoid multiple renders in a small span of time.\n     * This helps performance for bursty events (like onScroll).\n     */\n\n  }, {\n    key: '_setNextState',\n    value: function _setNextState(state) {\n      this._nextState = state;\n\n      if (!this._setNextStateAnimationFrameId) {\n        this._setNextStateAnimationFrameId = (0, _raf2.default)(this._setNextStateCallback);\n      }\n    }\n  }, {\n    key: '_setNextStateCallback',\n    value: function _setNextStateCallback() {\n      var state = this._nextState;\n\n      this._setNextStateAnimationFrameId = null;\n      this._nextState = null;\n\n      this.setState(state);\n    }\n  }, {\n    key: '_setScrollPosition',\n    value: function _setScrollPosition(_ref5) {\n      var scrollLeft = _ref5.scrollLeft;\n      var scrollTop = _ref5.scrollTop;\n\n      var newState = {\n        scrollPositionChangeReason: SCROLL_POSITION_CHANGE_REASONS.REQUESTED\n      };\n\n      if (scrollLeft >= 0) {\n        newState.scrollLeft = scrollLeft;\n      }\n\n      if (scrollTop >= 0) {\n        newState.scrollTop = scrollTop;\n      }\n\n      if (scrollLeft >= 0 && scrollLeft !== this.state.scrollLeft || scrollTop >= 0 && scrollTop !== this.state.scrollTop) {\n        this.setState(newState);\n      }\n    }\n  }, {\n    key: '_wrapCellClassNameGetter',\n    value: function _wrapCellClassNameGetter(className) {\n      return this._wrapPropertyGetter(className);\n    }\n  }, {\n    key: '_wrapCellStyleGetter',\n    value: function _wrapCellStyleGetter(style) {\n      return this._wrapPropertyGetter(style);\n    }\n  }, {\n    key: '_wrapPropertyGetter',\n    value: function _wrapPropertyGetter(value) {\n      return value instanceof Function ? value : function () {\n        return value;\n      };\n    }\n  }, {\n    key: '_wrapSizeGetter',\n    value: function _wrapSizeGetter(size) {\n      return this._wrapPropertyGetter(size);\n    }\n  }, {\n    key: '_updateScrollLeftForScrollToColumn',\n    value: function _updateScrollLeftForScrollToColumn() {\n      var props = arguments.length <= 0 || arguments[0] === undefined ? this.props : arguments[0];\n      var state = arguments.length <= 1 || arguments[1] === undefined ? this.state : arguments[1];\n      var columnCount = props.columnCount;\n      var scrollToAlignment = props.scrollToAlignment;\n      var scrollToColumn = props.scrollToColumn;\n      var width = props.width;\n      var scrollLeft = state.scrollLeft;\n\n\n      if (scrollToColumn >= 0 && columnCount > 0) {\n        var targetIndex = Math.max(0, Math.min(columnCount - 1, scrollToColumn));\n\n        var calculatedScrollLeft = this._columnSizeAndPositionManager.getUpdatedOffsetForIndex({\n          align: scrollToAlignment,\n          containerSize: width,\n          currentOffset: scrollLeft,\n          targetIndex: targetIndex\n        });\n\n        if (scrollLeft !== calculatedScrollLeft) {\n          this._setScrollPosition({\n            scrollLeft: calculatedScrollLeft\n          });\n        }\n      }\n    }\n  }, {\n    key: '_updateScrollTopForScrollToRow',\n    value: function _updateScrollTopForScrollToRow() {\n      var props = arguments.length <= 0 || arguments[0] === undefined ? this.props : arguments[0];\n      var state = arguments.length <= 1 || arguments[1] === undefined ? this.state : arguments[1];\n      var height = props.height;\n      var rowCount = props.rowCount;\n      var scrollToAlignment = props.scrollToAlignment;\n      var scrollToRow = props.scrollToRow;\n      var scrollTop = state.scrollTop;\n\n\n      if (scrollToRow >= 0 && rowCount > 0) {\n        var targetIndex = Math.max(0, Math.min(rowCount - 1, scrollToRow));\n\n        var calculatedScrollTop = this._rowSizeAndPositionManager.getUpdatedOffsetForIndex({\n          align: scrollToAlignment,\n          containerSize: height,\n          currentOffset: scrollTop,\n          targetIndex: targetIndex\n        });\n\n        if (scrollTop !== calculatedScrollTop) {\n          this._setScrollPosition({\n            scrollTop: calculatedScrollTop\n          });\n        }\n      }\n    }\n  }, {\n    key: '_onScroll',\n    value: function _onScroll(event) {\n      // In certain edge-cases React dispatches an onScroll event with an invalid target.scrollLeft / target.scrollTop.\n      // This invalid event can be detected by comparing event.target to this component's scrollable DOM element.\n      // See issue #404 for more information.\n      if (event.target !== this._scrollingContainer) {\n        return;\n      }\n\n      // Prevent pointer events from interrupting a smooth scroll\n      this._enablePointerEventsAfterDelay();\n\n      // When this component is shrunk drastically, React dispatches a series of back-to-back scroll events,\n      // Gradually converging on a scrollTop that is within the bounds of the new, smaller height.\n      // This causes a series of rapid renders that is slow for long lists.\n      // We can avoid that by doing some simple bounds checking to ensure that scrollTop never exceeds the total height.\n      var _props6 = this.props;\n      var height = _props6.height;\n      var width = _props6.width;\n\n      var scrollbarSize = this._scrollbarSize;\n      var totalRowsHeight = this._rowSizeAndPositionManager.getTotalSize();\n      var totalColumnsWidth = this._columnSizeAndPositionManager.getTotalSize();\n      var scrollLeft = Math.min(Math.max(0, totalColumnsWidth - width + scrollbarSize), event.target.scrollLeft);\n      var scrollTop = Math.min(Math.max(0, totalRowsHeight - height + scrollbarSize), event.target.scrollTop);\n\n      // Certain devices (like Apple touchpad) rapid-fire duplicate events.\n      // Don't force a re-render if this is the case.\n      // The mouse may move faster then the animation frame does.\n      // Use requestAnimationFrame to avoid over-updating.\n      if (this.state.scrollLeft !== scrollLeft || this.state.scrollTop !== scrollTop) {\n        // Browsers with cancelable scroll events (eg. Firefox) interrupt scrolling animations if scrollTop/scrollLeft is set.\n        // Other browsers (eg. Safari) don't scroll as well without the help under certain conditions (DOM or style changes during scrolling).\n        // All things considered, this seems to be the best current work around that I'm aware of.\n        // For more information see https://github.com/bvaughn/react-virtualized/pull/124\n        var scrollPositionChangeReason = event.cancelable ? SCROLL_POSITION_CHANGE_REASONS.OBSERVED : SCROLL_POSITION_CHANGE_REASONS.REQUESTED;\n\n        // Track scrolling direction so we can more efficiently overscan rows to reduce empty space around the edges while scrolling.\n        var scrollDirectionVertical = scrollTop > this.state.scrollTop ? _getOverscanIndices.SCROLL_DIRECTION_FORWARD : _getOverscanIndices.SCROLL_DIRECTION_BACKWARD;\n        var scrollDirectionHorizontal = scrollLeft > this.state.scrollLeft ? _getOverscanIndices.SCROLL_DIRECTION_FORWARD : _getOverscanIndices.SCROLL_DIRECTION_BACKWARD;\n\n        if (!this.state.isScrolling) {\n          this.setState({\n            isScrolling: true\n          });\n        }\n\n        this._setNextState({\n          isScrolling: true,\n          scrollDirectionHorizontal: scrollDirectionHorizontal,\n          scrollDirectionVertical: scrollDirectionVertical,\n          scrollLeft: scrollLeft,\n          scrollPositionChangeReason: scrollPositionChangeReason,\n          scrollTop: scrollTop\n        });\n      }\n\n      this._invokeOnScrollMemoizer({ scrollLeft: scrollLeft, scrollTop: scrollTop, totalColumnsWidth: totalColumnsWidth, totalRowsHeight: totalRowsHeight });\n    }\n  }]);\n\n  return Grid;\n}(_react.Component);\n\nGrid.propTypes = {\n  'aria-label': _react.PropTypes.string,\n\n  /**\n   * Set the width of the inner scrollable container to 'auto'.\n   * This is useful for single-column Grids to ensure that the column doesn't extend below a vertical scrollbar.\n   */\n  autoContainerWidth: _react.PropTypes.bool,\n\n  /**\n   * Removes fixed height from the scrollingContainer so that the total height\n   * of rows can stretch the window. Intended for use with WindowScroller\n   */\n  autoHeight: _react.PropTypes.bool,\n\n  /** Optional custom CSS class for individual cells */\n  cellClassName: _react.PropTypes.oneOfType([_react.PropTypes.string, _react.PropTypes.func]),\n\n  /** Optional custom styles for individual cells */\n  cellStyle: _react.PropTypes.oneOfType([_react.PropTypes.object, _react.PropTypes.func]),\n\n  /**\n   * Responsible for rendering a cell given an row and column index.\n   * Should implement the following interface: ({ columnIndex: number, rowIndex: number }): PropTypes.node\n   */\n  cellRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Responsible for rendering a group of cells given their index ranges.\n   * Should implement the following interface: ({\n   *   cellCache: Map,\n   *   cellRenderer: Function,\n   *   columnSizeAndPositionManager: CellSizeAndPositionManager,\n   *   columnStartIndex: number,\n   *   columnStopIndex: number,\n   *   isScrolling: boolean,\n   *   rowSizeAndPositionManager: CellSizeAndPositionManager,\n   *   rowStartIndex: number,\n   *   rowStopIndex: number,\n   *   scrollLeft: number,\n   *   scrollTop: number\n   * }): Array<PropTypes.node>\n   */\n  cellRangeRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Optional custom CSS class name to attach to root Grid element.\n   */\n  className: _react.PropTypes.string,\n\n  /**\n   * Number of columns in grid.\n   */\n  columnCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Either a fixed column width (number) or a function that returns the width of a column given its index.\n   * Should implement the following interface: (index: number): number\n   */\n  columnWidth: _react.PropTypes.oneOfType([_react.PropTypes.number, _react.PropTypes.func]).isRequired,\n\n  /**\n   * Used to estimate the total width of a Grid before all of its columns have actually been measured.\n   * The estimated total width is adjusted as columns are rendered.\n   */\n  estimatedColumnSize: _react.PropTypes.number.isRequired,\n\n  /**\n   * Used to estimate the total height of a Grid before all of its rows have actually been measured.\n   * The estimated total height is adjusted as rows are rendered.\n   */\n  estimatedRowSize: _react.PropTypes.number.isRequired,\n\n  /**\n   * Height of Grid; this property determines the number of visible (vs virtualized) rows.\n   */\n  height: _react.PropTypes.number.isRequired,\n\n  /**\n   * Optional renderer to be used in place of rows when either :rowCount or :columnCount is 0.\n   */\n  noContentRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Callback invoked whenever the scroll offset changes within the inner scrollable region.\n   * This callback can be used to sync scrolling between lists, tables, or grids.\n   * ({ clientHeight, clientWidth, scrollHeight, scrollLeft, scrollTop, scrollWidth }): void\n   */\n  onScroll: _react.PropTypes.func.isRequired,\n\n  /**\n   * Callback invoked with information about the section of the Grid that was just rendered.\n   * ({ columnStartIndex, columnStopIndex, rowStartIndex, rowStopIndex }): void\n   */\n  onSectionRendered: _react.PropTypes.func.isRequired,\n\n  /**\n   * Number of columns to render before/after the visible section of the grid.\n   * These columns can help for smoother scrolling on touch devices or browsers that send scroll events infrequently.\n   */\n  overscanColumnCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Number of rows to render above/below the visible section of the grid.\n   * These rows can help for smoother scrolling on touch devices or browsers that send scroll events infrequently.\n   */\n  overscanRowCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Either a fixed row height (number) or a function that returns the height of a row given its index.\n   * Should implement the following interface: ({ index: number }): number\n   */\n  rowHeight: _react.PropTypes.oneOfType([_react.PropTypes.number, _react.PropTypes.func]).isRequired,\n\n  /**\n   * Number of rows in grid.\n   */\n  rowCount: _react.PropTypes.number.isRequired,\n\n  /** Wait this amount of time after the last scroll event before resetting Grid `pointer-events`. */\n  scrollingResetTimeInterval: _react.PropTypes.number,\n\n  /** Horizontal offset. */\n  scrollLeft: _react.PropTypes.number,\n\n  /**\n   * Controls scroll-to-cell behavior of the Grid.\n   * The default (\"auto\") scrolls the least amount possible to ensure that the specified cell is fully visible.\n   * Use \"start\" to align cells to the top/left of the Grid and \"end\" to align bottom/right.\n   */\n  scrollToAlignment: _react.PropTypes.oneOf(['auto', 'end', 'start', 'center']).isRequired,\n\n  /**\n   * Column index to ensure visible (by forcefully scrolling if necessary)\n   */\n  scrollToColumn: _react.PropTypes.number,\n\n  /** Vertical offset. */\n  scrollTop: _react.PropTypes.number,\n\n  /**\n   * Row index to ensure visible (by forcefully scrolling if necessary)\n   */\n  scrollToRow: _react.PropTypes.number,\n\n  /** Optional inline style */\n  style: _react.PropTypes.object,\n\n  /** Tab index for focus */\n  tabIndex: _react.PropTypes.number,\n\n  /**\n   * Width of Grid; this property determines the number of visible (vs virtualized) columns.\n   */\n  width: _react.PropTypes.number.isRequired\n};\nGrid.defaultProps = {\n  'aria-label': 'grid',\n  cellStyle: {},\n  cellRangeRenderer: _defaultCellRangeRenderer2.default,\n  estimatedColumnSize: 100,\n  estimatedRowSize: 30,\n  noContentRenderer: function noContentRenderer() {\n    return null;\n  },\n  onScroll: function onScroll() {\n    return null;\n  },\n  onSectionRendered: function onSectionRendered() {\n    return null;\n  },\n  overscanColumnCount: 0,\n  overscanRowCount: 10,\n  scrollingResetTimeInterval: DEFAULT_SCROLLING_RESET_TIME_INTERVAL,\n  scrollToAlignment: 'auto',\n  style: {},\n  tabIndex: 0\n};\nexports.default = Grid;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nexports.default = defaultCellRangeRenderer;\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _classnames = require('classnames');\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\n/**\n * Default implementation of cellRangeRenderer used by Grid.\n * This renderer supports cell-caching while the user is scrolling.\n */\nfunction defaultCellRangeRenderer(_ref) {\n  var cellCache = _ref.cellCache;\n  var cellClassName = _ref.cellClassName;\n  var cellRenderer = _ref.cellRenderer;\n  var cellStyle = _ref.cellStyle;\n  var columnSizeAndPositionManager = _ref.columnSizeAndPositionManager;\n  var columnStartIndex = _ref.columnStartIndex;\n  var columnStopIndex = _ref.columnStopIndex;\n  var horizontalOffsetAdjustment = _ref.horizontalOffsetAdjustment;\n  var isScrolling = _ref.isScrolling;\n  var rowSizeAndPositionManager = _ref.rowSizeAndPositionManager;\n  var rowStartIndex = _ref.rowStartIndex;\n  var rowStopIndex = _ref.rowStopIndex;\n  var scrollLeft = _ref.scrollLeft;\n  var scrollTop = _ref.scrollTop;\n  var verticalOffsetAdjustment = _ref.verticalOffsetAdjustment;\n\n  var renderedCells = [];\n\n  for (var rowIndex = rowStartIndex; rowIndex <= rowStopIndex; rowIndex++) {\n    var rowDatum = rowSizeAndPositionManager.getSizeAndPositionOfCell(rowIndex);\n\n    for (var columnIndex = columnStartIndex; columnIndex <= columnStopIndex; columnIndex++) {\n      var columnDatum = columnSizeAndPositionManager.getSizeAndPositionOfCell(columnIndex);\n      var key = rowIndex + '-' + columnIndex;\n      var cellStyleObject = cellStyle({ rowIndex: rowIndex, columnIndex: columnIndex });\n      var renderedCell = void 0;\n\n      // Avoid re-creating cells while scrolling.\n      // This can lead to the same cell being created many times and can cause performance issues for \"heavy\" cells.\n      // If a scroll is in progress- cache and reuse cells.\n      // This cache will be thrown away once scrolling complets.\n      if (isScrolling) {\n        if (!cellCache[key]) {\n          cellCache[key] = cellRenderer({\n            columnIndex: columnIndex,\n            isScrolling: isScrolling,\n            rowIndex: rowIndex\n          });\n        }\n        renderedCell = cellCache[key];\n        // If the user is no longer scrolling, don't cache cells.\n        // This makes dynamic cell content difficult for users and would also lead to a heavier memory footprint.\n      } else {\n        renderedCell = cellRenderer({\n          columnIndex: columnIndex,\n          isScrolling: isScrolling,\n          rowIndex: rowIndex\n        });\n      }\n\n      if (renderedCell == null || renderedCell === false) {\n        continue;\n      }\n\n      var className = cellClassName({ columnIndex: columnIndex, rowIndex: rowIndex });\n\n      var child = _react2.default.createElement(\n        'div',\n        {\n          key: key,\n          className: (0, _classnames2.default)('Grid__cell', className),\n          style: _extends({\n            height: rowDatum.size,\n            left: columnDatum.offset + horizontalOffsetAdjustment,\n            top: rowDatum.offset + verticalOffsetAdjustment,\n            width: columnDatum.size\n          }, cellStyleObject)\n        },\n        renderedCell\n      );\n\n      renderedCells.push(child);\n    }\n  }\n\n  return renderedCells;\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.defaultCellRangeRenderer = exports.Grid = exports.default = undefined;\n\nvar _Grid2 = require('./Grid');\n\nvar _Grid3 = _interopRequireDefault(_Grid2);\n\nvar _defaultCellRangeRenderer2 = require('./defaultCellRangeRenderer');\n\nvar _defaultCellRangeRenderer3 = _interopRequireDefault(_defaultCellRangeRenderer2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _Grid3.default;\nexports.Grid = _Grid3.default;\nexports.defaultCellRangeRenderer = _defaultCellRangeRenderer3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\n * Just-in-time calculates and caches size and position information for a collection of cells.\n */\nvar CellSizeAndPositionManager = function () {\n  function CellSizeAndPositionManager(_ref) {\n    var cellCount = _ref.cellCount;\n    var cellSizeGetter = _ref.cellSizeGetter;\n    var estimatedCellSize = _ref.estimatedCellSize;\n\n    _classCallCheck(this, CellSizeAndPositionManager);\n\n    this._cellSizeGetter = cellSizeGetter;\n    this._cellCount = cellCount;\n    this._estimatedCellSize = estimatedCellSize;\n\n    // Cache of size and position data for cells, mapped by cell index.\n    // Note that invalid values may exist in this map so only rely on cells up to this._lastMeasuredIndex\n    this._cellSizeAndPositionData = {};\n\n    // Measurements for cells up to this index can be trusted; cells afterward should be estimated.\n    this._lastMeasuredIndex = -1;\n  }\n\n  _createClass(CellSizeAndPositionManager, [{\n    key: 'configure',\n    value: function configure(_ref2) {\n      var cellCount = _ref2.cellCount;\n      var estimatedCellSize = _ref2.estimatedCellSize;\n\n      this._cellCount = cellCount;\n      this._estimatedCellSize = estimatedCellSize;\n    }\n  }, {\n    key: 'getCellCount',\n    value: function getCellCount() {\n      return this._cellCount;\n    }\n  }, {\n    key: 'getEstimatedCellSize',\n    value: function getEstimatedCellSize() {\n      return this._estimatedCellSize;\n    }\n  }, {\n    key: 'getLastMeasuredIndex',\n    value: function getLastMeasuredIndex() {\n      return this._lastMeasuredIndex;\n    }\n\n    /**\n     * This method returns the size and position for the cell at the specified index.\n     * It just-in-time calculates (or used cached values) for cells leading up to the index.\n     */\n\n  }, {\n    key: 'getSizeAndPositionOfCell',\n    value: function getSizeAndPositionOfCell(index) {\n      if (index < 0 || index >= this._cellCount) {\n        throw Error('Requested index ' + index + ' is outside of range 0..' + this._cellCount);\n      }\n\n      if (index > this._lastMeasuredIndex) {\n        var lastMeasuredCellSizeAndPosition = this.getSizeAndPositionOfLastMeasuredCell();\n        var _offset = lastMeasuredCellSizeAndPosition.offset + lastMeasuredCellSizeAndPosition.size;\n\n        for (var i = this._lastMeasuredIndex + 1; i <= index; i++) {\n          var _size = this._cellSizeGetter({ index: i });\n\n          if (_size == null || isNaN(_size)) {\n            throw Error('Invalid size returned for cell ' + i + ' of value ' + _size);\n          }\n\n          this._cellSizeAndPositionData[i] = {\n            offset: _offset,\n            size: _size\n          };\n\n          _offset += _size;\n        }\n\n        this._lastMeasuredIndex = index;\n      }\n\n      return this._cellSizeAndPositionData[index];\n    }\n  }, {\n    key: 'getSizeAndPositionOfLastMeasuredCell',\n    value: function getSizeAndPositionOfLastMeasuredCell() {\n      return this._lastMeasuredIndex >= 0 ? this._cellSizeAndPositionData[this._lastMeasuredIndex] : {\n        offset: 0,\n        size: 0\n      };\n    }\n\n    /**\n     * Total size of all cells being measured.\n     * This value will be completedly estimated initially.\n     * As cells as measured the estimate will be updated.\n     */\n\n  }, {\n    key: 'getTotalSize',\n    value: function getTotalSize() {\n      var lastMeasuredCellSizeAndPosition = this.getSizeAndPositionOfLastMeasuredCell();\n\n      return lastMeasuredCellSizeAndPosition.offset + lastMeasuredCellSizeAndPosition.size + (this._cellCount - this._lastMeasuredIndex - 1) * this._estimatedCellSize;\n    }\n\n    /**\n     * Determines a new offset that ensures a certain cell is visible, given the current offset.\n     * If the cell is already visible then the current offset will be returned.\n     * If the current offset is too great or small, it will be adjusted just enough to ensure the specified index is visible.\n     *\n     * @param align Desired alignment within container; one of \"auto\" (default), \"start\", or \"end\"\n     * @param containerSize Size (width or height) of the container viewport\n     * @param currentOffset Container's current (x or y) offset\n     * @param totalSize Total size (width or height) of all cells\n     * @return Offset to use to ensure the specified cell is visible\n     */\n\n  }, {\n    key: 'getUpdatedOffsetForIndex',\n    value: function getUpdatedOffsetForIndex(_ref3) {\n      var _ref3$align = _ref3.align;\n      var align = _ref3$align === undefined ? 'auto' : _ref3$align;\n      var containerSize = _ref3.containerSize;\n      var currentOffset = _ref3.currentOffset;\n      var targetIndex = _ref3.targetIndex;\n\n      var datum = this.getSizeAndPositionOfCell(targetIndex);\n      var maxOffset = datum.offset;\n      var minOffset = maxOffset - containerSize + datum.size;\n\n      var idealOffset = void 0;\n\n      switch (align) {\n        case 'start':\n          idealOffset = maxOffset;\n          break;\n        case 'end':\n          idealOffset = minOffset;\n          break;\n        case 'center':\n          idealOffset = maxOffset - (containerSize - datum.size) / 2;\n          break;\n        default:\n          idealOffset = Math.max(minOffset, Math.min(maxOffset, currentOffset));\n          break;\n      }\n\n      var totalSize = this.getTotalSize();\n\n      return Math.max(0, Math.min(totalSize - containerSize, idealOffset));\n    }\n  }, {\n    key: 'getVisibleCellRange',\n    value: function getVisibleCellRange(_ref4) {\n      var containerSize = _ref4.containerSize;\n      var offset = _ref4.offset;\n\n      var totalSize = this.getTotalSize();\n\n      if (totalSize === 0) {\n        return {};\n      }\n\n      var maxOffset = offset + containerSize;\n      var start = this._findNearestCell(offset);\n\n      var datum = this.getSizeAndPositionOfCell(start);\n      offset = datum.offset + datum.size;\n\n      var stop = start;\n\n      while (offset < maxOffset && stop < this._cellCount - 1) {\n        stop++;\n\n        offset += this.getSizeAndPositionOfCell(stop).size;\n      }\n\n      return {\n        start: start,\n        stop: stop\n      };\n    }\n\n    /**\n     * Clear all cached values for cells after the specified index.\n     * This method should be called for any cell that has changed its size.\n     * It will not immediately perform any calculations; they'll be performed the next time getSizeAndPositionOfCell() is called.\n     */\n\n  }, {\n    key: 'resetCell',\n    value: function resetCell(index) {\n      this._lastMeasuredIndex = Math.min(this._lastMeasuredIndex, index - 1);\n    }\n  }, {\n    key: '_binarySearch',\n    value: function _binarySearch(_ref5) {\n      var high = _ref5.high;\n      var low = _ref5.low;\n      var offset = _ref5.offset;\n\n      var middle = void 0;\n      var currentOffset = void 0;\n\n      while (low <= high) {\n        middle = low + Math.floor((high - low) / 2);\n        currentOffset = this.getSizeAndPositionOfCell(middle).offset;\n\n        if (currentOffset === offset) {\n          return middle;\n        } else if (currentOffset < offset) {\n          low = middle + 1;\n        } else if (currentOffset > offset) {\n          high = middle - 1;\n        }\n      }\n\n      if (low > 0) {\n        return low - 1;\n      }\n    }\n  }, {\n    key: '_exponentialSearch',\n    value: function _exponentialSearch(_ref6) {\n      var index = _ref6.index;\n      var offset = _ref6.offset;\n\n      var interval = 1;\n\n      while (index < this._cellCount && this.getSizeAndPositionOfCell(index).offset < offset) {\n        index += interval;\n        interval *= 2;\n      }\n\n      return this._binarySearch({\n        high: Math.min(index, this._cellCount - 1),\n        low: Math.floor(index / 2),\n        offset: offset\n      });\n    }\n\n    /**\n     * Searches for the cell (index) nearest the specified offset.\n     *\n     * If no exact match is found the next lowest cell index will be returned.\n     * This allows partially visible cells (with offsets just before/above the fold) to be visible.\n     */\n\n  }, {\n    key: '_findNearestCell',\n    value: function _findNearestCell(offset) {\n      if (isNaN(offset)) {\n        throw Error('Invalid offset ' + offset + ' specified');\n      }\n\n      // Our search algorithms find the nearest match at or below the specified offset.\n      // So make sure the offset is at least 0 or no match will be found.\n      offset = Math.max(0, offset);\n\n      var lastMeasuredCellSizeAndPosition = this.getSizeAndPositionOfLastMeasuredCell();\n      var lastMeasuredIndex = Math.max(0, this._lastMeasuredIndex);\n\n      if (lastMeasuredCellSizeAndPosition.offset >= offset) {\n        // If we've already measured cells within this range just use a binary search as it's faster.\n        return this._binarySearch({\n          high: lastMeasuredIndex,\n          low: 0,\n          offset: offset\n        });\n      } else {\n        // If we haven't yet measured this high, fallback to an exponential search with an inner binary search.\n        // The exponential search avoids pre-computing sizes for the full set of cells as a binary search would.\n        // The overall complexity for this approach is O(log n).\n        return this._exponentialSearch({\n          index: lastMeasuredIndex,\n          offset: offset\n        });\n      }\n    }\n  }]);\n\n  return CellSizeAndPositionManager;\n}();\n\nexports.default = CellSizeAndPositionManager;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.DEFAULT_MAX_SCROLL_SIZE = undefined;\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _CellSizeAndPositionManager = require('./CellSizeAndPositionManager');\n\nvar _CellSizeAndPositionManager2 = _interopRequireDefault(_CellSizeAndPositionManager);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\n * Browsers have scroll offset limitations (eg Chrome stops scrolling at ~33.5M pixels where as Edge tops out at ~1.5M pixels).\n * After a certain position, the browser won't allow the user to scroll further (even via JavaScript scroll offset adjustments).\n * This util picks a lower ceiling for max size and artificially adjusts positions within to make it transparent for users.\n */\nvar DEFAULT_MAX_SCROLL_SIZE = exports.DEFAULT_MAX_SCROLL_SIZE = 1500000;\n\n/**\n * Extends CellSizeAndPositionManager and adds scaling behavior for lists that are too large to fit within a browser's native limits.\n */\n\nvar ScalingCellSizeAndPositionManager = function () {\n  function ScalingCellSizeAndPositionManager(_ref) {\n    var _ref$maxScrollSize = _ref.maxScrollSize;\n    var maxScrollSize = _ref$maxScrollSize === undefined ? DEFAULT_MAX_SCROLL_SIZE : _ref$maxScrollSize;\n\n    var params = _objectWithoutProperties(_ref, ['maxScrollSize']);\n\n    _classCallCheck(this, ScalingCellSizeAndPositionManager);\n\n    // Favor composition over inheritance to simplify IE10 support\n    this._cellSizeAndPositionManager = new _CellSizeAndPositionManager2.default(params);\n    this._maxScrollSize = maxScrollSize;\n  }\n\n  _createClass(ScalingCellSizeAndPositionManager, [{\n    key: 'configure',\n    value: function configure(params) {\n      this._cellSizeAndPositionManager.configure(params);\n    }\n  }, {\n    key: 'getCellCount',\n    value: function getCellCount() {\n      return this._cellSizeAndPositionManager.getCellCount();\n    }\n  }, {\n    key: 'getEstimatedCellSize',\n    value: function getEstimatedCellSize() {\n      return this._cellSizeAndPositionManager.getEstimatedCellSize();\n    }\n  }, {\n    key: 'getLastMeasuredIndex',\n    value: function getLastMeasuredIndex() {\n      return this._cellSizeAndPositionManager.getLastMeasuredIndex();\n    }\n\n    /**\n     * Number of pixels a cell at the given position (offset) should be shifted in order to fit within the scaled container.\n     * The offset passed to this function is scalled (safe) as well.\n     */\n\n  }, {\n    key: 'getOffsetAdjustment',\n    value: function getOffsetAdjustment(_ref2) {\n      var containerSize = _ref2.containerSize;\n      var offset = _ref2.offset;\n\n      var totalSize = this._cellSizeAndPositionManager.getTotalSize();\n      var safeTotalSize = this.getTotalSize();\n      var offsetPercentage = this._getOffsetPercentage({\n        containerSize: containerSize,\n        offset: offset,\n        totalSize: safeTotalSize\n      });\n\n      return Math.round(offsetPercentage * (safeTotalSize - totalSize));\n    }\n  }, {\n    key: 'getSizeAndPositionOfCell',\n    value: function getSizeAndPositionOfCell(index) {\n      return this._cellSizeAndPositionManager.getSizeAndPositionOfCell(index);\n    }\n  }, {\n    key: 'getSizeAndPositionOfLastMeasuredCell',\n    value: function getSizeAndPositionOfLastMeasuredCell() {\n      return this._cellSizeAndPositionManager.getSizeAndPositionOfLastMeasuredCell();\n    }\n\n    /** See CellSizeAndPositionManager#getTotalSize */\n\n  }, {\n    key: 'getTotalSize',\n    value: function getTotalSize() {\n      return Math.min(this._maxScrollSize, this._cellSizeAndPositionManager.getTotalSize());\n    }\n\n    /** See CellSizeAndPositionManager#getUpdatedOffsetForIndex */\n\n  }, {\n    key: 'getUpdatedOffsetForIndex',\n    value: function getUpdatedOffsetForIndex(_ref3) {\n      var _ref3$align = _ref3.align;\n      var align = _ref3$align === undefined ? 'auto' : _ref3$align;\n      var containerSize = _ref3.containerSize;\n      var currentOffset = _ref3.currentOffset;\n      var targetIndex = _ref3.targetIndex;\n      var totalSize = _ref3.totalSize;\n\n      currentOffset = this._safeOffsetToOffset({\n        containerSize: containerSize,\n        offset: currentOffset\n      });\n\n      var offset = this._cellSizeAndPositionManager.getUpdatedOffsetForIndex({\n        align: align,\n        containerSize: containerSize,\n        currentOffset: currentOffset,\n        targetIndex: targetIndex,\n        totalSize: totalSize\n      });\n\n      return this._offsetToSafeOffset({\n        containerSize: containerSize,\n        offset: offset\n      });\n    }\n\n    /** See CellSizeAndPositionManager#getVisibleCellRange */\n\n  }, {\n    key: 'getVisibleCellRange',\n    value: function getVisibleCellRange(_ref4) {\n      var containerSize = _ref4.containerSize;\n      var offset = _ref4.offset;\n\n      offset = this._safeOffsetToOffset({\n        containerSize: containerSize,\n        offset: offset\n      });\n\n      return this._cellSizeAndPositionManager.getVisibleCellRange({\n        containerSize: containerSize,\n        offset: offset\n      });\n    }\n  }, {\n    key: 'resetCell',\n    value: function resetCell(index) {\n      this._cellSizeAndPositionManager.resetCell(index);\n    }\n  }, {\n    key: '_getOffsetPercentage',\n    value: function _getOffsetPercentage(_ref5) {\n      var containerSize = _ref5.containerSize;\n      var offset = _ref5.offset;\n      var totalSize = _ref5.totalSize;\n\n      return totalSize <= containerSize ? 0 : offset / (totalSize - containerSize);\n    }\n  }, {\n    key: '_offsetToSafeOffset',\n    value: function _offsetToSafeOffset(_ref6) {\n      var containerSize = _ref6.containerSize;\n      var offset = _ref6.offset;\n\n      var totalSize = this._cellSizeAndPositionManager.getTotalSize();\n      var safeTotalSize = this.getTotalSize();\n\n      if (totalSize === safeTotalSize) {\n        return offset;\n      } else {\n        var offsetPercentage = this._getOffsetPercentage({\n          containerSize: containerSize,\n          offset: offset,\n          totalSize: totalSize\n        });\n\n        return Math.round(offsetPercentage * (safeTotalSize - containerSize));\n      }\n    }\n  }, {\n    key: '_safeOffsetToOffset',\n    value: function _safeOffsetToOffset(_ref7) {\n      var containerSize = _ref7.containerSize;\n      var offset = _ref7.offset;\n\n      var totalSize = this._cellSizeAndPositionManager.getTotalSize();\n      var safeTotalSize = this.getTotalSize();\n\n      if (totalSize === safeTotalSize) {\n        return offset;\n      } else {\n        var offsetPercentage = this._getOffsetPercentage({\n          containerSize: containerSize,\n          offset: offset,\n          totalSize: safeTotalSize\n        });\n\n        return Math.round(offsetPercentage * (totalSize - containerSize));\n      }\n    }\n  }]);\n\n  return ScalingCellSizeAndPositionManager;\n}();\n\nexports.default = ScalingCellSizeAndPositionManager;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = calculateSizeAndPositionDataAndUpdateScrollOffset;\n/**\n * Helper method that determines when to recalculate row or column metadata.\n *\n * @param cellCount Number of rows or columns in the current axis\n * @param cellsSize Width or height of cells for the current axis\n * @param computeMetadataCallback Method to invoke if cell metadata should be recalculated\n * @param computeMetadataCallbackProps Parameters to pass to :computeMetadataCallback\n * @param nextCellsCount Newly updated number of rows or columns in the current axis\n * @param nextCellsSize Newly updated width or height of cells for the current axis\n * @param nextScrollToIndex Newly updated scroll-to-index\n * @param scrollToIndex Scroll-to-index\n * @param updateScrollOffsetForScrollToIndex Callback to invoke if the scroll position should be recalculated\n */\nfunction calculateSizeAndPositionDataAndUpdateScrollOffset(_ref) {\n  var cellCount = _ref.cellCount;\n  var cellSize = _ref.cellSize;\n  var computeMetadataCallback = _ref.computeMetadataCallback;\n  var computeMetadataCallbackProps = _ref.computeMetadataCallbackProps;\n  var nextCellsCount = _ref.nextCellsCount;\n  var nextCellSize = _ref.nextCellSize;\n  var nextScrollToIndex = _ref.nextScrollToIndex;\n  var scrollToIndex = _ref.scrollToIndex;\n  var updateScrollOffsetForScrollToIndex = _ref.updateScrollOffsetForScrollToIndex;\n\n  // Don't compare cell sizes if they are functions because inline functions would cause infinite loops.\n  // In that event users should use the manual recompute methods to inform of changes.\n  if (cellCount !== nextCellsCount || (typeof cellSize === 'number' || typeof nextCellSize === 'number') && cellSize !== nextCellSize) {\n    computeMetadataCallback(computeMetadataCallbackProps);\n\n    // Updated cell metadata may have hidden the previous scrolled-to item.\n    // In this case we should also update the scrollTop to ensure it stays visible.\n    if (scrollToIndex >= 0 && scrollToIndex === nextScrollToIndex) {\n      updateScrollOffsetForScrollToIndex();\n    }\n  }\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = getOverscanIndices;\nvar SCROLL_DIRECTION_BACKWARD = exports.SCROLL_DIRECTION_BACKWARD = -1;\nvar SCROLL_DIRECTION_FIXED = exports.SCROLL_DIRECTION_FIXED = 0;\nvar SCROLL_DIRECTION_FORWARD = exports.SCROLL_DIRECTION_FORWARD = 1;\n\n/**\n * Calculates the number of cells to overscan before and after a specified range.\n * This function ensures that overscanning doesn't exceed the available cells.\n *\n * @param cellCount Number of rows or columns in the current axis\n * @param scrollDirection One of SCROLL_DIRECTION_BACKWARD\n * @param overscanCellsCount Maximum number of cells to over-render in either direction\n * @param startIndex Begin of range of visible cells\n * @param stopIndex End of range of visible cells\n */\nfunction getOverscanIndices(_ref) {\n  var cellCount = _ref.cellCount;\n  var overscanCellsCount = _ref.overscanCellsCount;\n  var scrollDirection = _ref.scrollDirection;\n  var startIndex = _ref.startIndex;\n  var stopIndex = _ref.stopIndex;\n\n  var overscanStartIndex = void 0;\n  var overscanStopIndex = void 0;\n\n  if (scrollDirection === SCROLL_DIRECTION_FORWARD) {\n    overscanStartIndex = startIndex;\n    overscanStopIndex = stopIndex + overscanCellsCount * 2;\n  } else if (scrollDirection === SCROLL_DIRECTION_BACKWARD) {\n    overscanStartIndex = startIndex - overscanCellsCount * 2;\n    overscanStopIndex = stopIndex;\n  } else {\n    overscanStartIndex = startIndex - overscanCellsCount;\n    overscanStopIndex = stopIndex + overscanCellsCount;\n  }\n\n  return {\n    overscanStartIndex: Math.max(0, overscanStartIndex),\n    overscanStopIndex: Math.min(cellCount - 1, overscanStopIndex)\n  };\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = updateScrollIndexHelper;\n/**\n * Helper function that determines when to update scroll offsets to ensure that a scroll-to-index remains visible.\n * This function also ensures that the scroll ofset isn't past the last column/row of cells.\n *\n * @param cellsSize Width or height of cells for the current axis\n * @param cellSizeAndPositionManager Manages size and position metadata of cells\n * @param previousCellsCount Previous number of rows or columns\n * @param previousCellsSize Previous width or height of cells\n * @param previousScrollToIndex Previous scroll-to-index\n * @param previousSize Previous width or height of the virtualized container\n * @param scrollOffset Current scrollLeft or scrollTop\n * @param scrollToIndex Scroll-to-index\n * @param size Width or height of the virtualized container\n * @param updateScrollIndexCallback Callback to invoke with an scroll-to-index value\n */\nfunction updateScrollIndexHelper(_ref) {\n  var cellSize = _ref.cellSize;\n  var cellSizeAndPositionManager = _ref.cellSizeAndPositionManager;\n  var previousCellsCount = _ref.previousCellsCount;\n  var previousCellSize = _ref.previousCellSize;\n  var previousScrollToAlignment = _ref.previousScrollToAlignment;\n  var previousScrollToIndex = _ref.previousScrollToIndex;\n  var previousSize = _ref.previousSize;\n  var scrollOffset = _ref.scrollOffset;\n  var scrollToAlignment = _ref.scrollToAlignment;\n  var scrollToIndex = _ref.scrollToIndex;\n  var size = _ref.size;\n  var updateScrollIndexCallback = _ref.updateScrollIndexCallback;\n\n  var cellCount = cellSizeAndPositionManager.getCellCount();\n  var hasScrollToIndex = scrollToIndex >= 0 && scrollToIndex < cellCount;\n  var sizeHasChanged = size !== previousSize || !previousCellSize || typeof cellSize === 'number' && cellSize !== previousCellSize;\n\n  // If we have a new scroll target OR if height/row-height has changed,\n  // We should ensure that the scroll target is visible.\n  if (hasScrollToIndex && (sizeHasChanged || scrollToAlignment !== previousScrollToAlignment || scrollToIndex !== previousScrollToIndex)) {\n    updateScrollIndexCallback(scrollToIndex);\n\n    // If we don't have a selected item but list size or number of children have decreased,\n    // Make sure we aren't scrolled too far past the current content.\n  } else if (!hasScrollToIndex && cellCount > 0 && (size < previousSize || cellCount < previousCellsCount)) {\n    // We need to ensure that the current scroll offset is still within the collection's range.\n    // To do this, we don't need to measure everything; CellMeasurer would perform poorly.\n    // Just check to make sure we're still okay.\n    // Only adjust the scroll position if we've scrolled below the last set of rows.\n    if (scrollOffset > cellSizeAndPositionManager.getTotalSize() - size) {\n      updateScrollIndexCallback(cellCount - 1);\n    }\n  }\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nexports.isRangeVisible = isRangeVisible;\nexports.scanForUnloadedRanges = scanForUnloadedRanges;\nexports.forceUpdateReactVirtualizedComponent = forceUpdateReactVirtualizedComponent;\n\nvar _react = require('react');\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nvar _createCallbackMemoizer = require('../utils/createCallbackMemoizer');\n\nvar _createCallbackMemoizer2 = _interopRequireDefault(_createCallbackMemoizer);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * Higher-order component that manages lazy-loading for \"infinite\" data.\n * This component decorates a virtual component and just-in-time prefetches rows as a user scrolls.\n * It is intended as a convenience component; fork it if you'd like finer-grained control over data-loading.\n */\nvar InfiniteLoader = function (_Component) {\n  _inherits(InfiniteLoader, _Component);\n\n  function InfiniteLoader(props, context) {\n    _classCallCheck(this, InfiniteLoader);\n\n    var _this = _possibleConstructorReturn(this, (InfiniteLoader.__proto__ || Object.getPrototypeOf(InfiniteLoader)).call(this, props, context));\n\n    _this._loadMoreRowsMemoizer = (0, _createCallbackMemoizer2.default)();\n\n    _this._onRowsRendered = _this._onRowsRendered.bind(_this);\n    _this._registerChild = _this._registerChild.bind(_this);\n    return _this;\n  }\n\n  _createClass(InfiniteLoader, [{\n    key: 'render',\n    value: function render() {\n      var children = this.props.children;\n\n\n      return children({\n        onRowsRendered: this._onRowsRendered,\n        registerChild: this._registerChild\n      });\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_loadUnloadedRanges',\n    value: function _loadUnloadedRanges(unloadedRanges) {\n      var _this2 = this;\n\n      var loadMoreRows = this.props.loadMoreRows;\n\n\n      unloadedRanges.forEach(function (unloadedRange) {\n        var promise = loadMoreRows(unloadedRange);\n        if (promise) {\n          promise.then(function () {\n            // Refresh the visible rows if any of them have just been loaded.\n            // Otherwise they will remain in their unloaded visual state.\n            if (isRangeVisible({\n              lastRenderedStartIndex: _this2._lastRenderedStartIndex,\n              lastRenderedStopIndex: _this2._lastRenderedStopIndex,\n              startIndex: unloadedRange.startIndex,\n              stopIndex: unloadedRange.stopIndex\n            })) {\n              if (_this2._registeredChild) {\n                forceUpdateReactVirtualizedComponent(_this2._registeredChild);\n              }\n            }\n          });\n        }\n      });\n    }\n  }, {\n    key: '_onRowsRendered',\n    value: function _onRowsRendered(_ref) {\n      var _this3 = this;\n\n      var startIndex = _ref.startIndex;\n      var stopIndex = _ref.stopIndex;\n      var _props = this.props;\n      var isRowLoaded = _props.isRowLoaded;\n      var minimumBatchSize = _props.minimumBatchSize;\n      var rowCount = _props.rowCount;\n      var threshold = _props.threshold;\n\n\n      this._lastRenderedStartIndex = startIndex;\n      this._lastRenderedStopIndex = stopIndex;\n\n      var unloadedRanges = scanForUnloadedRanges({\n        isRowLoaded: isRowLoaded,\n        minimumBatchSize: minimumBatchSize,\n        rowCount: rowCount,\n        startIndex: Math.max(0, startIndex - threshold),\n        stopIndex: Math.min(rowCount - 1, stopIndex + threshold)\n      });\n\n      // For memoize comparison\n      var squashedUnloadedRanges = unloadedRanges.reduce(function (reduced, unloadedRange) {\n        return reduced.concat([unloadedRange.startIndex, unloadedRange.stopIndex]);\n      }, []);\n\n      this._loadMoreRowsMemoizer({\n        callback: function callback() {\n          _this3._loadUnloadedRanges(unloadedRanges);\n        },\n        indices: { squashedUnloadedRanges: squashedUnloadedRanges }\n      });\n    }\n  }, {\n    key: '_registerChild',\n    value: function _registerChild(registeredChild) {\n      this._registeredChild = registeredChild;\n    }\n  }]);\n\n  return InfiniteLoader;\n}(_react.Component);\n\n/**\n * Determines if the specified start/stop range is visible based on the most recently rendered range.\n */\n\n\nInfiniteLoader.propTypes = {\n  /**\n   * Function respondible for rendering a virtualized component.\n   * This function should implement the following signature:\n   * ({ onRowsRendered, registerChild }) => PropTypes.element\n   *\n   * The specified :onRowsRendered function should be passed through to the child's :onRowsRendered property.\n   * The :registerChild callback should be set as the virtualized component's :ref.\n   */\n  children: _react.PropTypes.func.isRequired,\n\n  /**\n   * Function responsible for tracking the loaded state of each row.\n   * It should implement the following signature: ({ index: number }): boolean\n   */\n  isRowLoaded: _react.PropTypes.func.isRequired,\n\n  /**\n   * Callback to be invoked when more rows must be loaded.\n   * It should implement the following signature: ({ startIndex, stopIndex }): Promise\n   * The returned Promise should be resolved once row data has finished loading.\n   * It will be used to determine when to refresh the list with the newly-loaded data.\n   * This callback may be called multiple times in reaction to a single scroll event.\n   */\n  loadMoreRows: _react.PropTypes.func.isRequired,\n\n  /**\n   * Minimum number of rows to be loaded at a time.\n   * This property can be used to batch requests to reduce HTTP requests.\n   */\n  minimumBatchSize: _react.PropTypes.number.isRequired,\n\n  /**\n   * Number of rows in list; can be arbitrary high number if actual number is unknown.\n   */\n  rowCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Threshold at which to pre-fetch data.\n   * A threshold X means that data will start loading when a user scrolls within X rows.\n   * This value defaults to 15.\n   */\n  threshold: _react.PropTypes.number.isRequired\n};\nInfiniteLoader.defaultProps = {\n  minimumBatchSize: 10,\n  rowCount: 0,\n  threshold: 15\n};\nexports.default = InfiniteLoader;\nfunction isRangeVisible(_ref2) {\n  var lastRenderedStartIndex = _ref2.lastRenderedStartIndex;\n  var lastRenderedStopIndex = _ref2.lastRenderedStopIndex;\n  var startIndex = _ref2.startIndex;\n  var stopIndex = _ref2.stopIndex;\n\n  return !(startIndex > lastRenderedStopIndex || stopIndex < lastRenderedStartIndex);\n}\n\n/**\n * Returns all of the ranges within a larger range that contain unloaded rows.\n */\nfunction scanForUnloadedRanges(_ref3) {\n  var isRowLoaded = _ref3.isRowLoaded;\n  var minimumBatchSize = _ref3.minimumBatchSize;\n  var rowCount = _ref3.rowCount;\n  var startIndex = _ref3.startIndex;\n  var stopIndex = _ref3.stopIndex;\n\n  var unloadedRanges = [];\n\n  var rangeStartIndex = null;\n  var rangeStopIndex = null;\n\n  for (var index = startIndex; index <= stopIndex; index++) {\n    var loaded = isRowLoaded({ index: index });\n\n    if (!loaded) {\n      rangeStopIndex = index;\n      if (rangeStartIndex === null) {\n        rangeStartIndex = index;\n      }\n    } else if (rangeStopIndex !== null) {\n      unloadedRanges.push({\n        startIndex: rangeStartIndex,\n        stopIndex: rangeStopIndex\n      });\n\n      rangeStartIndex = rangeStopIndex = null;\n    }\n  }\n\n  // If :rangeStopIndex is not null it means we haven't ran out of unloaded rows.\n  // Scan forward to try filling our :minimumBatchSize.\n  if (rangeStopIndex !== null) {\n    var potentialStopIndex = Math.min(Math.max(rangeStopIndex, rangeStartIndex + minimumBatchSize - 1), rowCount - 1);\n\n    for (var _index = rangeStopIndex + 1; _index <= potentialStopIndex; _index++) {\n      if (!isRowLoaded({ index: _index })) {\n        rangeStopIndex = _index;\n      } else {\n        break;\n      }\n    }\n\n    unloadedRanges.push({\n      startIndex: rangeStartIndex,\n      stopIndex: rangeStopIndex\n    });\n  }\n\n  // Check to see if our first range ended prematurely.\n  // In this case we should scan backwards to try filling our :minimumBatchSize.\n  if (unloadedRanges.length) {\n    var firstUnloadedRange = unloadedRanges[0];\n\n    while (firstUnloadedRange.stopIndex - firstUnloadedRange.startIndex + 1 < minimumBatchSize && firstUnloadedRange.startIndex > 0) {\n      var _index2 = firstUnloadedRange.startIndex - 1;\n\n      if (!isRowLoaded({ index: _index2 })) {\n        firstUnloadedRange.startIndex = _index2;\n      } else {\n        break;\n      }\n    }\n  }\n\n  return unloadedRanges;\n}\n\n/**\n * Since RV components use shallowCompare we need to force a render (even though props haven't changed).\n * However InfiniteLoader may wrap a Grid or it may wrap a FlexTable or VirtualScroll.\n * In the first case the built-in React forceUpdate() method is sufficient to force a re-render,\n * But in the latter cases we need to use the RV-specific forceUpdateGrid() method.\n * Else the inner Grid will not be re-rendered and visuals may be stale.\n */\nfunction forceUpdateReactVirtualizedComponent(component) {\n  typeof component.forceUpdateGrid === 'function' ? component.forceUpdateGrid() : component.forceUpdate();\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.InfiniteLoader = exports.default = undefined;\n\nvar _InfiniteLoader2 = require('./InfiniteLoader');\n\nvar _InfiniteLoader3 = _interopRequireDefault(_InfiniteLoader2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _InfiniteLoader3.default;\nexports.InfiniteLoader = _InfiniteLoader3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * HOC that simplifies the process of synchronizing scrolling between two or more virtualized components.\n */\nvar ScrollSync = function (_Component) {\n  _inherits(ScrollSync, _Component);\n\n  function ScrollSync(props, context) {\n    _classCallCheck(this, ScrollSync);\n\n    var _this = _possibleConstructorReturn(this, (ScrollSync.__proto__ || Object.getPrototypeOf(ScrollSync)).call(this, props, context));\n\n    _this.state = {\n      clientHeight: 0,\n      clientWidth: 0,\n      scrollHeight: 0,\n      scrollLeft: 0,\n      scrollTop: 0,\n      scrollWidth: 0\n    };\n\n    _this._onScroll = _this._onScroll.bind(_this);\n    return _this;\n  }\n\n  _createClass(ScrollSync, [{\n    key: 'render',\n    value: function render() {\n      var children = this.props.children;\n      var _state = this.state;\n      var clientHeight = _state.clientHeight;\n      var clientWidth = _state.clientWidth;\n      var scrollHeight = _state.scrollHeight;\n      var scrollLeft = _state.scrollLeft;\n      var scrollTop = _state.scrollTop;\n      var scrollWidth = _state.scrollWidth;\n\n\n      return children({\n        clientHeight: clientHeight,\n        clientWidth: clientWidth,\n        onScroll: this._onScroll,\n        scrollHeight: scrollHeight,\n        scrollLeft: scrollLeft,\n        scrollTop: scrollTop,\n        scrollWidth: scrollWidth\n      });\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_onScroll',\n    value: function _onScroll(_ref) {\n      var clientHeight = _ref.clientHeight;\n      var clientWidth = _ref.clientWidth;\n      var scrollHeight = _ref.scrollHeight;\n      var scrollLeft = _ref.scrollLeft;\n      var scrollTop = _ref.scrollTop;\n      var scrollWidth = _ref.scrollWidth;\n\n      this.setState({ clientHeight: clientHeight, clientWidth: clientWidth, scrollHeight: scrollHeight, scrollLeft: scrollLeft, scrollTop: scrollTop, scrollWidth: scrollWidth });\n    }\n  }]);\n\n  return ScrollSync;\n}(_react.Component);\n\nScrollSync.propTypes = {\n  /**\n   * Function respondible for rendering 2 or more virtualized components.\n   * This function should implement the following signature:\n   * ({ onScroll, scrollLeft, scrollTop }) => PropTypes.element\n   */\n  children: _react.PropTypes.func.isRequired\n};\nexports.default = ScrollSync;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.ScrollSync = exports.default = undefined;\n\nvar _ScrollSync2 = require('./ScrollSync');\n\nvar _ScrollSync3 = _interopRequireDefault(_ScrollSync2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _ScrollSync3.default;\nexports.ScrollSync = _ScrollSync3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _Grid = require('../Grid');\n\nvar _Grid2 = _interopRequireDefault(_Grid);\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _classnames = require('classnames');\n\nvar _classnames2 = _interopRequireDefault(_classnames);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\n/**\n * It is inefficient to create and manage a large list of DOM elements within a scrolling container\n * if only a few of those elements are visible. The primary purpose of this component is to improve\n * performance by only rendering the DOM nodes that a user is able to see based on their current\n * scroll position.\n *\n * This component renders a virtualized list of elements with either fixed or dynamic heights.\n */\nvar VirtualScroll = function (_Component) {\n  _inherits(VirtualScroll, _Component);\n\n  function VirtualScroll(props, context) {\n    _classCallCheck(this, VirtualScroll);\n\n    var _this = _possibleConstructorReturn(this, (VirtualScroll.__proto__ || Object.getPrototypeOf(VirtualScroll)).call(this, props, context));\n\n    _this._cellRenderer = _this._cellRenderer.bind(_this);\n    _this._createRowClassNameGetter = _this._createRowClassNameGetter.bind(_this);\n    _this._createRowStyleGetter = _this._createRowStyleGetter.bind(_this);\n    _this._onScroll = _this._onScroll.bind(_this);\n    _this._onSectionRendered = _this._onSectionRendered.bind(_this);\n    return _this;\n  }\n\n  _createClass(VirtualScroll, [{\n    key: 'forceUpdateGrid',\n    value: function forceUpdateGrid() {\n      this.Grid.forceUpdate();\n    }\n\n    /** See Grid#measureAllCells */\n\n  }, {\n    key: 'measureAllRows',\n    value: function measureAllRows() {\n      this.Grid.measureAllCells();\n    }\n\n    /** See Grid#recomputeGridSize */\n\n  }, {\n    key: 'recomputeRowHeights',\n    value: function recomputeRowHeights() {\n      var index = arguments.length <= 0 || arguments[0] === undefined ? 0 : arguments[0];\n\n      this.Grid.recomputeGridSize({\n        rowIndex: index\n      });\n      this.forceUpdateGrid();\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _this2 = this;\n\n      var _props = this.props;\n      var className = _props.className;\n      var noRowsRenderer = _props.noRowsRenderer;\n      var scrollToIndex = _props.scrollToIndex;\n      var width = _props.width;\n\n\n      var classNames = (0, _classnames2.default)('VirtualScroll', className);\n\n      return _react2.default.createElement(_Grid2.default, _extends({}, this.props, {\n        autoContainerWidth: true,\n        cellRenderer: this._cellRenderer,\n        cellClassName: this._createRowClassNameGetter(),\n        cellStyle: this._createRowStyleGetter(),\n        className: classNames,\n        columnWidth: width,\n        columnCount: 1,\n        noContentRenderer: noRowsRenderer,\n        onScroll: this._onScroll,\n        onSectionRendered: this._onSectionRendered,\n        ref: function ref(_ref) {\n          _this2.Grid = _ref;\n        },\n        scrollToRow: scrollToIndex\n      }));\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_cellRenderer',\n    value: function _cellRenderer(_ref2) {\n      var columnIndex = _ref2.columnIndex;\n      var isScrolling = _ref2.isScrolling;\n      var rowIndex = _ref2.rowIndex;\n      var rowRenderer = this.props.rowRenderer;\n\n\n      return rowRenderer({\n        index: rowIndex,\n        isScrolling: isScrolling\n      });\n    }\n  }, {\n    key: '_createRowClassNameGetter',\n    value: function _createRowClassNameGetter() {\n      var rowClassName = this.props.rowClassName;\n\n\n      return rowClassName instanceof Function ? function (_ref3) {\n        var rowIndex = _ref3.rowIndex;\n        return rowClassName({ index: rowIndex });\n      } : function () {\n        return rowClassName;\n      };\n    }\n  }, {\n    key: '_createRowStyleGetter',\n    value: function _createRowStyleGetter() {\n      var rowStyle = this.props.rowStyle;\n\n\n      var wrapped = rowStyle instanceof Function ? rowStyle : function () {\n        return rowStyle;\n      };\n\n      // Default width to 100% to prevent list rows from flowing under the vertical scrollbar\n      return function (_ref4) {\n        var rowIndex = _ref4.rowIndex;\n        return _extends({\n          width: '100%'\n        }, wrapped({ index: rowIndex }));\n      };\n    }\n  }, {\n    key: '_onScroll',\n    value: function _onScroll(_ref5) {\n      var clientHeight = _ref5.clientHeight;\n      var scrollHeight = _ref5.scrollHeight;\n      var scrollTop = _ref5.scrollTop;\n      var onScroll = this.props.onScroll;\n\n\n      onScroll({ clientHeight: clientHeight, scrollHeight: scrollHeight, scrollTop: scrollTop });\n    }\n  }, {\n    key: '_onSectionRendered',\n    value: function _onSectionRendered(_ref6) {\n      var rowOverscanStartIndex = _ref6.rowOverscanStartIndex;\n      var rowOverscanStopIndex = _ref6.rowOverscanStopIndex;\n      var rowStartIndex = _ref6.rowStartIndex;\n      var rowStopIndex = _ref6.rowStopIndex;\n      var onRowsRendered = this.props.onRowsRendered;\n\n\n      onRowsRendered({\n        overscanStartIndex: rowOverscanStartIndex,\n        overscanStopIndex: rowOverscanStopIndex,\n        startIndex: rowStartIndex,\n        stopIndex: rowStopIndex\n      });\n    }\n  }]);\n\n  return VirtualScroll;\n}(_react.Component);\n\nVirtualScroll.propTypes = {\n  'aria-label': _react.PropTypes.string,\n\n  /**\n   * Removes fixed height from the scrollingContainer so that the total height\n   * of rows can stretch the window. Intended for use with WindowScroller\n   */\n  autoHeight: _react.PropTypes.bool,\n\n  /** Optional CSS class name */\n  className: _react.PropTypes.string,\n\n  /**\n   * Used to estimate the total height of a VirtualScroll before all of its rows have actually been measured.\n   * The estimated total height is adjusted as rows are rendered.\n   */\n  estimatedRowSize: _react.PropTypes.number.isRequired,\n\n  /** Height constraint for list (determines how many actual rows are rendered) */\n  height: _react.PropTypes.number.isRequired,\n\n  /** Optional renderer to be used in place of rows when rowCount is 0 */\n  noRowsRenderer: _react.PropTypes.func.isRequired,\n\n  /**\n   * Callback invoked with information about the slice of rows that were just rendered.\n   * ({ startIndex, stopIndex }): void\n   */\n  onRowsRendered: _react.PropTypes.func.isRequired,\n\n  /**\n   * Number of rows to render above/below the visible bounds of the list.\n   * These rows can help for smoother scrolling on touch devices.\n   */\n  overscanRowCount: _react.PropTypes.number.isRequired,\n\n  /**\n   * Callback invoked whenever the scroll offset changes within the inner scrollable region.\n   * This callback can be used to sync scrolling between lists, tables, or grids.\n   * ({ clientHeight, scrollHeight, scrollTop }): void\n   */\n  onScroll: _react.PropTypes.func.isRequired,\n\n  /**\n   * Either a fixed row height (number) or a function that returns the height of a row given its index.\n   * ({ index: number }): number\n   */\n  rowHeight: _react.PropTypes.oneOfType([_react.PropTypes.number, _react.PropTypes.func]).isRequired,\n\n  /** Responsbile for rendering a row given an index; ({ index: number }): node */\n  rowRenderer: _react.PropTypes.func.isRequired,\n\n  /** Optional custom CSS class for individual rows */\n  rowClassName: _react.PropTypes.oneOfType([_react.PropTypes.string, _react.PropTypes.func]),\n\n  /** Number of rows in list. */\n  rowCount: _react.PropTypes.number.isRequired,\n\n  /** Optional custom styles for individual cells */\n  rowStyle: _react.PropTypes.oneOfType([_react.PropTypes.object, _react.PropTypes.func]),\n\n  /** See Grid#scrollToAlignment */\n  scrollToAlignment: _react.PropTypes.oneOf(['auto', 'end', 'start', 'center']).isRequired,\n\n  /** Row index to ensure visible (by forcefully scrolling if necessary) */\n  scrollToIndex: _react.PropTypes.number,\n\n  /** Vertical offset. */\n  scrollTop: _react.PropTypes.number,\n\n  /** Optional inline style */\n  style: _react.PropTypes.object,\n\n  /** Tab index for focus */\n  tabIndex: _react.PropTypes.number,\n\n  /** Width of list */\n  width: _react.PropTypes.number.isRequired\n};\nVirtualScroll.defaultProps = {\n  estimatedRowSize: 30,\n  noRowsRenderer: function noRowsRenderer() {\n    return null;\n  },\n  onRowsRendered: function onRowsRendered() {\n    return null;\n  },\n  onScroll: function onScroll() {\n    return null;\n  },\n  overscanRowCount: 10,\n  scrollToAlignment: 'auto',\n  style: {}\n};\nexports.default = VirtualScroll;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.VirtualScroll = exports.default = undefined;\n\nvar _VirtualScroll2 = require('./VirtualScroll');\n\nvar _VirtualScroll3 = _interopRequireDefault(_VirtualScroll2);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _VirtualScroll3.default;\nexports.VirtualScroll = _VirtualScroll3.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactDom = require('react-dom');\n\nvar _reactDom2 = _interopRequireDefault(_reactDom);\n\nvar _reactAddonsShallowCompare = require('react-addons-shallow-compare');\n\nvar _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);\n\nvar _raf = require('raf');\n\nvar _raf2 = _interopRequireDefault(_raf);\n\nvar _onScroll = require('./utils/onScroll');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar WindowScroller = function (_Component) {\n  _inherits(WindowScroller, _Component);\n\n  function WindowScroller(props) {\n    _classCallCheck(this, WindowScroller);\n\n    var _this = _possibleConstructorReturn(this, (WindowScroller.__proto__ || Object.getPrototypeOf(WindowScroller)).call(this, props));\n\n    var height = typeof window !== 'undefined' ? window.innerHeight : 0;\n\n    _this.state = {\n      isScrolling: false,\n      height: height,\n      scrollTop: 0\n    };\n\n    _this._onScrollWindow = _this._onScrollWindow.bind(_this);\n    _this._onResizeWindow = _this._onResizeWindow.bind(_this);\n    _this._enablePointerEventsAfterDelayCallback = _this._enablePointerEventsAfterDelayCallback.bind(_this);\n    return _this;\n  }\n\n  _createClass(WindowScroller, [{\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      var height = this.state.height;\n\n      // Subtract documentElement top to handle edge-case where a user is navigating back (history) from an already-scrolled bage.\n      // In this case the body's top position will be a negative number and this element's top will be increased (by that amount).\n\n      this._positionFromTop = _reactDom2.default.findDOMNode(this).getBoundingClientRect().top - document.documentElement.getBoundingClientRect().top;\n\n      if (height !== window.innerHeight) {\n        this.setState({\n          height: window.innerHeight\n        });\n      }\n\n      (0, _onScroll.registerScrollListener)(this);\n      window.addEventListener('resize', this._onResizeWindow, false);\n    }\n  }, {\n    key: 'componentWillUnmount',\n    value: function componentWillUnmount() {\n      (0, _onScroll.unregisterScrollListener)(this);\n\n      window.removeEventListener('resize', this._onResizeWindow, false);\n    }\n\n    /**\n     * Updates the state during the next animation frame.\n     * Use this method to avoid multiple renders in a small span of time.\n     * This helps performance for bursty events (like onScroll).\n     */\n\n  }, {\n    key: '_setNextState',\n    value: function _setNextState(state) {\n      var _this2 = this;\n\n      if (this._setNextStateAnimationFrameId) {\n        _raf2.default.cancel(this._setNextStateAnimationFrameId);\n      }\n\n      this._setNextStateAnimationFrameId = (0, _raf2.default)(function () {\n        _this2._setNextStateAnimationFrameId = null;\n        _this2.setState(state);\n      });\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var children = this.props.children;\n      var _state = this.state;\n      var isScrolling = _state.isScrolling;\n      var scrollTop = _state.scrollTop;\n      var height = _state.height;\n\n\n      return _react2.default.createElement(\n        'div',\n        null,\n        children({\n          height: height,\n          isScrolling: isScrolling,\n          scrollTop: scrollTop\n        })\n      );\n    }\n  }, {\n    key: 'shouldComponentUpdate',\n    value: function shouldComponentUpdate(nextProps, nextState) {\n      return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);\n    }\n  }, {\n    key: '_enablePointerEventsAfterDelayCallback',\n    value: function _enablePointerEventsAfterDelayCallback() {\n      this.setState({\n        isScrolling: false\n      });\n    }\n  }, {\n    key: '_onResizeWindow',\n    value: function _onResizeWindow(event) {\n      var onResize = this.props.onResize;\n\n\n      var height = window.innerHeight || 0;\n\n      this.setState({ height: height });\n\n      onResize({ height: height });\n    }\n  }, {\n    key: '_onScrollWindow',\n    value: function _onScrollWindow(event) {\n      var onScroll = this.props.onScroll;\n\n      // In IE10+ scrollY is undefined, so we replace that with the latter\n\n      var scrollY = 'scrollY' in window ? window.scrollY : document.documentElement.scrollTop;\n\n      var scrollTop = Math.max(0, scrollY - this._positionFromTop);\n\n      var state = {\n        isScrolling: true,\n        scrollTop: scrollTop\n      };\n\n      if (!this.state.isScrolling) {\n        this.setState(state);\n      } else {\n        this._setNextState(state);\n      }\n\n      onScroll({ scrollTop: scrollTop });\n    }\n  }]);\n\n  return WindowScroller;\n}(_react.Component);\n\nWindowScroller.propTypes = {\n  /**\n   * Function respondible for rendering children.\n   * This function should implement the following signature:\n   * ({ height, scrollTop }) => PropTypes.element\n   */\n  children: _react.PropTypes.func.isRequired,\n\n  /** Callback to be invoked on-resize: ({ height }) */\n  onResize: _react.PropTypes.func.isRequired,\n\n  /** Callback to be invoked on-scroll: ({ scrollTop }) */\n  onScroll: _react.PropTypes.func.isRequired\n};\nWindowScroller.defaultProps = {\n  onResize: function onResize() {},\n  onScroll: function onScroll() {}\n};\nexports.default = WindowScroller;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.IS_SCROLLING_TIMEOUT = exports.WindowScroller = exports.default = undefined;\n\nvar _WindowScroller2 = require('./WindowScroller');\n\nvar _WindowScroller3 = _interopRequireDefault(_WindowScroller2);\n\nvar _onScroll = require('./utils/onScroll');\n\nvar _onScroll2 = _interopRequireDefault(_onScroll);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nexports.default = _WindowScroller3.default;\nexports.WindowScroller = _WindowScroller3.default;\nexports.IS_SCROLLING_TIMEOUT = _onScroll2.default;","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.registerScrollListener = registerScrollListener;\nexports.unregisterScrollListener = unregisterScrollListener;\nvar mountedInstances = [];\nvar originalBodyPointerEvents = null;\nvar disablePointerEventsTimeoutId = null;\n\n/**\n * Specifies the number of miliseconds during which to disable pointer events while a scroll is in progress.\n * This improves performance and makes scrolling smoother.\n */\nvar IS_SCROLLING_TIMEOUT = exports.IS_SCROLLING_TIMEOUT = 150;\n\nfunction enablePointerEventsIfDisabled() {\n  if (disablePointerEventsTimeoutId) {\n    disablePointerEventsTimeoutId = null;\n\n    document.body.style.pointerEvents = originalBodyPointerEvents;\n\n    originalBodyPointerEvents = null;\n  }\n}\n\nfunction enablePointerEventsAfterDelayCallback() {\n  enablePointerEventsIfDisabled();\n  mountedInstances.forEach(function (component) {\n    return component._enablePointerEventsAfterDelayCallback();\n  });\n}\n\nfunction enablePointerEventsAfterDelay() {\n  if (disablePointerEventsTimeoutId) {\n    clearTimeout(disablePointerEventsTimeoutId);\n  }\n\n  disablePointerEventsTimeoutId = setTimeout(enablePointerEventsAfterDelayCallback, IS_SCROLLING_TIMEOUT);\n}\n\nfunction onScrollWindow(event) {\n  if (originalBodyPointerEvents == null) {\n    originalBodyPointerEvents = document.body.style.pointerEvents;\n\n    document.body.style.pointerEvents = 'none';\n\n    enablePointerEventsAfterDelay();\n  }\n  mountedInstances.forEach(function (component) {\n    return component._onScrollWindow(event);\n  });\n}\n\nfunction registerScrollListener(component) {\n  if (!mountedInstances.length) {\n    window.addEventListener('scroll', onScrollWindow);\n  }\n  mountedInstances.push(component);\n}\n\nfunction unregisterScrollListener(component) {\n  mountedInstances = mountedInstances.filter(function (c) {\n    return c !== component;\n  });\n  if (!mountedInstances.length) {\n    window.removeEventListener('scroll', onScrollWindow);\n    if (disablePointerEventsTimeoutId) {\n      clearTimeout(disablePointerEventsTimeoutId);\n      enablePointerEventsIfDisabled();\n    }\n  }\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _ArrowKeyStepper = require('./ArrowKeyStepper');\n\nObject.defineProperty(exports, 'ArrowKeyStepper', {\n  enumerable: true,\n  get: function get() {\n    return _ArrowKeyStepper.ArrowKeyStepper;\n  }\n});\n\nvar _AutoSizer = require('./AutoSizer');\n\nObject.defineProperty(exports, 'AutoSizer', {\n  enumerable: true,\n  get: function get() {\n    return _AutoSizer.AutoSizer;\n  }\n});\n\nvar _CellMeasurer = require('./CellMeasurer');\n\nObject.defineProperty(exports, 'CellMeasurer', {\n  enumerable: true,\n  get: function get() {\n    return _CellMeasurer.CellMeasurer;\n  }\n});\nObject.defineProperty(exports, 'defaultCellMeasurerCellSizeCache', {\n  enumerable: true,\n  get: function get() {\n    return _CellMeasurer.defaultCellSizeCache;\n  }\n});\nObject.defineProperty(exports, 'uniformSizeCellMeasurerCellSizeCache', {\n  enumerable: true,\n  get: function get() {\n    return _CellMeasurer.defaultCellSizeCache;\n  }\n});\n\nvar _Collection = require('./Collection');\n\nObject.defineProperty(exports, 'Collection', {\n  enumerable: true,\n  get: function get() {\n    return _Collection.Collection;\n  }\n});\n\nvar _ColumnSizer = require('./ColumnSizer');\n\nObject.defineProperty(exports, 'ColumnSizer', {\n  enumerable: true,\n  get: function get() {\n    return _ColumnSizer.ColumnSizer;\n  }\n});\n\nvar _FlexTable = require('./FlexTable');\n\nObject.defineProperty(exports, 'defaultFlexTableCellDataGetter', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.defaultCellDataGetter;\n  }\n});\nObject.defineProperty(exports, 'defaultFlexTableCellRenderer', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.defaultCellRenderer;\n  }\n});\nObject.defineProperty(exports, 'defaultFlexTableHeaderRenderer', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.defaultHeaderRenderer;\n  }\n});\nObject.defineProperty(exports, 'defaultFlexTableRowRenderer', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.defaultRowRenderer;\n  }\n});\nObject.defineProperty(exports, 'FlexTable', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.FlexTable;\n  }\n});\nObject.defineProperty(exports, 'FlexColumn', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.FlexColumn;\n  }\n});\nObject.defineProperty(exports, 'SortDirection', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.SortDirection;\n  }\n});\nObject.defineProperty(exports, 'SortIndicator', {\n  enumerable: true,\n  get: function get() {\n    return _FlexTable.SortIndicator;\n  }\n});\n\nvar _Grid = require('./Grid');\n\nObject.defineProperty(exports, 'defaultCellRangeRenderer', {\n  enumerable: true,\n  get: function get() {\n    return _Grid.defaultCellRangeRenderer;\n  }\n});\nObject.defineProperty(exports, 'Grid', {\n  enumerable: true,\n  get: function get() {\n    return _Grid.Grid;\n  }\n});\n\nvar _InfiniteLoader = require('./InfiniteLoader');\n\nObject.defineProperty(exports, 'InfiniteLoader', {\n  enumerable: true,\n  get: function get() {\n    return _InfiniteLoader.InfiniteLoader;\n  }\n});\n\nvar _ScrollSync = require('./ScrollSync');\n\nObject.defineProperty(exports, 'ScrollSync', {\n  enumerable: true,\n  get: function get() {\n    return _ScrollSync.ScrollSync;\n  }\n});\n\nvar _VirtualScroll = require('./VirtualScroll');\n\nObject.defineProperty(exports, 'VirtualScroll', {\n  enumerable: true,\n  get: function get() {\n    return _VirtualScroll.VirtualScroll;\n  }\n});\n\nvar _WindowScroller = require('./WindowScroller');\n\nObject.defineProperty(exports, 'WindowScroller', {\n  enumerable: true,\n  get: function get() {\n    return _WindowScroller.WindowScroller;\n  }\n});","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = createCallbackMemoizer;\n/**\n * Helper utility that updates the specified callback whenever any of the specified indices have changed.\n */\nfunction createCallbackMemoizer() {\n  var requireAllKeys = arguments.length <= 0 || arguments[0] === undefined ? true : arguments[0];\n\n  var cachedIndices = {};\n\n  return function (_ref) {\n    var callback = _ref.callback;\n    var indices = _ref.indices;\n\n    var keys = Object.keys(indices);\n    var allInitialized = !requireAllKeys || keys.every(function (key) {\n      var value = indices[key];\n      return Array.isArray(value) ? value.length > 0 : value >= 0;\n    });\n    var indexChanged = keys.length !== Object.keys(cachedIndices).length || keys.some(function (key) {\n      var cachedValue = cachedIndices[key];\n      var value = indices[key];\n\n      return Array.isArray(value) ? cachedValue.join(',') !== value.join(',') : cachedValue !== value;\n    });\n\n    cachedIndices = indices;\n\n    if (allInitialized && indexChanged) {\n      callback(indices);\n    }\n  };\n}","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.default = getUpdatedOffsetForIndex;\n/**\n * Determines a new offset that ensures a certain cell is visible, given the current offset.\n * If the cell is already visible then the current offset will be returned.\n * If the current offset is too great or small, it will be adjusted just enough to ensure the specified index is visible.\n *\n * @param align Desired alignment within container; one of \"auto\" (default), \"start\", or \"end\"\n * @param cellOffset Offset (x or y) position for cell\n * @param cellSize Size (width or height) of cell\n * @param containerSize Total size (width or height) of the container\n * @param currentOffset Container's current (x or y) offset\n * @return Offset to use to ensure the specified cell is visible\n */\nfunction getUpdatedOffsetForIndex(_ref) {\n  var _ref$align = _ref.align;\n  var align = _ref$align === undefined ? 'auto' : _ref$align;\n  var cellOffset = _ref.cellOffset;\n  var cellSize = _ref.cellSize;\n  var containerSize = _ref.containerSize;\n  var currentOffset = _ref.currentOffset;\n\n  var maxOffset = cellOffset;\n  var minOffset = maxOffset - containerSize + cellSize;\n\n  switch (align) {\n    case 'start':\n      return maxOffset;\n    case 'end':\n      return minOffset;\n    case 'center':\n      return maxOffset - (containerSize - cellSize) / 2;\n    default:\n      return Math.max(minOffset, Math.min(maxOffset, currentOffset));\n  }\n}","'use strict';\n\n/**\n* Detect Element Resize.\n* Forked in order to guard against unsafe 'window' and 'document' references.\n*\n* https://github.com/sdecima/javascript-detect-element-resize\n* Sebastian Decima\n*\n* version: 0.5.3\n**/\n\n// Check `document` and `window` in case of server-side rendering\nvar _window;\nif (typeof window !== 'undefined') {\n  _window = window;\n} else if (typeof self !== 'undefined') {\n  _window = self;\n} else {\n  _window = undefined;\n}\n\nvar attachEvent = typeof document !== 'undefined' && document.attachEvent;\nvar stylesCreated = false;\n\nif (!attachEvent) {\n  var requestFrame = function () {\n    var raf = _window.requestAnimationFrame || _window.mozRequestAnimationFrame || _window.webkitRequestAnimationFrame || function (fn) {\n      return _window.setTimeout(fn, 20);\n    };\n    return function (fn) {\n      return raf(fn);\n    };\n  }();\n\n  var cancelFrame = function () {\n    var cancel = _window.cancelAnimationFrame || _window.mozCancelAnimationFrame || _window.webkitCancelAnimationFrame || _window.clearTimeout;\n    return function (id) {\n      return cancel(id);\n    };\n  }();\n\n  var resetTriggers = function resetTriggers(element) {\n    var triggers = element.__resizeTriggers__,\n        expand = triggers.firstElementChild,\n        contract = triggers.lastElementChild,\n        expandChild = expand.firstElementChild;\n    contract.scrollLeft = contract.scrollWidth;\n    contract.scrollTop = contract.scrollHeight;\n    expandChild.style.width = expand.offsetWidth + 1 + 'px';\n    expandChild.style.height = expand.offsetHeight + 1 + 'px';\n    expand.scrollLeft = expand.scrollWidth;\n    expand.scrollTop = expand.scrollHeight;\n  };\n\n  var checkTriggers = function checkTriggers(element) {\n    return element.offsetWidth != element.__resizeLast__.width || element.offsetHeight != element.__resizeLast__.height;\n  };\n\n  var scrollListener = function scrollListener(e) {\n    var element = this;\n    resetTriggers(this);\n    if (this.__resizeRAF__) cancelFrame(this.__resizeRAF__);\n    this.__resizeRAF__ = requestFrame(function () {\n      if (checkTriggers(element)) {\n        element.__resizeLast__.width = element.offsetWidth;\n        element.__resizeLast__.height = element.offsetHeight;\n        element.__resizeListeners__.forEach(function (fn) {\n          fn.call(element, e);\n        });\n      }\n    });\n  };\n\n  /* Detect CSS Animations support to detect element display/re-attach */\n  var animation = false,\n      animationstring = 'animation',\n      keyframeprefix = '',\n      animationstartevent = 'animationstart',\n      domPrefixes = 'Webkit Moz O ms'.split(' '),\n      startEvents = 'webkitAnimationStart animationstart oAnimationStart MSAnimationStart'.split(' '),\n      pfx = '';\n  {\n    var elm = document.createElement('fakeelement');\n    if (elm.style.animationName !== undefined) {\n      animation = true;\n    }\n\n    if (animation === false) {\n      for (var i = 0; i < domPrefixes.length; i++) {\n        if (elm.style[domPrefixes[i] + 'AnimationName'] !== undefined) {\n          pfx = domPrefixes[i];\n          animationstring = pfx + 'Animation';\n          keyframeprefix = '-' + pfx.toLowerCase() + '-';\n          animationstartevent = startEvents[i];\n          animation = true;\n          break;\n        }\n      }\n    }\n  }\n\n  var animationName = 'resizeanim';\n  var animationKeyframes = '@' + keyframeprefix + 'keyframes ' + animationName + ' { from { opacity: 0; } to { opacity: 0; } } ';\n  var animationStyle = keyframeprefix + 'animation: 1ms ' + animationName + '; ';\n}\n\nvar createStyles = function createStyles() {\n  if (!stylesCreated) {\n    //opacity:0 works around a chrome bug https://code.google.com/p/chromium/issues/detail?id=286360\n    var css = (animationKeyframes ? animationKeyframes : '') + '.resize-triggers { ' + (animationStyle ? animationStyle : '') + 'visibility: hidden; opacity: 0; } ' + '.resize-triggers, .resize-triggers > div, .contract-trigger:before { content: \\\" \\\"; display: block; position: absolute; top: 0; left: 0; height: 100%; width: 100%; overflow: hidden; } .resize-triggers > div { background: #eee; overflow: auto; } .contract-trigger:before { width: 200%; height: 200%; }',\n        head = document.head || document.getElementsByTagName('head')[0],\n        style = document.createElement('style');\n\n    style.type = 'text/css';\n    if (style.styleSheet) {\n      style.styleSheet.cssText = css;\n    } else {\n      style.appendChild(document.createTextNode(css));\n    }\n\n    head.appendChild(style);\n    stylesCreated = true;\n  }\n};\n\nvar addResizeListener = function addResizeListener(element, fn) {\n  if (attachEvent) element.attachEvent('onresize', fn);else {\n    if (!element.__resizeTriggers__) {\n      if (getComputedStyle(element).position == 'static') element.style.position = 'relative';\n      createStyles();\n      element.__resizeLast__ = {};\n      element.__resizeListeners__ = [];\n      (element.__resizeTriggers__ = document.createElement('div')).className = 'resize-triggers';\n      element.__resizeTriggers__.innerHTML = '<div class=\"expand-trigger\"><div></div></div>' + '<div class=\"contract-trigger\"></div>';\n      element.appendChild(element.__resizeTriggers__);\n      resetTriggers(element);\n      element.addEventListener('scroll', scrollListener, true);\n\n      /* Listen for a css animation to detect element display/re-attach */\n      animationstartevent && element.__resizeTriggers__.addEventListener(animationstartevent, function (e) {\n        if (e.animationName == animationName) resetTriggers(element);\n      });\n    }\n    element.__resizeListeners__.push(fn);\n  }\n};\n\nvar removeResizeListener = function removeResizeListener(element, fn) {\n  if (attachEvent) element.detachEvent('onresize', fn);else {\n    element.__resizeListeners__.splice(element.__resizeListeners__.indexOf(fn), 1);\n    if (!element.__resizeListeners__.length) {\n      element.removeEventListener('scroll', scrollListener, true);\n      element.__resizeTriggers__ = !element.removeChild(element.__resizeTriggers__);\n    }\n  }\n};\n\nmodule.exports = {\n  addResizeListener: addResizeListener,\n  removeResizeListener: removeResizeListener\n};","/**\n * Copyright 2013-present, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n *\n */\n\n'use strict';\n\nvar shallowEqual = require('fbjs/lib/shallowEqual');\n\n/**\n * Does a shallow comparison for props and state.\n * See ReactComponentWithPureRenderMixin\n * See also https://facebook.github.io/react/docs/shallow-compare.html\n */\nfunction shallowCompare(instance, nextProps, nextState) {\n  return !shallowEqual(instance.props, nextProps) || !shallowEqual(instance.state, nextState);\n}\n\nmodule.exports = shallowCompare;","'use strict';\nmodule.exports = function (str) {\n\treturn encodeURIComponent(str).replace(/[!'()*]/g, function (c) {\n\t\treturn '%' + c.charCodeAt(0).toString(16).toUpperCase();\n\t});\n};\n","(function(self) {\n  'use strict';\n\n  if (self.fetch) {\n    return\n  }\n\n  var support = {\n    searchParams: 'URLSearchParams' in self,\n    iterable: 'Symbol' in self && 'iterator' in Symbol,\n    blob: 'FileReader' in self && 'Blob' in self && (function() {\n      try {\n        new Blob()\n        return true\n      } catch(e) {\n        return false\n      }\n    })(),\n    formData: 'FormData' in self,\n    arrayBuffer: 'ArrayBuffer' in self\n  }\n\n  if (support.arrayBuffer) {\n    var viewClasses = [\n      '[object Int8Array]',\n      '[object Uint8Array]',\n      '[object Uint8ClampedArray]',\n      '[object Int16Array]',\n      '[object Uint16Array]',\n      '[object Int32Array]',\n      '[object Uint32Array]',\n      '[object Float32Array]',\n      '[object Float64Array]'\n    ]\n\n    var isDataView = function(obj) {\n      return obj && DataView.prototype.isPrototypeOf(obj)\n    }\n\n    var isArrayBufferView = ArrayBuffer.isView || function(obj) {\n      return obj && viewClasses.indexOf(Object.prototype.toString.call(obj)) > -1\n    }\n  }\n\n  function normalizeName(name) {\n    if (typeof name !== 'string') {\n      name = String(name)\n    }\n    if (/[^a-z0-9\\-#$%&'*+.\\^_`|~]/i.test(name)) {\n      throw new TypeError('Invalid character in header field name')\n    }\n    return name.toLowerCase()\n  }\n\n  function normalizeValue(value) {\n    if (typeof value !== 'string') {\n      value = String(value)\n    }\n    return value\n  }\n\n  // Build a destructive iterator for the value list\n  function iteratorFor(items) {\n    var iterator = {\n      next: function() {\n        var value = items.shift()\n        return {done: value === undefined, value: value}\n      }\n    }\n\n    if (support.iterable) {\n      iterator[Symbol.iterator] = function() {\n        return iterator\n      }\n    }\n\n    return iterator\n  }\n\n  function Headers(headers) {\n    this.map = {}\n\n    if (headers instanceof Headers) {\n      headers.forEach(function(value, name) {\n        this.append(name, value)\n      }, this)\n\n    } else if (headers) {\n      Object.getOwnPropertyNames(headers).forEach(function(name) {\n        this.append(name, headers[name])\n      }, this)\n    }\n  }\n\n  Headers.prototype.append = function(name, value) {\n    name = normalizeName(name)\n    value = normalizeValue(value)\n    var oldValue = this.map[name]\n    this.map[name] = oldValue ? oldValue+','+value : value\n  }\n\n  Headers.prototype['delete'] = function(name) {\n    delete this.map[normalizeName(name)]\n  }\n\n  Headers.prototype.get = function(name) {\n    name = normalizeName(name)\n    return this.has(name) ? this.map[name] : null\n  }\n\n  Headers.prototype.has = function(name) {\n    return this.map.hasOwnProperty(normalizeName(name))\n  }\n\n  Headers.prototype.set = function(name, value) {\n    this.map[normalizeName(name)] = normalizeValue(value)\n  }\n\n  Headers.prototype.forEach = function(callback, thisArg) {\n    for (var name in this.map) {\n      if (this.map.hasOwnProperty(name)) {\n        callback.call(thisArg, this.map[name], name, this)\n      }\n    }\n  }\n\n  Headers.prototype.keys = function() {\n    var items = []\n    this.forEach(function(value, name) { items.push(name) })\n    return iteratorFor(items)\n  }\n\n  Headers.prototype.values = function() {\n    var items = []\n    this.forEach(function(value) { items.push(value) })\n    return iteratorFor(items)\n  }\n\n  Headers.prototype.entries = function() {\n    var items = []\n    this.forEach(function(value, name) { items.push([name, value]) })\n    return iteratorFor(items)\n  }\n\n  if (support.iterable) {\n    Headers.prototype[Symbol.iterator] = Headers.prototype.entries\n  }\n\n  function consumed(body) {\n    if (body.bodyUsed) {\n      return Promise.reject(new TypeError('Already read'))\n    }\n    body.bodyUsed = true\n  }\n\n  function fileReaderReady(reader) {\n    return new Promise(function(resolve, reject) {\n      reader.onload = function() {\n        resolve(reader.result)\n      }\n      reader.onerror = function() {\n        reject(reader.error)\n      }\n    })\n  }\n\n  function readBlobAsArrayBuffer(blob) {\n    var reader = new FileReader()\n    var promise = fileReaderReady(reader)\n    reader.readAsArrayBuffer(blob)\n    return promise\n  }\n\n  function readBlobAsText(blob) {\n    var reader = new FileReader()\n    var promise = fileReaderReady(reader)\n    reader.readAsText(blob)\n    return promise\n  }\n\n  function readArrayBufferAsText(buf) {\n    var view = new Uint8Array(buf)\n    var chars = new Array(view.length)\n\n    for (var i = 0; i < view.length; i++) {\n      chars[i] = String.fromCharCode(view[i])\n    }\n    return chars.join('')\n  }\n\n  function bufferClone(buf) {\n    if (buf.slice) {\n      return buf.slice(0)\n    } else {\n      var view = new Uint8Array(buf.byteLength)\n      view.set(new Uint8Array(buf))\n      return view.buffer\n    }\n  }\n\n  function Body() {\n    this.bodyUsed = false\n\n    this._initBody = function(body) {\n      this._bodyInit = body\n      if (!body) {\n        this._bodyText = ''\n      } else if (typeof body === 'string') {\n        this._bodyText = body\n      } else if (support.blob && Blob.prototype.isPrototypeOf(body)) {\n        this._bodyBlob = body\n      } else if (support.formData && FormData.prototype.isPrototypeOf(body)) {\n        this._bodyFormData = body\n      } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n        this._bodyText = body.toString()\n      } else if (support.arrayBuffer && support.blob && isDataView(body)) {\n        this._bodyArrayBuffer = bufferClone(body.buffer)\n        // IE 10-11 can't handle a DataView body.\n        this._bodyInit = new Blob([this._bodyArrayBuffer])\n      } else if (support.arrayBuffer && (ArrayBuffer.prototype.isPrototypeOf(body) || isArrayBufferView(body))) {\n        this._bodyArrayBuffer = bufferClone(body)\n      } else {\n        throw new Error('unsupported BodyInit type')\n      }\n\n      if (!this.headers.get('content-type')) {\n        if (typeof body === 'string') {\n          this.headers.set('content-type', 'text/plain;charset=UTF-8')\n        } else if (this._bodyBlob && this._bodyBlob.type) {\n          this.headers.set('content-type', this._bodyBlob.type)\n        } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n          this.headers.set('content-type', 'application/x-www-form-urlencoded;charset=UTF-8')\n        }\n      }\n    }\n\n    if (support.blob) {\n      this.blob = function() {\n        var rejected = consumed(this)\n        if (rejected) {\n          return rejected\n        }\n\n        if (this._bodyBlob) {\n          return Promise.resolve(this._bodyBlob)\n        } else if (this._bodyArrayBuffer) {\n          return Promise.resolve(new Blob([this._bodyArrayBuffer]))\n        } else if (this._bodyFormData) {\n          throw new Error('could not read FormData body as blob')\n        } else {\n          return Promise.resolve(new Blob([this._bodyText]))\n        }\n      }\n\n      this.arrayBuffer = function() {\n        if (this._bodyArrayBuffer) {\n          return consumed(this) || Promise.resolve(this._bodyArrayBuffer)\n        } else {\n          return this.blob().then(readBlobAsArrayBuffer)\n        }\n      }\n    }\n\n    this.text = function() {\n      var rejected = consumed(this)\n      if (rejected) {\n        return rejected\n      }\n\n      if (this._bodyBlob) {\n        return readBlobAsText(this._bodyBlob)\n      } else if (this._bodyArrayBuffer) {\n        return Promise.resolve(readArrayBufferAsText(this._bodyArrayBuffer))\n      } else if (this._bodyFormData) {\n        throw new Error('could not read FormData body as text')\n      } else {\n        return Promise.resolve(this._bodyText)\n      }\n    }\n\n    if (support.formData) {\n      this.formData = function() {\n        return this.text().then(decode)\n      }\n    }\n\n    this.json = function() {\n      return this.text().then(JSON.parse)\n    }\n\n    return this\n  }\n\n  // HTTP methods whose capitalization should be normalized\n  var methods = ['DELETE', 'GET', 'HEAD', 'OPTIONS', 'POST', 'PUT']\n\n  function normalizeMethod(method) {\n    var upcased = method.toUpperCase()\n    return (methods.indexOf(upcased) > -1) ? upcased : method\n  }\n\n  function Request(input, options) {\n    options = options || {}\n    var body = options.body\n\n    if (typeof input === 'string') {\n      this.url = input\n    } else {\n      if (input.bodyUsed) {\n        throw new TypeError('Already read')\n      }\n      this.url = input.url\n      this.credentials = input.credentials\n      if (!options.headers) {\n        this.headers = new Headers(input.headers)\n      }\n      this.method = input.method\n      this.mode = input.mode\n      if (!body && input._bodyInit != null) {\n        body = input._bodyInit\n        input.bodyUsed = true\n      }\n    }\n\n    this.credentials = options.credentials || this.credentials || 'omit'\n    if (options.headers || !this.headers) {\n      this.headers = new Headers(options.headers)\n    }\n    this.method = normalizeMethod(options.method || this.method || 'GET')\n    this.mode = options.mode || this.mode || null\n    this.referrer = null\n\n    if ((this.method === 'GET' || this.method === 'HEAD') && body) {\n      throw new TypeError('Body not allowed for GET or HEAD requests')\n    }\n    this._initBody(body)\n  }\n\n  Request.prototype.clone = function() {\n    return new Request(this, { body: this._bodyInit })\n  }\n\n  function decode(body) {\n    var form = new FormData()\n    body.trim().split('&').forEach(function(bytes) {\n      if (bytes) {\n        var split = bytes.split('=')\n        var name = split.shift().replace(/\\+/g, ' ')\n        var value = split.join('=').replace(/\\+/g, ' ')\n        form.append(decodeURIComponent(name), decodeURIComponent(value))\n      }\n    })\n    return form\n  }\n\n  function parseHeaders(rawHeaders) {\n    var headers = new Headers()\n    rawHeaders.split('\\r\\n').forEach(function(line) {\n      var parts = line.split(':')\n      var key = parts.shift().trim()\n      if (key) {\n        var value = parts.join(':').trim()\n        headers.append(key, value)\n      }\n    })\n    return headers\n  }\n\n  Body.call(Request.prototype)\n\n  function Response(bodyInit, options) {\n    if (!options) {\n      options = {}\n    }\n\n    this.type = 'default'\n    this.status = 'status' in options ? options.status : 200\n    this.ok = this.status >= 200 && this.status < 300\n    this.statusText = 'statusText' in options ? options.statusText : 'OK'\n    this.headers = new Headers(options.headers)\n    this.url = options.url || ''\n    this._initBody(bodyInit)\n  }\n\n  Body.call(Response.prototype)\n\n  Response.prototype.clone = function() {\n    return new Response(this._bodyInit, {\n      status: this.status,\n      statusText: this.statusText,\n      headers: new Headers(this.headers),\n      url: this.url\n    })\n  }\n\n  Response.error = function() {\n    var response = new Response(null, {status: 0, statusText: ''})\n    response.type = 'error'\n    return response\n  }\n\n  var redirectStatuses = [301, 302, 303, 307, 308]\n\n  Response.redirect = function(url, status) {\n    if (redirectStatuses.indexOf(status) === -1) {\n      throw new RangeError('Invalid status code')\n    }\n\n    return new Response(null, {status: status, headers: {location: url}})\n  }\n\n  self.Headers = Headers\n  self.Request = Request\n  self.Response = Response\n\n  self.fetch = function(input, init) {\n    return new Promise(function(resolve, reject) {\n      var request = new Request(input, init)\n      var xhr = new XMLHttpRequest()\n\n      xhr.onload = function() {\n        var options = {\n          status: xhr.status,\n          statusText: xhr.statusText,\n          headers: parseHeaders(xhr.getAllResponseHeaders() || '')\n        }\n        options.url = 'responseURL' in xhr ? xhr.responseURL : options.headers.get('X-Request-URL')\n        var body = 'response' in xhr ? xhr.response : xhr.responseText\n        resolve(new Response(body, options))\n      }\n\n      xhr.onerror = function() {\n        reject(new TypeError('Network request failed'))\n      }\n\n      xhr.ontimeout = function() {\n        reject(new TypeError('Network request failed'))\n      }\n\n      xhr.open(request.method, request.url, true)\n\n      if (request.credentials === 'include') {\n        xhr.withCredentials = true\n      }\n\n      if ('responseType' in xhr && support.blob) {\n        xhr.responseType = 'blob'\n      }\n\n      request.headers.forEach(function(value, name) {\n        xhr.setRequestHeader(name, value)\n      })\n\n      xhr.send(typeof request._bodyInit === 'undefined' ? null : request._bodyInit)\n    })\n  }\n  self.fetch.polyfill = true\n})(typeof self !== 'undefined' ? self : this);\n"]} diff --git a/examples/dist/bundle.js b/examples/dist/bundle.js index 59885cff38..3991718cb0 100644 --- a/examples/dist/bundle.js +++ b/examples/dist/bundle.js @@ -275,6 +275,16 @@ var _Select = require('./Select'); var _Select2 = _interopRequireDefault(_Select); +function reduce(obj) { + var props = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; + + return Object.keys(obj).reduce(function (props, key) { + var value = obj[key]; + if (value !== undefined) props[key] = value; + return props; + }, props); +} + var AsyncCreatable = _react2['default'].createClass({ displayName: 'AsyncCreatableSelect', @@ -289,10 +299,14 @@ var AsyncCreatable = _react2['default'].createClass({ _Select2['default'].Creatable, _this.props, function (creatableProps) { - return _react2['default'].createElement(_Select2['default'], _extends({}, asyncProps, creatableProps, { + return _react2['default'].createElement(_Select2['default'], _extends({}, reduce(asyncProps, reduce(creatableProps, {})), { onInputChange: function (input) { creatableProps.onInputChange(input); return asyncProps.onInputChange(input); + }, + ref: function (ref) { + creatableProps.ref(ref); + asyncProps.ref(ref); } })); } @@ -357,9 +371,15 @@ var Creatable = _react2['default'].createClass({ // ({ label: string, labelKey: string, valueKey: string }): Object newOptionCreator: _react2['default'].PropTypes.func, + // input change handler: function (inputValue) {} + onInputChange: _react2['default'].PropTypes.func, + // input keyDown handler: function (event) {} onInputKeyDown: _react2['default'].PropTypes.func, + // new option click handler: function (option) {} + onNewOptionClick: _react2['default'].PropTypes.func, + // See Select.propTypes.options options: _react2['default'].PropTypes.array, @@ -396,6 +416,7 @@ var Creatable = _react2['default'].createClass({ var _props = this.props; var isValidNewOption = _props.isValidNewOption; var newOptionCreator = _props.newOptionCreator; + var onNewOptionClick = _props.onNewOptionClick; var _props$options = _props.options; var options = _props$options === undefined ? [] : _props$options; var shouldKeyDownEventCreateNewOption = _props.shouldKeyDownEventCreateNewOption; @@ -406,9 +427,13 @@ var Creatable = _react2['default'].createClass({ // Don't add the same option twice. if (_isOptionUnique) { - options.unshift(option); + if (onNewOptionClick) { + onNewOptionClick(option); + } else { + options.unshift(option); - this.select.selectValue(option); + this.select.selectValue(option); + } } } }, @@ -478,11 +503,18 @@ var Creatable = _react2['default'].createClass({ var menuRenderer = this.props.menuRenderer; return menuRenderer(_extends({}, params, { - onSelect: this.onOptionSelect + onSelect: this.onOptionSelect, + selectValue: this.onOptionSelect })); }, onInputChange: function onInputChange(input) { + var onInputChange = this.props.onInputChange; + + if (onInputChange) { + onInputChange(input); + } + // This value may be needed in between Select mounts (when this.select is null) this.inputValue = input; }, @@ -1067,6 +1099,7 @@ var Select = _react2['default'].createClass({ clearAllText: stringOrNode, // title for the "clear" control when multi: true clearValueText: stringOrNode, // title for the "clear" control clearable: _react2['default'].PropTypes.bool, // should it be possible to reset value + deleteRemoves: _react2['default'].PropTypes.bool, // whether backspace removes an item if there is no text input delimiter: _react2['default'].PropTypes.string, // delimiter to use to join multiple values for the hidden field value disabled: _react2['default'].PropTypes.bool, // whether the Select is disabled or not escapeClearsValue: _react2['default'].PropTypes.bool, // whether escape clears the value when the menu is closed @@ -1135,6 +1168,7 @@ var Select = _react2['default'].createClass({ clearable: true, clearAllText: 'Clear all', clearValueText: 'Clear value', + deleteRemoves: true, delimiter: ',', disabled: false, escapeClearsValue: true, @@ -1540,6 +1574,13 @@ var Select = _react2['default'].createClass({ } this.focusStartOption(); break; + case 46: + // backspace + if (!this.state.inputValue && this.props.deleteRemoves) { + event.preventDefault(); + this.popValue(); + } + return; default: return; } @@ -1865,70 +1906,69 @@ var Select = _react2['default'].createClass({ }, renderInput: function renderInput(valueArray, focusedOptionIndex) { - var _this5 = this; + var _classNames, + _this5 = this; + + var className = (0, _classnames2['default'])('Select-input', this.props.inputProps.className); + var isOpen = !!this.state.isOpen; + + var ariaOwns = (0, _classnames2['default'])((_classNames = {}, _defineProperty(_classNames, this._instancePrefix + '-list', isOpen), _defineProperty(_classNames, this._instancePrefix + '-backspace-remove-message', this.props.multi && !this.props.disabled && this.state.isFocused && !this.state.inputValue), _classNames)); + + // TODO: Check how this project includes Object.assign() + var inputProps = _extends({}, this.props.inputProps, { + role: 'combobox', + 'aria-expanded': '' + isOpen, + 'aria-owns': ariaOwns, + 'aria-haspopup': '' + isOpen, + 'aria-activedescendant': isOpen ? this._instancePrefix + '-option-' + focusedOptionIndex : this._instancePrefix + '-value', + 'aria-labelledby': this.props['aria-labelledby'], + 'aria-label': this.props['aria-label'], + className: className, + tabIndex: this.props.tabIndex, + onBlur: this.handleInputBlur, + onChange: this.handleInputChange, + onFocus: this.handleInputFocus, + ref: function ref(_ref) { + return _this5.input = _ref; + }, + required: this.state.required, + value: this.state.inputValue + }); if (this.props.inputRenderer) { - return this.props.inputRenderer(); - } else { - var _classNames; + return this.props.inputRenderer(inputProps); + } - var className = (0, _classnames2['default'])('Select-input', this.props.inputProps.className); - var isOpen = !!this.state.isOpen; + if (this.props.disabled || !this.props.searchable) { + var _props$inputProps = this.props.inputProps; + var inputClassName = _props$inputProps.inputClassName; - var ariaOwns = (0, _classnames2['default'])((_classNames = {}, _defineProperty(_classNames, this._instancePrefix + '-list', isOpen), _defineProperty(_classNames, this._instancePrefix + '-backspace-remove-message', this.props.multi && !this.props.disabled && this.state.isFocused && !this.state.inputValue), _classNames)); + var divProps = _objectWithoutProperties(_props$inputProps, ['inputClassName']); - // TODO: Check how this project includes Object.assign() - var inputProps = _extends({}, this.props.inputProps, { + return _react2['default'].createElement('div', _extends({}, divProps, { role: 'combobox', - 'aria-expanded': '' + isOpen, - 'aria-owns': ariaOwns, - 'aria-haspopup': '' + isOpen, + 'aria-expanded': isOpen, + 'aria-owns': isOpen ? this._instancePrefix + '-list' : this._instancePrefix + '-value', 'aria-activedescendant': isOpen ? this._instancePrefix + '-option-' + focusedOptionIndex : this._instancePrefix + '-value', - 'aria-labelledby': this.props['aria-labelledby'], - 'aria-label': this.props['aria-label'], className: className, - tabIndex: this.props.tabIndex, + tabIndex: this.props.tabIndex || 0, onBlur: this.handleInputBlur, - onChange: this.handleInputChange, onFocus: this.handleInputFocus, - ref: function ref(_ref) { - return _this5.input = _ref; + ref: function (ref) { + return _this5.input = ref; }, - required: this.state.required, - value: this.state.inputValue - }); - - if (this.props.disabled || !this.props.searchable) { - var _props$inputProps = this.props.inputProps; - var inputClassName = _props$inputProps.inputClassName; - - var divProps = _objectWithoutProperties(_props$inputProps, ['inputClassName']); - - return _react2['default'].createElement('div', _extends({}, divProps, { - role: 'combobox', - 'aria-expanded': isOpen, - 'aria-owns': isOpen ? this._instancePrefix + '-list' : this._instancePrefix + '-value', - 'aria-activedescendant': isOpen ? this._instancePrefix + '-option-' + focusedOptionIndex : this._instancePrefix + '-value', - className: className, - tabIndex: this.props.tabIndex || 0, - onBlur: this.handleInputBlur, - onFocus: this.handleInputFocus, - ref: function (ref) { - return _this5.input = ref; - }, - 'aria-readonly': '' + !!this.props.disabled, - style: { border: 0, width: 1, display: 'inline-block' } })); - } + 'aria-readonly': '' + !!this.props.disabled, + style: { border: 0, width: 1, display: 'inline-block' } })); + } - if (this.props.autosize) { - return _react2['default'].createElement(_reactInputAutosize2['default'], _extends({}, inputProps, { minWidth: '5' })); - } - return _react2['default'].createElement( - 'div', - { className: className }, - _react2['default'].createElement('input', inputProps) - ); + if (this.props.autosize) { + return _react2['default'].createElement(_reactInputAutosize2['default'], _extends({}, inputProps, { minWidth: '5' })); } + return _react2['default'].createElement( + 'div', + { className: className }, + _react2['default'].createElement('input', inputProps) + ); }, renderClear: function renderClear() { @@ -2165,4 +2205,4 @@ exports['default'] = Select; module.exports = exports['default']; },{"./Async":1,"./AsyncCreatable":2,"./Creatable":3,"./Option":4,"./Value":5,"./utils/defaultArrowRenderer":6,"./utils/defaultFilterOptions":7,"./utils/defaultMenuRenderer":8,"classnames":undefined,"react":undefined,"react-dom":undefined,"react-input-autosize":undefined}]},{},[]) -//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","/Users/bvaughn/Documents/git/react-select/src/Async.js","/Users/bvaughn/Documents/git/react-select/src/AsyncCreatable.js","/Users/bvaughn/Documents/git/react-select/src/Creatable.js","/Users/bvaughn/Documents/git/react-select/src/Option.js","/Users/bvaughn/Documents/git/react-select/src/Value.js","/Users/bvaughn/Documents/git/react-select/src/utils/defaultArrowRenderer.js","/Users/bvaughn/Documents/git/react-select/src/utils/defaultFilterOptions.js","/Users/bvaughn/Documents/git/react-select/src/utils/defaultMenuRenderer.js","/Users/bvaughn/Documents/git/react-select/src/utils/stripDiacritics.js","/Users/bvaughn/Documents/git/react-select/src/Select.js"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","import React, { Component, PropTypes } from 'react';\nimport Select from './Select';\nimport stripDiacritics from './utils/stripDiacritics';\n\nconst propTypes = {\n\tautoload: React.PropTypes.bool.isRequired,       // automatically call the `loadOptions` prop on-mount; defaults to true\n\tcache: React.PropTypes.any,                      // object to use to cache results; set to null/false to disable caching\n\tchildren: React.PropTypes.func.isRequired,       // Child function responsible for creating the inner Select component; (props: Object): PropTypes.element\n\tignoreAccents: React.PropTypes.bool,             // strip diacritics when filtering; defaults to true\n\tignoreCase: React.PropTypes.bool,                // perform case-insensitive filtering; defaults to true\n\tloadingPlaceholder: React.PropTypes.oneOfType([  // replaces the placeholder while options are loading\n\t\tReact.PropTypes.string,\n\t\tReact.PropTypes.node\n\t]),\n\tloadOptions: React.PropTypes.func.isRequired,    // callback to load options asynchronously; (inputValue: string, callback: Function): ?Promise\n\toptions: PropTypes.array.isRequired,             // array of options\n\tplaceholder: React.PropTypes.oneOfType([         // field placeholder, displayed when there's no value (shared with Select)\n\t\tReact.PropTypes.string,\n\t\tReact.PropTypes.node\n\t]),\n\tnoResultsText: React.PropTypes.oneOfType([       // field noResultsText, displayed when no options come back from the server\n\t\tReact.PropTypes.string,\n\t\tReact.PropTypes.node\n\t]),\n\tonChange: React.PropTypes.func,                  // onChange handler: function (newValue) {}\n\tsearchPromptText: React.PropTypes.oneOfType([    // label to prompt for search input\n\t\tReact.PropTypes.string,\n\t\tReact.PropTypes.node\n\t]),\n\tonInputChange: React.PropTypes.func,             // optional for keeping track of what is being typed\n\tvalue: React.PropTypes.any,                      // initial field value\n};\n\nconst defaultCache = {};\n\nconst defaultProps = {\n\tautoload: true,\n\tcache: defaultCache,\n\tchildren: defaultChildren,\n\tignoreAccents: true,\n\tignoreCase: true,\n\tloadingPlaceholder: 'Loading...',\n\toptions: [],\n\tsearchPromptText: 'Type to search',\n};\n\nexport default class Async extends Component {\n\tconstructor (props, context) {\n\t\tsuper(props, context);\n\n\t\tthis._cache = props.cache === defaultCache ? {} : props.cache;\n\n\t\tthis.state = {\n\t\t\tisLoading: false,\n\t\t\toptions: props.options,\n\t\t};\n\n\t\tthis._onInputChange = this._onInputChange.bind(this);\n\t}\n\n\tcomponentDidMount () {\n\t\tconst { autoload } = this.props;\n\n\t\tif (autoload) {\n\t\t\tthis.loadOptions('');\n\t\t}\n\t}\n\n\tcomponentWillUpdate (nextProps, nextState) {\n\t\tconst propertiesToSync = ['options'];\n\t\tpropertiesToSync.forEach((prop) => {\n\t\t\tif (this.props[prop] !== nextProps[prop]) {\n\t\t\t\tthis.setState({\n\t\t\t\t\t[prop]: nextProps[prop]\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t}\n\n\tclearOptions() {\n\t\tthis.setState({ options: [] });\n\t}\n\n\tloadOptions (inputValue) {\n\t\tconst { loadOptions } = this.props;\n\t\tconst cache = this._cache;\n\n\t\tif (\n\t\t\tcache &&\n\t\t\tcache.hasOwnProperty(inputValue)\n\t\t) {\n\t\t\tthis.setState({\n\t\t\t\toptions: cache[inputValue]\n\t\t\t});\n\n\t\t\treturn;\n\t\t}\n\n\t\tconst callback = (error, data) => {\n\t\t\tif (callback === this._callback) {\n\t\t\t\tthis._callback = null;\n\n\t\t\t\tconst options = data && data.options || [];\n\n\t\t\t\tif (cache) {\n\t\t\t\t\tcache[inputValue] = options;\n\t\t\t\t}\n\n\t\t\t\tthis.setState({\n\t\t\t\t\tisLoading: false,\n\t\t\t\t\toptions\n\t\t\t\t});\n\t\t\t}\n\t\t};\n\n\t\t// Ignore all but the most recent request\n\t\tthis._callback = callback;\n\n\t\tconst promise = loadOptions(inputValue, callback);\n\t\tif (promise) {\n\t\t\tpromise.then(\n\t\t\t\t(data) => callback(null, data),\n\t\t\t\t(error) => callback(error)\n\t\t\t);\n\t\t}\n\n\t\tif (\n\t\t\tthis._callback &&\n\t\t\t!this.state.isLoading\n\t\t) {\n\t\t\tthis.setState({\n\t\t\t\tisLoading: true\n\t\t\t});\n\t\t}\n\n\t\treturn inputValue;\n\t}\n\n\t_onInputChange (inputValue) {\n\t\tconst { ignoreAccents, ignoreCase, onInputChange } = this.props;\n\n\t\tif (ignoreAccents) {\n\t\t\tinputValue = stripDiacritics(inputValue);\n\t\t}\n\n\t\tif (ignoreCase) {\n\t\t\tinputValue = inputValue.toLowerCase();\n\t\t}\n\n\t\tif (onInputChange) {\n\t\t\tonInputChange(inputValue);\n\t\t}\n\n\t\treturn this.loadOptions(inputValue);\n\t}\n\n\tinputValue() {\n\t\tif (this.select) {\n\t\t\treturn this.select.state.inputValue;\n\t\t}\n\t\treturn '';\n\t}\n\n\tnoResultsText() {\n\t\tconst { loadingPlaceholder, noResultsText, searchPromptText } = this.props;\n\t\tconst { isLoading } = this.state;\n\n\t\tconst inputValue = this.inputValue();\n\n\t\tif (isLoading) {\n\t\t\treturn loadingPlaceholder;\n\t\t}\n\t\tif (inputValue && noResultsText) {\n\t\t\treturn noResultsText;\n\t\t}\n\t\treturn searchPromptText;\n\t}\n\n\trender () {\n\t\tconst { children, loadingPlaceholder, placeholder } = this.props;\n\t\tconst { isLoading, options } = this.state;\n\n\t\tconst props = {\n\t\t\tnoResultsText: this.noResultsText(),\n\t\t\tplaceholder: isLoading ? loadingPlaceholder : placeholder,\n\t\t\toptions: (isLoading && loadingPlaceholder) ? [] : options,\n\t\t\tref: (ref) => (this.select = ref),\n\t\t\tonChange: (newValues) => {\n\t\t\t\tif (this.props.value && (newValues.length > this.props.value.length)) {\n\t\t\t\t\tthis.clearOptions();\n\t\t\t\t}\n\t\t\t\tthis.props.onChange(newValues);\n\t\t\t}\n\t\t};\n\n\t\treturn children({\n\t\t\t...this.props,\n\t\t\t...props,\n\t\t\tisLoading,\n\t\t\tonInputChange: this._onInputChange\n\t\t});\n\t}\n}\n\nAsync.propTypes = propTypes;\nAsync.defaultProps = defaultProps;\n\nfunction defaultChildren (props) {\n\treturn (\n\t\t<Select {...props} />\n\t);\n};\n","import React from 'react';\nimport Select from './Select';\n\nconst AsyncCreatable = React.createClass({\n\tdisplayName: 'AsyncCreatableSelect',\n\n\trender () {\n\t\treturn (\n\t\t\t<Select.Async {...this.props}>\n\t\t\t\t{(asyncProps) => (\n\t\t\t\t\t<Select.Creatable {...this.props}>\n\t\t\t\t\t\t{(creatableProps) => (\n\t\t\t\t\t\t\t<Select\n\t\t\t\t\t\t\t\t{...asyncProps}\n\t\t\t\t\t\t\t\t{...creatableProps}\n\t\t\t\t\t\t\t\tonInputChange={(input) => {\n\t\t\t\t\t\t\t\t\tcreatableProps.onInputChange(input);\n\t\t\t\t\t\t\t\t\treturn asyncProps.onInputChange(input);\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t)}\n\t\t\t\t\t</Select.Creatable>\n\t\t\t\t)}\n\t\t\t</Select.Async>\n\t\t);\n\t}\n});\n\nmodule.exports = AsyncCreatable;\n","import React from 'react';\nimport Select from './Select';\nimport defaultFilterOptions from './utils/defaultFilterOptions';\nimport defaultMenuRenderer from './utils/defaultMenuRenderer';\n\nconst Creatable = React.createClass({\n\tdisplayName: 'CreatableSelect',\n\n\tpropTypes: {\n\t\t// Child function responsible for creating the inner Select component\n\t\t// This component can be used to compose HOCs (eg Creatable and Async)\n\t\t// (props: Object): PropTypes.element\n\t\tchildren: React.PropTypes.func,\n\n\t\t// See Select.propTypes.filterOptions\n\t\tfilterOptions: React.PropTypes.any,\n\n\t\t// Searches for any matching option within the set of options.\n\t\t// This function prevents duplicate options from being created.\n\t\t// ({ option: Object, options: Array, labelKey: string, valueKey: string }): boolean\n\t\tisOptionUnique: React.PropTypes.func,\n\n    // Determines if the current input text represents a valid option.\n    // ({ label: string }): boolean\n    isValidNewOption: React.PropTypes.func,\n\n\t\t// See Select.propTypes.menuRenderer\n\t\tmenuRenderer: React.PropTypes.any,\n\n    // Factory to create new option.\n    // ({ label: string, labelKey: string, valueKey: string }): Object\n\t\tnewOptionCreator: React.PropTypes.func,\n\n\t\t// input keyDown handler: function (event) {}\n\t\tonInputKeyDown: React.PropTypes.func,\n\n\t\t// See Select.propTypes.options\n\t\toptions: React.PropTypes.array,\n\n    // Creates prompt/placeholder option text.\n    // (filterText: string): string\n\t\tpromptTextCreator: React.PropTypes.func,\n\n\t\t// Decides if a keyDown event (eg its `keyCode`) should result in the creation of a new option.\n\t\tshouldKeyDownEventCreateNewOption: React.PropTypes.func,\n\t},\n\n\t// Default prop methods\n\tstatics: {\n\t\tisOptionUnique,\n\t\tisValidNewOption,\n\t\tnewOptionCreator,\n\t\tpromptTextCreator,\n\t\tshouldKeyDownEventCreateNewOption\n\t},\n\n\tgetDefaultProps () {\n\t\treturn {\n\t\t\tfilterOptions: defaultFilterOptions,\n\t\t\tisOptionUnique,\n\t\t\tisValidNewOption,\n\t\t\tmenuRenderer: defaultMenuRenderer,\n\t\t\tnewOptionCreator,\n\t\t\tpromptTextCreator,\n\t\t\tshouldKeyDownEventCreateNewOption,\n\t\t};\n\t},\n\n\tcreateNewOption () {\n\t\tconst {\n\t\t\tisValidNewOption,\n\t\t\tnewOptionCreator,\n\t\t\toptions = [],\n\t\t\tshouldKeyDownEventCreateNewOption\n\t\t} = this.props;\n\n\t\tif (isValidNewOption({ label: this.inputValue })) {\n\t\t\tconst option = newOptionCreator({ label: this.inputValue, labelKey: this.labelKey, valueKey: this.valueKey });\n\t\t\tconst isOptionUnique = this.isOptionUnique({ option });\n\n\t\t\t// Don't add the same option twice.\n\t\t\tif (isOptionUnique) {\n\t\t\t\toptions.unshift(option);\n\n\t\t\t\tthis.select.selectValue(option);\n\t\t\t}\n\t\t}\n\t},\n\n\tfilterOptions (...params) {\n\t\tconst { filterOptions, isValidNewOption, options, promptTextCreator } = this.props;\n\n\t\t// TRICKY Check currently selected options as well.\n\t\t// Don't display a create-prompt for a value that's selected.\n\t\t// This covers async edge-cases where a newly-created Option isn't yet in the async-loaded array.\n\t\tconst excludeOptions = params[2] || [];\n\n\t\tconst filteredOptions = filterOptions(...params) || [];\n\n\t\tif (isValidNewOption({ label: this.inputValue })) {\n\t\t\tconst { newOptionCreator } = this.props;\n\n\t\t\tconst option = newOptionCreator({\n\t\t\t\tlabel: this.inputValue,\n\t\t\t\tlabelKey: this.labelKey,\n\t\t\t\tvalueKey: this.valueKey\n\t\t\t});\n\n\t\t\t// TRICKY Compare to all options (not just filtered options) in case option has already been selected).\n\t\t\t// For multi-selects, this would remove it from the filtered list.\n\t\t\tconst isOptionUnique = this.isOptionUnique({\n\t\t\t\toption,\n\t\t\t\toptions: excludeOptions.concat(filteredOptions)\n\t\t\t});\n\n\t\t\tif (isOptionUnique) {\n\t\t\t\tconst prompt = promptTextCreator(this.inputValue);\n\n\t\t\t\tthis._createPlaceholderOption = newOptionCreator({\n\t\t\t\t\tlabel: prompt,\n\t\t\t\t\tlabelKey: this.labelKey,\n\t\t\t\t\tvalueKey: this.valueKey\n\t\t\t\t});\n\n\t\t\t\tfilteredOptions.unshift(this._createPlaceholderOption);\n\t\t\t}\n\t\t}\n\n\t\treturn filteredOptions;\n\t},\n\n\tisOptionUnique ({\n\t\toption,\n\t\toptions\n\t}) {\n\t\tconst { isOptionUnique } = this.props;\n\n\t\toptions = options || this.select.filterOptions();\n\n\t\treturn isOptionUnique({\n\t\t\tlabelKey: this.labelKey,\n\t\t\toption,\n\t\t\toptions,\n\t\t\tvalueKey: this.valueKey\n\t\t});\n\t},\n\n\tmenuRenderer (params) {\n\t\tconst { menuRenderer } = this.props;\n\n\t\treturn menuRenderer({\n\t\t\t...params,\n\t\t\tonSelect: this.onOptionSelect\n\t\t});\n\t},\n\n\tonInputChange (input) {\n\t\t// This value may be needed in between Select mounts (when this.select is null)\n\t\tthis.inputValue = input;\n\t},\n\n\tonInputKeyDown (event) {\n\t\tconst { shouldKeyDownEventCreateNewOption, onInputKeyDown } = this.props;\n\t\tconst focusedOption = this.select.getFocusedOption();\n\n\t\tif (\n\t\t\tfocusedOption &&\n\t\t\tfocusedOption === this._createPlaceholderOption &&\n\t\t\tshouldKeyDownEventCreateNewOption({ keyCode: event.keyCode })\n\t\t) {\n\t\t\tthis.createNewOption();\n\n\t\t\t// Prevent decorated Select from doing anything additional with this keyDown event\n\t\t\tevent.preventDefault();\n\t\t} else if (onInputKeyDown) {\n\t\t\tonInputKeyDown(event);\n\t\t}\n\t},\n\n\tonOptionSelect (option, event) {\n\t\tif (option === this._createPlaceholderOption) {\n\t\t\tthis.createNewOption();\n\t\t} else {\n\t\t\tthis.select.selectValue(option);\n\t\t}\n\t},\n\n\trender () {\n\t\tconst {\n\t\t\tchildren = defaultChildren,\n\t\t\tnewOptionCreator,\n\t\t\tshouldKeyDownEventCreateNewOption,\n\t\t\t...restProps\n\t\t} = this.props;\n\n\t\tconst props = {\n\t\t\t...restProps,\n\t\t\tallowCreate: true,\n\t\t\tfilterOptions: this.filterOptions,\n\t\t\tmenuRenderer: this.menuRenderer,\n\t\t\tonInputChange: this.onInputChange,\n\t\t\tonInputKeyDown: this.onInputKeyDown,\n\t\t\tref: (ref) => {\n\t\t\t\tthis.select = ref;\n\n\t\t\t\t// These values may be needed in between Select mounts (when this.select is null)\n\t\t\t\tif (ref) {\n\t\t\t\t\tthis.labelKey = ref.props.labelKey;\n\t\t\t\t\tthis.valueKey = ref.props.valueKey;\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\treturn children(props);\n\t}\n});\n\nfunction defaultChildren (props) {\n\treturn (\n\t\t<Select {...props} />\n\t);\n};\n\nfunction isOptionUnique ({ option, options, labelKey, valueKey }) {\n\treturn options\n\t\t.filter((existingOption) =>\n\t\t\texistingOption[labelKey] === option[labelKey] ||\n\t\t\texistingOption[valueKey] === option[valueKey]\n\t\t)\n\t\t.length === 0;\n};\n\nfunction isValidNewOption ({ label }) {\n\treturn !!label;\n};\n\nfunction newOptionCreator ({ label, labelKey, valueKey }) {\n\tconst option = {};\n\toption[valueKey] = label;\n \toption[labelKey] = label;\n \toption.className = 'Select-create-option-placeholder';\n \treturn option;\n};\n\nfunction promptTextCreator (label) {\n\treturn `Create option \"${label}\"`;\n}\n\nfunction shouldKeyDownEventCreateNewOption ({ keyCode }) {\n\tswitch (keyCode) {\n\t\tcase 9:   // TAB\n\t\tcase 13:  // ENTER\n\t\tcase 188: // COMMA\n\t\t\treturn true;\n\t}\n\n\treturn false;\n};\n\nmodule.exports = Creatable;\n","import React from 'react';\nimport classNames from 'classnames';\n\nconst Option = React.createClass({\n\tpropTypes: {\n\t\tchildren: React.PropTypes.node,\n\t\tclassName: React.PropTypes.string,             // className (based on mouse position)\n\t\tinstancePrefix: React.PropTypes.string.isRequired,  // unique prefix for the ids (used for aria)\n\t\tisDisabled: React.PropTypes.bool,              // the option is disabled\n\t\tisFocused: React.PropTypes.bool,               // the option is focused\n\t\tisSelected: React.PropTypes.bool,              // the option is selected\n\t\tonFocus: React.PropTypes.func,                 // method to handle mouseEnter on option element\n\t\tonSelect: React.PropTypes.func,                // method to handle click on option element\n\t\tonUnfocus: React.PropTypes.func,               // method to handle mouseLeave on option element\n\t\toption: React.PropTypes.object.isRequired,     // object that is base for that option\n\t\toptionIndex: React.PropTypes.number,           // index of the option, used to generate unique ids for aria\n\t},\n\tblockEvent (event) {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\tif ((event.target.tagName !== 'A') || !('href' in event.target)) {\n\t\t\treturn;\n\t\t}\n\t\tif (event.target.target) {\n\t\t\twindow.open(event.target.href, event.target.target);\n\t\t} else {\n\t\t\twindow.location.href = event.target.href;\n\t\t}\n\t},\n\n\thandleMouseDown (event) {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\tthis.props.onSelect(this.props.option, event);\n\t},\n\n\thandleMouseEnter (event) {\n\t\tthis.onFocus(event);\n\t},\n\n\thandleMouseMove (event) {\n\t\tthis.onFocus(event);\n\t},\n\n\thandleTouchEnd(event){\n\t\t// Check if the view is being dragged, In this case\n\t\t// we don't want to fire the click event (because the user only wants to scroll)\n\t\tif(this.dragging) return;\n\n\t\tthis.handleMouseDown(event);\n\t},\n\n\thandleTouchMove (event) {\n\t\t// Set a flag that the view is being dragged\n\t\tthis.dragging = true;\n\t},\n\n\thandleTouchStart (event) {\n\t\t// Set a flag that the view is not being dragged\n\t\tthis.dragging = false;\n\t},\n\n\tonFocus (event) {\n\t\tif (!this.props.isFocused) {\n\t\t\tthis.props.onFocus(this.props.option, event);\n\t\t}\n\t},\n\trender () {\n\t\tvar { option, instancePrefix, optionIndex } = this.props;\n\t\tvar className = classNames(this.props.className, option.className);\n\n\t\treturn option.disabled ? (\n\t\t\t<div className={className}\n\t\t\t\tonMouseDown={this.blockEvent}\n\t\t\t\tonClick={this.blockEvent}>\n\t\t\t\t{this.props.children}\n\t\t\t</div>\n\t\t) : (\n\t\t\t<div className={className}\n\t\t\t\tstyle={option.style}\n\t\t\t\trole=\"option\"\n\t\t\t\t onMouseDown={this.handleMouseDown}\n\t\t\t\tonMouseEnter={this.handleMouseEnter}\n\t\t\t\tonMouseMove={this.handleMouseMove}\n\t\t\t\tonTouchStart={this.handleTouchStart}\n\t\t\t\tonTouchMove={this.handleTouchMove}\n\t\t\t\tonTouchEnd={this.handleTouchEnd}\n\t\t\t\tid={instancePrefix + '-option-' + optionIndex}\n\t\t\t\ttitle={option.title}>\n\t\t\t\t{this.props.children}\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nmodule.exports = Option;\n","import React from 'react';\nimport classNames from 'classnames';\n\nconst Value = React.createClass({\n\n\tdisplayName: 'Value',\n\n\tpropTypes: {\n\t\tchildren: React.PropTypes.node,\n\t\tdisabled: React.PropTypes.bool,               // disabled prop passed to ReactSelect\n\t\tid: React.PropTypes.string,                   // Unique id for the value - used for aria\n\t\tonClick: React.PropTypes.func,                // method to handle click on value label\n\t\tonRemove: React.PropTypes.func,               // method to handle removal of the value\n\t\tvalue: React.PropTypes.object.isRequired,     // the option object for this value\n\t},\n\n\thandleMouseDown (event) {\n\t\tif (event.type === 'mousedown' && event.button !== 0) {\n\t\t\treturn;\n\t\t}\n\t\tif (this.props.onClick) {\n\t\t\tevent.stopPropagation();\n\t\t\tthis.props.onClick(this.props.value, event);\n\t\t\treturn;\n\t\t}\n\t\tif (this.props.value.href) {\n\t\t\tevent.stopPropagation();\n\t\t}\n\t},\n\n\tonRemove (event) {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\tthis.props.onRemove(this.props.value);\n\t},\n\n\thandleTouchEndRemove (event){\n\t\t// Check if the view is being dragged, In this case\n\t\t// we don't want to fire the click event (because the user only wants to scroll)\n\t\tif(this.dragging) return;\n\n\t\t// Fire the mouse events\n\t\tthis.onRemove(event);\n\t},\n\n\thandleTouchMove (event) {\n\t\t// Set a flag that the view is being dragged\n\t\tthis.dragging = true;\n\t},\n\n\thandleTouchStart (event) {\n\t\t// Set a flag that the view is not being dragged\n\t\tthis.dragging = false;\n\t},\n\n\trenderRemoveIcon () {\n\t\tif (this.props.disabled || !this.props.onRemove) return;\n\t\treturn (\n\t\t\t<span className=\"Select-value-icon\"\n\t\t\t\taria-hidden=\"true\"\n\t\t\t\tonMouseDown={this.onRemove}\n\t\t\t\tonTouchEnd={this.handleTouchEndRemove}\n\t\t\t\tonTouchStart={this.handleTouchStart}\n\t\t\t\tonTouchMove={this.handleTouchMove}>\n\t\t\t\t&times;\n\t\t\t</span>\n\t\t);\n\t},\n\n\trenderLabel () {\n\t\tlet className = 'Select-value-label';\n\t\treturn this.props.onClick || this.props.value.href ? (\n\t\t\t<a className={className} href={this.props.value.href} target={this.props.value.target} onMouseDown={this.handleMouseDown} onTouchEnd={this.handleMouseDown}>\n\t\t\t\t{this.props.children}\n\t\t\t</a>\n\t\t) : (\n\t\t\t<span className={className} role=\"option\" aria-selected=\"true\" id={this.props.id}>\n\t\t\t\t{this.props.children}\n\t\t\t</span>\n\t\t);\n\t},\n\n\trender () {\n\t\treturn (\n\t\t\t<div className={classNames('Select-value', this.props.value.className)}\n\t\t\t\tstyle={this.props.value.style}\n\t\t\t\ttitle={this.props.value.title}\n\t\t\t\t>\n\t\t\t\t{this.renderRemoveIcon()}\n\t\t\t\t{this.renderLabel()}\n\t\t\t</div>\n\t\t);\n\t}\n\n});\n\nmodule.exports = Value;\n","import React from 'react';\n\nexport default function arrowRenderer ({ onMouseDown }) {\n\treturn (\n\t\t<span\n\t\t\tclassName=\"Select-arrow\"\n\t\t\tonMouseDown={onMouseDown}\n\t\t/>\n\t);\n};\n","import stripDiacritics from './stripDiacritics';\n\nfunction filterOptions (options, filterValue, excludeOptions, props) {\n\tif (props.ignoreAccents) {\n\t\tfilterValue = stripDiacritics(filterValue);\n\t}\n\n\tif (props.ignoreCase) {\n\t\tfilterValue = filterValue.toLowerCase();\n\t}\n\n\tif (excludeOptions) excludeOptions = excludeOptions.map(i => i[props.valueKey]);\n\n\treturn options.filter(option => {\n\t\tif (excludeOptions && excludeOptions.indexOf(option[props.valueKey]) > -1) return false;\n\t\tif (props.filterOption) return props.filterOption.call(this, option, filterValue);\n\t\tif (!filterValue) return true;\n\t\tvar valueTest = String(option[props.valueKey]);\n\t\tvar labelTest = String(option[props.labelKey]);\n\t\tif (props.ignoreAccents) {\n\t\t\tif (props.matchProp !== 'label') valueTest = stripDiacritics(valueTest);\n\t\t\tif (props.matchProp !== 'value') labelTest = stripDiacritics(labelTest);\n\t\t}\n\t\tif (props.ignoreCase) {\n\t\t\tif (props.matchProp !== 'label') valueTest = valueTest.toLowerCase();\n\t\t\tif (props.matchProp !== 'value') labelTest = labelTest.toLowerCase();\n\t\t}\n\t\treturn props.matchPos === 'start' ? (\n\t\t\t(props.matchProp !== 'label' && valueTest.substr(0, filterValue.length) === filterValue) ||\n\t\t\t(props.matchProp !== 'value' && labelTest.substr(0, filterValue.length) === filterValue)\n\t\t) : (\n\t\t\t(props.matchProp !== 'label' && valueTest.indexOf(filterValue) >= 0) ||\n\t\t\t(props.matchProp !== 'value' && labelTest.indexOf(filterValue) >= 0)\n\t\t);\n\t});\n}\n\nmodule.exports = filterOptions;\n","import classNames from 'classnames';\nimport React from 'react';\n\nfunction menuRenderer ({\n\tfocusedOption,\n\tinstancePrefix,\n\tlabelKey,\n\tonFocus,\n\tonSelect,\n\toptionClassName,\n\toptionComponent,\n\toptionRenderer,\n\toptions,\n\tvalueArray,\n\tvalueKey,\n\tonOptionRef\n}) {\n\tlet Option = optionComponent;\n\n\treturn options.map((option, i) => {\n\t\tlet isSelected = valueArray && valueArray.indexOf(option) > -1;\n\t\tlet isFocused = option === focusedOption;\n\t\tlet optionClass = classNames(optionClassName, {\n\t\t\t'Select-option': true,\n\t\t\t'is-selected': isSelected,\n\t\t\t'is-focused': isFocused,\n\t\t\t'is-disabled': option.disabled,\n\t\t});\n\n\t\treturn (\n\t\t\t<Option\n\t\t\t\tclassName={optionClass}\n\t\t\t\tinstancePrefix={instancePrefix}\n\t\t\t\tisDisabled={option.disabled}\n\t\t\t\tisFocused={isFocused}\n\t\t\t\tisSelected={isSelected}\n\t\t\t\tkey={`option-${i}-${option[valueKey]}`}\n\t\t\t\tonFocus={onFocus}\n\t\t\t\tonSelect={onSelect}\n\t\t\t\toption={option}\n\t\t\t\toptionIndex={i}\n\t\t\t\tref={ref => { onOptionRef(ref, isFocused); }}\n\t\t\t>\n\t\t\t\t{optionRenderer(option, i)}\n\t\t\t</Option>\n\t\t);\n\t});\n}\n\nmodule.exports = menuRenderer;\n","var map = [\n\t{ 'base':'A', 'letters':/[\\u0041\\u24B6\\uFF21\\u00C0\\u00C1\\u00C2\\u1EA6\\u1EA4\\u1EAA\\u1EA8\\u00C3\\u0100\\u0102\\u1EB0\\u1EAE\\u1EB4\\u1EB2\\u0226\\u01E0\\u00C4\\u01DE\\u1EA2\\u00C5\\u01FA\\u01CD\\u0200\\u0202\\u1EA0\\u1EAC\\u1EB6\\u1E00\\u0104\\u023A\\u2C6F]/g },\n\t{ 'base':'AA','letters':/[\\uA732]/g },\n\t{ 'base':'AE','letters':/[\\u00C6\\u01FC\\u01E2]/g },\n\t{ 'base':'AO','letters':/[\\uA734]/g },\n\t{ 'base':'AU','letters':/[\\uA736]/g },\n\t{ 'base':'AV','letters':/[\\uA738\\uA73A]/g },\n\t{ 'base':'AY','letters':/[\\uA73C]/g },\n\t{ 'base':'B', 'letters':/[\\u0042\\u24B7\\uFF22\\u1E02\\u1E04\\u1E06\\u0243\\u0182\\u0181]/g },\n\t{ 'base':'C', 'letters':/[\\u0043\\u24B8\\uFF23\\u0106\\u0108\\u010A\\u010C\\u00C7\\u1E08\\u0187\\u023B\\uA73E]/g },\n\t{ 'base':'D', 'letters':/[\\u0044\\u24B9\\uFF24\\u1E0A\\u010E\\u1E0C\\u1E10\\u1E12\\u1E0E\\u0110\\u018B\\u018A\\u0189\\uA779]/g },\n\t{ 'base':'DZ','letters':/[\\u01F1\\u01C4]/g },\n\t{ 'base':'Dz','letters':/[\\u01F2\\u01C5]/g },\n\t{ 'base':'E', 'letters':/[\\u0045\\u24BA\\uFF25\\u00C8\\u00C9\\u00CA\\u1EC0\\u1EBE\\u1EC4\\u1EC2\\u1EBC\\u0112\\u1E14\\u1E16\\u0114\\u0116\\u00CB\\u1EBA\\u011A\\u0204\\u0206\\u1EB8\\u1EC6\\u0228\\u1E1C\\u0118\\u1E18\\u1E1A\\u0190\\u018E]/g },\n\t{ 'base':'F', 'letters':/[\\u0046\\u24BB\\uFF26\\u1E1E\\u0191\\uA77B]/g },\n\t{ 'base':'G', 'letters':/[\\u0047\\u24BC\\uFF27\\u01F4\\u011C\\u1E20\\u011E\\u0120\\u01E6\\u0122\\u01E4\\u0193\\uA7A0\\uA77D\\uA77E]/g },\n\t{ 'base':'H', 'letters':/[\\u0048\\u24BD\\uFF28\\u0124\\u1E22\\u1E26\\u021E\\u1E24\\u1E28\\u1E2A\\u0126\\u2C67\\u2C75\\uA78D]/g },\n\t{ 'base':'I', 'letters':/[\\u0049\\u24BE\\uFF29\\u00CC\\u00CD\\u00CE\\u0128\\u012A\\u012C\\u0130\\u00CF\\u1E2E\\u1EC8\\u01CF\\u0208\\u020A\\u1ECA\\u012E\\u1E2C\\u0197]/g },\n\t{ 'base':'J', 'letters':/[\\u004A\\u24BF\\uFF2A\\u0134\\u0248]/g },\n\t{ 'base':'K', 'letters':/[\\u004B\\u24C0\\uFF2B\\u1E30\\u01E8\\u1E32\\u0136\\u1E34\\u0198\\u2C69\\uA740\\uA742\\uA744\\uA7A2]/g },\n\t{ 'base':'L', 'letters':/[\\u004C\\u24C1\\uFF2C\\u013F\\u0139\\u013D\\u1E36\\u1E38\\u013B\\u1E3C\\u1E3A\\u0141\\u023D\\u2C62\\u2C60\\uA748\\uA746\\uA780]/g },\n\t{ 'base':'LJ','letters':/[\\u01C7]/g },\n\t{ 'base':'Lj','letters':/[\\u01C8]/g },\n\t{ 'base':'M', 'letters':/[\\u004D\\u24C2\\uFF2D\\u1E3E\\u1E40\\u1E42\\u2C6E\\u019C]/g },\n\t{ 'base':'N', 'letters':/[\\u004E\\u24C3\\uFF2E\\u01F8\\u0143\\u00D1\\u1E44\\u0147\\u1E46\\u0145\\u1E4A\\u1E48\\u0220\\u019D\\uA790\\uA7A4]/g },\n\t{ 'base':'NJ','letters':/[\\u01CA]/g },\n\t{ 'base':'Nj','letters':/[\\u01CB]/g },\n\t{ 'base':'O', 'letters':/[\\u004F\\u24C4\\uFF2F\\u00D2\\u00D3\\u00D4\\u1ED2\\u1ED0\\u1ED6\\u1ED4\\u00D5\\u1E4C\\u022C\\u1E4E\\u014C\\u1E50\\u1E52\\u014E\\u022E\\u0230\\u00D6\\u022A\\u1ECE\\u0150\\u01D1\\u020C\\u020E\\u01A0\\u1EDC\\u1EDA\\u1EE0\\u1EDE\\u1EE2\\u1ECC\\u1ED8\\u01EA\\u01EC\\u00D8\\u01FE\\u0186\\u019F\\uA74A\\uA74C]/g },\n\t{ 'base':'OI','letters':/[\\u01A2]/g },\n\t{ 'base':'OO','letters':/[\\uA74E]/g },\n\t{ 'base':'OU','letters':/[\\u0222]/g },\n\t{ 'base':'P', 'letters':/[\\u0050\\u24C5\\uFF30\\u1E54\\u1E56\\u01A4\\u2C63\\uA750\\uA752\\uA754]/g },\n\t{ 'base':'Q', 'letters':/[\\u0051\\u24C6\\uFF31\\uA756\\uA758\\u024A]/g },\n\t{ 'base':'R', 'letters':/[\\u0052\\u24C7\\uFF32\\u0154\\u1E58\\u0158\\u0210\\u0212\\u1E5A\\u1E5C\\u0156\\u1E5E\\u024C\\u2C64\\uA75A\\uA7A6\\uA782]/g },\n\t{ 'base':'S', 'letters':/[\\u0053\\u24C8\\uFF33\\u1E9E\\u015A\\u1E64\\u015C\\u1E60\\u0160\\u1E66\\u1E62\\u1E68\\u0218\\u015E\\u2C7E\\uA7A8\\uA784]/g },\n\t{ 'base':'T', 'letters':/[\\u0054\\u24C9\\uFF34\\u1E6A\\u0164\\u1E6C\\u021A\\u0162\\u1E70\\u1E6E\\u0166\\u01AC\\u01AE\\u023E\\uA786]/g },\n\t{ 'base':'TZ','letters':/[\\uA728]/g },\n\t{ 'base':'U', 'letters':/[\\u0055\\u24CA\\uFF35\\u00D9\\u00DA\\u00DB\\u0168\\u1E78\\u016A\\u1E7A\\u016C\\u00DC\\u01DB\\u01D7\\u01D5\\u01D9\\u1EE6\\u016E\\u0170\\u01D3\\u0214\\u0216\\u01AF\\u1EEA\\u1EE8\\u1EEE\\u1EEC\\u1EF0\\u1EE4\\u1E72\\u0172\\u1E76\\u1E74\\u0244]/g },\n\t{ 'base':'V', 'letters':/[\\u0056\\u24CB\\uFF36\\u1E7C\\u1E7E\\u01B2\\uA75E\\u0245]/g },\n\t{ 'base':'VY','letters':/[\\uA760]/g },\n\t{ 'base':'W', 'letters':/[\\u0057\\u24CC\\uFF37\\u1E80\\u1E82\\u0174\\u1E86\\u1E84\\u1E88\\u2C72]/g },\n\t{ 'base':'X', 'letters':/[\\u0058\\u24CD\\uFF38\\u1E8A\\u1E8C]/g },\n\t{ 'base':'Y', 'letters':/[\\u0059\\u24CE\\uFF39\\u1EF2\\u00DD\\u0176\\u1EF8\\u0232\\u1E8E\\u0178\\u1EF6\\u1EF4\\u01B3\\u024E\\u1EFE]/g },\n\t{ 'base':'Z', 'letters':/[\\u005A\\u24CF\\uFF3A\\u0179\\u1E90\\u017B\\u017D\\u1E92\\u1E94\\u01B5\\u0224\\u2C7F\\u2C6B\\uA762]/g },\n\t{ 'base':'a', 'letters':/[\\u0061\\u24D0\\uFF41\\u1E9A\\u00E0\\u00E1\\u00E2\\u1EA7\\u1EA5\\u1EAB\\u1EA9\\u00E3\\u0101\\u0103\\u1EB1\\u1EAF\\u1EB5\\u1EB3\\u0227\\u01E1\\u00E4\\u01DF\\u1EA3\\u00E5\\u01FB\\u01CE\\u0201\\u0203\\u1EA1\\u1EAD\\u1EB7\\u1E01\\u0105\\u2C65\\u0250]/g },\n\t{ 'base':'aa','letters':/[\\uA733]/g },\n\t{ 'base':'ae','letters':/[\\u00E6\\u01FD\\u01E3]/g },\n\t{ 'base':'ao','letters':/[\\uA735]/g },\n\t{ 'base':'au','letters':/[\\uA737]/g },\n\t{ 'base':'av','letters':/[\\uA739\\uA73B]/g },\n\t{ 'base':'ay','letters':/[\\uA73D]/g },\n\t{ 'base':'b', 'letters':/[\\u0062\\u24D1\\uFF42\\u1E03\\u1E05\\u1E07\\u0180\\u0183\\u0253]/g },\n\t{ 'base':'c', 'letters':/[\\u0063\\u24D2\\uFF43\\u0107\\u0109\\u010B\\u010D\\u00E7\\u1E09\\u0188\\u023C\\uA73F\\u2184]/g },\n\t{ 'base':'d', 'letters':/[\\u0064\\u24D3\\uFF44\\u1E0B\\u010F\\u1E0D\\u1E11\\u1E13\\u1E0F\\u0111\\u018C\\u0256\\u0257\\uA77A]/g },\n\t{ 'base':'dz','letters':/[\\u01F3\\u01C6]/g },\n\t{ 'base':'e', 'letters':/[\\u0065\\u24D4\\uFF45\\u00E8\\u00E9\\u00EA\\u1EC1\\u1EBF\\u1EC5\\u1EC3\\u1EBD\\u0113\\u1E15\\u1E17\\u0115\\u0117\\u00EB\\u1EBB\\u011B\\u0205\\u0207\\u1EB9\\u1EC7\\u0229\\u1E1D\\u0119\\u1E19\\u1E1B\\u0247\\u025B\\u01DD]/g },\n\t{ 'base':'f', 'letters':/[\\u0066\\u24D5\\uFF46\\u1E1F\\u0192\\uA77C]/g },\n\t{ 'base':'g', 'letters':/[\\u0067\\u24D6\\uFF47\\u01F5\\u011D\\u1E21\\u011F\\u0121\\u01E7\\u0123\\u01E5\\u0260\\uA7A1\\u1D79\\uA77F]/g },\n\t{ 'base':'h', 'letters':/[\\u0068\\u24D7\\uFF48\\u0125\\u1E23\\u1E27\\u021F\\u1E25\\u1E29\\u1E2B\\u1E96\\u0127\\u2C68\\u2C76\\u0265]/g },\n\t{ 'base':'hv','letters':/[\\u0195]/g },\n\t{ 'base':'i', 'letters':/[\\u0069\\u24D8\\uFF49\\u00EC\\u00ED\\u00EE\\u0129\\u012B\\u012D\\u00EF\\u1E2F\\u1EC9\\u01D0\\u0209\\u020B\\u1ECB\\u012F\\u1E2D\\u0268\\u0131]/g },\n\t{ 'base':'j', 'letters':/[\\u006A\\u24D9\\uFF4A\\u0135\\u01F0\\u0249]/g },\n\t{ 'base':'k', 'letters':/[\\u006B\\u24DA\\uFF4B\\u1E31\\u01E9\\u1E33\\u0137\\u1E35\\u0199\\u2C6A\\uA741\\uA743\\uA745\\uA7A3]/g },\n\t{ 'base':'l', 'letters':/[\\u006C\\u24DB\\uFF4C\\u0140\\u013A\\u013E\\u1E37\\u1E39\\u013C\\u1E3D\\u1E3B\\u017F\\u0142\\u019A\\u026B\\u2C61\\uA749\\uA781\\uA747]/g },\n\t{ 'base':'lj','letters':/[\\u01C9]/g },\n\t{ 'base':'m', 'letters':/[\\u006D\\u24DC\\uFF4D\\u1E3F\\u1E41\\u1E43\\u0271\\u026F]/g },\n\t{ 'base':'n', 'letters':/[\\u006E\\u24DD\\uFF4E\\u01F9\\u0144\\u00F1\\u1E45\\u0148\\u1E47\\u0146\\u1E4B\\u1E49\\u019E\\u0272\\u0149\\uA791\\uA7A5]/g },\n\t{ 'base':'nj','letters':/[\\u01CC]/g },\n\t{ 'base':'o', 'letters':/[\\u006F\\u24DE\\uFF4F\\u00F2\\u00F3\\u00F4\\u1ED3\\u1ED1\\u1ED7\\u1ED5\\u00F5\\u1E4D\\u022D\\u1E4F\\u014D\\u1E51\\u1E53\\u014F\\u022F\\u0231\\u00F6\\u022B\\u1ECF\\u0151\\u01D2\\u020D\\u020F\\u01A1\\u1EDD\\u1EDB\\u1EE1\\u1EDF\\u1EE3\\u1ECD\\u1ED9\\u01EB\\u01ED\\u00F8\\u01FF\\u0254\\uA74B\\uA74D\\u0275]/g },\n\t{ 'base':'oi','letters':/[\\u01A3]/g },\n\t{ 'base':'ou','letters':/[\\u0223]/g },\n\t{ 'base':'oo','letters':/[\\uA74F]/g },\n\t{ 'base':'p', 'letters':/[\\u0070\\u24DF\\uFF50\\u1E55\\u1E57\\u01A5\\u1D7D\\uA751\\uA753\\uA755]/g },\n\t{ 'base':'q', 'letters':/[\\u0071\\u24E0\\uFF51\\u024B\\uA757\\uA759]/g },\n\t{ 'base':'r', 'letters':/[\\u0072\\u24E1\\uFF52\\u0155\\u1E59\\u0159\\u0211\\u0213\\u1E5B\\u1E5D\\u0157\\u1E5F\\u024D\\u027D\\uA75B\\uA7A7\\uA783]/g },\n\t{ 'base':'s', 'letters':/[\\u0073\\u24E2\\uFF53\\u00DF\\u015B\\u1E65\\u015D\\u1E61\\u0161\\u1E67\\u1E63\\u1E69\\u0219\\u015F\\u023F\\uA7A9\\uA785\\u1E9B]/g },\n\t{ 'base':'t', 'letters':/[\\u0074\\u24E3\\uFF54\\u1E6B\\u1E97\\u0165\\u1E6D\\u021B\\u0163\\u1E71\\u1E6F\\u0167\\u01AD\\u0288\\u2C66\\uA787]/g },\n\t{ 'base':'tz','letters':/[\\uA729]/g },\n\t{ 'base':'u', 'letters':/[\\u0075\\u24E4\\uFF55\\u00F9\\u00FA\\u00FB\\u0169\\u1E79\\u016B\\u1E7B\\u016D\\u00FC\\u01DC\\u01D8\\u01D6\\u01DA\\u1EE7\\u016F\\u0171\\u01D4\\u0215\\u0217\\u01B0\\u1EEB\\u1EE9\\u1EEF\\u1EED\\u1EF1\\u1EE5\\u1E73\\u0173\\u1E77\\u1E75\\u0289]/g },\n\t{ 'base':'v', 'letters':/[\\u0076\\u24E5\\uFF56\\u1E7D\\u1E7F\\u028B\\uA75F\\u028C]/g },\n\t{ 'base':'vy','letters':/[\\uA761]/g },\n\t{ 'base':'w', 'letters':/[\\u0077\\u24E6\\uFF57\\u1E81\\u1E83\\u0175\\u1E87\\u1E85\\u1E98\\u1E89\\u2C73]/g },\n\t{ 'base':'x', 'letters':/[\\u0078\\u24E7\\uFF58\\u1E8B\\u1E8D]/g },\n\t{ 'base':'y', 'letters':/[\\u0079\\u24E8\\uFF59\\u1EF3\\u00FD\\u0177\\u1EF9\\u0233\\u1E8F\\u00FF\\u1EF7\\u1E99\\u1EF5\\u01B4\\u024F\\u1EFF]/g },\n\t{ 'base':'z', 'letters':/[\\u007A\\u24E9\\uFF5A\\u017A\\u1E91\\u017C\\u017E\\u1E93\\u1E95\\u01B6\\u0225\\u0240\\u2C6C\\uA763]/g },\n];\n\nmodule.exports = function stripDiacritics (str) {\n\tfor (var i = 0; i < map.length; i++) {\n\t\tstr = str.replace(map[i].letters, map[i].base);\n\t}\n\treturn str;\n};\n","/*!\n  Copyright (c) 2016 Jed Watson.\n  Licensed under the MIT License (MIT), see\n  http://jedwatson.github.io/react-select\n*/\n\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport AutosizeInput from 'react-input-autosize';\nimport classNames from 'classnames';\n\nimport defaultArrowRenderer from './utils/defaultArrowRenderer';\nimport defaultFilterOptions from './utils/defaultFilterOptions';\nimport defaultMenuRenderer from './utils/defaultMenuRenderer';\n\nimport Async from './Async';\nimport AsyncCreatable from './AsyncCreatable';\nimport Creatable from './Creatable';\nimport Option from './Option';\nimport Value from './Value';\n\nfunction stringifyValue (value) {\n\tconst valueType = typeof value;\n\tif (valueType === 'string') {\n\t\treturn value;\n\t} else if (valueType === 'object') {\n\t\treturn JSON.stringify(value);\n\t} else if (valueType === 'number' || valueType === 'boolean') {\n\t\treturn String(value);\n\t} else {\n\t\treturn '';\n\t}\n}\n\nconst stringOrNode = React.PropTypes.oneOfType([\n\tReact.PropTypes.string,\n\tReact.PropTypes.node\n]);\n\nlet instanceId = 1;\n\nconst Select = React.createClass({\n\n\tdisplayName: 'Select',\n\n\tpropTypes: {\n\t\taddLabelText: React.PropTypes.string,       // placeholder displayed when you want to add a label on a multi-value input\n\t\t'aria-label': React.PropTypes.string,       // Aria label (for assistive tech)\n\t\t'aria-labelledby': React.PropTypes.string,\t// HTML ID of an element that should be used as the label (for assistive tech)\n\t\tarrowRenderer: React.PropTypes.func,\t\t\t\t// Create drop-down caret element\n\t\tautoBlur: React.PropTypes.bool,             // automatically blur the component when an option is selected\n\t\tautofocus: React.PropTypes.bool,            // autofocus the component on mount\n\t\tautosize: React.PropTypes.bool,             // whether to enable autosizing or not\n\t\tbackspaceRemoves: React.PropTypes.bool,     // whether backspace removes an item if there is no text input\n\t\tbackspaceToRemoveMessage: React.PropTypes.string,  // Message to use for screenreaders to press backspace to remove the current item - {label} is replaced with the item label\n\t\tclassName: React.PropTypes.string,          // className for the outer element\n\t\tclearAllText: stringOrNode,                 // title for the \"clear\" control when multi: true\n\t\tclearValueText: stringOrNode,               // title for the \"clear\" control\n\t\tclearable: React.PropTypes.bool,            // should it be possible to reset value\n\t\tdelimiter: React.PropTypes.string,          // delimiter to use to join multiple values for the hidden field value\n\t\tdisabled: React.PropTypes.bool,             // whether the Select is disabled or not\n\t\tescapeClearsValue: React.PropTypes.bool,    // whether escape clears the value when the menu is closed\n\t\tfilterOption: React.PropTypes.func,         // method to filter a single option (option, filterString)\n\t\tfilterOptions: React.PropTypes.any,         // boolean to enable default filtering or function to filter the options array ([options], filterString, [values])\n\t\tignoreAccents: React.PropTypes.bool,        // whether to strip diacritics when filtering\n\t\tignoreCase: React.PropTypes.bool,           // whether to perform case-insensitive filtering\n\t\tinputProps: React.PropTypes.object,         // custom attributes for the Input\n\t\tinputRenderer: React.PropTypes.func,        // returns a custom input component\n\t\tinstanceId: React.PropTypes.string,         // set the components instanceId\n\t\tisLoading: React.PropTypes.bool,            // whether the Select is loading externally or not (such as options being loaded)\n\t\tjoinValues: React.PropTypes.bool,           // joins multiple values into a single form field with the delimiter (legacy mode)\n\t\tlabelKey: React.PropTypes.string,           // path of the label value in option objects\n\t\tmatchPos: React.PropTypes.string,           // (any|start) match the start or entire string when filtering\n\t\tmatchProp: React.PropTypes.string,          // (any|label|value) which option property to filter on\n\t\tmenuBuffer: React.PropTypes.number,         // optional buffer (in px) between the bottom of the viewport and the bottom of the menu\n\t\tmenuContainerStyle: React.PropTypes.object, // optional style to apply to the menu container\n\t\tmenuRenderer: React.PropTypes.func,         // renders a custom menu with options\n\t\tmenuStyle: React.PropTypes.object,          // optional style to apply to the menu\n\t\tmulti: React.PropTypes.bool,                // multi-value input\n\t\tname: React.PropTypes.string,               // generates a hidden <input /> tag with this field name for html forms\n\t\tnoResultsText: stringOrNode,                // placeholder displayed when there are no matching search results\n\t\tonBlur: React.PropTypes.func,               // onBlur handler: function (event) {}\n\t\tonBlurResetsInput: React.PropTypes.bool,    // whether input is cleared on blur\n\t\tonChange: React.PropTypes.func,             // onChange handler: function (newValue) {}\n\t\tonClose: React.PropTypes.func,              // fires when the menu is closed\n\t\tonCloseResetsInput: React.PropTypes.bool,\t\t// whether input is cleared when menu is closed through the arrow\n\t\tonFocus: React.PropTypes.func,              // onFocus handler: function (event) {}\n\t\tonInputChange: React.PropTypes.func,        // onInputChange handler: function (inputValue) {}\n\t\tonInputKeyDown: React.PropTypes.func,       // input keyDown handler: function (event) {}\n\t\tonMenuScrollToBottom: React.PropTypes.func, // fires when the menu is scrolled to the bottom; can be used to paginate options\n\t\tonOpen: React.PropTypes.func,               // fires when the menu is opened\n\t\tonValueClick: React.PropTypes.func,         // onClick handler for value labels: function (value, event) {}\n\t\topenAfterFocus: React.PropTypes.bool,       // boolean to enable opening dropdown when focused\n\t\topenOnFocus: React.PropTypes.bool,          // always open options menu on focus\n\t\toptionClassName: React.PropTypes.string,    // additional class(es) to apply to the <Option /> elements\n\t\toptionComponent: React.PropTypes.func,      // option component to render in dropdown\n\t\toptionRenderer: React.PropTypes.func,       // optionRenderer: function (option) {}\n\t\toptions: React.PropTypes.array,             // array of options\n\t\tpageSize: React.PropTypes.number,           // number of entries to page when using page up/down keys\n\t\tplaceholder: stringOrNode,                  // field placeholder, displayed when there's no value\n\t\trequired: React.PropTypes.bool,             // applies HTML5 required attribute when needed\n\t\tresetValue: React.PropTypes.any,            // value to use when you clear the control\n\t\tscrollMenuIntoView: React.PropTypes.bool,   // boolean to enable the viewport to shift so that the full menu fully visible when engaged\n\t\tsearchable: React.PropTypes.bool,           // whether to enable searching feature or not\n\t\tsimpleValue: React.PropTypes.bool,          // pass the value to onChange as a simple value (legacy pre 1.0 mode), defaults to false\n\t\tstyle: React.PropTypes.object,              // optional style to apply to the control\n\t\ttabIndex: React.PropTypes.string,           // optional tab index of the control\n\t\ttabSelectsValue: React.PropTypes.bool,      // whether to treat tabbing out while focused to be value selection\n\t\tvalue: React.PropTypes.any,                 // initial field value\n\t\tvalueComponent: React.PropTypes.func,       // value component to render\n\t\tvalueKey: React.PropTypes.string,           // path of the label value in option objects\n\t\tvalueRenderer: React.PropTypes.func,        // valueRenderer: function (option) {}\n\t\twrapperStyle: React.PropTypes.object,       // optional style to apply to the component wrapper\n\t},\n\n\tstatics: { Async, AsyncCreatable, Creatable },\n\n\tgetDefaultProps () {\n\t\treturn {\n\t\t\taddLabelText: 'Add \"{label}\"?',\n\t\t\tarrowRenderer: defaultArrowRenderer,\n\t\t\tautosize: true,\n\t\t\tbackspaceRemoves: true,\n\t\t\tbackspaceToRemoveMessage: 'Press backspace to remove {label}',\n\t\t\tclearable: true,\n\t\t\tclearAllText: 'Clear all',\n\t\t\tclearValueText: 'Clear value',\n\t\t\tdelimiter: ',',\n\t\t\tdisabled: false,\n\t\t\tescapeClearsValue: true,\n\t\t\tfilterOptions: defaultFilterOptions,\n\t\t\tignoreAccents: true,\n\t\t\tignoreCase: true,\n\t\t\tinputProps: {},\n\t\t\tisLoading: false,\n\t\t\tjoinValues: false,\n\t\t\tlabelKey: 'label',\n\t\t\tmatchPos: 'any',\n\t\t\tmatchProp: 'any',\n\t\t\tmenuBuffer: 0,\n\t\t\tmenuRenderer: defaultMenuRenderer,\n\t\t\tmulti: false,\n\t\t\tnoResultsText: 'No results found',\n\t\t\tonBlurResetsInput: true,\n\t\t\tonCloseResetsInput: true,\n\t\t\topenAfterFocus: false,\n\t\t\toptionComponent: Option,\n\t\t\tpageSize: 5,\n\t\t\tplaceholder: 'Select...',\n\t\t\trequired: false,\n\t\t\tscrollMenuIntoView: true,\n\t\t\tsearchable: true,\n\t\t\tsimpleValue: false,\n\t\t\ttabSelectsValue: true,\n\t\t\tvalueComponent: Value,\n\t\t\tvalueKey: 'value',\n\t\t};\n\t},\n\n\tgetInitialState () {\n\t\treturn {\n\t\t\tinputValue: '',\n\t\t\tisFocused: false,\n\t\t\tisOpen: false,\n\t\t\tisPseudoFocused: false,\n\t\t\trequired: false,\n\t\t};\n\t},\n\n\tcomponentWillMount() {\n\t\tthis._instancePrefix = 'react-select-' + (this.props.instanceId || ++instanceId) + '-';\n\t\tconst valueArray = this.getValueArray(this.props.value);\n\n\t\tif (this.props.required) {\n\t\t\tthis.setState({\n\t\t\t\trequired: this.handleRequired(valueArray[0], this.props.multi),\n\t\t\t});\n\t\t}\n\t},\n\n\tcomponentDidMount () {\n\t\tif (this.props.autofocus) {\n\t\t\tthis.focus();\n\t\t}\n\t},\n\n\tcomponentWillReceiveProps(nextProps) {\n\t\tconst valueArray = this.getValueArray(nextProps.value, nextProps);\n\n\t\tif (nextProps.required) {\n\t\t\tthis.setState({\n\t\t\t\trequired: this.handleRequired(valueArray[0], nextProps.multi),\n\t\t\t});\n\t\t}\n\t},\n\n\tcomponentWillUpdate (nextProps, nextState) {\n\t\tif (nextState.isOpen !== this.state.isOpen) {\n\t\t\tthis.toggleTouchOutsideEvent(nextState.isOpen);\n\t\t\tconst handler = nextState.isOpen ? nextProps.onOpen : nextProps.onClose;\n\t\t\thandler && handler();\n\t\t}\n\t},\n\n\tcomponentDidUpdate (prevProps, prevState) {\n\t\t// focus to the selected option\n\t\tif (this.menu && this.focused && this.state.isOpen && !this.hasScrolledToOption) {\n\t\t\tlet focusedOptionNode = ReactDOM.findDOMNode(this.focused);\n\t\t\tlet menuNode = ReactDOM.findDOMNode(this.menu);\n\t\t\tmenuNode.scrollTop = focusedOptionNode.offsetTop;\n\t\t\tthis.hasScrolledToOption = true;\n\t\t} else if (!this.state.isOpen) {\n\t\t\tthis.hasScrolledToOption = false;\n\t\t}\n\n\t\tif (this._scrollToFocusedOptionOnUpdate && this.focused && this.menu) {\n\t\t\tthis._scrollToFocusedOptionOnUpdate = false;\n\t\t\tvar focusedDOM = ReactDOM.findDOMNode(this.focused);\n\t\t\tvar menuDOM = ReactDOM.findDOMNode(this.menu);\n\t\t\tvar focusedRect = focusedDOM.getBoundingClientRect();\n\t\t\tvar menuRect = menuDOM.getBoundingClientRect();\n\t\t\tif (focusedRect.bottom > menuRect.bottom || focusedRect.top < menuRect.top) {\n\t\t\t\tmenuDOM.scrollTop = (focusedDOM.offsetTop + focusedDOM.clientHeight - menuDOM.offsetHeight);\n\t\t\t}\n\t\t}\n\t\tif (this.props.scrollMenuIntoView && this.menuContainer) {\n\t\t\tvar menuContainerRect = this.menuContainer.getBoundingClientRect();\n\t\t\tif (window.innerHeight < menuContainerRect.bottom + this.props.menuBuffer) {\n\t\t\t\twindow.scrollBy(0, menuContainerRect.bottom + this.props.menuBuffer - window.innerHeight);\n\t\t\t}\n\t\t}\n\t\tif (prevProps.disabled !== this.props.disabled) {\n\t\t\tthis.setState({ isFocused: false }); // eslint-disable-line react/no-did-update-set-state\n\t\t\tthis.closeMenu();\n\t\t}\n\t},\n\n\tcomponentWillUnmount() {\n\t\tif (!document.removeEventListener && document.detachEvent) {\n\t\t\tdocument.detachEvent('ontouchstart', this.handleTouchOutside);\n\t\t} else {\n\t\t\tdocument.removeEventListener('touchstart', this.handleTouchOutside);\n\t\t}\n\t},\n\n\ttoggleTouchOutsideEvent(enabled) {\n\t\tif (enabled) {\n\t\t\tif (!document.addEventListener && document.attachEvent) {\n\t\t\t\tdocument.attachEvent('ontouchstart', this.handleTouchOutside);\n\t\t\t} else {\n\t\t\t\tdocument.addEventListener('touchstart', this.handleTouchOutside);\n\t\t\t}\n\t\t} else {\n\t\t\tif (!document.removeEventListener && document.detachEvent) {\n\t\t\t\tdocument.detachEvent('ontouchstart', this.handleTouchOutside);\n\t\t\t} else {\n\t\t\t\tdocument.removeEventListener('touchstart', this.handleTouchOutside);\n\t\t\t}\n\t\t}\n\t},\n\n\thandleTouchOutside(event) {\n\t\t// handle touch outside on ios to dismiss menu\n\t\tif (this.wrapper && !this.wrapper.contains(event.target)) {\n\t\t\tthis.closeMenu();\n\t\t}\n\t},\n\n\tfocus () {\n\t\tif (!this.input) return;\n\t\tthis.input.focus();\n\n\t\tif (this.props.openAfterFocus) {\n\t\t\tthis.setState({\n\t\t\t\tisOpen: true,\n\t\t\t});\n\t\t}\n\t},\n\n\tblurInput() {\n\t\tif (!this.input) return;\n\t\tthis.input.blur();\n\t},\n\n\thandleTouchMove (event) {\n\t\t// Set a flag that the view is being dragged\n\t\tthis.dragging = true;\n\t},\n\n\thandleTouchStart (event) {\n\t\t// Set a flag that the view is not being dragged\n\t\tthis.dragging = false;\n\t},\n\n\thandleTouchEnd (event) {\n\t\t// Check if the view is being dragged, In this case\n\t\t// we don't want to fire the click event (because the user only wants to scroll)\n\t\tif(this.dragging) return;\n\n\t\t// Fire the mouse events\n\t\tthis.handleMouseDown(event);\n\t},\n\n\thandleTouchEndClearValue (event) {\n\t\t// Check if the view is being dragged, In this case\n\t\t// we don't want to fire the click event (because the user only wants to scroll)\n\t\tif(this.dragging) return;\n\n\t\t// Clear the value\n\t\tthis.clearValue(event);\n\t},\n\n\thandleMouseDown (event) {\n\t\t// if the event was triggered by a mousedown and not the primary\n\t\t// button, or if the component is disabled, ignore it.\n\t\tif (this.props.disabled || (event.type === 'mousedown' && event.button !== 0)) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (event.target.tagName === 'INPUT') {\n\t\t\treturn;\n\t\t}\n\n\t\t// prevent default event handlers\n\t\tevent.stopPropagation();\n\t\tevent.preventDefault();\n\n\t\t// for the non-searchable select, toggle the menu\n\t\tif (!this.props.searchable) {\n\t\t\tthis.focus();\n\t\t\treturn this.setState({\n\t\t\t\tisOpen: !this.state.isOpen,\n\t\t\t});\n\t\t}\n\n\t\tif (this.state.isFocused) {\n\t\t\t// On iOS, we can get into a state where we think the input is focused but it isn't really,\n\t\t\t// since iOS ignores programmatic calls to input.focus() that weren't triggered by a click event.\n\t\t\t// Call focus() again here to be safe.\n\t\t\tthis.focus();\n\n\t\t\tlet input = this.input;\n\t\t\tif (typeof input.getInput === 'function') {\n\t\t\t\t// Get the actual DOM input if the ref is an <AutosizeInput /> component\n\t\t\t\tinput = input.getInput();\n\t\t\t}\n\n\t\t\t// clears the value so that the cursor will be at the end of input when the component re-renders\n\t\t\tinput.value = '';\n\n\t\t\t// if the input is focused, ensure the menu is open\n\t\t\tthis.setState({\n\t\t\t\tisOpen: true,\n\t\t\t\tisPseudoFocused: false,\n\t\t\t});\n\t\t} else {\n\t\t\t// otherwise, focus the input and open the menu\n\t\t\tthis._openAfterFocus = true;\n\t\t\tthis.focus();\n\t\t}\n\t},\n\n\thandleMouseDownOnArrow (event) {\n\t\t// if the event was triggered by a mousedown and not the primary\n\t\t// button, or if the component is disabled, ignore it.\n\t\tif (this.props.disabled || (event.type === 'mousedown' && event.button !== 0)) {\n\t\t\treturn;\n\t\t}\n\t\t// If the menu isn't open, let the event bubble to the main handleMouseDown\n\t\tif (!this.state.isOpen) {\n\t\t\treturn;\n\t\t}\n\t\t// prevent default event handlers\n\t\tevent.stopPropagation();\n\t\tevent.preventDefault();\n\t\t// close the menu\n\t\tthis.closeMenu();\n\t},\n\n\thandleMouseDownOnMenu (event) {\n\t\t// if the event was triggered by a mousedown and not the primary\n\t\t// button, or if the component is disabled, ignore it.\n\t\tif (this.props.disabled || (event.type === 'mousedown' && event.button !== 0)) {\n\t\t\treturn;\n\t\t}\n\t\tevent.stopPropagation();\n\t\tevent.preventDefault();\n\n\t\tthis._openAfterFocus = true;\n\t\tthis.focus();\n\t},\n\n\tcloseMenu () {\n\t\tif(this.props.onCloseResetsInput) {\n\t\t\tthis.setState({\n\t\t\t\tisOpen: false,\n\t\t\t\tisPseudoFocused: this.state.isFocused && !this.props.multi,\n\t\t\t\tinputValue: ''\n\t\t\t});\n\t\t}\telse {\n\t\t\tthis.setState({\n\t\t\t\tisOpen: false,\n\t\t\t\tisPseudoFocused: this.state.isFocused && !this.props.multi,\n\t\t\t\tinputValue: this.state.inputValue\n\t\t\t});\n\t\t}\n\t\tthis.hasScrolledToOption = false;\n\t},\n\n\thandleInputFocus (event) {\n\t\tif (this.props.disabled) return;\n\t\tvar isOpen = this.state.isOpen || this._openAfterFocus || this.props.openOnFocus;\n\t\tif (this.props.onFocus) {\n\t\t\tthis.props.onFocus(event);\n\t\t}\n\t\tthis.setState({\n\t\t\tisFocused: true,\n\t\t\tisOpen: isOpen\n\t\t});\n\t\tthis._openAfterFocus = false;\n\t},\n\n\thandleInputBlur (event) {\n\t\t// The check for menu.contains(activeElement) is necessary to prevent IE11's scrollbar from closing the menu in certain contexts.\n\t\tif (this.menu && (this.menu === document.activeElement || this.menu.contains(document.activeElement))) {\n\t\t\tthis.focus();\n\t\t\treturn;\n\t\t}\n\n\t\tif (this.props.onBlur) {\n\t\t\tthis.props.onBlur(event);\n\t\t}\n\t\tvar onBlurredState = {\n\t\t\tisFocused: false,\n\t\t\tisOpen: false,\n\t\t\tisPseudoFocused: false,\n\t\t};\n\t\tif (this.props.onBlurResetsInput) {\n\t\t\tonBlurredState.inputValue = '';\n\t\t}\n\t\tthis.setState(onBlurredState);\n\t},\n\n\thandleInputChange (event) {\n\t\tlet newInputValue = event.target.value;\n\n\t\tif (this.state.inputValue !== event.target.value && this.props.onInputChange) {\n\t\t\tlet nextState = this.props.onInputChange(newInputValue);\n\t\t\t// Note: != used deliberately here to catch undefined and null\n\t\t\tif (nextState != null && typeof nextState !== 'object') {\n\t\t\t\tnewInputValue = '' + nextState;\n\t\t\t}\n\t\t}\n\n\t\tthis.setState({\n\t\t\tisOpen: true,\n\t\t\tisPseudoFocused: false,\n\t\t\tinputValue: newInputValue\n\t\t});\n\t},\n\n\thandleKeyDown (event) {\n\t\tif (this.props.disabled) return;\n\n\t\tif (typeof this.props.onInputKeyDown === 'function') {\n\t\t\tthis.props.onInputKeyDown(event);\n\t\t\tif (event.defaultPrevented) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\tswitch (event.keyCode) {\n\t\t\tcase 8: // backspace\n\t\t\t\tif (!this.state.inputValue && this.props.backspaceRemoves) {\n\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\tthis.popValue();\n\t\t\t\t}\n\t\t\treturn;\n\t\t\tcase 9: // tab\n\t\t\t\tif (event.shiftKey || !this.state.isOpen || !this.props.tabSelectsValue) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tthis.selectFocusedOption();\n\t\t\treturn;\n\t\t\tcase 13: // enter\n\t\t\t\tif (!this.state.isOpen) return;\n\t\t\t\tevent.stopPropagation();\n\t\t\t\tthis.selectFocusedOption();\n\t\t\tbreak;\n\t\t\tcase 27: // escape\n\t\t\t\tif (this.state.isOpen) {\n\t\t\t\t\tthis.closeMenu();\n\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t} else if (this.props.clearable && this.props.escapeClearsValue) {\n\t\t\t\t\tthis.clearValue(event);\n\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t}\n\t\t\tbreak;\n\t\t\tcase 38: // up\n\t\t\t\tthis.focusPreviousOption();\n\t\t\tbreak;\n\t\t\tcase 40: // down\n\t\t\t\tthis.focusNextOption();\n\t\t\tbreak;\n\t\t\tcase 33: // page up\n\t\t\t\tthis.focusPageUpOption();\n\t\t\tbreak;\n\t\t\tcase 34: // page down\n\t\t\t\tthis.focusPageDownOption();\n\t\t\tbreak;\n\t\t\tcase 35: // end key\n\t\t\t\tif (event.shiftKey) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tthis.focusEndOption();\n\t\t\tbreak;\n\t\t\tcase 36: // home key\n\t\t\t\tif (event.shiftKey) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tthis.focusStartOption();\n\t\t\tbreak;\n\t\t\tdefault: return;\n\t\t}\n\t\tevent.preventDefault();\n\t},\n\n\thandleValueClick (option, event) {\n\t\tif (!this.props.onValueClick) return;\n\t\tthis.props.onValueClick(option, event);\n\t},\n\n\thandleMenuScroll (event) {\n\t\tif (!this.props.onMenuScrollToBottom) return;\n\t\tlet { target } = event;\n\t\tif (target.scrollHeight > target.offsetHeight && !(target.scrollHeight - target.offsetHeight - target.scrollTop)) {\n\t\t\tthis.props.onMenuScrollToBottom();\n\t\t}\n\t},\n\n\thandleRequired (value, multi) {\n\t\tif (!value) return true;\n\t\treturn (multi ? value.length === 0 : Object.keys(value).length === 0);\n\t},\n\n\tgetOptionLabel (op) {\n\t\treturn op[this.props.labelKey];\n\t},\n\n\t/**\n\t * Turns a value into an array from the given options\n\t * @param\t{String|Number|Array}\tvalue\t\t- the value of the select input\n\t * @param\t{Object}\t\tnextProps\t- optionally specify the nextProps so the returned array uses the latest configuration\n\t * @returns\t{Array}\tthe value of the select represented in an array\n\t */\n\tgetValueArray (value, nextProps) {\n\t\t/** support optionally passing in the `nextProps` so `componentWillReceiveProps` updates will function as expected */\n\t\tconst props = typeof nextProps === 'object' ? nextProps : this.props;\n\t\tif (props.multi) {\n\t\t\tif (typeof value === 'string') value = value.split(props.delimiter);\n\t\t\tif (!Array.isArray(value)) {\n\t\t\t\tif (value === null || value === undefined) return [];\n\t\t\t\tvalue = [value];\n\t\t\t}\n\t\t\treturn value.map(value => this.expandValue(value, props)).filter(i => i);\n\t\t}\n\t\tvar expandedValue = this.expandValue(value, props);\n\t\treturn expandedValue ? [expandedValue] : [];\n\t},\n\n\t/**\n\t * Retrieve a value from the given options and valueKey\n\t * @param\t{String|Number|Array}\tvalue\t- the selected value(s)\n\t * @param\t{Object}\t\tprops\t- the Select component's props (or nextProps)\n\t */\n\texpandValue (value, props) {\n\t\tconst valueType = typeof value;\n\t\tif (valueType !== 'string' && valueType !== 'number' && valueType !== 'boolean') return value;\n\t\tlet { options, valueKey } = props;\n\t\tif (!options) return;\n\t\tfor (var i = 0; i < options.length; i++) {\n\t\t\tif (options[i][valueKey] === value) return options[i];\n\t\t}\n\t},\n\n\tsetValue (value) {\n\t\tif (this.props.autoBlur){\n\t\t\tthis.blurInput();\n\t\t}\n\t\tif (!this.props.onChange) return;\n\t\tif (this.props.required) {\n\t\t\tconst required = this.handleRequired(value, this.props.multi);\n\t\t\tthis.setState({ required });\n\t\t}\n\t\tif (this.props.simpleValue && value) {\n\t\t\tvalue = this.props.multi ? value.map(i => i[this.props.valueKey]).join(this.props.delimiter) : value[this.props.valueKey];\n\t\t}\n\t\tthis.props.onChange(value);\n\t},\n\n\tselectValue (value) {\n\t\t//NOTE: update value in the callback to make sure the input value is empty so that there are no styling issues (Chrome had issue otherwise)\n\t\tthis.hasScrolledToOption = false;\n\t\tif (this.props.multi) {\n\t\t\tthis.setState({\n\t\t\t\tinputValue: '',\n\t\t\t\tfocusedIndex: null\n\t\t\t}, () => {\n\t\t\t\tthis.addValue(value);\n\t\t\t});\n\t\t} else {\n\t\t\tthis.setState({\n\t\t\t\tisOpen: false,\n\t\t\t\tinputValue: '',\n\t\t\t\tisPseudoFocused: this.state.isFocused,\n\t\t\t}, () => {\n\t\t\t\tthis.setValue(value);\n\t\t\t});\n\t\t}\n\t},\n\n\taddValue (value) {\n\t\tvar valueArray = this.getValueArray(this.props.value);\n\t\tthis.setValue(valueArray.concat(value));\n\t},\n\n\tpopValue () {\n\t\tvar valueArray = this.getValueArray(this.props.value);\n\t\tif (!valueArray.length) return;\n\t\tif (valueArray[valueArray.length-1].clearableValue === false) return;\n\t\tthis.setValue(valueArray.slice(0, valueArray.length - 1));\n\t},\n\n\tremoveValue (value) {\n\t\tvar valueArray = this.getValueArray(this.props.value);\n\t\tthis.setValue(valueArray.filter(i => i !== value));\n\t\tthis.focus();\n\t},\n\n\tclearValue (event) {\n\t\t// if the event was triggered by a mousedown and not the primary\n\t\t// button, ignore it.\n\t\tif (event && event.type === 'mousedown' && event.button !== 0) {\n\t\t\treturn;\n\t\t}\n\t\tevent.stopPropagation();\n\t\tevent.preventDefault();\n\t\tthis.setValue(this.getResetValue());\n\t\tthis.setState({\n\t\t\tisOpen: false,\n\t\t\tinputValue: '',\n\t\t}, this.focus);\n\t},\n\n\tgetResetValue() {\n\t\tif (this.props.resetValue !== undefined) {\n\t\t\treturn this.props.resetValue;\n\t\t} else if (this.props.multi) {\n\t\t\treturn [];\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t},\n\n\tfocusOption (option) {\n\t\tthis.setState({\n\t\t\tfocusedOption: option\n\t\t});\n\t},\n\n\tfocusNextOption () {\n\t\tthis.focusAdjacentOption('next');\n\t},\n\n\tfocusPreviousOption () {\n\t\tthis.focusAdjacentOption('previous');\n\t},\n\n\tfocusPageUpOption () {\n\t\tthis.focusAdjacentOption('page_up');\n\t},\n\n\tfocusPageDownOption () {\n\t\tthis.focusAdjacentOption('page_down');\n\t},\n\n\tfocusStartOption () {\n\t\tthis.focusAdjacentOption('start');\n\t},\n\n\tfocusEndOption () {\n\t\tthis.focusAdjacentOption('end');\n\t},\n\n\tfocusAdjacentOption (dir) {\n\t\tvar options = this._visibleOptions\n\t\t\t.map((option, index) => ({ option, index }))\n\t\t\t.filter(option => !option.option.disabled);\n\t\tthis._scrollToFocusedOptionOnUpdate = true;\n\t\tif (!this.state.isOpen) {\n\t\t\tthis.setState({\n\t\t\t\tisOpen: true,\n\t\t\t\tinputValue: '',\n\t\t\t\tfocusedOption: this._focusedOption || options[dir === 'next' ? 0 : options.length - 1].option\n\t\t\t});\n\t\t\treturn;\n\t\t}\n\t\tif (!options.length) return;\n\t\tvar focusedIndex = -1;\n\t\tfor (var i = 0; i < options.length; i++) {\n\t\t\tif (this._focusedOption === options[i].option) {\n\t\t\t\tfocusedIndex = i;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t\tif (dir === 'next' && focusedIndex !== -1 ) {\n\t\t\tfocusedIndex = (focusedIndex + 1) % options.length;\n\t\t} else if (dir === 'previous') {\n\t\t\tif (focusedIndex > 0) {\n\t\t\t\tfocusedIndex = focusedIndex - 1;\n\t\t\t} else {\n\t\t\t\tfocusedIndex = options.length - 1;\n\t\t\t}\n\t\t} else if (dir === 'start') {\n\t\t\tfocusedIndex = 0;\n\t\t} else if (dir === 'end') {\n\t\t\tfocusedIndex = options.length - 1;\n\t\t} else if (dir === 'page_up') {\n\t\t\tvar potentialIndex = focusedIndex - this.props.pageSize;\n\t\t\tif ( potentialIndex < 0 ) {\n\t\t\t\tfocusedIndex = 0;\n\t\t\t} else {\n\t\t\t\tfocusedIndex = potentialIndex;\n\t\t\t}\n\t\t} else if (dir === 'page_down') {\n\t\t\tvar potentialIndex = focusedIndex + this.props.pageSize;\n\t\t\tif ( potentialIndex > options.length - 1 ) {\n\t\t\t\tfocusedIndex = options.length - 1;\n\t\t\t} else {\n\t\t\t\tfocusedIndex = potentialIndex;\n\t\t\t}\n\t\t}\n\n\t\tif (focusedIndex === -1) {\n\t\t\tfocusedIndex = 0;\n\t\t}\n\n\t\tthis.setState({\n\t\t\tfocusedIndex: options[focusedIndex].index,\n\t\t\tfocusedOption: options[focusedIndex].option\n\t\t});\n\t},\n\n\tgetFocusedOption () {\n\t\treturn this._focusedOption;\n\t},\n\n\tgetInputValue () {\n\t\treturn this.state.inputValue;\n\t},\n\n\tselectFocusedOption () {\n\t\tif (this._focusedOption) {\n\t\t\treturn this.selectValue(this._focusedOption);\n\t\t}\n\t},\n\n\trenderLoading () {\n\t\tif (!this.props.isLoading) return;\n\t\treturn (\n\t\t\t<span className=\"Select-loading-zone\" aria-hidden=\"true\">\n\t\t\t\t<span className=\"Select-loading\" />\n\t\t\t</span>\n\t\t);\n\t},\n\n\trenderValue (valueArray, isOpen) {\n\t\tlet renderLabel = this.props.valueRenderer || this.getOptionLabel;\n\t\tlet ValueComponent = this.props.valueComponent;\n\t\tif (!valueArray.length) {\n\t\t\treturn !this.state.inputValue ? <div className=\"Select-placeholder\">{this.props.placeholder}</div> : null;\n\t\t}\n\t\tlet onClick = this.props.onValueClick ? this.handleValueClick : null;\n\t\tif (this.props.multi) {\n\t\t\treturn valueArray.map((value, i) => {\n\t\t\t\treturn (\n\t\t\t\t\t<ValueComponent\n\t\t\t\t\t\tid={this._instancePrefix + '-value-' + i}\n\t\t\t\t\t\tinstancePrefix={this._instancePrefix}\n\t\t\t\t\t\tdisabled={this.props.disabled || value.clearableValue === false}\n\t\t\t\t\t\tkey={`value-${i}-${value[this.props.valueKey]}`}\n\t\t\t\t\t\tonClick={onClick}\n\t\t\t\t\t\tonRemove={this.removeValue}\n\t\t\t\t\t\tvalue={value}\n\t\t\t\t\t>\n\t\t\t\t\t\t{renderLabel(value, i)}\n\t\t\t\t\t\t<span className=\"Select-aria-only\">&nbsp;</span>\n\t\t\t\t\t</ValueComponent>\n\t\t\t\t);\n\t\t\t});\n\t\t} else if (!this.state.inputValue) {\n\t\t\tif (isOpen) onClick = null;\n\t\t\treturn (\n\t\t\t\t<ValueComponent\n\t\t\t\t\tid={this._instancePrefix + '-value-item'}\n\t\t\t\t\tdisabled={this.props.disabled}\n\t\t\t\t\tinstancePrefix={this._instancePrefix}\n\t\t\t\t\tonClick={onClick}\n\t\t\t\t\tvalue={valueArray[0]}\n\t\t\t\t>\n\t\t\t\t\t{renderLabel(valueArray[0])}\n\t\t\t\t</ValueComponent>\n\t\t\t);\n\t\t}\n\t},\n\n\trenderInput (valueArray, focusedOptionIndex) {\n\t\tif (this.props.inputRenderer) {\n\t\t\treturn this.props.inputRenderer();\n\t\t} else {\n\t\t\tvar className = classNames('Select-input', this.props.inputProps.className);\n\t\t\tconst isOpen = !!this.state.isOpen;\n\n\t\t\tconst ariaOwns = classNames({\n\t\t\t\t[this._instancePrefix + '-list']: isOpen,\n\t\t\t\t[this._instancePrefix + '-backspace-remove-message']: this.props.multi\n\t\t\t\t\t&& !this.props.disabled\n\t\t\t\t\t&& this.state.isFocused\n\t\t\t\t\t&& !this.state.inputValue\n\t\t\t});\n\n\t\t\t// TODO: Check how this project includes Object.assign()\n\t\t\tconst inputProps = Object.assign({}, this.props.inputProps, {\n\t\t\t\trole: 'combobox',\n\t\t\t\t'aria-expanded': '' + isOpen,\n\t\t\t\t'aria-owns': ariaOwns,\n\t\t\t\t'aria-haspopup': '' + isOpen,\n\t\t\t\t'aria-activedescendant': isOpen ? this._instancePrefix + '-option-' + focusedOptionIndex : this._instancePrefix + '-value',\n\t\t\t\t'aria-labelledby': this.props['aria-labelledby'],\n\t\t\t\t'aria-label': this.props['aria-label'],\n\t\t\t\tclassName: className,\n\t\t\t\ttabIndex: this.props.tabIndex,\n\t\t\t\tonBlur: this.handleInputBlur,\n\t\t\t\tonChange: this.handleInputChange,\n\t\t\t\tonFocus: this.handleInputFocus,\n\t\t\t\tref: ref => this.input = ref,\n\t\t\t\trequired: this.state.required,\n\t\t\t\tvalue: this.state.inputValue\n\t\t\t});\n\n\t\t\tif (this.props.disabled || !this.props.searchable) {\n\t\t\t\tconst { inputClassName, ...divProps } = this.props.inputProps;\n\t\t\t\treturn (\n\t\t\t\t\t<div\n\t\t\t\t\t\t{...divProps}\n\t\t\t\t\t\trole=\"combobox\"\n\t\t\t\t\t\taria-expanded={isOpen}\n\t\t\t\t\t\taria-owns={isOpen ? this._instancePrefix + '-list' : this._instancePrefix + '-value'}\n\t\t\t\t\t\taria-activedescendant={isOpen ? this._instancePrefix + '-option-' + focusedOptionIndex : this._instancePrefix + '-value'}\n\t\t\t\t\t\tclassName={className}\n\t\t\t\t\t\ttabIndex={this.props.tabIndex || 0}\n\t\t\t\t\t\tonBlur={this.handleInputBlur}\n\t\t\t\t\t\tonFocus={this.handleInputFocus}\n\t\t\t\t\t\tref={ref => this.input = ref}\n\t\t\t\t\t\taria-readonly={'' + !!this.props.disabled}\n\t\t\t\t\t\tstyle={{ border: 0, width: 1, display:'inline-block' }}/>\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tif (this.props.autosize) {\n\t\t\t\treturn (\n\t\t\t\t\t<AutosizeInput {...inputProps} minWidth=\"5\" />\n\t\t\t\t);\n\t\t\t}\n\t\t\treturn (\n\t\t\t\t<div className={ className }>\n\t\t\t\t\t<input {...inputProps} />\n\t\t\t\t</div>\n\t\t\t);\n\t\t}\n\t},\n\n\trenderClear () {\n\t\tif (!this.props.clearable || (!this.props.value || this.props.value === 0) || (this.props.multi && !this.props.value.length) || this.props.disabled || this.props.isLoading) return;\n\t\treturn (\n\t\t\t<span className=\"Select-clear-zone\" title={this.props.multi ? this.props.clearAllText : this.props.clearValueText}\n\t\t\t\taria-label={this.props.multi ? this.props.clearAllText : this.props.clearValueText}\n\t\t\t\tonMouseDown={this.clearValue}\n\t\t\t\tonTouchStart={this.handleTouchStart}\n\t\t\t\tonTouchMove={this.handleTouchMove}\n\t\t\t\tonTouchEnd={this.handleTouchEndClearValue}\n\t\t\t>\n\t\t\t\t<span className=\"Select-clear\" dangerouslySetInnerHTML={{ __html: '&times;' }} />\n\t\t\t</span>\n\t\t);\n\t},\n\n\trenderArrow () {\n\t\tconst onMouseDown = this.handleMouseDownOnArrow;\n\t\tconst arrow = this.props.arrowRenderer({ onMouseDown });\n\n\t\treturn (\n\t\t\t<span\n\t\t\t\tclassName=\"Select-arrow-zone\"\n\t\t\t\tonMouseDown={onMouseDown}\n\t\t\t>\n\t\t\t\t{arrow}\n\t\t\t</span>\n\t\t);\n\t},\n\n\tfilterOptions (excludeOptions) {\n\t\tvar filterValue = this.state.inputValue;\n\t\tvar options = this.props.options || [];\n\t\tif (this.props.filterOptions) {\n\t\t\t// Maintain backwards compatibility with boolean attribute\n\t\t\tconst filterOptions = typeof this.props.filterOptions === 'function'\n\t\t\t\t? this.props.filterOptions\n\t\t\t\t: defaultFilterOptions;\n\n\t\t\treturn filterOptions(\n\t\t\t\toptions,\n\t\t\t\tfilterValue,\n\t\t\t\texcludeOptions,\n\t\t\t\t{\n\t\t\t\t\tfilterOption: this.props.filterOption,\n\t\t\t\t\tignoreAccents: this.props.ignoreAccents,\n\t\t\t\t\tignoreCase: this.props.ignoreCase,\n\t\t\t\t\tlabelKey: this.props.labelKey,\n\t\t\t\t\tmatchPos: this.props.matchPos,\n\t\t\t\t\tmatchProp: this.props.matchProp,\n\t\t\t\t\tvalueKey: this.props.valueKey,\n\t\t\t\t}\n\t\t\t);\n\t\t} else {\n\t\t\treturn options;\n\t\t}\n\t},\n\n\tonOptionRef(ref, isFocused) {\n\t\tif (isFocused) {\n\t\t\tthis.focused = ref;\n\t\t}\n\t},\n\n\trenderMenu (options, valueArray, focusedOption) {\n\t\tif (options && options.length) {\n\t\t\treturn this.props.menuRenderer({\n\t\t\t\tfocusedOption,\n\t\t\t\tfocusOption: this.focusOption,\n\t\t\t\tinstancePrefix: this._instancePrefix,\n\t\t\t\tlabelKey: this.props.labelKey,\n\t\t\t\tonFocus: this.focusOption,\n\t\t\t\tonSelect: this.selectValue,\n\t\t\t\toptionClassName: this.props.optionClassName,\n\t\t\t\toptionComponent: this.props.optionComponent,\n\t\t\t\toptionRenderer: this.props.optionRenderer || this.getOptionLabel,\n\t\t\t\toptions,\n\t\t\t\tselectValue: this.selectValue,\n\t\t\t\tvalueArray,\n\t\t\t\tvalueKey: this.props.valueKey,\n\t\t\t\tonOptionRef: this.onOptionRef,\n\t\t\t});\n\t\t} else if (this.props.noResultsText) {\n\t\t\treturn (\n\t\t\t\t<div className=\"Select-noresults\">\n\t\t\t\t\t{this.props.noResultsText}\n\t\t\t\t</div>\n\t\t\t);\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t},\n\n\trenderHiddenField (valueArray) {\n\t\tif (!this.props.name) return;\n\t\tif (this.props.joinValues) {\n\t\t\tlet value = valueArray.map(i => stringifyValue(i[this.props.valueKey])).join(this.props.delimiter);\n\t\t\treturn (\n\t\t\t\t<input\n\t\t\t\t\ttype=\"hidden\"\n\t\t\t\t\tref={ref => this.value = ref}\n\t\t\t\t\tname={this.props.name}\n\t\t\t\t\tvalue={value}\n\t\t\t\t\tdisabled={this.props.disabled} />\n\t\t\t);\n\t\t}\n\t\treturn valueArray.map((item, index) => (\n\t\t\t<input key={'hidden.' + index}\n\t\t\t\ttype=\"hidden\"\n\t\t\t\tref={'value' + index}\n\t\t\t\tname={this.props.name}\n\t\t\t\tvalue={stringifyValue(item[this.props.valueKey])}\n\t\t\t\tdisabled={this.props.disabled} />\n\t\t));\n\t},\n\n\tgetFocusableOptionIndex (selectedOption) {\n\t\tvar options = this._visibleOptions;\n\t\tif (!options.length) return null;\n\n\t\tlet focusedOption = this.state.focusedOption || selectedOption;\n\t\tif (focusedOption && !focusedOption.disabled) {\n\t\t\tconst focusedOptionIndex = options.indexOf(focusedOption);\n\t\t\tif (focusedOptionIndex !== -1) {\n\t\t\t\treturn focusedOptionIndex;\n\t\t\t}\n\t\t}\n\n\t\tfor (var i = 0; i < options.length; i++) {\n\t\t\tif (!options[i].disabled) return i;\n\t\t}\n\t\treturn null;\n\t},\n\n\trenderOuter (options, valueArray, focusedOption) {\n\t\tlet menu = this.renderMenu(options, valueArray, focusedOption);\n\t\tif (!menu) {\n\t\t\treturn null;\n\t\t}\n\n\t\treturn (\n\t\t\t<div ref={ref => this.menuContainer = ref} className=\"Select-menu-outer\" style={this.props.menuContainerStyle}>\n\t\t\t\t<div ref={ref => this.menu = ref} role=\"listbox\" className=\"Select-menu\" id={this._instancePrefix + '-list'}\n\t\t\t\t\t\t style={this.props.menuStyle}\n\t\t\t\t\t\t onScroll={this.handleMenuScroll}\n\t\t\t\t\t\t onMouseDown={this.handleMouseDownOnMenu}>\n\t\t\t\t\t{menu}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t},\n\n\trender () {\n\t\tlet valueArray = this.getValueArray(this.props.value);\n\t\tlet options =\tthis._visibleOptions = this.filterOptions(this.props.multi ? this.getValueArray(this.props.value) : null);\n\t\tlet isOpen = this.state.isOpen;\n\t\tif (this.props.multi && !options.length && valueArray.length && !this.state.inputValue) isOpen = false;\n\t\tconst focusedOptionIndex = this.getFocusableOptionIndex(valueArray[0]);\n\n\t\tlet focusedOption = null;\n\t\tif (focusedOptionIndex !== null) {\n\t\t\tfocusedOption = this._focusedOption = options[focusedOptionIndex];\n\t\t} else {\n\t\t\tfocusedOption = this._focusedOption = null;\n\t\t}\n\t\tlet className = classNames('Select', this.props.className, {\n\t\t\t'Select--multi': this.props.multi,\n\t\t\t'Select--single': !this.props.multi,\n\t\t\t'is-disabled': this.props.disabled,\n\t\t\t'is-focused': this.state.isFocused,\n\t\t\t'is-loading': this.props.isLoading,\n\t\t\t'is-open': isOpen,\n\t\t\t'is-pseudo-focused': this.state.isPseudoFocused,\n\t\t\t'is-searchable': this.props.searchable,\n\t\t\t'has-value': valueArray.length,\n\t\t});\n\n\t\tlet removeMessage = null;\n\t\tif (this.props.multi &&\n\t\t\t!this.props.disabled &&\n\t\t\tvalueArray.length &&\n\t\t\t!this.state.inputValue &&\n\t\t\tthis.state.isFocused &&\n\t\t\tthis.props.backspaceRemoves) {\n\t\t\tremoveMessage = (\n\t\t\t\t<span id={this._instancePrefix + '-backspace-remove-message'} className=\"Select-aria-only\" aria-live=\"assertive\">\n\t\t\t\t\t{this.props.backspaceToRemoveMessage.replace('{label}', valueArray[valueArray.length - 1][this.props.labelKey])}\n\t\t\t\t</span>\n\t\t\t);\n\t\t}\n\n\t\treturn (\n\t\t\t<div ref={ref => this.wrapper = ref}\n\t\t\t\t className={className}\n\t\t\t\t style={this.props.wrapperStyle}>\n\t\t\t\t{this.renderHiddenField(valueArray)}\n\t\t\t\t<div ref={ref => this.control = ref}\n\t\t\t\t\tclassName=\"Select-control\"\n\t\t\t\t\tstyle={this.props.style}\n\t\t\t\t\tonKeyDown={this.handleKeyDown}\n\t\t\t\t\tonMouseDown={this.handleMouseDown}\n\t\t\t\t\tonTouchEnd={this.handleTouchEnd}\n\t\t\t\t\tonTouchStart={this.handleTouchStart}\n\t\t\t\t\tonTouchMove={this.handleTouchMove}\n\t\t\t\t>\n\t\t\t\t\t<span className=\"Select-multi-value-wrapper\" id={this._instancePrefix + '-value'}>\n\t\t\t\t\t\t{this.renderValue(valueArray, isOpen)}\n\t\t\t\t\t\t{this.renderInput(valueArray, focusedOptionIndex)}\n\t\t\t\t\t</span>\n\t\t\t\t\t{removeMessage}\n\t\t\t\t\t{this.renderLoading()}\n\t\t\t\t\t{this.renderClear()}\n\t\t\t\t\t{this.renderArrow()}\n\t\t\t\t</div>\n\t\t\t\t{isOpen ? this.renderOuter(options, !this.props.multi ? valueArray : null, focusedOption) : null}\n\t\t\t</div>\n\t\t);\n\t}\n\n});\n\nexport default Select;\n"]} +//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","/Users/SVITY/www/github/react-select/src/Async.js","/Users/SVITY/www/github/react-select/src/AsyncCreatable.js","/Users/SVITY/www/github/react-select/src/Creatable.js","/Users/SVITY/www/github/react-select/src/Option.js","/Users/SVITY/www/github/react-select/src/Value.js","/Users/SVITY/www/github/react-select/src/utils/defaultArrowRenderer.js","/Users/SVITY/www/github/react-select/src/utils/defaultFilterOptions.js","/Users/SVITY/www/github/react-select/src/utils/defaultMenuRenderer.js","/Users/SVITY/www/github/react-select/src/utils/stripDiacritics.js","/Users/SVITY/www/github/react-select/src/Select.js"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","import React, { Component, PropTypes } from 'react';\nimport Select from './Select';\nimport stripDiacritics from './utils/stripDiacritics';\n\nconst propTypes = {\n\tautoload: React.PropTypes.bool.isRequired,       // automatically call the `loadOptions` prop on-mount; defaults to true\n\tcache: React.PropTypes.any,                      // object to use to cache results; set to null/false to disable caching\n\tchildren: React.PropTypes.func.isRequired,       // Child function responsible for creating the inner Select component; (props: Object): PropTypes.element\n\tignoreAccents: React.PropTypes.bool,             // strip diacritics when filtering; defaults to true\n\tignoreCase: React.PropTypes.bool,                // perform case-insensitive filtering; defaults to true\n\tloadingPlaceholder: React.PropTypes.oneOfType([  // replaces the placeholder while options are loading\n\t\tReact.PropTypes.string,\n\t\tReact.PropTypes.node\n\t]),\n\tloadOptions: React.PropTypes.func.isRequired,    // callback to load options asynchronously; (inputValue: string, callback: Function): ?Promise\n\toptions: PropTypes.array.isRequired,             // array of options\n\tplaceholder: React.PropTypes.oneOfType([         // field placeholder, displayed when there's no value (shared with Select)\n\t\tReact.PropTypes.string,\n\t\tReact.PropTypes.node\n\t]),\n\tnoResultsText: React.PropTypes.oneOfType([       // field noResultsText, displayed when no options come back from the server\n\t\tReact.PropTypes.string,\n\t\tReact.PropTypes.node\n\t]),\n\tonChange: React.PropTypes.func,                  // onChange handler: function (newValue) {}\n\tsearchPromptText: React.PropTypes.oneOfType([    // label to prompt for search input\n\t\tReact.PropTypes.string,\n\t\tReact.PropTypes.node\n\t]),\n\tonInputChange: React.PropTypes.func,             // optional for keeping track of what is being typed\n\tvalue: React.PropTypes.any,                      // initial field value\n};\n\nconst defaultCache = {};\n\nconst defaultProps = {\n\tautoload: true,\n\tcache: defaultCache,\n\tchildren: defaultChildren,\n\tignoreAccents: true,\n\tignoreCase: true,\n\tloadingPlaceholder: 'Loading...',\n\toptions: [],\n\tsearchPromptText: 'Type to search',\n};\n\nexport default class Async extends Component {\n\tconstructor (props, context) {\n\t\tsuper(props, context);\n\n\t\tthis._cache = props.cache === defaultCache ? {} : props.cache;\n\n\t\tthis.state = {\n\t\t\tisLoading: false,\n\t\t\toptions: props.options,\n\t\t};\n\n\t\tthis._onInputChange = this._onInputChange.bind(this);\n\t}\n\n\tcomponentDidMount () {\n\t\tconst { autoload } = this.props;\n\n\t\tif (autoload) {\n\t\t\tthis.loadOptions('');\n\t\t}\n\t}\n\n\tcomponentWillUpdate (nextProps, nextState) {\n\t\tconst propertiesToSync = ['options'];\n\t\tpropertiesToSync.forEach((prop) => {\n\t\t\tif (this.props[prop] !== nextProps[prop]) {\n\t\t\t\tthis.setState({\n\t\t\t\t\t[prop]: nextProps[prop]\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t}\n\n\tclearOptions() {\n\t\tthis.setState({ options: [] });\n\t}\n\n\tloadOptions (inputValue) {\n\t\tconst { loadOptions } = this.props;\n\t\tconst cache = this._cache;\n\n\t\tif (\n\t\t\tcache &&\n\t\t\tcache.hasOwnProperty(inputValue)\n\t\t) {\n\t\t\tthis.setState({\n\t\t\t\toptions: cache[inputValue]\n\t\t\t});\n\n\t\t\treturn;\n\t\t}\n\n\t\tconst callback = (error, data) => {\n\t\t\tif (callback === this._callback) {\n\t\t\t\tthis._callback = null;\n\n\t\t\t\tconst options = data && data.options || [];\n\n\t\t\t\tif (cache) {\n\t\t\t\t\tcache[inputValue] = options;\n\t\t\t\t}\n\n\t\t\t\tthis.setState({\n\t\t\t\t\tisLoading: false,\n\t\t\t\t\toptions\n\t\t\t\t});\n\t\t\t}\n\t\t};\n\n\t\t// Ignore all but the most recent request\n\t\tthis._callback = callback;\n\n\t\tconst promise = loadOptions(inputValue, callback);\n\t\tif (promise) {\n\t\t\tpromise.then(\n\t\t\t\t(data) => callback(null, data),\n\t\t\t\t(error) => callback(error)\n\t\t\t);\n\t\t}\n\n\t\tif (\n\t\t\tthis._callback &&\n\t\t\t!this.state.isLoading\n\t\t) {\n\t\t\tthis.setState({\n\t\t\t\tisLoading: true\n\t\t\t});\n\t\t}\n\n\t\treturn inputValue;\n\t}\n\n\t_onInputChange (inputValue) {\n\t\tconst { ignoreAccents, ignoreCase, onInputChange } = this.props;\n\n\t\tif (ignoreAccents) {\n\t\t\tinputValue = stripDiacritics(inputValue);\n\t\t}\n\n\t\tif (ignoreCase) {\n\t\t\tinputValue = inputValue.toLowerCase();\n\t\t}\n\n\t\tif (onInputChange) {\n\t\t\tonInputChange(inputValue);\n\t\t}\n\n\t\treturn this.loadOptions(inputValue);\n\t}\n\n\tinputValue() {\n\t\tif (this.select) {\n\t\t\treturn this.select.state.inputValue;\n\t\t}\n\t\treturn '';\n\t}\n\n\tnoResultsText() {\n\t\tconst { loadingPlaceholder, noResultsText, searchPromptText } = this.props;\n\t\tconst { isLoading } = this.state;\n\n\t\tconst inputValue = this.inputValue();\n\n\t\tif (isLoading) {\n\t\t\treturn loadingPlaceholder;\n\t\t}\n\t\tif (inputValue && noResultsText) {\n\t\t\treturn noResultsText;\n\t\t}\n\t\treturn searchPromptText;\n\t}\n\n\trender () {\n\t\tconst { children, loadingPlaceholder, placeholder } = this.props;\n\t\tconst { isLoading, options } = this.state;\n\n\t\tconst props = {\n\t\t\tnoResultsText: this.noResultsText(),\n\t\t\tplaceholder: isLoading ? loadingPlaceholder : placeholder,\n\t\t\toptions: (isLoading && loadingPlaceholder) ? [] : options,\n\t\t\tref: (ref) => (this.select = ref),\n\t\t\tonChange: (newValues) => {\n\t\t\t\tif (this.props.value && (newValues.length > this.props.value.length)) {\n\t\t\t\t\tthis.clearOptions();\n\t\t\t\t}\n\t\t\t\tthis.props.onChange(newValues);\n\t\t\t}\n\t\t};\n\n\t\treturn children({\n\t\t\t...this.props,\n\t\t\t...props,\n\t\t\tisLoading,\n\t\t\tonInputChange: this._onInputChange\n\t\t});\n\t}\n}\n\nAsync.propTypes = propTypes;\nAsync.defaultProps = defaultProps;\n\nfunction defaultChildren (props) {\n\treturn (\n\t\t<Select {...props} />\n\t);\n};\n","import React from 'react';\nimport Select from './Select';\n\nfunction reduce(obj, props = {}){\n  return Object.keys(obj)\n  .reduce((props, key) => {\n    const value = obj[key];\n    if (value !== undefined) props[key] = value;\n    return props;\n  }, props);\n}\n\nconst AsyncCreatable = React.createClass({\n\tdisplayName: 'AsyncCreatableSelect',\n\n\trender () {\n\t\treturn (\n\t\t\t<Select.Async {...this.props}>\n\t\t\t\t{(asyncProps) => (\n\t\t\t\t\t<Select.Creatable {...this.props}>\n\t\t\t\t\t\t{(creatableProps) => (\n\t\t\t\t\t\t\t<Select\n\t\t\t\t\t\t\t\t{...reduce(asyncProps, reduce(creatableProps, {}))}\n\t\t\t\t\t\t\t\tonInputChange={(input) => {\n\t\t\t\t\t\t\t\t\tcreatableProps.onInputChange(input);\n\t\t\t\t\t\t\t\t\treturn asyncProps.onInputChange(input);\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\tref={(ref) => {\n\t\t\t\t\t\t\t\t\tcreatableProps.ref(ref);\n\t\t\t\t\t\t\t\t\tasyncProps.ref(ref);\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t)}\n\t\t\t\t\t</Select.Creatable>\n\t\t\t\t)}\n\t\t\t</Select.Async>\n\t\t);\n\t}\n});\n\nmodule.exports = AsyncCreatable;\n","import React from 'react';\nimport Select from './Select';\nimport defaultFilterOptions from './utils/defaultFilterOptions';\nimport defaultMenuRenderer from './utils/defaultMenuRenderer';\n\nconst Creatable = React.createClass({\n\tdisplayName: 'CreatableSelect',\n\n\tpropTypes: {\n\t\t// Child function responsible for creating the inner Select component\n\t\t// This component can be used to compose HOCs (eg Creatable and Async)\n\t\t// (props: Object): PropTypes.element\n\t\tchildren: React.PropTypes.func,\n\n\t\t// See Select.propTypes.filterOptions\n\t\tfilterOptions: React.PropTypes.any,\n\n\t\t// Searches for any matching option within the set of options.\n\t\t// This function prevents duplicate options from being created.\n\t\t// ({ option: Object, options: Array, labelKey: string, valueKey: string }): boolean\n\t\tisOptionUnique: React.PropTypes.func,\n\n    // Determines if the current input text represents a valid option.\n    // ({ label: string }): boolean\n    isValidNewOption: React.PropTypes.func,\n\n\t\t// See Select.propTypes.menuRenderer\n\t\tmenuRenderer: React.PropTypes.any,\n\n    // Factory to create new option.\n    // ({ label: string, labelKey: string, valueKey: string }): Object\n\t\tnewOptionCreator: React.PropTypes.func,\n\n\t\t// input change handler: function (inputValue) {}\n\t\tonInputChange: React.PropTypes.func,\n\n\t\t// input keyDown handler: function (event) {}\n\t\tonInputKeyDown: React.PropTypes.func,\n\n\t\t// new option click handler: function (option) {}\n\t\tonNewOptionClick: React.PropTypes.func,\n\n\t\t// See Select.propTypes.options\n\t\toptions: React.PropTypes.array,\n\n    // Creates prompt/placeholder option text.\n    // (filterText: string): string\n\t\tpromptTextCreator: React.PropTypes.func,\n\n\t\t// Decides if a keyDown event (eg its `keyCode`) should result in the creation of a new option.\n\t\tshouldKeyDownEventCreateNewOption: React.PropTypes.func,\n\t},\n\n\t// Default prop methods\n\tstatics: {\n\t\tisOptionUnique,\n\t\tisValidNewOption,\n\t\tnewOptionCreator,\n\t\tpromptTextCreator,\n\t\tshouldKeyDownEventCreateNewOption\n\t},\n\n\tgetDefaultProps () {\n\t\treturn {\n\t\t\tfilterOptions: defaultFilterOptions,\n\t\t\tisOptionUnique,\n\t\t\tisValidNewOption,\n\t\t\tmenuRenderer: defaultMenuRenderer,\n\t\t\tnewOptionCreator,\n\t\t\tpromptTextCreator,\n\t\t\tshouldKeyDownEventCreateNewOption,\n\t\t};\n\t},\n\n\tcreateNewOption () {\n\t\tconst {\n\t\t\tisValidNewOption,\n\t\t\tnewOptionCreator,\n\t\t\tonNewOptionClick,\n\t\t\toptions = [],\n\t\t\tshouldKeyDownEventCreateNewOption\n\t\t} = this.props;\n\n\t\tif (isValidNewOption({ label: this.inputValue })) {\n\t\t\tconst option = newOptionCreator({ label: this.inputValue, labelKey: this.labelKey, valueKey: this.valueKey });\n\t\t\tconst isOptionUnique = this.isOptionUnique({ option });\n\n\t\t\t// Don't add the same option twice.\n\t\t\tif (isOptionUnique) {\n\t\t\t\tif (onNewOptionClick) {\n\t\t\t\t\tonNewOptionClick(option);\n\t\t\t\t} else {\n\t\t\t\t\toptions.unshift(option);\n\n\t\t\t\t\tthis.select.selectValue(option);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\n\tfilterOptions (...params) {\n\t\tconst { filterOptions, isValidNewOption, options, promptTextCreator } = this.props;\n\n\t\t// TRICKY Check currently selected options as well.\n\t\t// Don't display a create-prompt for a value that's selected.\n\t\t// This covers async edge-cases where a newly-created Option isn't yet in the async-loaded array.\n\t\tconst excludeOptions = params[2] || [];\n\n\t\tconst filteredOptions = filterOptions(...params) || [];\n\n\t\tif (isValidNewOption({ label: this.inputValue })) {\n\t\t\tconst { newOptionCreator } = this.props;\n\n\t\t\tconst option = newOptionCreator({\n\t\t\t\tlabel: this.inputValue,\n\t\t\t\tlabelKey: this.labelKey,\n\t\t\t\tvalueKey: this.valueKey\n\t\t\t});\n\n\t\t\t// TRICKY Compare to all options (not just filtered options) in case option has already been selected).\n\t\t\t// For multi-selects, this would remove it from the filtered list.\n\t\t\tconst isOptionUnique = this.isOptionUnique({\n\t\t\t\toption,\n\t\t\t\toptions: excludeOptions.concat(filteredOptions)\n\t\t\t});\n\n\t\t\tif (isOptionUnique) {\n\t\t\t\tconst prompt = promptTextCreator(this.inputValue);\n\n\t\t\t\tthis._createPlaceholderOption = newOptionCreator({\n\t\t\t\t\tlabel: prompt,\n\t\t\t\t\tlabelKey: this.labelKey,\n\t\t\t\t\tvalueKey: this.valueKey\n\t\t\t\t});\n\n\t\t\t\tfilteredOptions.unshift(this._createPlaceholderOption);\n\t\t\t}\n\t\t}\n\n\t\treturn filteredOptions;\n\t},\n\n\tisOptionUnique ({\n\t\toption,\n\t\toptions\n\t}) {\n\t\tconst { isOptionUnique } = this.props;\n\n\t\toptions = options || this.select.filterOptions();\n\n\t\treturn isOptionUnique({\n\t\t\tlabelKey: this.labelKey,\n\t\t\toption,\n\t\t\toptions,\n\t\t\tvalueKey: this.valueKey\n\t\t});\n\t},\n\n\tmenuRenderer (params) {\n\t\tconst { menuRenderer } = this.props;\n\n\t\treturn menuRenderer({\n\t\t\t...params,\n\t\t\tonSelect: this.onOptionSelect,\n\t\t\tselectValue: this.onOptionSelect\n\t\t});\n\t},\n\n\tonInputChange (input) {\n\t\tconst { onInputChange } = this.props;\n\n\t\tif (onInputChange) {\n\t\t\tonInputChange(input);\n\t\t}\n\n\t\t// This value may be needed in between Select mounts (when this.select is null)\n\t\tthis.inputValue = input;\n\t},\n\n\tonInputKeyDown (event) {\n\t\tconst { shouldKeyDownEventCreateNewOption, onInputKeyDown } = this.props;\n\t\tconst focusedOption = this.select.getFocusedOption();\n\n\t\tif (\n\t\t\tfocusedOption &&\n\t\t\tfocusedOption === this._createPlaceholderOption &&\n\t\t\tshouldKeyDownEventCreateNewOption({ keyCode: event.keyCode })\n\t\t) {\n\t\t\tthis.createNewOption();\n\n\t\t\t// Prevent decorated Select from doing anything additional with this keyDown event\n\t\t\tevent.preventDefault();\n\t\t} else if (onInputKeyDown) {\n\t\t\tonInputKeyDown(event);\n\t\t}\n\t},\n\n\tonOptionSelect (option, event) {\n\t\tif (option === this._createPlaceholderOption) {\n\t\t\tthis.createNewOption();\n\t\t} else {\n\t\t\tthis.select.selectValue(option);\n\t\t}\n\t},\n\n\trender () {\n\t\tconst {\n\t\t\tchildren = defaultChildren,\n\t\t\tnewOptionCreator,\n\t\t\tshouldKeyDownEventCreateNewOption,\n\t\t\t...restProps\n\t\t} = this.props;\n\n\t\tconst props = {\n\t\t\t...restProps,\n\t\t\tallowCreate: true,\n\t\t\tfilterOptions: this.filterOptions,\n\t\t\tmenuRenderer: this.menuRenderer,\n\t\t\tonInputChange: this.onInputChange,\n\t\t\tonInputKeyDown: this.onInputKeyDown,\n\t\t\tref: (ref) => {\n\t\t\t\tthis.select = ref;\n\n\t\t\t\t// These values may be needed in between Select mounts (when this.select is null)\n\t\t\t\tif (ref) {\n\t\t\t\t\tthis.labelKey = ref.props.labelKey;\n\t\t\t\t\tthis.valueKey = ref.props.valueKey;\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\treturn children(props);\n\t}\n});\n\nfunction defaultChildren (props) {\n\treturn (\n\t\t<Select {...props} />\n\t);\n};\n\nfunction isOptionUnique ({ option, options, labelKey, valueKey }) {\n\treturn options\n\t\t.filter((existingOption) =>\n\t\t\texistingOption[labelKey] === option[labelKey] ||\n\t\t\texistingOption[valueKey] === option[valueKey]\n\t\t)\n\t\t.length === 0;\n};\n\nfunction isValidNewOption ({ label }) {\n\treturn !!label;\n};\n\nfunction newOptionCreator ({ label, labelKey, valueKey }) {\n\tconst option = {};\n\toption[valueKey] = label;\n \toption[labelKey] = label;\n \toption.className = 'Select-create-option-placeholder';\n \treturn option;\n};\n\nfunction promptTextCreator (label) {\n\treturn `Create option \"${label}\"`;\n}\n\nfunction shouldKeyDownEventCreateNewOption ({ keyCode }) {\n\tswitch (keyCode) {\n\t\tcase 9:   // TAB\n\t\tcase 13:  // ENTER\n\t\tcase 188: // COMMA\n\t\t\treturn true;\n\t}\n\n\treturn false;\n};\n\nmodule.exports = Creatable;\n","import React from 'react';\nimport classNames from 'classnames';\n\nconst Option = React.createClass({\n\tpropTypes: {\n\t\tchildren: React.PropTypes.node,\n\t\tclassName: React.PropTypes.string,             // className (based on mouse position)\n\t\tinstancePrefix: React.PropTypes.string.isRequired,  // unique prefix for the ids (used for aria)\n\t\tisDisabled: React.PropTypes.bool,              // the option is disabled\n\t\tisFocused: React.PropTypes.bool,               // the option is focused\n\t\tisSelected: React.PropTypes.bool,              // the option is selected\n\t\tonFocus: React.PropTypes.func,                 // method to handle mouseEnter on option element\n\t\tonSelect: React.PropTypes.func,                // method to handle click on option element\n\t\tonUnfocus: React.PropTypes.func,               // method to handle mouseLeave on option element\n\t\toption: React.PropTypes.object.isRequired,     // object that is base for that option\n\t\toptionIndex: React.PropTypes.number,           // index of the option, used to generate unique ids for aria\n\t},\n\tblockEvent (event) {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\tif ((event.target.tagName !== 'A') || !('href' in event.target)) {\n\t\t\treturn;\n\t\t}\n\t\tif (event.target.target) {\n\t\t\twindow.open(event.target.href, event.target.target);\n\t\t} else {\n\t\t\twindow.location.href = event.target.href;\n\t\t}\n\t},\n\n\thandleMouseDown (event) {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\tthis.props.onSelect(this.props.option, event);\n\t},\n\n\thandleMouseEnter (event) {\n\t\tthis.onFocus(event);\n\t},\n\n\thandleMouseMove (event) {\n\t\tthis.onFocus(event);\n\t},\n\n\thandleTouchEnd(event){\n\t\t// Check if the view is being dragged, In this case\n\t\t// we don't want to fire the click event (because the user only wants to scroll)\n\t\tif(this.dragging) return;\n\n\t\tthis.handleMouseDown(event);\n\t},\n\n\thandleTouchMove (event) {\n\t\t// Set a flag that the view is being dragged\n\t\tthis.dragging = true;\n\t},\n\n\thandleTouchStart (event) {\n\t\t// Set a flag that the view is not being dragged\n\t\tthis.dragging = false;\n\t},\n\n\tonFocus (event) {\n\t\tif (!this.props.isFocused) {\n\t\t\tthis.props.onFocus(this.props.option, event);\n\t\t}\n\t},\n\trender () {\n\t\tvar { option, instancePrefix, optionIndex } = this.props;\n\t\tvar className = classNames(this.props.className, option.className);\n\n\t\treturn option.disabled ? (\n\t\t\t<div className={className}\n\t\t\t\tonMouseDown={this.blockEvent}\n\t\t\t\tonClick={this.blockEvent}>\n\t\t\t\t{this.props.children}\n\t\t\t</div>\n\t\t) : (\n\t\t\t<div className={className}\n\t\t\t\tstyle={option.style}\n\t\t\t\trole=\"option\"\n\t\t\t\t onMouseDown={this.handleMouseDown}\n\t\t\t\tonMouseEnter={this.handleMouseEnter}\n\t\t\t\tonMouseMove={this.handleMouseMove}\n\t\t\t\tonTouchStart={this.handleTouchStart}\n\t\t\t\tonTouchMove={this.handleTouchMove}\n\t\t\t\tonTouchEnd={this.handleTouchEnd}\n\t\t\t\tid={instancePrefix + '-option-' + optionIndex}\n\t\t\t\ttitle={option.title}>\n\t\t\t\t{this.props.children}\n\t\t\t</div>\n\t\t);\n\t}\n});\n\nmodule.exports = Option;\n","import React from 'react';\nimport classNames from 'classnames';\n\nconst Value = React.createClass({\n\n\tdisplayName: 'Value',\n\n\tpropTypes: {\n\t\tchildren: React.PropTypes.node,\n\t\tdisabled: React.PropTypes.bool,               // disabled prop passed to ReactSelect\n\t\tid: React.PropTypes.string,                   // Unique id for the value - used for aria\n\t\tonClick: React.PropTypes.func,                // method to handle click on value label\n\t\tonRemove: React.PropTypes.func,               // method to handle removal of the value\n\t\tvalue: React.PropTypes.object.isRequired,     // the option object for this value\n\t},\n\n\thandleMouseDown (event) {\n\t\tif (event.type === 'mousedown' && event.button !== 0) {\n\t\t\treturn;\n\t\t}\n\t\tif (this.props.onClick) {\n\t\t\tevent.stopPropagation();\n\t\t\tthis.props.onClick(this.props.value, event);\n\t\t\treturn;\n\t\t}\n\t\tif (this.props.value.href) {\n\t\t\tevent.stopPropagation();\n\t\t}\n\t},\n\n\tonRemove (event) {\n\t\tevent.preventDefault();\n\t\tevent.stopPropagation();\n\t\tthis.props.onRemove(this.props.value);\n\t},\n\n\thandleTouchEndRemove (event){\n\t\t// Check if the view is being dragged, In this case\n\t\t// we don't want to fire the click event (because the user only wants to scroll)\n\t\tif(this.dragging) return;\n\n\t\t// Fire the mouse events\n\t\tthis.onRemove(event);\n\t},\n\n\thandleTouchMove (event) {\n\t\t// Set a flag that the view is being dragged\n\t\tthis.dragging = true;\n\t},\n\n\thandleTouchStart (event) {\n\t\t// Set a flag that the view is not being dragged\n\t\tthis.dragging = false;\n\t},\n\n\trenderRemoveIcon () {\n\t\tif (this.props.disabled || !this.props.onRemove) return;\n\t\treturn (\n\t\t\t<span className=\"Select-value-icon\"\n\t\t\t\taria-hidden=\"true\"\n\t\t\t\tonMouseDown={this.onRemove}\n\t\t\t\tonTouchEnd={this.handleTouchEndRemove}\n\t\t\t\tonTouchStart={this.handleTouchStart}\n\t\t\t\tonTouchMove={this.handleTouchMove}>\n\t\t\t\t&times;\n\t\t\t</span>\n\t\t);\n\t},\n\n\trenderLabel () {\n\t\tlet className = 'Select-value-label';\n\t\treturn this.props.onClick || this.props.value.href ? (\n\t\t\t<a className={className} href={this.props.value.href} target={this.props.value.target} onMouseDown={this.handleMouseDown} onTouchEnd={this.handleMouseDown}>\n\t\t\t\t{this.props.children}\n\t\t\t</a>\n\t\t) : (\n\t\t\t<span className={className} role=\"option\" aria-selected=\"true\" id={this.props.id}>\n\t\t\t\t{this.props.children}\n\t\t\t</span>\n\t\t);\n\t},\n\n\trender () {\n\t\treturn (\n\t\t\t<div className={classNames('Select-value', this.props.value.className)}\n\t\t\t\tstyle={this.props.value.style}\n\t\t\t\ttitle={this.props.value.title}\n\t\t\t\t>\n\t\t\t\t{this.renderRemoveIcon()}\n\t\t\t\t{this.renderLabel()}\n\t\t\t</div>\n\t\t);\n\t}\n\n});\n\nmodule.exports = Value;\n","import React from 'react';\n\nexport default function arrowRenderer ({ onMouseDown }) {\n\treturn (\n\t\t<span\n\t\t\tclassName=\"Select-arrow\"\n\t\t\tonMouseDown={onMouseDown}\n\t\t/>\n\t);\n};\n","import stripDiacritics from './stripDiacritics';\n\nfunction filterOptions (options, filterValue, excludeOptions, props) {\n\tif (props.ignoreAccents) {\n\t\tfilterValue = stripDiacritics(filterValue);\n\t}\n\n\tif (props.ignoreCase) {\n\t\tfilterValue = filterValue.toLowerCase();\n\t}\n\n\tif (excludeOptions) excludeOptions = excludeOptions.map(i => i[props.valueKey]);\n\n\treturn options.filter(option => {\n\t\tif (excludeOptions && excludeOptions.indexOf(option[props.valueKey]) > -1) return false;\n\t\tif (props.filterOption) return props.filterOption.call(this, option, filterValue);\n\t\tif (!filterValue) return true;\n\t\tvar valueTest = String(option[props.valueKey]);\n\t\tvar labelTest = String(option[props.labelKey]);\n\t\tif (props.ignoreAccents) {\n\t\t\tif (props.matchProp !== 'label') valueTest = stripDiacritics(valueTest);\n\t\t\tif (props.matchProp !== 'value') labelTest = stripDiacritics(labelTest);\n\t\t}\n\t\tif (props.ignoreCase) {\n\t\t\tif (props.matchProp !== 'label') valueTest = valueTest.toLowerCase();\n\t\t\tif (props.matchProp !== 'value') labelTest = labelTest.toLowerCase();\n\t\t}\n\t\treturn props.matchPos === 'start' ? (\n\t\t\t(props.matchProp !== 'label' && valueTest.substr(0, filterValue.length) === filterValue) ||\n\t\t\t(props.matchProp !== 'value' && labelTest.substr(0, filterValue.length) === filterValue)\n\t\t) : (\n\t\t\t(props.matchProp !== 'label' && valueTest.indexOf(filterValue) >= 0) ||\n\t\t\t(props.matchProp !== 'value' && labelTest.indexOf(filterValue) >= 0)\n\t\t);\n\t});\n}\n\nmodule.exports = filterOptions;\n","import classNames from 'classnames';\nimport React from 'react';\n\nfunction menuRenderer ({\n\tfocusedOption,\n\tinstancePrefix,\n\tlabelKey,\n\tonFocus,\n\tonSelect,\n\toptionClassName,\n\toptionComponent,\n\toptionRenderer,\n\toptions,\n\tvalueArray,\n\tvalueKey,\n\tonOptionRef\n}) {\n\tlet Option = optionComponent;\n\n\treturn options.map((option, i) => {\n\t\tlet isSelected = valueArray && valueArray.indexOf(option) > -1;\n\t\tlet isFocused = option === focusedOption;\n\t\tlet optionClass = classNames(optionClassName, {\n\t\t\t'Select-option': true,\n\t\t\t'is-selected': isSelected,\n\t\t\t'is-focused': isFocused,\n\t\t\t'is-disabled': option.disabled,\n\t\t});\n\n\t\treturn (\n\t\t\t<Option\n\t\t\t\tclassName={optionClass}\n\t\t\t\tinstancePrefix={instancePrefix}\n\t\t\t\tisDisabled={option.disabled}\n\t\t\t\tisFocused={isFocused}\n\t\t\t\tisSelected={isSelected}\n\t\t\t\tkey={`option-${i}-${option[valueKey]}`}\n\t\t\t\tonFocus={onFocus}\n\t\t\t\tonSelect={onSelect}\n\t\t\t\toption={option}\n\t\t\t\toptionIndex={i}\n\t\t\t\tref={ref => { onOptionRef(ref, isFocused); }}\n\t\t\t>\n\t\t\t\t{optionRenderer(option, i)}\n\t\t\t</Option>\n\t\t);\n\t});\n}\n\nmodule.exports = menuRenderer;\n","var map = [\n\t{ 'base':'A', 'letters':/[\\u0041\\u24B6\\uFF21\\u00C0\\u00C1\\u00C2\\u1EA6\\u1EA4\\u1EAA\\u1EA8\\u00C3\\u0100\\u0102\\u1EB0\\u1EAE\\u1EB4\\u1EB2\\u0226\\u01E0\\u00C4\\u01DE\\u1EA2\\u00C5\\u01FA\\u01CD\\u0200\\u0202\\u1EA0\\u1EAC\\u1EB6\\u1E00\\u0104\\u023A\\u2C6F]/g },\n\t{ 'base':'AA','letters':/[\\uA732]/g },\n\t{ 'base':'AE','letters':/[\\u00C6\\u01FC\\u01E2]/g },\n\t{ 'base':'AO','letters':/[\\uA734]/g },\n\t{ 'base':'AU','letters':/[\\uA736]/g },\n\t{ 'base':'AV','letters':/[\\uA738\\uA73A]/g },\n\t{ 'base':'AY','letters':/[\\uA73C]/g },\n\t{ 'base':'B', 'letters':/[\\u0042\\u24B7\\uFF22\\u1E02\\u1E04\\u1E06\\u0243\\u0182\\u0181]/g },\n\t{ 'base':'C', 'letters':/[\\u0043\\u24B8\\uFF23\\u0106\\u0108\\u010A\\u010C\\u00C7\\u1E08\\u0187\\u023B\\uA73E]/g },\n\t{ 'base':'D', 'letters':/[\\u0044\\u24B9\\uFF24\\u1E0A\\u010E\\u1E0C\\u1E10\\u1E12\\u1E0E\\u0110\\u018B\\u018A\\u0189\\uA779]/g },\n\t{ 'base':'DZ','letters':/[\\u01F1\\u01C4]/g },\n\t{ 'base':'Dz','letters':/[\\u01F2\\u01C5]/g },\n\t{ 'base':'E', 'letters':/[\\u0045\\u24BA\\uFF25\\u00C8\\u00C9\\u00CA\\u1EC0\\u1EBE\\u1EC4\\u1EC2\\u1EBC\\u0112\\u1E14\\u1E16\\u0114\\u0116\\u00CB\\u1EBA\\u011A\\u0204\\u0206\\u1EB8\\u1EC6\\u0228\\u1E1C\\u0118\\u1E18\\u1E1A\\u0190\\u018E]/g },\n\t{ 'base':'F', 'letters':/[\\u0046\\u24BB\\uFF26\\u1E1E\\u0191\\uA77B]/g },\n\t{ 'base':'G', 'letters':/[\\u0047\\u24BC\\uFF27\\u01F4\\u011C\\u1E20\\u011E\\u0120\\u01E6\\u0122\\u01E4\\u0193\\uA7A0\\uA77D\\uA77E]/g },\n\t{ 'base':'H', 'letters':/[\\u0048\\u24BD\\uFF28\\u0124\\u1E22\\u1E26\\u021E\\u1E24\\u1E28\\u1E2A\\u0126\\u2C67\\u2C75\\uA78D]/g },\n\t{ 'base':'I', 'letters':/[\\u0049\\u24BE\\uFF29\\u00CC\\u00CD\\u00CE\\u0128\\u012A\\u012C\\u0130\\u00CF\\u1E2E\\u1EC8\\u01CF\\u0208\\u020A\\u1ECA\\u012E\\u1E2C\\u0197]/g },\n\t{ 'base':'J', 'letters':/[\\u004A\\u24BF\\uFF2A\\u0134\\u0248]/g },\n\t{ 'base':'K', 'letters':/[\\u004B\\u24C0\\uFF2B\\u1E30\\u01E8\\u1E32\\u0136\\u1E34\\u0198\\u2C69\\uA740\\uA742\\uA744\\uA7A2]/g },\n\t{ 'base':'L', 'letters':/[\\u004C\\u24C1\\uFF2C\\u013F\\u0139\\u013D\\u1E36\\u1E38\\u013B\\u1E3C\\u1E3A\\u0141\\u023D\\u2C62\\u2C60\\uA748\\uA746\\uA780]/g },\n\t{ 'base':'LJ','letters':/[\\u01C7]/g },\n\t{ 'base':'Lj','letters':/[\\u01C8]/g },\n\t{ 'base':'M', 'letters':/[\\u004D\\u24C2\\uFF2D\\u1E3E\\u1E40\\u1E42\\u2C6E\\u019C]/g },\n\t{ 'base':'N', 'letters':/[\\u004E\\u24C3\\uFF2E\\u01F8\\u0143\\u00D1\\u1E44\\u0147\\u1E46\\u0145\\u1E4A\\u1E48\\u0220\\u019D\\uA790\\uA7A4]/g },\n\t{ 'base':'NJ','letters':/[\\u01CA]/g },\n\t{ 'base':'Nj','letters':/[\\u01CB]/g },\n\t{ 'base':'O', 'letters':/[\\u004F\\u24C4\\uFF2F\\u00D2\\u00D3\\u00D4\\u1ED2\\u1ED0\\u1ED6\\u1ED4\\u00D5\\u1E4C\\u022C\\u1E4E\\u014C\\u1E50\\u1E52\\u014E\\u022E\\u0230\\u00D6\\u022A\\u1ECE\\u0150\\u01D1\\u020C\\u020E\\u01A0\\u1EDC\\u1EDA\\u1EE0\\u1EDE\\u1EE2\\u1ECC\\u1ED8\\u01EA\\u01EC\\u00D8\\u01FE\\u0186\\u019F\\uA74A\\uA74C]/g },\n\t{ 'base':'OI','letters':/[\\u01A2]/g },\n\t{ 'base':'OO','letters':/[\\uA74E]/g },\n\t{ 'base':'OU','letters':/[\\u0222]/g },\n\t{ 'base':'P', 'letters':/[\\u0050\\u24C5\\uFF30\\u1E54\\u1E56\\u01A4\\u2C63\\uA750\\uA752\\uA754]/g },\n\t{ 'base':'Q', 'letters':/[\\u0051\\u24C6\\uFF31\\uA756\\uA758\\u024A]/g },\n\t{ 'base':'R', 'letters':/[\\u0052\\u24C7\\uFF32\\u0154\\u1E58\\u0158\\u0210\\u0212\\u1E5A\\u1E5C\\u0156\\u1E5E\\u024C\\u2C64\\uA75A\\uA7A6\\uA782]/g },\n\t{ 'base':'S', 'letters':/[\\u0053\\u24C8\\uFF33\\u1E9E\\u015A\\u1E64\\u015C\\u1E60\\u0160\\u1E66\\u1E62\\u1E68\\u0218\\u015E\\u2C7E\\uA7A8\\uA784]/g },\n\t{ 'base':'T', 'letters':/[\\u0054\\u24C9\\uFF34\\u1E6A\\u0164\\u1E6C\\u021A\\u0162\\u1E70\\u1E6E\\u0166\\u01AC\\u01AE\\u023E\\uA786]/g },\n\t{ 'base':'TZ','letters':/[\\uA728]/g },\n\t{ 'base':'U', 'letters':/[\\u0055\\u24CA\\uFF35\\u00D9\\u00DA\\u00DB\\u0168\\u1E78\\u016A\\u1E7A\\u016C\\u00DC\\u01DB\\u01D7\\u01D5\\u01D9\\u1EE6\\u016E\\u0170\\u01D3\\u0214\\u0216\\u01AF\\u1EEA\\u1EE8\\u1EEE\\u1EEC\\u1EF0\\u1EE4\\u1E72\\u0172\\u1E76\\u1E74\\u0244]/g },\n\t{ 'base':'V', 'letters':/[\\u0056\\u24CB\\uFF36\\u1E7C\\u1E7E\\u01B2\\uA75E\\u0245]/g },\n\t{ 'base':'VY','letters':/[\\uA760]/g },\n\t{ 'base':'W', 'letters':/[\\u0057\\u24CC\\uFF37\\u1E80\\u1E82\\u0174\\u1E86\\u1E84\\u1E88\\u2C72]/g },\n\t{ 'base':'X', 'letters':/[\\u0058\\u24CD\\uFF38\\u1E8A\\u1E8C]/g },\n\t{ 'base':'Y', 'letters':/[\\u0059\\u24CE\\uFF39\\u1EF2\\u00DD\\u0176\\u1EF8\\u0232\\u1E8E\\u0178\\u1EF6\\u1EF4\\u01B3\\u024E\\u1EFE]/g },\n\t{ 'base':'Z', 'letters':/[\\u005A\\u24CF\\uFF3A\\u0179\\u1E90\\u017B\\u017D\\u1E92\\u1E94\\u01B5\\u0224\\u2C7F\\u2C6B\\uA762]/g },\n\t{ 'base':'a', 'letters':/[\\u0061\\u24D0\\uFF41\\u1E9A\\u00E0\\u00E1\\u00E2\\u1EA7\\u1EA5\\u1EAB\\u1EA9\\u00E3\\u0101\\u0103\\u1EB1\\u1EAF\\u1EB5\\u1EB3\\u0227\\u01E1\\u00E4\\u01DF\\u1EA3\\u00E5\\u01FB\\u01CE\\u0201\\u0203\\u1EA1\\u1EAD\\u1EB7\\u1E01\\u0105\\u2C65\\u0250]/g },\n\t{ 'base':'aa','letters':/[\\uA733]/g },\n\t{ 'base':'ae','letters':/[\\u00E6\\u01FD\\u01E3]/g },\n\t{ 'base':'ao','letters':/[\\uA735]/g },\n\t{ 'base':'au','letters':/[\\uA737]/g },\n\t{ 'base':'av','letters':/[\\uA739\\uA73B]/g },\n\t{ 'base':'ay','letters':/[\\uA73D]/g },\n\t{ 'base':'b', 'letters':/[\\u0062\\u24D1\\uFF42\\u1E03\\u1E05\\u1E07\\u0180\\u0183\\u0253]/g },\n\t{ 'base':'c', 'letters':/[\\u0063\\u24D2\\uFF43\\u0107\\u0109\\u010B\\u010D\\u00E7\\u1E09\\u0188\\u023C\\uA73F\\u2184]/g },\n\t{ 'base':'d', 'letters':/[\\u0064\\u24D3\\uFF44\\u1E0B\\u010F\\u1E0D\\u1E11\\u1E13\\u1E0F\\u0111\\u018C\\u0256\\u0257\\uA77A]/g },\n\t{ 'base':'dz','letters':/[\\u01F3\\u01C6]/g },\n\t{ 'base':'e', 'letters':/[\\u0065\\u24D4\\uFF45\\u00E8\\u00E9\\u00EA\\u1EC1\\u1EBF\\u1EC5\\u1EC3\\u1EBD\\u0113\\u1E15\\u1E17\\u0115\\u0117\\u00EB\\u1EBB\\u011B\\u0205\\u0207\\u1EB9\\u1EC7\\u0229\\u1E1D\\u0119\\u1E19\\u1E1B\\u0247\\u025B\\u01DD]/g },\n\t{ 'base':'f', 'letters':/[\\u0066\\u24D5\\uFF46\\u1E1F\\u0192\\uA77C]/g },\n\t{ 'base':'g', 'letters':/[\\u0067\\u24D6\\uFF47\\u01F5\\u011D\\u1E21\\u011F\\u0121\\u01E7\\u0123\\u01E5\\u0260\\uA7A1\\u1D79\\uA77F]/g },\n\t{ 'base':'h', 'letters':/[\\u0068\\u24D7\\uFF48\\u0125\\u1E23\\u1E27\\u021F\\u1E25\\u1E29\\u1E2B\\u1E96\\u0127\\u2C68\\u2C76\\u0265]/g },\n\t{ 'base':'hv','letters':/[\\u0195]/g },\n\t{ 'base':'i', 'letters':/[\\u0069\\u24D8\\uFF49\\u00EC\\u00ED\\u00EE\\u0129\\u012B\\u012D\\u00EF\\u1E2F\\u1EC9\\u01D0\\u0209\\u020B\\u1ECB\\u012F\\u1E2D\\u0268\\u0131]/g },\n\t{ 'base':'j', 'letters':/[\\u006A\\u24D9\\uFF4A\\u0135\\u01F0\\u0249]/g },\n\t{ 'base':'k', 'letters':/[\\u006B\\u24DA\\uFF4B\\u1E31\\u01E9\\u1E33\\u0137\\u1E35\\u0199\\u2C6A\\uA741\\uA743\\uA745\\uA7A3]/g },\n\t{ 'base':'l', 'letters':/[\\u006C\\u24DB\\uFF4C\\u0140\\u013A\\u013E\\u1E37\\u1E39\\u013C\\u1E3D\\u1E3B\\u017F\\u0142\\u019A\\u026B\\u2C61\\uA749\\uA781\\uA747]/g },\n\t{ 'base':'lj','letters':/[\\u01C9]/g },\n\t{ 'base':'m', 'letters':/[\\u006D\\u24DC\\uFF4D\\u1E3F\\u1E41\\u1E43\\u0271\\u026F]/g },\n\t{ 'base':'n', 'letters':/[\\u006E\\u24DD\\uFF4E\\u01F9\\u0144\\u00F1\\u1E45\\u0148\\u1E47\\u0146\\u1E4B\\u1E49\\u019E\\u0272\\u0149\\uA791\\uA7A5]/g },\n\t{ 'base':'nj','letters':/[\\u01CC]/g },\n\t{ 'base':'o', 'letters':/[\\u006F\\u24DE\\uFF4F\\u00F2\\u00F3\\u00F4\\u1ED3\\u1ED1\\u1ED7\\u1ED5\\u00F5\\u1E4D\\u022D\\u1E4F\\u014D\\u1E51\\u1E53\\u014F\\u022F\\u0231\\u00F6\\u022B\\u1ECF\\u0151\\u01D2\\u020D\\u020F\\u01A1\\u1EDD\\u1EDB\\u1EE1\\u1EDF\\u1EE3\\u1ECD\\u1ED9\\u01EB\\u01ED\\u00F8\\u01FF\\u0254\\uA74B\\uA74D\\u0275]/g },\n\t{ 'base':'oi','letters':/[\\u01A3]/g },\n\t{ 'base':'ou','letters':/[\\u0223]/g },\n\t{ 'base':'oo','letters':/[\\uA74F]/g },\n\t{ 'base':'p', 'letters':/[\\u0070\\u24DF\\uFF50\\u1E55\\u1E57\\u01A5\\u1D7D\\uA751\\uA753\\uA755]/g },\n\t{ 'base':'q', 'letters':/[\\u0071\\u24E0\\uFF51\\u024B\\uA757\\uA759]/g },\n\t{ 'base':'r', 'letters':/[\\u0072\\u24E1\\uFF52\\u0155\\u1E59\\u0159\\u0211\\u0213\\u1E5B\\u1E5D\\u0157\\u1E5F\\u024D\\u027D\\uA75B\\uA7A7\\uA783]/g },\n\t{ 'base':'s', 'letters':/[\\u0073\\u24E2\\uFF53\\u00DF\\u015B\\u1E65\\u015D\\u1E61\\u0161\\u1E67\\u1E63\\u1E69\\u0219\\u015F\\u023F\\uA7A9\\uA785\\u1E9B]/g },\n\t{ 'base':'t', 'letters':/[\\u0074\\u24E3\\uFF54\\u1E6B\\u1E97\\u0165\\u1E6D\\u021B\\u0163\\u1E71\\u1E6F\\u0167\\u01AD\\u0288\\u2C66\\uA787]/g },\n\t{ 'base':'tz','letters':/[\\uA729]/g },\n\t{ 'base':'u', 'letters':/[\\u0075\\u24E4\\uFF55\\u00F9\\u00FA\\u00FB\\u0169\\u1E79\\u016B\\u1E7B\\u016D\\u00FC\\u01DC\\u01D8\\u01D6\\u01DA\\u1EE7\\u016F\\u0171\\u01D4\\u0215\\u0217\\u01B0\\u1EEB\\u1EE9\\u1EEF\\u1EED\\u1EF1\\u1EE5\\u1E73\\u0173\\u1E77\\u1E75\\u0289]/g },\n\t{ 'base':'v', 'letters':/[\\u0076\\u24E5\\uFF56\\u1E7D\\u1E7F\\u028B\\uA75F\\u028C]/g },\n\t{ 'base':'vy','letters':/[\\uA761]/g },\n\t{ 'base':'w', 'letters':/[\\u0077\\u24E6\\uFF57\\u1E81\\u1E83\\u0175\\u1E87\\u1E85\\u1E98\\u1E89\\u2C73]/g },\n\t{ 'base':'x', 'letters':/[\\u0078\\u24E7\\uFF58\\u1E8B\\u1E8D]/g },\n\t{ 'base':'y', 'letters':/[\\u0079\\u24E8\\uFF59\\u1EF3\\u00FD\\u0177\\u1EF9\\u0233\\u1E8F\\u00FF\\u1EF7\\u1E99\\u1EF5\\u01B4\\u024F\\u1EFF]/g },\n\t{ 'base':'z', 'letters':/[\\u007A\\u24E9\\uFF5A\\u017A\\u1E91\\u017C\\u017E\\u1E93\\u1E95\\u01B6\\u0225\\u0240\\u2C6C\\uA763]/g },\n];\n\nmodule.exports = function stripDiacritics (str) {\n\tfor (var i = 0; i < map.length; i++) {\n\t\tstr = str.replace(map[i].letters, map[i].base);\n\t}\n\treturn str;\n};\n","/*!\n  Copyright (c) 2016 Jed Watson.\n  Licensed under the MIT License (MIT), see\n  http://jedwatson.github.io/react-select\n*/\n\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport AutosizeInput from 'react-input-autosize';\nimport classNames from 'classnames';\n\nimport defaultArrowRenderer from './utils/defaultArrowRenderer';\nimport defaultFilterOptions from './utils/defaultFilterOptions';\nimport defaultMenuRenderer from './utils/defaultMenuRenderer';\n\nimport Async from './Async';\nimport AsyncCreatable from './AsyncCreatable';\nimport Creatable from './Creatable';\nimport Option from './Option';\nimport Value from './Value';\n\nfunction stringifyValue (value) {\n\tconst valueType = typeof value;\n\tif (valueType === 'string') {\n\t\treturn value;\n\t} else if (valueType === 'object') {\n\t\treturn JSON.stringify(value);\n\t} else if (valueType === 'number' || valueType === 'boolean') {\n\t\treturn String(value);\n\t} else {\n\t\treturn '';\n\t}\n}\n\nconst stringOrNode = React.PropTypes.oneOfType([\n\tReact.PropTypes.string,\n\tReact.PropTypes.node\n]);\n\nlet instanceId = 1;\n\nconst Select = React.createClass({\n\n\tdisplayName: 'Select',\n\n\tpropTypes: {\n\t\taddLabelText: React.PropTypes.string,       // placeholder displayed when you want to add a label on a multi-value input\n\t\t'aria-label': React.PropTypes.string,       // Aria label (for assistive tech)\n\t\t'aria-labelledby': React.PropTypes.string,\t// HTML ID of an element that should be used as the label (for assistive tech)\n\t\tarrowRenderer: React.PropTypes.func,\t\t\t\t// Create drop-down caret element\n\t\tautoBlur: React.PropTypes.bool,             // automatically blur the component when an option is selected\n\t\tautofocus: React.PropTypes.bool,            // autofocus the component on mount\n\t\tautosize: React.PropTypes.bool,             // whether to enable autosizing or not\n\t\tbackspaceRemoves: React.PropTypes.bool,     // whether backspace removes an item if there is no text input\n\t\tbackspaceToRemoveMessage: React.PropTypes.string,  // Message to use for screenreaders to press backspace to remove the current item - {label} is replaced with the item label\n\t\tclassName: React.PropTypes.string,          // className for the outer element\n\t\tclearAllText: stringOrNode,                 // title for the \"clear\" control when multi: true\n\t\tclearValueText: stringOrNode,               // title for the \"clear\" control\n\t\tclearable: React.PropTypes.bool,            // should it be possible to reset value\n\t\tdeleteRemoves: React.PropTypes.bool,        // whether backspace removes an item if there is no text input\n\t\tdelimiter: React.PropTypes.string,          // delimiter to use to join multiple values for the hidden field value\n\t\tdisabled: React.PropTypes.bool,             // whether the Select is disabled or not\n\t\tescapeClearsValue: React.PropTypes.bool,    // whether escape clears the value when the menu is closed\n\t\tfilterOption: React.PropTypes.func,         // method to filter a single option (option, filterString)\n\t\tfilterOptions: React.PropTypes.any,         // boolean to enable default filtering or function to filter the options array ([options], filterString, [values])\n\t\tignoreAccents: React.PropTypes.bool,        // whether to strip diacritics when filtering\n\t\tignoreCase: React.PropTypes.bool,           // whether to perform case-insensitive filtering\n\t\tinputProps: React.PropTypes.object,         // custom attributes for the Input\n\t\tinputRenderer: React.PropTypes.func,        // returns a custom input component\n\t\tinstanceId: React.PropTypes.string,         // set the components instanceId\n\t\tisLoading: React.PropTypes.bool,            // whether the Select is loading externally or not (such as options being loaded)\n\t\tjoinValues: React.PropTypes.bool,           // joins multiple values into a single form field with the delimiter (legacy mode)\n\t\tlabelKey: React.PropTypes.string,           // path of the label value in option objects\n\t\tmatchPos: React.PropTypes.string,           // (any|start) match the start or entire string when filtering\n\t\tmatchProp: React.PropTypes.string,          // (any|label|value) which option property to filter on\n\t\tmenuBuffer: React.PropTypes.number,         // optional buffer (in px) between the bottom of the viewport and the bottom of the menu\n\t\tmenuContainerStyle: React.PropTypes.object, // optional style to apply to the menu container\n\t\tmenuRenderer: React.PropTypes.func,         // renders a custom menu with options\n\t\tmenuStyle: React.PropTypes.object,          // optional style to apply to the menu\n\t\tmulti: React.PropTypes.bool,                // multi-value input\n\t\tname: React.PropTypes.string,               // generates a hidden <input /> tag with this field name for html forms\n\t\tnoResultsText: stringOrNode,                // placeholder displayed when there are no matching search results\n\t\tonBlur: React.PropTypes.func,               // onBlur handler: function (event) {}\n\t\tonBlurResetsInput: React.PropTypes.bool,    // whether input is cleared on blur\n\t\tonChange: React.PropTypes.func,             // onChange handler: function (newValue) {}\n\t\tonClose: React.PropTypes.func,              // fires when the menu is closed\n\t\tonCloseResetsInput: React.PropTypes.bool,\t\t// whether input is cleared when menu is closed through the arrow\n\t\tonFocus: React.PropTypes.func,              // onFocus handler: function (event) {}\n\t\tonInputChange: React.PropTypes.func,        // onInputChange handler: function (inputValue) {}\n\t\tonInputKeyDown: React.PropTypes.func,       // input keyDown handler: function (event) {}\n\t\tonMenuScrollToBottom: React.PropTypes.func, // fires when the menu is scrolled to the bottom; can be used to paginate options\n\t\tonOpen: React.PropTypes.func,               // fires when the menu is opened\n\t\tonValueClick: React.PropTypes.func,         // onClick handler for value labels: function (value, event) {}\n\t\topenAfterFocus: React.PropTypes.bool,       // boolean to enable opening dropdown when focused\n\t\topenOnFocus: React.PropTypes.bool,          // always open options menu on focus\n\t\toptionClassName: React.PropTypes.string,    // additional class(es) to apply to the <Option /> elements\n\t\toptionComponent: React.PropTypes.func,      // option component to render in dropdown\n\t\toptionRenderer: React.PropTypes.func,       // optionRenderer: function (option) {}\n\t\toptions: React.PropTypes.array,             // array of options\n\t\tpageSize: React.PropTypes.number,           // number of entries to page when using page up/down keys\n\t\tplaceholder: stringOrNode,                  // field placeholder, displayed when there's no value\n\t\trequired: React.PropTypes.bool,             // applies HTML5 required attribute when needed\n\t\tresetValue: React.PropTypes.any,            // value to use when you clear the control\n\t\tscrollMenuIntoView: React.PropTypes.bool,   // boolean to enable the viewport to shift so that the full menu fully visible when engaged\n\t\tsearchable: React.PropTypes.bool,           // whether to enable searching feature or not\n\t\tsimpleValue: React.PropTypes.bool,          // pass the value to onChange as a simple value (legacy pre 1.0 mode), defaults to false\n\t\tstyle: React.PropTypes.object,              // optional style to apply to the control\n\t\ttabIndex: React.PropTypes.string,           // optional tab index of the control\n\t\ttabSelectsValue: React.PropTypes.bool,      // whether to treat tabbing out while focused to be value selection\n\t\tvalue: React.PropTypes.any,                 // initial field value\n\t\tvalueComponent: React.PropTypes.func,       // value component to render\n\t\tvalueKey: React.PropTypes.string,           // path of the label value in option objects\n\t\tvalueRenderer: React.PropTypes.func,        // valueRenderer: function (option) {}\n\t\twrapperStyle: React.PropTypes.object,       // optional style to apply to the component wrapper\n\t},\n\n\tstatics: { Async, AsyncCreatable, Creatable },\n\n\tgetDefaultProps () {\n\t\treturn {\n\t\t\taddLabelText: 'Add \"{label}\"?',\n\t\t\tarrowRenderer: defaultArrowRenderer,\n\t\t\tautosize: true,\n\t\t\tbackspaceRemoves: true,\n\t\t\tbackspaceToRemoveMessage: 'Press backspace to remove {label}',\n\t\t\tclearable: true,\n\t\t\tclearAllText: 'Clear all',\n\t\t\tclearValueText: 'Clear value',\n\t\t\tdeleteRemoves: true,\n\t\t\tdelimiter: ',',\n\t\t\tdisabled: false,\n\t\t\tescapeClearsValue: true,\n\t\t\tfilterOptions: defaultFilterOptions,\n\t\t\tignoreAccents: true,\n\t\t\tignoreCase: true,\n\t\t\tinputProps: {},\n\t\t\tisLoading: false,\n\t\t\tjoinValues: false,\n\t\t\tlabelKey: 'label',\n\t\t\tmatchPos: 'any',\n\t\t\tmatchProp: 'any',\n\t\t\tmenuBuffer: 0,\n\t\t\tmenuRenderer: defaultMenuRenderer,\n\t\t\tmulti: false,\n\t\t\tnoResultsText: 'No results found',\n\t\t\tonBlurResetsInput: true,\n\t\t\tonCloseResetsInput: true,\n\t\t\topenAfterFocus: false,\n\t\t\toptionComponent: Option,\n\t\t\tpageSize: 5,\n\t\t\tplaceholder: 'Select...',\n\t\t\trequired: false,\n\t\t\tscrollMenuIntoView: true,\n\t\t\tsearchable: true,\n\t\t\tsimpleValue: false,\n\t\t\ttabSelectsValue: true,\n\t\t\tvalueComponent: Value,\n\t\t\tvalueKey: 'value',\n\t\t};\n\t},\n\n\tgetInitialState () {\n\t\treturn {\n\t\t\tinputValue: '',\n\t\t\tisFocused: false,\n\t\t\tisOpen: false,\n\t\t\tisPseudoFocused: false,\n\t\t\trequired: false,\n\t\t};\n\t},\n\n\tcomponentWillMount() {\n\t\tthis._instancePrefix = 'react-select-' + (this.props.instanceId || ++instanceId) + '-';\n\t\tconst valueArray = this.getValueArray(this.props.value);\n\n\t\tif (this.props.required) {\n\t\t\tthis.setState({\n\t\t\t\trequired: this.handleRequired(valueArray[0], this.props.multi),\n\t\t\t});\n\t\t}\n\t},\n\n\tcomponentDidMount () {\n\t\tif (this.props.autofocus) {\n\t\t\tthis.focus();\n\t\t}\n\t},\n\n\tcomponentWillReceiveProps(nextProps) {\n\t\tconst valueArray = this.getValueArray(nextProps.value, nextProps);\n\n\t\tif (nextProps.required) {\n\t\t\tthis.setState({\n\t\t\t\trequired: this.handleRequired(valueArray[0], nextProps.multi),\n\t\t\t});\n\t\t}\n\t},\n\n\tcomponentWillUpdate (nextProps, nextState) {\n\t\tif (nextState.isOpen !== this.state.isOpen) {\n\t\t\tthis.toggleTouchOutsideEvent(nextState.isOpen);\n\t\t\tconst handler = nextState.isOpen ? nextProps.onOpen : nextProps.onClose;\n\t\t\thandler && handler();\n\t\t}\n\t},\n\n\tcomponentDidUpdate (prevProps, prevState) {\n\t\t// focus to the selected option\n\t\tif (this.menu && this.focused && this.state.isOpen && !this.hasScrolledToOption) {\n\t\t\tlet focusedOptionNode = ReactDOM.findDOMNode(this.focused);\n\t\t\tlet menuNode = ReactDOM.findDOMNode(this.menu);\n\t\t\tmenuNode.scrollTop = focusedOptionNode.offsetTop;\n\t\t\tthis.hasScrolledToOption = true;\n\t\t} else if (!this.state.isOpen) {\n\t\t\tthis.hasScrolledToOption = false;\n\t\t}\n\n\t\tif (this._scrollToFocusedOptionOnUpdate && this.focused && this.menu) {\n\t\t\tthis._scrollToFocusedOptionOnUpdate = false;\n\t\t\tvar focusedDOM = ReactDOM.findDOMNode(this.focused);\n\t\t\tvar menuDOM = ReactDOM.findDOMNode(this.menu);\n\t\t\tvar focusedRect = focusedDOM.getBoundingClientRect();\n\t\t\tvar menuRect = menuDOM.getBoundingClientRect();\n\t\t\tif (focusedRect.bottom > menuRect.bottom || focusedRect.top < menuRect.top) {\n\t\t\t\tmenuDOM.scrollTop = (focusedDOM.offsetTop + focusedDOM.clientHeight - menuDOM.offsetHeight);\n\t\t\t}\n\t\t}\n\t\tif (this.props.scrollMenuIntoView && this.menuContainer) {\n\t\t\tvar menuContainerRect = this.menuContainer.getBoundingClientRect();\n\t\t\tif (window.innerHeight < menuContainerRect.bottom + this.props.menuBuffer) {\n\t\t\t\twindow.scrollBy(0, menuContainerRect.bottom + this.props.menuBuffer - window.innerHeight);\n\t\t\t}\n\t\t}\n\t\tif (prevProps.disabled !== this.props.disabled) {\n\t\t\tthis.setState({ isFocused: false }); // eslint-disable-line react/no-did-update-set-state\n\t\t\tthis.closeMenu();\n\t\t}\n\t},\n\n\tcomponentWillUnmount() {\n\t\tif (!document.removeEventListener && document.detachEvent) {\n\t\t\tdocument.detachEvent('ontouchstart', this.handleTouchOutside);\n\t\t} else {\n\t\t\tdocument.removeEventListener('touchstart', this.handleTouchOutside);\n\t\t}\n\t},\n\n\ttoggleTouchOutsideEvent(enabled) {\n\t\tif (enabled) {\n\t\t\tif (!document.addEventListener && document.attachEvent) {\n\t\t\t\tdocument.attachEvent('ontouchstart', this.handleTouchOutside);\n\t\t\t} else {\n\t\t\t\tdocument.addEventListener('touchstart', this.handleTouchOutside);\n\t\t\t}\n\t\t} else {\n\t\t\tif (!document.removeEventListener && document.detachEvent) {\n\t\t\t\tdocument.detachEvent('ontouchstart', this.handleTouchOutside);\n\t\t\t} else {\n\t\t\t\tdocument.removeEventListener('touchstart', this.handleTouchOutside);\n\t\t\t}\n\t\t}\n\t},\n\n\thandleTouchOutside(event) {\n\t\t// handle touch outside on ios to dismiss menu\n\t\tif (this.wrapper && !this.wrapper.contains(event.target)) {\n\t\t\tthis.closeMenu();\n\t\t}\n\t},\n\n\tfocus () {\n\t\tif (!this.input) return;\n\t\tthis.input.focus();\n\n\t\tif (this.props.openAfterFocus) {\n\t\t\tthis.setState({\n\t\t\t\tisOpen: true,\n\t\t\t});\n\t\t}\n\t},\n\n\tblurInput() {\n\t\tif (!this.input) return;\n\t\tthis.input.blur();\n\t},\n\n\thandleTouchMove (event) {\n\t\t// Set a flag that the view is being dragged\n\t\tthis.dragging = true;\n\t},\n\n\thandleTouchStart (event) {\n\t\t// Set a flag that the view is not being dragged\n\t\tthis.dragging = false;\n\t},\n\n\thandleTouchEnd (event) {\n\t\t// Check if the view is being dragged, In this case\n\t\t// we don't want to fire the click event (because the user only wants to scroll)\n\t\tif(this.dragging) return;\n\n\t\t// Fire the mouse events\n\t\tthis.handleMouseDown(event);\n\t},\n\n\thandleTouchEndClearValue (event) {\n\t\t// Check if the view is being dragged, In this case\n\t\t// we don't want to fire the click event (because the user only wants to scroll)\n\t\tif(this.dragging) return;\n\n\t\t// Clear the value\n\t\tthis.clearValue(event);\n\t},\n\n\thandleMouseDown (event) {\n\t\t// if the event was triggered by a mousedown and not the primary\n\t\t// button, or if the component is disabled, ignore it.\n\t\tif (this.props.disabled || (event.type === 'mousedown' && event.button !== 0)) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (event.target.tagName === 'INPUT') {\n\t\t\treturn;\n\t\t}\n\n\t\t// prevent default event handlers\n\t\tevent.stopPropagation();\n\t\tevent.preventDefault();\n\n\t\t// for the non-searchable select, toggle the menu\n\t\tif (!this.props.searchable) {\n\t\t\tthis.focus();\n\t\t\treturn this.setState({\n\t\t\t\tisOpen: !this.state.isOpen,\n\t\t\t});\n\t\t}\n\n\t\tif (this.state.isFocused) {\n\t\t\t// On iOS, we can get into a state where we think the input is focused but it isn't really,\n\t\t\t// since iOS ignores programmatic calls to input.focus() that weren't triggered by a click event.\n\t\t\t// Call focus() again here to be safe.\n\t\t\tthis.focus();\n\n\t\t\tlet input = this.input;\n\t\t\tif (typeof input.getInput === 'function') {\n\t\t\t\t// Get the actual DOM input if the ref is an <AutosizeInput /> component\n\t\t\t\tinput = input.getInput();\n\t\t\t}\n\n\t\t\t// clears the value so that the cursor will be at the end of input when the component re-renders\n\t\t\tinput.value = '';\n\n\t\t\t// if the input is focused, ensure the menu is open\n\t\t\tthis.setState({\n\t\t\t\tisOpen: true,\n\t\t\t\tisPseudoFocused: false,\n\t\t\t});\n\t\t} else {\n\t\t\t// otherwise, focus the input and open the menu\n\t\t\tthis._openAfterFocus = true;\n\t\t\tthis.focus();\n\t\t}\n\t},\n\n\thandleMouseDownOnArrow (event) {\n\t\t// if the event was triggered by a mousedown and not the primary\n\t\t// button, or if the component is disabled, ignore it.\n\t\tif (this.props.disabled || (event.type === 'mousedown' && event.button !== 0)) {\n\t\t\treturn;\n\t\t}\n\t\t// If the menu isn't open, let the event bubble to the main handleMouseDown\n\t\tif (!this.state.isOpen) {\n\t\t\treturn;\n\t\t}\n\t\t// prevent default event handlers\n\t\tevent.stopPropagation();\n\t\tevent.preventDefault();\n\t\t// close the menu\n\t\tthis.closeMenu();\n\t},\n\n\thandleMouseDownOnMenu (event) {\n\t\t// if the event was triggered by a mousedown and not the primary\n\t\t// button, or if the component is disabled, ignore it.\n\t\tif (this.props.disabled || (event.type === 'mousedown' && event.button !== 0)) {\n\t\t\treturn;\n\t\t}\n\t\tevent.stopPropagation();\n\t\tevent.preventDefault();\n\n\t\tthis._openAfterFocus = true;\n\t\tthis.focus();\n\t},\n\n\tcloseMenu () {\n\t\tif(this.props.onCloseResetsInput) {\n\t\t\tthis.setState({\n\t\t\t\tisOpen: false,\n\t\t\t\tisPseudoFocused: this.state.isFocused && !this.props.multi,\n\t\t\t\tinputValue: ''\n\t\t\t});\n\t\t}\telse {\n\t\t\tthis.setState({\n\t\t\t\tisOpen: false,\n\t\t\t\tisPseudoFocused: this.state.isFocused && !this.props.multi,\n\t\t\t\tinputValue: this.state.inputValue\n\t\t\t});\n\t\t}\n\t\tthis.hasScrolledToOption = false;\n\t},\n\n\thandleInputFocus (event) {\n\t\tif (this.props.disabled) return;\n\t\tvar isOpen = this.state.isOpen || this._openAfterFocus || this.props.openOnFocus;\n\t\tif (this.props.onFocus) {\n\t\t\tthis.props.onFocus(event);\n\t\t}\n\t\tthis.setState({\n\t\t\tisFocused: true,\n\t\t\tisOpen: isOpen\n\t\t});\n\t\tthis._openAfterFocus = false;\n\t},\n\n\thandleInputBlur (event) {\n\t\t// The check for menu.contains(activeElement) is necessary to prevent IE11's scrollbar from closing the menu in certain contexts.\n\t\tif (this.menu && (this.menu === document.activeElement || this.menu.contains(document.activeElement))) {\n\t\t\tthis.focus();\n\t\t\treturn;\n\t\t}\n\n\t\tif (this.props.onBlur) {\n\t\t\tthis.props.onBlur(event);\n\t\t}\n\t\tvar onBlurredState = {\n\t\t\tisFocused: false,\n\t\t\tisOpen: false,\n\t\t\tisPseudoFocused: false,\n\t\t};\n\t\tif (this.props.onBlurResetsInput) {\n\t\t\tonBlurredState.inputValue = '';\n\t\t}\n\t\tthis.setState(onBlurredState);\n\t},\n\n\thandleInputChange (event) {\n\t\tlet newInputValue = event.target.value;\n\n\t\tif (this.state.inputValue !== event.target.value && this.props.onInputChange) {\n\t\t\tlet nextState = this.props.onInputChange(newInputValue);\n\t\t\t// Note: != used deliberately here to catch undefined and null\n\t\t\tif (nextState != null && typeof nextState !== 'object') {\n\t\t\t\tnewInputValue = '' + nextState;\n\t\t\t}\n\t\t}\n\n\t\tthis.setState({\n\t\t\tisOpen: true,\n\t\t\tisPseudoFocused: false,\n\t\t\tinputValue: newInputValue\n\t\t});\n\t},\n\n\thandleKeyDown (event) {\n\t\tif (this.props.disabled) return;\n\n\t\tif (typeof this.props.onInputKeyDown === 'function') {\n\t\t\tthis.props.onInputKeyDown(event);\n\t\t\tif (event.defaultPrevented) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\tswitch (event.keyCode) {\n\t\t\tcase 8: // backspace\n\t\t\t\tif (!this.state.inputValue && this.props.backspaceRemoves) {\n\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\tthis.popValue();\n\t\t\t\t}\n\t\t\treturn;\n\t\t\tcase 9: // tab\n\t\t\t\tif (event.shiftKey || !this.state.isOpen || !this.props.tabSelectsValue) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tthis.selectFocusedOption();\n\t\t\treturn;\n\t\t\tcase 13: // enter\n\t\t\t\tif (!this.state.isOpen) return;\n\t\t\t\tevent.stopPropagation();\n\t\t\t\tthis.selectFocusedOption();\n\t\t\tbreak;\n\t\t\tcase 27: // escape\n\t\t\t\tif (this.state.isOpen) {\n\t\t\t\t\tthis.closeMenu();\n\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t} else if (this.props.clearable && this.props.escapeClearsValue) {\n\t\t\t\t\tthis.clearValue(event);\n\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t}\n\t\t\tbreak;\n\t\t\tcase 38: // up\n\t\t\t\tthis.focusPreviousOption();\n\t\t\tbreak;\n\t\t\tcase 40: // down\n\t\t\t\tthis.focusNextOption();\n\t\t\tbreak;\n\t\t\tcase 33: // page up\n\t\t\t\tthis.focusPageUpOption();\n\t\t\tbreak;\n\t\t\tcase 34: // page down\n\t\t\t\tthis.focusPageDownOption();\n\t\t\tbreak;\n\t\t\tcase 35: // end key\n\t\t\t\tif (event.shiftKey) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tthis.focusEndOption();\n\t\t\tbreak;\n\t\t\tcase 36: // home key\n\t\t\t\tif (event.shiftKey) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tthis.focusStartOption();\n\t\t\tbreak;\n\t\t\tcase 46: // backspace\n\t\t\t\tif (!this.state.inputValue && this.props.deleteRemoves) {\n\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\tthis.popValue();\n\t\t\t\t}\n\t\t\treturn;\n\t\t\tdefault: return;\n\t\t}\n\t\tevent.preventDefault();\n\t},\n\n\thandleValueClick (option, event) {\n\t\tif (!this.props.onValueClick) return;\n\t\tthis.props.onValueClick(option, event);\n\t},\n\n\thandleMenuScroll (event) {\n\t\tif (!this.props.onMenuScrollToBottom) return;\n\t\tlet { target } = event;\n\t\tif (target.scrollHeight > target.offsetHeight && !(target.scrollHeight - target.offsetHeight - target.scrollTop)) {\n\t\t\tthis.props.onMenuScrollToBottom();\n\t\t}\n\t},\n\n\thandleRequired (value, multi) {\n\t\tif (!value) return true;\n\t\treturn (multi ? value.length === 0 : Object.keys(value).length === 0);\n\t},\n\n\tgetOptionLabel (op) {\n\t\treturn op[this.props.labelKey];\n\t},\n\n\t/**\n\t * Turns a value into an array from the given options\n\t * @param\t{String|Number|Array}\tvalue\t\t- the value of the select input\n\t * @param\t{Object}\t\tnextProps\t- optionally specify the nextProps so the returned array uses the latest configuration\n\t * @returns\t{Array}\tthe value of the select represented in an array\n\t */\n\tgetValueArray (value, nextProps) {\n\t\t/** support optionally passing in the `nextProps` so `componentWillReceiveProps` updates will function as expected */\n\t\tconst props = typeof nextProps === 'object' ? nextProps : this.props;\n\t\tif (props.multi) {\n\t\t\tif (typeof value === 'string') value = value.split(props.delimiter);\n\t\t\tif (!Array.isArray(value)) {\n\t\t\t\tif (value === null || value === undefined) return [];\n\t\t\t\tvalue = [value];\n\t\t\t}\n\t\t\treturn value.map(value => this.expandValue(value, props)).filter(i => i);\n\t\t}\n\t\tvar expandedValue = this.expandValue(value, props);\n\t\treturn expandedValue ? [expandedValue] : [];\n\t},\n\n\t/**\n\t * Retrieve a value from the given options and valueKey\n\t * @param\t{String|Number|Array}\tvalue\t- the selected value(s)\n\t * @param\t{Object}\t\tprops\t- the Select component's props (or nextProps)\n\t */\n\texpandValue (value, props) {\n\t\tconst valueType = typeof value;\n\t\tif (valueType !== 'string' && valueType !== 'number' && valueType !== 'boolean') return value;\n\t\tlet { options, valueKey } = props;\n\t\tif (!options) return;\n\t\tfor (var i = 0; i < options.length; i++) {\n\t\t\tif (options[i][valueKey] === value) return options[i];\n\t\t}\n\t},\n\n\tsetValue (value) {\n\t\tif (this.props.autoBlur){\n\t\t\tthis.blurInput();\n\t\t}\n\t\tif (!this.props.onChange) return;\n\t\tif (this.props.required) {\n\t\t\tconst required = this.handleRequired(value, this.props.multi);\n\t\t\tthis.setState({ required });\n\t\t}\n\t\tif (this.props.simpleValue && value) {\n\t\t\tvalue = this.props.multi ? value.map(i => i[this.props.valueKey]).join(this.props.delimiter) : value[this.props.valueKey];\n\t\t}\n\t\tthis.props.onChange(value);\n\t},\n\n\tselectValue (value) {\n\t\t//NOTE: update value in the callback to make sure the input value is empty so that there are no styling issues (Chrome had issue otherwise)\n\t\tthis.hasScrolledToOption = false;\n\t\tif (this.props.multi) {\n\t\t\tthis.setState({\n\t\t\t\tinputValue: '',\n\t\t\t\tfocusedIndex: null\n\t\t\t}, () => {\n\t\t\t\tthis.addValue(value);\n\t\t\t});\n\t\t} else {\n\t\t\tthis.setState({\n\t\t\t\tisOpen: false,\n\t\t\t\tinputValue: '',\n\t\t\t\tisPseudoFocused: this.state.isFocused,\n\t\t\t}, () => {\n\t\t\t\tthis.setValue(value);\n\t\t\t});\n\t\t}\n\t},\n\n\taddValue (value) {\n\t\tvar valueArray = this.getValueArray(this.props.value);\n\t\tthis.setValue(valueArray.concat(value));\n\t},\n\n\tpopValue () {\n\t\tvar valueArray = this.getValueArray(this.props.value);\n\t\tif (!valueArray.length) return;\n\t\tif (valueArray[valueArray.length-1].clearableValue === false) return;\n\t\tthis.setValue(valueArray.slice(0, valueArray.length - 1));\n\t},\n\n\tremoveValue (value) {\n\t\tvar valueArray = this.getValueArray(this.props.value);\n\t\tthis.setValue(valueArray.filter(i => i !== value));\n\t\tthis.focus();\n\t},\n\n\tclearValue (event) {\n\t\t// if the event was triggered by a mousedown and not the primary\n\t\t// button, ignore it.\n\t\tif (event && event.type === 'mousedown' && event.button !== 0) {\n\t\t\treturn;\n\t\t}\n\t\tevent.stopPropagation();\n\t\tevent.preventDefault();\n\t\tthis.setValue(this.getResetValue());\n\t\tthis.setState({\n\t\t\tisOpen: false,\n\t\t\tinputValue: '',\n\t\t}, this.focus);\n\t},\n\n\tgetResetValue() {\n\t\tif (this.props.resetValue !== undefined) {\n\t\t\treturn this.props.resetValue;\n\t\t} else if (this.props.multi) {\n\t\t\treturn [];\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t},\n\n\tfocusOption (option) {\n\t\tthis.setState({\n\t\t\tfocusedOption: option\n\t\t});\n\t},\n\n\tfocusNextOption () {\n\t\tthis.focusAdjacentOption('next');\n\t},\n\n\tfocusPreviousOption () {\n\t\tthis.focusAdjacentOption('previous');\n\t},\n\n\tfocusPageUpOption () {\n\t\tthis.focusAdjacentOption('page_up');\n\t},\n\n\tfocusPageDownOption () {\n\t\tthis.focusAdjacentOption('page_down');\n\t},\n\n\tfocusStartOption () {\n\t\tthis.focusAdjacentOption('start');\n\t},\n\n\tfocusEndOption () {\n\t\tthis.focusAdjacentOption('end');\n\t},\n\n\tfocusAdjacentOption (dir) {\n\t\tvar options = this._visibleOptions\n\t\t\t.map((option, index) => ({ option, index }))\n\t\t\t.filter(option => !option.option.disabled);\n\t\tthis._scrollToFocusedOptionOnUpdate = true;\n\t\tif (!this.state.isOpen) {\n\t\t\tthis.setState({\n\t\t\t\tisOpen: true,\n\t\t\t\tinputValue: '',\n\t\t\t\tfocusedOption: this._focusedOption || options[dir === 'next' ? 0 : options.length - 1].option\n\t\t\t});\n\t\t\treturn;\n\t\t}\n\t\tif (!options.length) return;\n\t\tvar focusedIndex = -1;\n\t\tfor (var i = 0; i < options.length; i++) {\n\t\t\tif (this._focusedOption === options[i].option) {\n\t\t\t\tfocusedIndex = i;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t\tif (dir === 'next' && focusedIndex !== -1 ) {\n\t\t\tfocusedIndex = (focusedIndex + 1) % options.length;\n\t\t} else if (dir === 'previous') {\n\t\t\tif (focusedIndex > 0) {\n\t\t\t\tfocusedIndex = focusedIndex - 1;\n\t\t\t} else {\n\t\t\t\tfocusedIndex = options.length - 1;\n\t\t\t}\n\t\t} else if (dir === 'start') {\n\t\t\tfocusedIndex = 0;\n\t\t} else if (dir === 'end') {\n\t\t\tfocusedIndex = options.length - 1;\n\t\t} else if (dir === 'page_up') {\n\t\t\tvar potentialIndex = focusedIndex - this.props.pageSize;\n\t\t\tif ( potentialIndex < 0 ) {\n\t\t\t\tfocusedIndex = 0;\n\t\t\t} else {\n\t\t\t\tfocusedIndex = potentialIndex;\n\t\t\t}\n\t\t} else if (dir === 'page_down') {\n\t\t\tvar potentialIndex = focusedIndex + this.props.pageSize;\n\t\t\tif ( potentialIndex > options.length - 1 ) {\n\t\t\t\tfocusedIndex = options.length - 1;\n\t\t\t} else {\n\t\t\t\tfocusedIndex = potentialIndex;\n\t\t\t}\n\t\t}\n\n\t\tif (focusedIndex === -1) {\n\t\t\tfocusedIndex = 0;\n\t\t}\n\n\t\tthis.setState({\n\t\t\tfocusedIndex: options[focusedIndex].index,\n\t\t\tfocusedOption: options[focusedIndex].option\n\t\t});\n\t},\n\n\tgetFocusedOption () {\n\t\treturn this._focusedOption;\n\t},\n\n\tgetInputValue () {\n\t\treturn this.state.inputValue;\n\t},\n\n\tselectFocusedOption () {\n\t\tif (this._focusedOption) {\n\t\t\treturn this.selectValue(this._focusedOption);\n\t\t}\n\t},\n\n\trenderLoading () {\n\t\tif (!this.props.isLoading) return;\n\t\treturn (\n\t\t\t<span className=\"Select-loading-zone\" aria-hidden=\"true\">\n\t\t\t\t<span className=\"Select-loading\" />\n\t\t\t</span>\n\t\t);\n\t},\n\n\trenderValue (valueArray, isOpen) {\n\t\tlet renderLabel = this.props.valueRenderer || this.getOptionLabel;\n\t\tlet ValueComponent = this.props.valueComponent;\n\t\tif (!valueArray.length) {\n\t\t\treturn !this.state.inputValue ? <div className=\"Select-placeholder\">{this.props.placeholder}</div> : null;\n\t\t}\n\t\tlet onClick = this.props.onValueClick ? this.handleValueClick : null;\n\t\tif (this.props.multi) {\n\t\t\treturn valueArray.map((value, i) => {\n\t\t\t\treturn (\n\t\t\t\t\t<ValueComponent\n\t\t\t\t\t\tid={this._instancePrefix + '-value-' + i}\n\t\t\t\t\t\tinstancePrefix={this._instancePrefix}\n\t\t\t\t\t\tdisabled={this.props.disabled || value.clearableValue === false}\n\t\t\t\t\t\tkey={`value-${i}-${value[this.props.valueKey]}`}\n\t\t\t\t\t\tonClick={onClick}\n\t\t\t\t\t\tonRemove={this.removeValue}\n\t\t\t\t\t\tvalue={value}\n\t\t\t\t\t>\n\t\t\t\t\t\t{renderLabel(value, i)}\n\t\t\t\t\t\t<span className=\"Select-aria-only\">&nbsp;</span>\n\t\t\t\t\t</ValueComponent>\n\t\t\t\t);\n\t\t\t});\n\t\t} else if (!this.state.inputValue) {\n\t\t\tif (isOpen) onClick = null;\n\t\t\treturn (\n\t\t\t\t<ValueComponent\n\t\t\t\t\tid={this._instancePrefix + '-value-item'}\n\t\t\t\t\tdisabled={this.props.disabled}\n\t\t\t\t\tinstancePrefix={this._instancePrefix}\n\t\t\t\t\tonClick={onClick}\n\t\t\t\t\tvalue={valueArray[0]}\n\t\t\t\t>\n\t\t\t\t\t{renderLabel(valueArray[0])}\n\t\t\t\t</ValueComponent>\n\t\t\t);\n\t\t}\n\t},\n\n\trenderInput (valueArray, focusedOptionIndex) {\n\t\tvar className = classNames('Select-input', this.props.inputProps.className);\n\t\tconst isOpen = !!this.state.isOpen;\n\n\t\tconst ariaOwns = classNames({\n\t\t\t[this._instancePrefix + '-list']: isOpen,\n\t\t\t[this._instancePrefix + '-backspace-remove-message']: this.props.multi\n\t\t\t\t&& !this.props.disabled\n\t\t\t\t&& this.state.isFocused\n\t\t\t\t&& !this.state.inputValue\n\t\t});\n\n\t\t// TODO: Check how this project includes Object.assign()\n\t\tconst inputProps = Object.assign({}, this.props.inputProps, {\n\t\t\trole: 'combobox',\n\t\t\t'aria-expanded': '' + isOpen,\n\t\t\t'aria-owns': ariaOwns,\n\t\t\t'aria-haspopup': '' + isOpen,\n\t\t\t'aria-activedescendant': isOpen ? this._instancePrefix + '-option-' + focusedOptionIndex : this._instancePrefix + '-value',\n\t\t\t'aria-labelledby': this.props['aria-labelledby'],\n\t\t\t'aria-label': this.props['aria-label'],\n\t\t\tclassName: className,\n\t\t\ttabIndex: this.props.tabIndex,\n\t\t\tonBlur: this.handleInputBlur,\n\t\t\tonChange: this.handleInputChange,\n\t\t\tonFocus: this.handleInputFocus,\n\t\t\tref: ref => this.input = ref,\n\t\t\trequired: this.state.required,\n\t\t\tvalue: this.state.inputValue\n\t\t});\n\n\t\tif (this.props.inputRenderer) {\n\t\t\treturn this.props.inputRenderer(inputProps);\n\t\t}\n\n\t\tif (this.props.disabled || !this.props.searchable) {\n\t\t\tconst { inputClassName, ...divProps } = this.props.inputProps;\n\t\t\treturn (\n\t\t\t\t<div\n\t\t\t\t\t{...divProps}\n\t\t\t\t\trole=\"combobox\"\n\t\t\t\t\taria-expanded={isOpen}\n\t\t\t\t\taria-owns={isOpen ? this._instancePrefix + '-list' : this._instancePrefix + '-value'}\n\t\t\t\t\taria-activedescendant={isOpen ? this._instancePrefix + '-option-' + focusedOptionIndex : this._instancePrefix + '-value'}\n\t\t\t\t\tclassName={className}\n\t\t\t\t\ttabIndex={this.props.tabIndex || 0}\n\t\t\t\t\tonBlur={this.handleInputBlur}\n\t\t\t\t\tonFocus={this.handleInputFocus}\n\t\t\t\t\tref={ref => this.input = ref}\n\t\t\t\t\taria-readonly={'' + !!this.props.disabled}\n\t\t\t\t\tstyle={{ border: 0, width: 1, display:'inline-block' }}/>\n\t\t\t);\n\t\t}\n\n\t\tif (this.props.autosize) {\n\t\t\treturn (\n\t\t\t\t<AutosizeInput {...inputProps} minWidth=\"5\" />\n\t\t\t);\n\t\t}\n\t\treturn (\n\t\t\t<div className={ className }>\n\t\t\t\t<input {...inputProps} />\n\t\t\t</div>\n\t\t);\n\t},\n\n\trenderClear () {\n\t\tif (!this.props.clearable || (!this.props.value || this.props.value === 0) || (this.props.multi && !this.props.value.length) || this.props.disabled || this.props.isLoading) return;\n\t\treturn (\n\t\t\t<span className=\"Select-clear-zone\" title={this.props.multi ? this.props.clearAllText : this.props.clearValueText}\n\t\t\t\taria-label={this.props.multi ? this.props.clearAllText : this.props.clearValueText}\n\t\t\t\tonMouseDown={this.clearValue}\n\t\t\t\tonTouchStart={this.handleTouchStart}\n\t\t\t\tonTouchMove={this.handleTouchMove}\n\t\t\t\tonTouchEnd={this.handleTouchEndClearValue}\n\t\t\t>\n\t\t\t\t<span className=\"Select-clear\" dangerouslySetInnerHTML={{ __html: '&times;' }} />\n\t\t\t</span>\n\t\t);\n\t},\n\n\trenderArrow () {\n\t\tconst onMouseDown = this.handleMouseDownOnArrow;\n\t\tconst arrow = this.props.arrowRenderer({ onMouseDown });\n\n\t\treturn (\n\t\t\t<span\n\t\t\t\tclassName=\"Select-arrow-zone\"\n\t\t\t\tonMouseDown={onMouseDown}\n\t\t\t>\n\t\t\t\t{arrow}\n\t\t\t</span>\n\t\t);\n\t},\n\n\tfilterOptions (excludeOptions) {\n\t\tvar filterValue = this.state.inputValue;\n\t\tvar options = this.props.options || [];\n\t\tif (this.props.filterOptions) {\n\t\t\t// Maintain backwards compatibility with boolean attribute\n\t\t\tconst filterOptions = typeof this.props.filterOptions === 'function'\n\t\t\t\t? this.props.filterOptions\n\t\t\t\t: defaultFilterOptions;\n\n\t\t\treturn filterOptions(\n\t\t\t\toptions,\n\t\t\t\tfilterValue,\n\t\t\t\texcludeOptions,\n\t\t\t\t{\n\t\t\t\t\tfilterOption: this.props.filterOption,\n\t\t\t\t\tignoreAccents: this.props.ignoreAccents,\n\t\t\t\t\tignoreCase: this.props.ignoreCase,\n\t\t\t\t\tlabelKey: this.props.labelKey,\n\t\t\t\t\tmatchPos: this.props.matchPos,\n\t\t\t\t\tmatchProp: this.props.matchProp,\n\t\t\t\t\tvalueKey: this.props.valueKey,\n\t\t\t\t}\n\t\t\t);\n\t\t} else {\n\t\t\treturn options;\n\t\t}\n\t},\n\n\tonOptionRef(ref, isFocused) {\n\t\tif (isFocused) {\n\t\t\tthis.focused = ref;\n\t\t}\n\t},\n\n\trenderMenu (options, valueArray, focusedOption) {\n\t\tif (options && options.length) {\n\t\t\treturn this.props.menuRenderer({\n\t\t\t\tfocusedOption,\n\t\t\t\tfocusOption: this.focusOption,\n\t\t\t\tinstancePrefix: this._instancePrefix,\n\t\t\t\tlabelKey: this.props.labelKey,\n\t\t\t\tonFocus: this.focusOption,\n\t\t\t\tonSelect: this.selectValue,\n\t\t\t\toptionClassName: this.props.optionClassName,\n\t\t\t\toptionComponent: this.props.optionComponent,\n\t\t\t\toptionRenderer: this.props.optionRenderer || this.getOptionLabel,\n\t\t\t\toptions,\n\t\t\t\tselectValue: this.selectValue,\n\t\t\t\tvalueArray,\n\t\t\t\tvalueKey: this.props.valueKey,\n\t\t\t\tonOptionRef: this.onOptionRef,\n\t\t\t});\n\t\t} else if (this.props.noResultsText) {\n\t\t\treturn (\n\t\t\t\t<div className=\"Select-noresults\">\n\t\t\t\t\t{this.props.noResultsText}\n\t\t\t\t</div>\n\t\t\t);\n\t\t} else {\n\t\t\treturn null;\n\t\t}\n\t},\n\n\trenderHiddenField (valueArray) {\n\t\tif (!this.props.name) return;\n\t\tif (this.props.joinValues) {\n\t\t\tlet value = valueArray.map(i => stringifyValue(i[this.props.valueKey])).join(this.props.delimiter);\n\t\t\treturn (\n\t\t\t\t<input\n\t\t\t\t\ttype=\"hidden\"\n\t\t\t\t\tref={ref => this.value = ref}\n\t\t\t\t\tname={this.props.name}\n\t\t\t\t\tvalue={value}\n\t\t\t\t\tdisabled={this.props.disabled} />\n\t\t\t);\n\t\t}\n\t\treturn valueArray.map((item, index) => (\n\t\t\t<input key={'hidden.' + index}\n\t\t\t\ttype=\"hidden\"\n\t\t\t\tref={'value' + index}\n\t\t\t\tname={this.props.name}\n\t\t\t\tvalue={stringifyValue(item[this.props.valueKey])}\n\t\t\t\tdisabled={this.props.disabled} />\n\t\t));\n\t},\n\n\tgetFocusableOptionIndex (selectedOption) {\n\t\tvar options = this._visibleOptions;\n\t\tif (!options.length) return null;\n\n\t\tlet focusedOption = this.state.focusedOption || selectedOption;\n\t\tif (focusedOption && !focusedOption.disabled) {\n\t\t\tconst focusedOptionIndex = options.indexOf(focusedOption);\n\t\t\tif (focusedOptionIndex !== -1) {\n\t\t\t\treturn focusedOptionIndex;\n\t\t\t}\n\t\t}\n\n\t\tfor (var i = 0; i < options.length; i++) {\n\t\t\tif (!options[i].disabled) return i;\n\t\t}\n\t\treturn null;\n\t},\n\n\trenderOuter (options, valueArray, focusedOption) {\n\t\tlet menu = this.renderMenu(options, valueArray, focusedOption);\n\t\tif (!menu) {\n\t\t\treturn null;\n\t\t}\n\n\t\treturn (\n\t\t\t<div ref={ref => this.menuContainer = ref} className=\"Select-menu-outer\" style={this.props.menuContainerStyle}>\n\t\t\t\t<div ref={ref => this.menu = ref} role=\"listbox\" className=\"Select-menu\" id={this._instancePrefix + '-list'}\n\t\t\t\t\t\t style={this.props.menuStyle}\n\t\t\t\t\t\t onScroll={this.handleMenuScroll}\n\t\t\t\t\t\t onMouseDown={this.handleMouseDownOnMenu}>\n\t\t\t\t\t{menu}\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t);\n\t},\n\n\trender () {\n\t\tlet valueArray = this.getValueArray(this.props.value);\n\t\tlet options =\tthis._visibleOptions = this.filterOptions(this.props.multi ? this.getValueArray(this.props.value) : null);\n\t\tlet isOpen = this.state.isOpen;\n\t\tif (this.props.multi && !options.length && valueArray.length && !this.state.inputValue) isOpen = false;\n\t\tconst focusedOptionIndex = this.getFocusableOptionIndex(valueArray[0]);\n\n\t\tlet focusedOption = null;\n\t\tif (focusedOptionIndex !== null) {\n\t\t\tfocusedOption = this._focusedOption = options[focusedOptionIndex];\n\t\t} else {\n\t\t\tfocusedOption = this._focusedOption = null;\n\t\t}\n\t\tlet className = classNames('Select', this.props.className, {\n\t\t\t'Select--multi': this.props.multi,\n\t\t\t'Select--single': !this.props.multi,\n\t\t\t'is-disabled': this.props.disabled,\n\t\t\t'is-focused': this.state.isFocused,\n\t\t\t'is-loading': this.props.isLoading,\n\t\t\t'is-open': isOpen,\n\t\t\t'is-pseudo-focused': this.state.isPseudoFocused,\n\t\t\t'is-searchable': this.props.searchable,\n\t\t\t'has-value': valueArray.length,\n\t\t});\n\n\t\tlet removeMessage = null;\n\t\tif (this.props.multi &&\n\t\t\t!this.props.disabled &&\n\t\t\tvalueArray.length &&\n\t\t\t!this.state.inputValue &&\n\t\t\tthis.state.isFocused &&\n\t\t\tthis.props.backspaceRemoves) {\n\t\t\tremoveMessage = (\n\t\t\t\t<span id={this._instancePrefix + '-backspace-remove-message'} className=\"Select-aria-only\" aria-live=\"assertive\">\n\t\t\t\t\t{this.props.backspaceToRemoveMessage.replace('{label}', valueArray[valueArray.length - 1][this.props.labelKey])}\n\t\t\t\t</span>\n\t\t\t);\n\t\t}\n\n\t\treturn (\n\t\t\t<div ref={ref => this.wrapper = ref}\n\t\t\t\t className={className}\n\t\t\t\t style={this.props.wrapperStyle}>\n\t\t\t\t{this.renderHiddenField(valueArray)}\n\t\t\t\t<div ref={ref => this.control = ref}\n\t\t\t\t\tclassName=\"Select-control\"\n\t\t\t\t\tstyle={this.props.style}\n\t\t\t\t\tonKeyDown={this.handleKeyDown}\n\t\t\t\t\tonMouseDown={this.handleMouseDown}\n\t\t\t\t\tonTouchEnd={this.handleTouchEnd}\n\t\t\t\t\tonTouchStart={this.handleTouchStart}\n\t\t\t\t\tonTouchMove={this.handleTouchMove}\n\t\t\t\t>\n\t\t\t\t\t<span className=\"Select-multi-value-wrapper\" id={this._instancePrefix + '-value'}>\n\t\t\t\t\t\t{this.renderValue(valueArray, isOpen)}\n\t\t\t\t\t\t{this.renderInput(valueArray, focusedOptionIndex)}\n\t\t\t\t\t</span>\n\t\t\t\t\t{removeMessage}\n\t\t\t\t\t{this.renderLoading()}\n\t\t\t\t\t{this.renderClear()}\n\t\t\t\t\t{this.renderArrow()}\n\t\t\t\t</div>\n\t\t\t\t{isOpen ? this.renderOuter(options, !this.props.multi ? valueArray : null, focusedOption) : null}\n\t\t\t</div>\n\t\t);\n\t}\n\n});\n\nexport default Select;\n"]} diff --git a/examples/dist/common.js b/examples/dist/common.js index 9cc0152977..d58e74a774 100644 --- a/examples/dist/common.js +++ b/examples/dist/common.js @@ -85,7 +85,7 @@ var EventListener = { module.exports = EventListener; }).call(this,require('_process')) -},{"./emptyFunction":8,"_process":27}],2:[function(require,module,exports){ +},{"./emptyFunction":8,"_process":25}],2:[function(require,module,exports){ /** * Copyright (c) 2013-present, Facebook, Inc. * All rights reserved. @@ -363,7 +363,7 @@ function createArrayFromMixed(obj) { module.exports = createArrayFromMixed; }).call(this,require('_process')) -},{"./invariant":16,"_process":27}],7:[function(require,module,exports){ +},{"./invariant":16,"_process":25}],7:[function(require,module,exports){ (function (process){ 'use strict'; @@ -450,7 +450,7 @@ function createNodesFromMarkup(markup, handleScript) { module.exports = createNodesFromMarkup; }).call(this,require('_process')) -},{"./ExecutionEnvironment":2,"./createArrayFromMixed":6,"./getMarkupWrap":12,"./invariant":16,"_process":27}],8:[function(require,module,exports){ +},{"./ExecutionEnvironment":2,"./createArrayFromMixed":6,"./getMarkupWrap":12,"./invariant":16,"_process":25}],8:[function(require,module,exports){ "use strict"; /** @@ -512,7 +512,7 @@ if (process.env.NODE_ENV !== 'production') { module.exports = emptyObject; }).call(this,require('_process')) -},{"_process":27}],10:[function(require,module,exports){ +},{"_process":25}],10:[function(require,module,exports){ /** * Copyright (c) 2013-present, Facebook, Inc. * All rights reserved. @@ -672,7 +672,7 @@ function getMarkupWrap(nodeName) { module.exports = getMarkupWrap; }).call(this,require('_process')) -},{"./ExecutionEnvironment":2,"./invariant":16,"_process":27}],13:[function(require,module,exports){ +},{"./ExecutionEnvironment":2,"./invariant":16,"_process":25}],13:[function(require,module,exports){ /** * Copyright (c) 2013-present, Facebook, Inc. * All rights reserved. @@ -836,7 +836,7 @@ function invariant(condition, format, a, b, c, d, e, f) { module.exports = invariant; }).call(this,require('_process')) -},{"_process":27}],17:[function(require,module,exports){ +},{"_process":25}],17:[function(require,module,exports){ 'use strict'; /** @@ -885,92 +885,6 @@ function isTextNode(object) { module.exports = isTextNode; },{"./isNode":17}],19:[function(require,module,exports){ -(function (process){ -/** - * Copyright (c) 2013-present, Facebook, Inc. - * All rights reserved. - * - * This source code is licensed under the BSD-style license found in the - * LICENSE file in the root directory of this source tree. An additional grant - * of patent rights can be found in the PATENTS file in the same directory. - * - * @typechecks static-only - */ - -'use strict'; - -var invariant = require('./invariant'); - -/** - * Constructs an enumeration with keys equal to their value. - * - * For example: - * - * var COLORS = keyMirror({blue: null, red: null}); - * var myColor = COLORS.blue; - * var isColorValid = !!COLORS[myColor]; - * - * The last line could not be performed if the values of the generated enum were - * not equal to their keys. - * - * Input: {key1: val1, key2: val2} - * Output: {key1: key1, key2: key2} - * - * @param {object} obj - * @return {object} - */ -var keyMirror = function keyMirror(obj) { - var ret = {}; - var key; - !(obj instanceof Object && !Array.isArray(obj)) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'keyMirror(...): Argument must be an object.') : invariant(false) : void 0; - for (key in obj) { - if (!obj.hasOwnProperty(key)) { - continue; - } - ret[key] = key; - } - return ret; -}; - -module.exports = keyMirror; -}).call(this,require('_process')) - -},{"./invariant":16,"_process":27}],20:[function(require,module,exports){ -"use strict"; - -/** - * Copyright (c) 2013-present, Facebook, Inc. - * All rights reserved. - * - * This source code is licensed under the BSD-style license found in the - * LICENSE file in the root directory of this source tree. An additional grant - * of patent rights can be found in the PATENTS file in the same directory. - * - */ - -/** - * Allows extraction of a minified key. Let's the build system minify keys - * without losing the ability to dynamically use key strings as values - * themselves. Pass in an object with a single key/val pair and it will return - * you the string key of that single record. Suppose you want to grab the - * value for a key 'className' inside of an object. Key/val minification may - * have aliased that key to be 'xa12'. keyOf({className: null}) will return - * 'xa12' in that case. Resolve keys you want to use once at startup time, then - * reuse those resolutions. - */ -var keyOf = function keyOf(oneKeyObj) { - var key; - for (key in oneKeyObj) { - if (!oneKeyObj.hasOwnProperty(key)) { - continue; - } - return key; - } - return null; -}; - -module.exports = keyOf; -},{}],21:[function(require,module,exports){ /** * Copyright (c) 2013-present, Facebook, Inc. * All rights reserved. @@ -1000,7 +914,7 @@ function memoizeStringOnly(callback) { } module.exports = memoizeStringOnly; -},{}],22:[function(require,module,exports){ +},{}],20:[function(require,module,exports){ /** * Copyright (c) 2013-present, Facebook, Inc. * All rights reserved. @@ -1023,7 +937,7 @@ if (ExecutionEnvironment.canUseDOM) { } module.exports = performance || {}; -},{"./ExecutionEnvironment":2}],23:[function(require,module,exports){ +},{"./ExecutionEnvironment":2}],21:[function(require,module,exports){ 'use strict'; /** @@ -1057,7 +971,7 @@ if (performance.now) { } module.exports = performanceNow; -},{"./performance":22}],24:[function(require,module,exports){ +},{"./performance":20}],22:[function(require,module,exports){ /** * Copyright (c) 2013-present, Facebook, Inc. * All rights reserved. @@ -1125,7 +1039,7 @@ function shallowEqual(objA, objB) { } module.exports = shallowEqual; -},{}],25:[function(require,module,exports){ +},{}],23:[function(require,module,exports){ (function (process){ /** * Copyright 2014-2015, Facebook, Inc. @@ -1195,7 +1109,7 @@ if (process.env.NODE_ENV !== 'production') { module.exports = warning; }).call(this,require('_process')) -},{"./emptyFunction":8,"_process":27}],26:[function(require,module,exports){ +},{"./emptyFunction":8,"_process":25}],24:[function(require,module,exports){ 'use strict'; /* eslint-disable no-unused-vars */ var hasOwnProperty = Object.prototype.hasOwnProperty; @@ -1280,7 +1194,7 @@ module.exports = shouldUseNative() ? Object.assign : function (target, source) { return to; }; -},{}],27:[function(require,module,exports){ +},{}],25:[function(require,module,exports){ // shim for using process in browser var process = module.exports = {}; @@ -1462,7 +1376,81 @@ process.chdir = function (dir) { }; process.umask = function() { return 0; }; -},{}],28:[function(require,module,exports){ +},{}],26:[function(require,module,exports){ +/** + * Copyright 2013-present, Facebook, Inc. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. An additional grant + * of patent rights can be found in the PATENTS file in the same directory. + * + */ + +'use strict'; + +var ARIADOMPropertyConfig = { + Properties: { + // Global States and Properties + 'aria-current': 0, // state + 'aria-details': 0, + 'aria-disabled': 0, // state + 'aria-hidden': 0, // state + 'aria-invalid': 0, // state + 'aria-keyshortcuts': 0, + 'aria-label': 0, + 'aria-roledescription': 0, + // Widget Attributes + 'aria-autocomplete': 0, + 'aria-checked': 0, + 'aria-expanded': 0, + 'aria-haspopup': 0, + 'aria-level': 0, + 'aria-modal': 0, + 'aria-multiline': 0, + 'aria-multiselectable': 0, + 'aria-orientation': 0, + 'aria-placeholder': 0, + 'aria-pressed': 0, + 'aria-readonly': 0, + 'aria-required': 0, + 'aria-selected': 0, + 'aria-sort': 0, + 'aria-valuemax': 0, + 'aria-valuemin': 0, + 'aria-valuenow': 0, + 'aria-valuetext': 0, + // Live Region Attributes + 'aria-atomic': 0, + 'aria-busy': 0, + 'aria-live': 0, + 'aria-relevant': 0, + // Drag-and-Drop Attributes + 'aria-dropeffect': 0, + 'aria-grabbed': 0, + // Relationship Attributes + 'aria-activedescendant': 0, + 'aria-colcount': 0, + 'aria-colindex': 0, + 'aria-colspan': 0, + 'aria-controls': 0, + 'aria-describedby': 0, + 'aria-errormessage': 0, + 'aria-flowto': 0, + 'aria-labelledby': 0, + 'aria-owns': 0, + 'aria-posinset': 0, + 'aria-rowcount': 0, + 'aria-rowindex': 0, + 'aria-rowspan': 0, + 'aria-setsize': 0 + }, + DOMAttributeNames: {}, + DOMPropertyNames: {} +}; + +module.exports = ARIADOMPropertyConfig; +},{}],27:[function(require,module,exports){ /** * Copyright 2013-present, Facebook, Inc. * All rights reserved. @@ -1471,7 +1459,6 @@ process.umask = function() { return 0; }; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule AutoFocusUtils */ 'use strict'; @@ -1487,7 +1474,7 @@ var AutoFocusUtils = { }; module.exports = AutoFocusUtils; -},{"./ReactDOMComponentTree":69,"fbjs/lib/focusNode":10}],29:[function(require,module,exports){ +},{"./ReactDOMComponentTree":58,"fbjs/lib/focusNode":10}],28:[function(require,module,exports){ /** * Copyright 2013-present Facebook, Inc. * All rights reserved. @@ -1496,20 +1483,16 @@ module.exports = AutoFocusUtils; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule BeforeInputEventPlugin */ 'use strict'; -var EventConstants = require('./EventConstants'); var EventPropagators = require('./EventPropagators'); var ExecutionEnvironment = require('fbjs/lib/ExecutionEnvironment'); var FallbackCompositionState = require('./FallbackCompositionState'); var SyntheticCompositionEvent = require('./SyntheticCompositionEvent'); var SyntheticInputEvent = require('./SyntheticInputEvent'); -var keyOf = require('fbjs/lib/keyOf'); - var END_KEYCODES = [9, 13, 27, 32]; // Tab, Return, Esc, Space var START_KEYCODE = 229; @@ -1542,37 +1525,35 @@ function isPresto() { var SPACEBAR_CODE = 32; var SPACEBAR_CHAR = String.fromCharCode(SPACEBAR_CODE); -var topLevelTypes = EventConstants.topLevelTypes; - // Events and their corresponding property names. var eventTypes = { beforeInput: { phasedRegistrationNames: { - bubbled: keyOf({ onBeforeInput: null }), - captured: keyOf({ onBeforeInputCapture: null }) + bubbled: 'onBeforeInput', + captured: 'onBeforeInputCapture' }, - dependencies: [topLevelTypes.topCompositionEnd, topLevelTypes.topKeyPress, topLevelTypes.topTextInput, topLevelTypes.topPaste] + dependencies: ['topCompositionEnd', 'topKeyPress', 'topTextInput', 'topPaste'] }, compositionEnd: { phasedRegistrationNames: { - bubbled: keyOf({ onCompositionEnd: null }), - captured: keyOf({ onCompositionEndCapture: null }) + bubbled: 'onCompositionEnd', + captured: 'onCompositionEndCapture' }, - dependencies: [topLevelTypes.topBlur, topLevelTypes.topCompositionEnd, topLevelTypes.topKeyDown, topLevelTypes.topKeyPress, topLevelTypes.topKeyUp, topLevelTypes.topMouseDown] + dependencies: ['topBlur', 'topCompositionEnd', 'topKeyDown', 'topKeyPress', 'topKeyUp', 'topMouseDown'] }, compositionStart: { phasedRegistrationNames: { - bubbled: keyOf({ onCompositionStart: null }), - captured: keyOf({ onCompositionStartCapture: null }) + bubbled: 'onCompositionStart', + captured: 'onCompositionStartCapture' }, - dependencies: [topLevelTypes.topBlur, topLevelTypes.topCompositionStart, topLevelTypes.topKeyDown, topLevelTypes.topKeyPress, topLevelTypes.topKeyUp, topLevelTypes.topMouseDown] + dependencies: ['topBlur', 'topCompositionStart', 'topKeyDown', 'topKeyPress', 'topKeyUp', 'topMouseDown'] }, compositionUpdate: { phasedRegistrationNames: { - bubbled: keyOf({ onCompositionUpdate: null }), - captured: keyOf({ onCompositionUpdateCapture: null }) + bubbled: 'onCompositionUpdate', + captured: 'onCompositionUpdateCapture' }, - dependencies: [topLevelTypes.topBlur, topLevelTypes.topCompositionUpdate, topLevelTypes.topKeyDown, topLevelTypes.topKeyPress, topLevelTypes.topKeyUp, topLevelTypes.topMouseDown] + dependencies: ['topBlur', 'topCompositionUpdate', 'topKeyDown', 'topKeyPress', 'topKeyUp', 'topMouseDown'] } }; @@ -1598,11 +1579,11 @@ function isKeypressCommand(nativeEvent) { */ function getCompositionEventType(topLevelType) { switch (topLevelType) { - case topLevelTypes.topCompositionStart: + case 'topCompositionStart': return eventTypes.compositionStart; - case topLevelTypes.topCompositionEnd: + case 'topCompositionEnd': return eventTypes.compositionEnd; - case topLevelTypes.topCompositionUpdate: + case 'topCompositionUpdate': return eventTypes.compositionUpdate; } } @@ -1616,7 +1597,7 @@ function getCompositionEventType(topLevelType) { * @return {boolean} */ function isFallbackCompositionStart(topLevelType, nativeEvent) { - return topLevelType === topLevelTypes.topKeyDown && nativeEvent.keyCode === START_KEYCODE; + return topLevelType === 'topKeyDown' && nativeEvent.keyCode === START_KEYCODE; } /** @@ -1628,16 +1609,16 @@ function isFallbackCompositionStart(topLevelType, nativeEvent) { */ function isFallbackCompositionEnd(topLevelType, nativeEvent) { switch (topLevelType) { - case topLevelTypes.topKeyUp: + case 'topKeyUp': // Command keys insert or clear IME input. return END_KEYCODES.indexOf(nativeEvent.keyCode) !== -1; - case topLevelTypes.topKeyDown: + case 'topKeyDown': // Expect IME keyCode on each keydown. If we get any other // code we must have exited earlier. return nativeEvent.keyCode !== START_KEYCODE; - case topLevelTypes.topKeyPress: - case topLevelTypes.topMouseDown: - case topLevelTypes.topBlur: + case 'topKeyPress': + case 'topMouseDown': + case 'topBlur': // Events are not possible without cancelling IME. return true; default: @@ -1722,9 +1703,9 @@ function extractCompositionEvent(topLevelType, targetInst, nativeEvent, nativeEv */ function getNativeBeforeInputChars(topLevelType, nativeEvent) { switch (topLevelType) { - case topLevelTypes.topCompositionEnd: + case 'topCompositionEnd': return getDataFromCustomEvent(nativeEvent); - case topLevelTypes.topKeyPress: + case 'topKeyPress': /** * If native `textInput` events are available, our goal is to make * use of them. However, there is a special case: the spacebar key. @@ -1747,7 +1728,7 @@ function getNativeBeforeInputChars(topLevelType, nativeEvent) { hasSpaceKeypress = true; return SPACEBAR_CHAR; - case topLevelTypes.topTextInput: + case 'topTextInput': // Record the characters to be added to the DOM. var chars = nativeEvent.data; @@ -1780,7 +1761,7 @@ function getFallbackBeforeInputChars(topLevelType, nativeEvent) { // If composition event is available, we extract a string only at // compositionevent, otherwise extract it at fallback events. if (currentComposition) { - if (topLevelType === topLevelTypes.topCompositionEnd || !canUseCompositionEvent && isFallbackCompositionEnd(topLevelType, nativeEvent)) { + if (topLevelType === 'topCompositionEnd' || !canUseCompositionEvent && isFallbackCompositionEnd(topLevelType, nativeEvent)) { var chars = currentComposition.getData(); FallbackCompositionState.release(currentComposition); currentComposition = null; @@ -1790,11 +1771,11 @@ function getFallbackBeforeInputChars(topLevelType, nativeEvent) { } switch (topLevelType) { - case topLevelTypes.topPaste: + case 'topPaste': // If a paste event occurs after a keypress, throw out the input // chars. Paste events should not lead to BeforeInput events. return null; - case topLevelTypes.topKeyPress: + case 'topKeyPress': /** * As of v27, Firefox may fire keypress events even when no character * will be inserted. A few possibilities: @@ -1815,7 +1796,7 @@ function getFallbackBeforeInputChars(topLevelType, nativeEvent) { return String.fromCharCode(nativeEvent.which); } return null; - case topLevelTypes.topCompositionEnd: + case 'topCompositionEnd': return useFallbackCompositionData ? null : nativeEvent.data; default: return null; @@ -1878,7 +1859,7 @@ var BeforeInputEventPlugin = { }; module.exports = BeforeInputEventPlugin; -},{"./EventConstants":43,"./EventPropagators":47,"./FallbackCompositionState":48,"./SyntheticCompositionEvent":126,"./SyntheticInputEvent":130,"fbjs/lib/ExecutionEnvironment":2,"fbjs/lib/keyOf":20}],30:[function(require,module,exports){ +},{"./EventPropagators":44,"./FallbackCompositionState":45,"./SyntheticCompositionEvent":109,"./SyntheticInputEvent":113,"fbjs/lib/ExecutionEnvironment":2}],29:[function(require,module,exports){ /** * Copyright 2013-present, Facebook, Inc. * All rights reserved. @@ -1887,7 +1868,6 @@ module.exports = BeforeInputEventPlugin; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule CSSProperty */ 'use strict'; @@ -2027,7 +2007,7 @@ var CSSProperty = { }; module.exports = CSSProperty; -},{}],31:[function(require,module,exports){ +},{}],30:[function(require,module,exports){ (function (process){ /** * Copyright 2013-present, Facebook, Inc. @@ -2037,7 +2017,6 @@ module.exports = CSSProperty; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule CSSPropertyOperations */ 'use strict'; @@ -2199,7 +2178,11 @@ var CSSPropertyOperations = { */ setValueForStyles: function (node, styles, component) { if (process.env.NODE_ENV !== 'production') { - ReactInstrumentation.debugTool.onHostOperation(component._debugID, 'update styles', styles); + ReactInstrumentation.debugTool.onHostOperation({ + instanceID: component._debugID, + type: 'update styles', + payload: styles + }); } var style = node.style; @@ -2236,7 +2219,7 @@ var CSSPropertyOperations = { module.exports = CSSPropertyOperations; }).call(this,require('_process')) -},{"./CSSProperty":30,"./ReactInstrumentation":99,"./dangerousStyleValue":144,"_process":27,"fbjs/lib/ExecutionEnvironment":2,"fbjs/lib/camelizeStyleName":4,"fbjs/lib/hyphenateStyleName":15,"fbjs/lib/memoizeStringOnly":21,"fbjs/lib/warning":25}],32:[function(require,module,exports){ +},{"./CSSProperty":29,"./ReactInstrumentation":87,"./dangerousStyleValue":126,"_process":25,"fbjs/lib/ExecutionEnvironment":2,"fbjs/lib/camelizeStyleName":4,"fbjs/lib/hyphenateStyleName":15,"fbjs/lib/memoizeStringOnly":19,"fbjs/lib/warning":23}],31:[function(require,module,exports){ (function (process){ /** * Copyright 2013-present, Facebook, Inc. @@ -2246,13 +2229,14 @@ module.exports = CSSPropertyOperations; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule CallbackQueue + * */ 'use strict'; -var _prodInvariant = require('./reactProdInvariant'), - _assign = require('object-assign'); +var _prodInvariant = require('./reactProdInvariant'); + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } var PooledClass = require('./PooledClass'); @@ -2269,12 +2253,15 @@ var invariant = require('fbjs/lib/invariant'); * @implements PooledClass * @internal */ -function CallbackQueue() { - this._callbacks = null; - this._contexts = null; -} -_assign(CallbackQueue.prototype, { +var CallbackQueue = function () { + function CallbackQueue(arg) { + _classCallCheck(this, CallbackQueue); + + this._callbacks = null; + this._contexts = null; + this._arg = arg; + } /** * Enqueues a callback to be invoked when `notifyAll` is invoked. @@ -2283,12 +2270,14 @@ _assign(CallbackQueue.prototype, { * @param {?object} context Context to call `callback` with. * @internal */ - enqueue: function (callback, context) { + + + CallbackQueue.prototype.enqueue = function enqueue(callback, context) { this._callbacks = this._callbacks || []; - this._contexts = this._contexts || []; this._callbacks.push(callback); + this._contexts = this._contexts || []; this._contexts.push(context); - }, + }; /** * Invokes all enqueued callbacks and clears the queue. This is invoked after @@ -2296,57 +2285,63 @@ _assign(CallbackQueue.prototype, { * * @internal */ - notifyAll: function () { + + + CallbackQueue.prototype.notifyAll = function notifyAll() { var callbacks = this._callbacks; var contexts = this._contexts; - if (callbacks) { + var arg = this._arg; + if (callbacks && contexts) { !(callbacks.length === contexts.length) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Mismatched list of contexts in callback queue') : _prodInvariant('24') : void 0; this._callbacks = null; this._contexts = null; for (var i = 0; i < callbacks.length; i++) { - callbacks[i].call(contexts[i]); + callbacks[i].call(contexts[i], arg); } callbacks.length = 0; contexts.length = 0; } - }, + }; - checkpoint: function () { + CallbackQueue.prototype.checkpoint = function checkpoint() { return this._callbacks ? this._callbacks.length : 0; - }, + }; - rollback: function (len) { - if (this._callbacks) { + CallbackQueue.prototype.rollback = function rollback(len) { + if (this._callbacks && this._contexts) { this._callbacks.length = len; this._contexts.length = len; } - }, + }; /** * Resets the internal queue. * * @internal */ - reset: function () { + + + CallbackQueue.prototype.reset = function reset() { this._callbacks = null; this._contexts = null; - }, + }; /** * `PooledClass` looks for this. */ - destructor: function () { - this.reset(); - } -}); -PooledClass.addPoolingTo(CallbackQueue); + CallbackQueue.prototype.destructor = function destructor() { + this.reset(); + }; + + return CallbackQueue; +}(); -module.exports = CallbackQueue; +module.exports = PooledClass.addPoolingTo(CallbackQueue); }).call(this,require('_process')) -},{"./PooledClass":52,"./reactProdInvariant":163,"_process":27,"fbjs/lib/invariant":16,"object-assign":26}],33:[function(require,module,exports){ +},{"./PooledClass":49,"./reactProdInvariant":145,"_process":25,"fbjs/lib/invariant":16}],32:[function(require,module,exports){ /** * Copyright 2013-present, Facebook, Inc. * All rights reserved. @@ -2355,12 +2350,10 @@ module.exports = CallbackQueue; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule ChangeEventPlugin */ 'use strict'; -var EventConstants = require('./EventConstants'); var EventPluginHub = require('./EventPluginHub'); var EventPropagators = require('./EventPropagators'); var ExecutionEnvironment = require('fbjs/lib/ExecutionEnvironment'); @@ -2371,17 +2364,14 @@ var SyntheticEvent = require('./SyntheticEvent'); var getEventTarget = require('./getEventTarget'); var isEventSupported = require('./isEventSupported'); var isTextInputElement = require('./isTextInputElement'); -var keyOf = require('fbjs/lib/keyOf'); - -var topLevelTypes = EventConstants.topLevelTypes; var eventTypes = { change: { phasedRegistrationNames: { - bubbled: keyOf({ onChange: null }), - captured: keyOf({ onChangeCapture: null }) + bubbled: 'onChange', + captured: 'onChangeCapture' }, - dependencies: [topLevelTypes.topBlur, topLevelTypes.topChange, topLevelTypes.topClick, topLevelTypes.topFocus, topLevelTypes.topInput, topLevelTypes.topKeyDown, topLevelTypes.topKeyUp, topLevelTypes.topSelectionChange] + dependencies: ['topBlur', 'topChange', 'topClick', 'topFocus', 'topInput', 'topKeyDown', 'topKeyUp', 'topSelectionChange'] } }; @@ -2446,17 +2436,17 @@ function stopWatchingForChangeEventIE8() { } function getTargetInstForChangeEvent(topLevelType, targetInst) { - if (topLevelType === topLevelTypes.topChange) { + if (topLevelType === 'topChange') { return targetInst; } } function handleEventsForChangeEventIE8(topLevelType, target, targetInst) { - if (topLevelType === topLevelTypes.topFocus) { + if (topLevelType === 'topFocus') { // stopWatching() should be a noop here but we call it just in case we // missed a blur event somehow. stopWatchingForChangeEventIE8(); startWatchingForChangeEventIE8(target, targetInst); - } else if (topLevelType === topLevelTypes.topBlur) { + } else if (topLevelType === 'topBlur') { stopWatchingForChangeEventIE8(); } } @@ -2554,7 +2544,7 @@ function handlePropertyChange(nativeEvent) { * If a `change` event should be fired, returns the target's ID. */ function getTargetInstForInputEvent(topLevelType, targetInst) { - if (topLevelType === topLevelTypes.topInput) { + if (topLevelType === 'topInput') { // In modern browsers (i.e., not IE8 or IE9), the input event is exactly // what we want so fall through here and trigger an abstract event return targetInst; @@ -2562,7 +2552,7 @@ function getTargetInstForInputEvent(topLevelType, targetInst) { } function handleEventsForInputEventIE(topLevelType, target, targetInst) { - if (topLevelType === topLevelTypes.topFocus) { + if (topLevelType === 'topFocus') { // In IE8, we can capture almost all .value changes by adding a // propertychange handler and looking for events with propertyName // equal to 'value' @@ -2578,14 +2568,14 @@ function handleEventsForInputEventIE(topLevelType, target, targetInst) { // missed a blur event somehow. stopWatchingForValueChange(); startWatchingForValueChange(target, targetInst); - } else if (topLevelType === topLevelTypes.topBlur) { + } else if (topLevelType === 'topBlur') { stopWatchingForValueChange(); } } // For IE8 and IE9. function getTargetInstForInputEventIE(topLevelType, targetInst) { - if (topLevelType === topLevelTypes.topSelectionChange || topLevelType === topLevelTypes.topKeyUp || topLevelType === topLevelTypes.topKeyDown) { + if (topLevelType === 'topSelectionChange' || topLevelType === 'topKeyUp' || topLevelType === 'topKeyDown') { // On the selectionchange event, the target is just document which isn't // helpful for us so just check activeElement instead. // @@ -2614,7 +2604,7 @@ function shouldUseClickEvent(elem) { } function getTargetInstForClickEvent(topLevelType, targetInst) { - if (topLevelType === topLevelTypes.topClick) { + if (topLevelType === 'topClick') { return targetInst; } } @@ -2672,7 +2662,7 @@ var ChangeEventPlugin = { }; module.exports = ChangeEventPlugin; -},{"./EventConstants":43,"./EventPluginHub":44,"./EventPropagators":47,"./ReactDOMComponentTree":69,"./ReactUpdates":119,"./SyntheticEvent":128,"./getEventTarget":152,"./isEventSupported":159,"./isTextInputElement":160,"fbjs/lib/ExecutionEnvironment":2,"fbjs/lib/keyOf":20}],34:[function(require,module,exports){ +},{"./EventPluginHub":41,"./EventPropagators":44,"./ReactDOMComponentTree":58,"./ReactUpdates":102,"./SyntheticEvent":111,"./getEventTarget":134,"./isEventSupported":142,"./isTextInputElement":143,"fbjs/lib/ExecutionEnvironment":2}],33:[function(require,module,exports){ (function (process){ /** * Copyright 2013-present, Facebook, Inc. @@ -2682,14 +2672,12 @@ module.exports = ChangeEventPlugin; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule DOMChildrenOperations */ 'use strict'; var DOMLazyTree = require('./DOMLazyTree'); var Danger = require('./Danger'); -var ReactMultiChildUpdateTypes = require('./ReactMultiChildUpdateTypes'); var ReactDOMComponentTree = require('./ReactDOMComponentTree'); var ReactInstrumentation = require('./ReactInstrumentation'); @@ -2788,7 +2776,11 @@ function replaceDelimitedText(openingComment, closingComment, stringText) { } if (process.env.NODE_ENV !== 'production') { - ReactInstrumentation.debugTool.onHostOperation(ReactDOMComponentTree.getInstanceFromNode(openingComment)._debugID, 'replace text', stringText); + ReactInstrumentation.debugTool.onHostOperation({ + instanceID: ReactDOMComponentTree.getInstanceFromNode(openingComment)._debugID, + type: 'replace text', + payload: stringText + }); } } @@ -2797,11 +2789,19 @@ if (process.env.NODE_ENV !== 'production') { dangerouslyReplaceNodeWithMarkup = function (oldChild, markup, prevInstance) { Danger.dangerouslyReplaceNodeWithMarkup(oldChild, markup); if (prevInstance._debugID !== 0) { - ReactInstrumentation.debugTool.onHostOperation(prevInstance._debugID, 'replace with', markup.toString()); + ReactInstrumentation.debugTool.onHostOperation({ + instanceID: prevInstance._debugID, + type: 'replace with', + payload: markup.toString() + }); } else { var nextInstance = ReactDOMComponentTree.getInstanceFromNode(markup.node); if (nextInstance._debugID !== 0) { - ReactInstrumentation.debugTool.onHostOperation(nextInstance._debugID, 'mount', markup.toString()); + ReactInstrumentation.debugTool.onHostOperation({ + instanceID: nextInstance._debugID, + type: 'mount', + payload: markup.toString() + }); } } }; @@ -2831,34 +2831,54 @@ var DOMChildrenOperations = { for (var k = 0; k < updates.length; k++) { var update = updates[k]; switch (update.type) { - case ReactMultiChildUpdateTypes.INSERT_MARKUP: + case 'INSERT_MARKUP': insertLazyTreeChildAt(parentNode, update.content, getNodeAfter(parentNode, update.afterNode)); if (process.env.NODE_ENV !== 'production') { - ReactInstrumentation.debugTool.onHostOperation(parentNodeDebugID, 'insert child', { toIndex: update.toIndex, content: update.content.toString() }); + ReactInstrumentation.debugTool.onHostOperation({ + instanceID: parentNodeDebugID, + type: 'insert child', + payload: { toIndex: update.toIndex, content: update.content.toString() } + }); } break; - case ReactMultiChildUpdateTypes.MOVE_EXISTING: + case 'MOVE_EXISTING': moveChild(parentNode, update.fromNode, getNodeAfter(parentNode, update.afterNode)); if (process.env.NODE_ENV !== 'production') { - ReactInstrumentation.debugTool.onHostOperation(parentNodeDebugID, 'move child', { fromIndex: update.fromIndex, toIndex: update.toIndex }); + ReactInstrumentation.debugTool.onHostOperation({ + instanceID: parentNodeDebugID, + type: 'move child', + payload: { fromIndex: update.fromIndex, toIndex: update.toIndex } + }); } break; - case ReactMultiChildUpdateTypes.SET_MARKUP: + case 'SET_MARKUP': setInnerHTML(parentNode, update.content); if (process.env.NODE_ENV !== 'production') { - ReactInstrumentation.debugTool.onHostOperation(parentNodeDebugID, 'replace children', update.content.toString()); + ReactInstrumentation.debugTool.onHostOperation({ + instanceID: parentNodeDebugID, + type: 'replace children', + payload: update.content.toString() + }); } break; - case ReactMultiChildUpdateTypes.TEXT_CONTENT: + case 'TEXT_CONTENT': setTextContent(parentNode, update.content); if (process.env.NODE_ENV !== 'production') { - ReactInstrumentation.debugTool.onHostOperation(parentNodeDebugID, 'replace text', update.content.toString()); + ReactInstrumentation.debugTool.onHostOperation({ + instanceID: parentNodeDebugID, + type: 'replace text', + payload: update.content.toString() + }); } break; - case ReactMultiChildUpdateTypes.REMOVE_NODE: + case 'REMOVE_NODE': removeChild(parentNode, update.fromNode); if (process.env.NODE_ENV !== 'production') { - ReactInstrumentation.debugTool.onHostOperation(parentNodeDebugID, 'remove child', { fromIndex: update.fromIndex }); + ReactInstrumentation.debugTool.onHostOperation({ + instanceID: parentNodeDebugID, + type: 'remove child', + payload: { fromIndex: update.fromIndex } + }); } break; } @@ -2870,7 +2890,7 @@ var DOMChildrenOperations = { module.exports = DOMChildrenOperations; }).call(this,require('_process')) -},{"./DOMLazyTree":35,"./Danger":39,"./ReactDOMComponentTree":69,"./ReactInstrumentation":99,"./ReactMultiChildUpdateTypes":104,"./createMicrosoftUnsafeLocalFunction":143,"./setInnerHTML":165,"./setTextContent":166,"_process":27}],35:[function(require,module,exports){ +},{"./DOMLazyTree":34,"./Danger":38,"./ReactDOMComponentTree":58,"./ReactInstrumentation":87,"./createMicrosoftUnsafeLocalFunction":125,"./setInnerHTML":147,"./setTextContent":148,"_process":25}],34:[function(require,module,exports){ /** * Copyright 2015-present, Facebook, Inc. * All rights reserved. @@ -2879,7 +2899,6 @@ module.exports = DOMChildrenOperations; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule DOMLazyTree */ 'use strict'; @@ -2989,7 +3008,7 @@ DOMLazyTree.queueHTML = queueHTML; DOMLazyTree.queueText = queueText; module.exports = DOMLazyTree; -},{"./DOMNamespaces":36,"./createMicrosoftUnsafeLocalFunction":143,"./setInnerHTML":165,"./setTextContent":166}],36:[function(require,module,exports){ +},{"./DOMNamespaces":35,"./createMicrosoftUnsafeLocalFunction":125,"./setInnerHTML":147,"./setTextContent":148}],35:[function(require,module,exports){ /** * Copyright 2013-present, Facebook, Inc. * All rights reserved. @@ -2998,7 +3017,6 @@ module.exports = DOMLazyTree; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule DOMNamespaces */ 'use strict'; @@ -3010,7 +3028,7 @@ var DOMNamespaces = { }; module.exports = DOMNamespaces; -},{}],37:[function(require,module,exports){ +},{}],36:[function(require,module,exports){ (function (process){ /** * Copyright 2013-present, Facebook, Inc. @@ -3020,7 +3038,6 @@ module.exports = DOMNamespaces; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule DOMProperty */ 'use strict'; @@ -3191,9 +3208,13 @@ var DOMProperty = { /** * Mapping from lowercase property names to the properly cased version, used * to warn in the case of missing properties. Available only in __DEV__. + * + * autofocus is predefined, because adding it to the property whitelist + * causes unintended side effects. + * * @type {Object} */ - getPossibleStandardName: process.env.NODE_ENV !== 'production' ? {} : null, + getPossibleStandardName: process.env.NODE_ENV !== 'production' ? { autofocus: 'autoFocus' } : null, /** * All of the isCustomAttribute() functions that have been injected. @@ -3220,7 +3241,7 @@ var DOMProperty = { module.exports = DOMProperty; }).call(this,require('_process')) -},{"./reactProdInvariant":163,"_process":27,"fbjs/lib/invariant":16}],38:[function(require,module,exports){ +},{"./reactProdInvariant":145,"_process":25,"fbjs/lib/invariant":16}],37:[function(require,module,exports){ (function (process){ /** * Copyright 2013-present, Facebook, Inc. @@ -3230,7 +3251,6 @@ module.exports = DOMProperty; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule DOMPropertyOperations */ 'use strict'; @@ -3375,7 +3395,11 @@ var DOMPropertyOperations = { if (process.env.NODE_ENV !== 'production') { var payload = {}; payload[name] = value; - ReactInstrumentation.debugTool.onHostOperation(ReactDOMComponentTree.getInstanceFromNode(node)._debugID, 'update attribute', payload); + ReactInstrumentation.debugTool.onHostOperation({ + instanceID: ReactDOMComponentTree.getInstanceFromNode(node)._debugID, + type: 'update attribute', + payload: payload + }); } }, @@ -3392,7 +3416,11 @@ var DOMPropertyOperations = { if (process.env.NODE_ENV !== 'production') { var payload = {}; payload[name] = value; - ReactInstrumentation.debugTool.onHostOperation(ReactDOMComponentTree.getInstanceFromNode(node)._debugID, 'update attribute', payload); + ReactInstrumentation.debugTool.onHostOperation({ + instanceID: ReactDOMComponentTree.getInstanceFromNode(node)._debugID, + type: 'update attribute', + payload: payload + }); } }, @@ -3405,7 +3433,11 @@ var DOMPropertyOperations = { deleteValueForAttribute: function (node, name) { node.removeAttribute(name); if (process.env.NODE_ENV !== 'production') { - ReactInstrumentation.debugTool.onHostOperation(ReactDOMComponentTree.getInstanceFromNode(node)._debugID, 'remove attribute', name); + ReactInstrumentation.debugTool.onHostOperation({ + instanceID: ReactDOMComponentTree.getInstanceFromNode(node)._debugID, + type: 'remove attribute', + payload: name + }); } }, @@ -3436,7 +3468,11 @@ var DOMPropertyOperations = { } if (process.env.NODE_ENV !== 'production') { - ReactInstrumentation.debugTool.onHostOperation(ReactDOMComponentTree.getInstanceFromNode(node)._debugID, 'remove attribute', name); + ReactInstrumentation.debugTool.onHostOperation({ + instanceID: ReactDOMComponentTree.getInstanceFromNode(node)._debugID, + type: 'remove attribute', + payload: name + }); } } @@ -3445,7 +3481,7 @@ var DOMPropertyOperations = { module.exports = DOMPropertyOperations; }).call(this,require('_process')) -},{"./DOMProperty":37,"./ReactDOMComponentTree":69,"./ReactInstrumentation":99,"./quoteAttributeValueForBrowser":162,"_process":27,"fbjs/lib/warning":25}],39:[function(require,module,exports){ +},{"./DOMProperty":36,"./ReactDOMComponentTree":58,"./ReactInstrumentation":87,"./quoteAttributeValueForBrowser":144,"_process":25,"fbjs/lib/warning":23}],38:[function(require,module,exports){ (function (process){ /** * Copyright 2013-present, Facebook, Inc. @@ -3455,7 +3491,6 @@ module.exports = DOMPropertyOperations; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule Danger */ 'use strict'; @@ -3497,7 +3532,7 @@ var Danger = { module.exports = Danger; }).call(this,require('_process')) -},{"./DOMLazyTree":35,"./reactProdInvariant":163,"_process":27,"fbjs/lib/ExecutionEnvironment":2,"fbjs/lib/createNodesFromMarkup":7,"fbjs/lib/emptyFunction":8,"fbjs/lib/invariant":16}],40:[function(require,module,exports){ +},{"./DOMLazyTree":34,"./reactProdInvariant":145,"_process":25,"fbjs/lib/ExecutionEnvironment":2,"fbjs/lib/createNodesFromMarkup":7,"fbjs/lib/emptyFunction":8,"fbjs/lib/invariant":16}],39:[function(require,module,exports){ /** * Copyright 2013-present, Facebook, Inc. * All rights reserved. @@ -3506,13 +3541,10 @@ module.exports = Danger; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule DefaultEventPluginOrder */ 'use strict'; -var keyOf = require('fbjs/lib/keyOf'); - /** * Module that is injectable into `EventPluginHub`, that specifies a * deterministic ordering of `EventPlugin`s. A convenient way to reason about @@ -3522,61 +3554,11 @@ var keyOf = require('fbjs/lib/keyOf'); * `ResponderEventPlugin` must occur before `SimpleEventPlugin` so that * preventing default on events is convenient in `SimpleEventPlugin` handlers. */ -var DefaultEventPluginOrder = [keyOf({ ResponderEventPlugin: null }), keyOf({ SimpleEventPlugin: null }), keyOf({ TapEventPlugin: null }), keyOf({ EnterLeaveEventPlugin: null }), keyOf({ ChangeEventPlugin: null }), keyOf({ SelectEventPlugin: null }), keyOf({ BeforeInputEventPlugin: null })]; - -module.exports = DefaultEventPluginOrder; -},{"fbjs/lib/keyOf":20}],41:[function(require,module,exports){ -/** - * Copyright 2013-present, Facebook, Inc. - * All rights reserved. - * - * This source code is licensed under the BSD-style license found in the - * LICENSE file in the root directory of this source tree. An additional grant - * of patent rights can be found in the PATENTS file in the same directory. - * - * @providesModule DisabledInputUtils - */ - -'use strict'; - -var disableableMouseListenerNames = { - onClick: true, - onDoubleClick: true, - onMouseDown: true, - onMouseMove: true, - onMouseUp: true, - - onClickCapture: true, - onDoubleClickCapture: true, - onMouseDownCapture: true, - onMouseMoveCapture: true, - onMouseUpCapture: true -}; - -/** - * Implements a host component that does not receive mouse events - * when `disabled` is set. - */ -var DisabledInputUtils = { - getHostProps: function (inst, props) { - if (!props.disabled) { - return props; - } - - // Copy the props, except the mouse listeners - var hostProps = {}; - for (var key in props) { - if (!disableableMouseListenerNames[key] && props.hasOwnProperty(key)) { - hostProps[key] = props[key]; - } - } - return hostProps; - } -}; +var DefaultEventPluginOrder = ['ResponderEventPlugin', 'SimpleEventPlugin', 'TapEventPlugin', 'EnterLeaveEventPlugin', 'ChangeEventPlugin', 'SelectEventPlugin', 'BeforeInputEventPlugin']; -module.exports = DisabledInputUtils; -},{}],42:[function(require,module,exports){ +module.exports = DefaultEventPluginOrder; +},{}],40:[function(require,module,exports){ /** * Copyright 2013-present, Facebook, Inc. * All rights reserved. @@ -3585,28 +3567,22 @@ module.exports = DisabledInputUtils; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule EnterLeaveEventPlugin */ 'use strict'; -var EventConstants = require('./EventConstants'); var EventPropagators = require('./EventPropagators'); var ReactDOMComponentTree = require('./ReactDOMComponentTree'); var SyntheticMouseEvent = require('./SyntheticMouseEvent'); -var keyOf = require('fbjs/lib/keyOf'); - -var topLevelTypes = EventConstants.topLevelTypes; - var eventTypes = { mouseEnter: { - registrationName: keyOf({ onMouseEnter: null }), - dependencies: [topLevelTypes.topMouseOut, topLevelTypes.topMouseOver] + registrationName: 'onMouseEnter', + dependencies: ['topMouseOut', 'topMouseOver'] }, mouseLeave: { - registrationName: keyOf({ onMouseLeave: null }), - dependencies: [topLevelTypes.topMouseOut, topLevelTypes.topMouseOver] + registrationName: 'onMouseLeave', + dependencies: ['topMouseOut', 'topMouseOver'] } }; @@ -3622,10 +3598,10 @@ var EnterLeaveEventPlugin = { * the `mouseover` top-level event. */ extractEvents: function (topLevelType, targetInst, nativeEvent, nativeEventTarget) { - if (topLevelType === topLevelTypes.topMouseOver && (nativeEvent.relatedTarget || nativeEvent.fromElement)) { + if (topLevelType === 'topMouseOver' && (nativeEvent.relatedTarget || nativeEvent.fromElement)) { return null; } - if (topLevelType !== topLevelTypes.topMouseOut && topLevelType !== topLevelTypes.topMouseOver) { + if (topLevelType !== 'topMouseOut' && topLevelType !== 'topMouseOver') { // Must not be a mouse in or mouse out - ignoring. return null; } @@ -3646,7 +3622,7 @@ var EnterLeaveEventPlugin = { var from; var to; - if (topLevelType === topLevelTypes.topMouseOut) { + if (topLevelType === 'topMouseOut') { from = targetInst; var related = nativeEvent.relatedTarget || nativeEvent.toElement; to = related ? ReactDOMComponentTree.getClosestInstanceFromNode(related) : null; @@ -3682,105 +3658,7 @@ var EnterLeaveEventPlugin = { }; module.exports = EnterLeaveEventPlugin; -},{"./EventConstants":43,"./EventPropagators":47,"./ReactDOMComponentTree":69,"./SyntheticMouseEvent":132,"fbjs/lib/keyOf":20}],43:[function(require,module,exports){ -/** - * Copyright 2013-present, Facebook, Inc. - * All rights reserved. - * - * This source code is licensed under the BSD-style license found in the - * LICENSE file in the root directory of this source tree. An additional grant - * of patent rights can be found in the PATENTS file in the same directory. - * - * @providesModule EventConstants - */ - -'use strict'; - -var keyMirror = require('fbjs/lib/keyMirror'); - -var PropagationPhases = keyMirror({ bubbled: null, captured: null }); - -/** - * Types of raw signals from the browser caught at the top level. - */ -var topLevelTypes = keyMirror({ - topAbort: null, - topAnimationEnd: null, - topAnimationIteration: null, - topAnimationStart: null, - topBlur: null, - topCanPlay: null, - topCanPlayThrough: null, - topChange: null, - topClick: null, - topCompositionEnd: null, - topCompositionStart: null, - topCompositionUpdate: null, - topContextMenu: null, - topCopy: null, - topCut: null, - topDoubleClick: null, - topDrag: null, - topDragEnd: null, - topDragEnter: null, - topDragExit: null, - topDragLeave: null, - topDragOver: null, - topDragStart: null, - topDrop: null, - topDurationChange: null, - topEmptied: null, - topEncrypted: null, - topEnded: null, - topError: null, - topFocus: null, - topInput: null, - topInvalid: null, - topKeyDown: null, - topKeyPress: null, - topKeyUp: null, - topLoad: null, - topLoadedData: null, - topLoadedMetadata: null, - topLoadStart: null, - topMouseDown: null, - topMouseMove: null, - topMouseOut: null, - topMouseOver: null, - topMouseUp: null, - topPaste: null, - topPause: null, - topPlay: null, - topPlaying: null, - topProgress: null, - topRateChange: null, - topReset: null, - topScroll: null, - topSeeked: null, - topSeeking: null, - topSelectionChange: null, - topStalled: null, - topSubmit: null, - topSuspend: null, - topTextInput: null, - topTimeUpdate: null, - topTouchCancel: null, - topTouchEnd: null, - topTouchMove: null, - topTouchStart: null, - topTransitionEnd: null, - topVolumeChange: null, - topWaiting: null, - topWheel: null -}); - -var EventConstants = { - topLevelTypes: topLevelTypes, - PropagationPhases: PropagationPhases -}; - -module.exports = EventConstants; -},{"fbjs/lib/keyMirror":19}],44:[function(require,module,exports){ +},{"./EventPropagators":44,"./ReactDOMComponentTree":58,"./SyntheticMouseEvent":115}],41:[function(require,module,exports){ (function (process){ /** * Copyright 2013-present, Facebook, Inc. @@ -3790,7 +3668,6 @@ module.exports = EventConstants; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule EventPluginHub */ 'use strict'; @@ -3845,6 +3722,28 @@ var getDictionaryKey = function (inst) { return '.' + inst._rootNodeID; }; +function isInteractive(tag) { + return tag === 'button' || tag === 'input' || tag === 'select' || tag === 'textarea'; +} + +function shouldPreventMouseEvent(name, type, props) { + switch (name) { + case 'onClick': + case 'onClickCapture': + case 'onDoubleClick': + case 'onDoubleClickCapture': + case 'onMouseDown': + case 'onMouseDownCapture': + case 'onMouseMove': + case 'onMouseMoveCapture': + case 'onMouseUp': + case 'onMouseUpCapture': + return !!(props.disabled && isInteractive(type)); + default: + return false; + } +} + /** * This is a unified interface for event plugins to be installed and configured. * @@ -3913,7 +3812,12 @@ var EventPluginHub = { * @return {?function} The stored callback. */ getListener: function (inst, registrationName) { + // TODO: shouldPreventMouseEvent is DOM-specific and definitely should not + // live here; needs to be moved to a better place soon var bankForRegistrationName = listenerBank[registrationName]; + if (shouldPreventMouseEvent(registrationName, inst._currentElement.type, inst._currentElement.props)) { + return null; + } var key = getDictionaryKey(inst); return bankForRegistrationName && bankForRegistrationName[key]; }, @@ -4035,7 +3939,7 @@ var EventPluginHub = { module.exports = EventPluginHub; }).call(this,require('_process')) -},{"./EventPluginRegistry":45,"./EventPluginUtils":46,"./ReactErrorUtils":90,"./accumulateInto":139,"./forEachAccumulated":148,"./reactProdInvariant":163,"_process":27,"fbjs/lib/invariant":16}],45:[function(require,module,exports){ +},{"./EventPluginRegistry":42,"./EventPluginUtils":43,"./ReactErrorUtils":78,"./accumulateInto":122,"./forEachAccumulated":130,"./reactProdInvariant":145,"_process":25,"fbjs/lib/invariant":16}],42:[function(require,module,exports){ (function (process){ /** * Copyright 2013-present, Facebook, Inc. @@ -4045,7 +3949,7 @@ module.exports = EventPluginHub; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule EventPluginRegistry + * */ 'use strict'; @@ -4057,7 +3961,7 @@ var invariant = require('fbjs/lib/invariant'); /** * Injectable ordering of event plugins. */ -var EventPluginOrder = null; +var eventPluginOrder = null; /** * Injectable mapping from names to event plugin modules. @@ -4070,22 +3974,22 @@ var namesToPlugins = {}; * @private */ function recomputePluginOrdering() { - if (!EventPluginOrder) { - // Wait until an `EventPluginOrder` is injected. + if (!eventPluginOrder) { + // Wait until an `eventPluginOrder` is injected. return; } for (var pluginName in namesToPlugins) { - var PluginModule = namesToPlugins[pluginName]; - var pluginIndex = EventPluginOrder.indexOf(pluginName); + var pluginModule = namesToPlugins[pluginName]; + var pluginIndex = eventPluginOrder.indexOf(pluginName); !(pluginIndex > -1) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginRegistry: Cannot inject event plugins that do not exist in the plugin ordering, `%s`.', pluginName) : _prodInvariant('96', pluginName) : void 0; if (EventPluginRegistry.plugins[pluginIndex]) { continue; } - !PluginModule.extractEvents ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginRegistry: Event plugins must implement an `extractEvents` method, but `%s` does not.', pluginName) : _prodInvariant('97', pluginName) : void 0; - EventPluginRegistry.plugins[pluginIndex] = PluginModule; - var publishedEvents = PluginModule.eventTypes; + !pluginModule.extractEvents ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginRegistry: Event plugins must implement an `extractEvents` method, but `%s` does not.', pluginName) : _prodInvariant('97', pluginName) : void 0; + EventPluginRegistry.plugins[pluginIndex] = pluginModule; + var publishedEvents = pluginModule.eventTypes; for (var eventName in publishedEvents) { - !publishEventForPlugin(publishedEvents[eventName], PluginModule, eventName) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginRegistry: Failed to publish event `%s` for plugin `%s`.', eventName, pluginName) : _prodInvariant('98', eventName, pluginName) : void 0; + !publishEventForPlugin(publishedEvents[eventName], pluginModule, eventName) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginRegistry: Failed to publish event `%s` for plugin `%s`.', eventName, pluginName) : _prodInvariant('98', eventName, pluginName) : void 0; } } } @@ -4098,7 +4002,7 @@ function recomputePluginOrdering() { * @return {boolean} True if the event was successfully published. * @private */ -function publishEventForPlugin(dispatchConfig, PluginModule, eventName) { +function publishEventForPlugin(dispatchConfig, pluginModule, eventName) { !!EventPluginRegistry.eventNameDispatchConfigs.hasOwnProperty(eventName) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginHub: More than one plugin attempted to publish the same event name, `%s`.', eventName) : _prodInvariant('99', eventName) : void 0; EventPluginRegistry.eventNameDispatchConfigs[eventName] = dispatchConfig; @@ -4107,12 +4011,12 @@ function publishEventForPlugin(dispatchConfig, PluginModule, eventName) { for (var phaseName in phasedRegistrationNames) { if (phasedRegistrationNames.hasOwnProperty(phaseName)) { var phasedRegistrationName = phasedRegistrationNames[phaseName]; - publishRegistrationName(phasedRegistrationName, PluginModule, eventName); + publishRegistrationName(phasedRegistrationName, pluginModule, eventName); } } return true; } else if (dispatchConfig.registrationName) { - publishRegistrationName(dispatchConfig.registrationName, PluginModule, eventName); + publishRegistrationName(dispatchConfig.registrationName, pluginModule, eventName); return true; } return false; @@ -4126,10 +4030,10 @@ function publishEventForPlugin(dispatchConfig, PluginModule, eventName) { * @param {object} PluginModule Plugin publishing the event. * @private */ -function publishRegistrationName(registrationName, PluginModule, eventName) { +function publishRegistrationName(registrationName, pluginModule, eventName) { !!EventPluginRegistry.registrationNameModules[registrationName] ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginHub: More than one plugin attempted to publish the same registration name, `%s`.', registrationName) : _prodInvariant('100', registrationName) : void 0; - EventPluginRegistry.registrationNameModules[registrationName] = PluginModule; - EventPluginRegistry.registrationNameDependencies[registrationName] = PluginModule.eventTypes[eventName].dependencies; + EventPluginRegistry.registrationNameModules[registrationName] = pluginModule; + EventPluginRegistry.registrationNameDependencies[registrationName] = pluginModule.eventTypes[eventName].dependencies; if (process.env.NODE_ENV !== 'production') { var lowerCasedName = registrationName.toLowerCase(); @@ -4175,6 +4079,7 @@ var EventPluginRegistry = { * @type {Object} */ possibleRegistrationNames: process.env.NODE_ENV !== 'production' ? {} : null, + // Trust the developer to only use possibleRegistrationNames in __DEV__ /** * Injects an ordering of plugins (by plugin name). This allows the ordering @@ -4185,10 +4090,10 @@ var EventPluginRegistry = { * @internal * @see {EventPluginHub.injection.injectEventPluginOrder} */ - injectEventPluginOrder: function (InjectedEventPluginOrder) { - !!EventPluginOrder ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginRegistry: Cannot inject event plugin ordering more than once. You are likely trying to load more than one copy of React.') : _prodInvariant('101') : void 0; + injectEventPluginOrder: function (injectedEventPluginOrder) { + !!eventPluginOrder ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginRegistry: Cannot inject event plugin ordering more than once. You are likely trying to load more than one copy of React.') : _prodInvariant('101') : void 0; // Clone the ordering so it cannot be dynamically mutated. - EventPluginOrder = Array.prototype.slice.call(InjectedEventPluginOrder); + eventPluginOrder = Array.prototype.slice.call(injectedEventPluginOrder); recomputePluginOrdering(); }, @@ -4208,10 +4113,10 @@ var EventPluginRegistry = { if (!injectedNamesToPlugins.hasOwnProperty(pluginName)) { continue; } - var PluginModule = injectedNamesToPlugins[pluginName]; - if (!namesToPlugins.hasOwnProperty(pluginName) || namesToPlugins[pluginName] !== PluginModule) { + var pluginModule = injectedNamesToPlugins[pluginName]; + if (!namesToPlugins.hasOwnProperty(pluginName) || namesToPlugins[pluginName] !== pluginModule) { !!namesToPlugins[pluginName] ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginRegistry: Cannot inject two different event plugins using the same name, `%s`.', pluginName) : _prodInvariant('102', pluginName) : void 0; - namesToPlugins[pluginName] = PluginModule; + namesToPlugins[pluginName] = pluginModule; isOrderingDirty = true; } } @@ -4232,13 +4137,19 @@ var EventPluginRegistry = { if (dispatchConfig.registrationName) { return EventPluginRegistry.registrationNameModules[dispatchConfig.registrationName] || null; } - for (var phase in dispatchConfig.phasedRegistrationNames) { - if (!dispatchConfig.phasedRegistrationNames.hasOwnProperty(phase)) { - continue; - } - var PluginModule = EventPluginRegistry.registrationNameModules[dispatchConfig.phasedRegistrationNames[phase]]; - if (PluginModule) { - return PluginModule; + if (dispatchConfig.phasedRegistrationNames !== undefined) { + // pulling phasedRegistrationNames out of dispatchConfig helps Flow see + // that it is not undefined. + var phasedRegistrationNames = dispatchConfig.phasedRegistrationNames; + + for (var phase in phasedRegistrationNames) { + if (!phasedRegistrationNames.hasOwnProperty(phase)) { + continue; + } + var pluginModule = EventPluginRegistry.registrationNameModules[phasedRegistrationNames[phase]]; + if (pluginModule) { + return pluginModule; + } } } return null; @@ -4249,7 +4160,7 @@ var EventPluginRegistry = { * @private */ _resetEventPlugins: function () { - EventPluginOrder = null; + eventPluginOrder = null; for (var pluginName in namesToPlugins) { if (namesToPlugins.hasOwnProperty(pluginName)) { delete namesToPlugins[pluginName]; @@ -4286,7 +4197,7 @@ var EventPluginRegistry = { module.exports = EventPluginRegistry; }).call(this,require('_process')) -},{"./reactProdInvariant":163,"_process":27,"fbjs/lib/invariant":16}],46:[function(require,module,exports){ +},{"./reactProdInvariant":145,"_process":25,"fbjs/lib/invariant":16}],43:[function(require,module,exports){ (function (process){ /** * Copyright 2013-present, Facebook, Inc. @@ -4296,14 +4207,12 @@ module.exports = EventPluginRegistry; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule EventPluginUtils */ 'use strict'; var _prodInvariant = require('./reactProdInvariant'); -var EventConstants = require('./EventConstants'); var ReactErrorUtils = require('./ReactErrorUtils'); var invariant = require('fbjs/lib/invariant'); @@ -4334,17 +4243,15 @@ var injection = { } }; -var topLevelTypes = EventConstants.topLevelTypes; - function isEndish(topLevelType) { - return topLevelType === topLevelTypes.topMouseUp || topLevelType === topLevelTypes.topTouchEnd || topLevelType === topLevelTypes.topTouchCancel; + return topLevelType === 'topMouseUp' || topLevelType === 'topTouchEnd' || topLevelType === 'topTouchCancel'; } function isMoveish(topLevelType) { - return topLevelType === topLevelTypes.topMouseMove || topLevelType === topLevelTypes.topTouchMove; + return topLevelType === 'topMouseMove' || topLevelType === 'topTouchMove'; } function isStartish(topLevelType) { - return topLevelType === topLevelTypes.topMouseDown || topLevelType === topLevelTypes.topTouchStart; + return topLevelType === 'topMouseDown' || topLevelType === 'topTouchStart'; } var validateEventDispatches; @@ -4519,7 +4426,7 @@ var EventPluginUtils = { module.exports = EventPluginUtils; }).call(this,require('_process')) -},{"./EventConstants":43,"./ReactErrorUtils":90,"./reactProdInvariant":163,"_process":27,"fbjs/lib/invariant":16,"fbjs/lib/warning":25}],47:[function(require,module,exports){ +},{"./ReactErrorUtils":78,"./reactProdInvariant":145,"_process":25,"fbjs/lib/invariant":16,"fbjs/lib/warning":23}],44:[function(require,module,exports){ (function (process){ /** * Copyright 2013-present, Facebook, Inc. @@ -4529,12 +4436,10 @@ module.exports = EventPluginUtils; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule EventPropagators */ 'use strict'; -var EventConstants = require('./EventConstants'); var EventPluginHub = require('./EventPluginHub'); var EventPluginUtils = require('./EventPluginUtils'); @@ -4542,7 +4447,6 @@ var accumulateInto = require('./accumulateInto'); var forEachAccumulated = require('./forEachAccumulated'); var warning = require('fbjs/lib/warning'); -var PropagationPhases = EventConstants.PropagationPhases; var getListener = EventPluginHub.getListener; /** @@ -4560,11 +4464,10 @@ function listenerAtPhase(inst, event, propagationPhase) { * Mutating the event's members allows us to not have to create a wrapping * "dispatch" object that pairs the event with the listener. */ -function accumulateDirectionalDispatches(inst, upwards, event) { +function accumulateDirectionalDispatches(inst, phase, event) { if (process.env.NODE_ENV !== 'production') { process.env.NODE_ENV !== 'production' ? warning(inst, 'Dispatching inst must not be null') : void 0; } - var phase = upwards ? PropagationPhases.bubbled : PropagationPhases.captured; var listener = listenerAtPhase(inst, event, phase); if (listener) { event._dispatchListeners = accumulateInto(event._dispatchListeners, listener); @@ -4660,7 +4563,7 @@ var EventPropagators = { module.exports = EventPropagators; }).call(this,require('_process')) -},{"./EventConstants":43,"./EventPluginHub":44,"./EventPluginUtils":46,"./accumulateInto":139,"./forEachAccumulated":148,"_process":27,"fbjs/lib/warning":25}],48:[function(require,module,exports){ +},{"./EventPluginHub":41,"./EventPluginUtils":43,"./accumulateInto":122,"./forEachAccumulated":130,"_process":25,"fbjs/lib/warning":23}],45:[function(require,module,exports){ /** * Copyright 2013-present, Facebook, Inc. * All rights reserved. @@ -4669,7 +4572,6 @@ module.exports = EventPropagators; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule FallbackCompositionState */ 'use strict'; @@ -4756,7 +4658,7 @@ _assign(FallbackCompositionState.prototype, { PooledClass.addPoolingTo(FallbackCompositionState); module.exports = FallbackCompositionState; -},{"./PooledClass":52,"./getTextContentAccessor":156,"object-assign":26}],49:[function(require,module,exports){ +},{"./PooledClass":49,"./getTextContentAccessor":139,"object-assign":24}],46:[function(require,module,exports){ /** * Copyright 2013-present, Facebook, Inc. * All rights reserved. @@ -4765,7 +4667,6 @@ module.exports = FallbackCompositionState; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule HTMLDOMPropertyConfig */ 'use strict'; @@ -4969,7 +4870,7 @@ var HTMLDOMPropertyConfig = { }; module.exports = HTMLDOMPropertyConfig; -},{"./DOMProperty":37}],50:[function(require,module,exports){ +},{"./DOMProperty":36}],47:[function(require,module,exports){ /** * Copyright 2013-present, Facebook, Inc. * All rights reserved. @@ -4978,7 +4879,6 @@ module.exports = HTMLDOMPropertyConfig; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule KeyEscapeUtils * */ @@ -5029,7 +4929,7 @@ var KeyEscapeUtils = { }; module.exports = KeyEscapeUtils; -},{}],51:[function(require,module,exports){ +},{}],48:[function(require,module,exports){ (function (process){ /** * Copyright 2013-present, Facebook, Inc. @@ -5039,15 +4939,13 @@ module.exports = KeyEscapeUtils; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule LinkedValueUtils */ 'use strict'; var _prodInvariant = require('./reactProdInvariant'); -var ReactPropTypes = require('./ReactPropTypes'); -var ReactPropTypeLocations = require('./ReactPropTypeLocations'); +var React = require('react/lib/React'); var ReactPropTypesSecret = require('./ReactPropTypesSecret'); var invariant = require('fbjs/lib/invariant'); @@ -5089,7 +4987,7 @@ var propTypes = { } return new Error('You provided a `checked` prop to a form field without an ' + '`onChange` handler. This will render a read-only field. If ' + 'the field should be mutable use `defaultChecked`. Otherwise, ' + 'set either `onChange` or `readOnly`.'); }, - onChange: ReactPropTypes.func + onChange: React.PropTypes.func }; var loggedTypeFailures = {}; @@ -5111,7 +5009,7 @@ var LinkedValueUtils = { checkPropTypes: function (tagName, props, owner) { for (var propName in propTypes) { if (propTypes.hasOwnProperty(propName)) { - var error = propTypes[propName](props, propName, tagName, ReactPropTypeLocations.prop, null, ReactPropTypesSecret); + var error = propTypes[propName](props, propName, tagName, 'prop', null, ReactPropTypesSecret); } if (error instanceof Error && !(error.message in loggedTypeFailures)) { // Only monitor this failure once because there tends to be a lot of the @@ -5169,7 +5067,7 @@ var LinkedValueUtils = { module.exports = LinkedValueUtils; }).call(this,require('_process')) -},{"./ReactPropTypeLocations":109,"./ReactPropTypes":110,"./ReactPropTypesSecret":111,"./reactProdInvariant":163,"_process":27,"fbjs/lib/invariant":16,"fbjs/lib/warning":25}],52:[function(require,module,exports){ +},{"./ReactPropTypesSecret":95,"./reactProdInvariant":145,"_process":25,"fbjs/lib/invariant":16,"fbjs/lib/warning":23,"react/lib/React":154}],49:[function(require,module,exports){ (function (process){ /** * Copyright 2013-present, Facebook, Inc. @@ -5179,7 +5077,7 @@ module.exports = LinkedValueUtils; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule PooledClass + * */ 'use strict'; @@ -5272,6 +5170,8 @@ var DEFAULT_POOLER = oneArgumentPooler; * @param {Function} pooler Customizable pooler. */ var addPoolingTo = function (CopyConstructor, pooler) { + // Casting as any so that flow ignores the actual implementation and trusts + // it to match the type we declared var NewKlass = CopyConstructor; NewKlass.instancePool = []; NewKlass.getPooled = pooler || DEFAULT_POOLER; @@ -5294,8 +5194,7 @@ var PooledClass = { module.exports = PooledClass; }).call(this,require('_process')) -},{"./reactProdInvariant":163,"_process":27,"fbjs/lib/invariant":16}],53:[function(require,module,exports){ -(function (process){ +},{"./reactProdInvariant":145,"_process":25,"fbjs/lib/invariant":16}],50:[function(require,module,exports){ /** * Copyright 2013-present, Facebook, Inc. * All rights reserved. @@ -5304,112 +5203,18 @@ module.exports = PooledClass; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule React */ 'use strict'; var _assign = require('object-assign'); -var ReactChildren = require('./ReactChildren'); -var ReactComponent = require('./ReactComponent'); -var ReactPureComponent = require('./ReactPureComponent'); -var ReactClass = require('./ReactClass'); -var ReactDOMFactories = require('./ReactDOMFactories'); -var ReactElement = require('./ReactElement'); -var ReactPropTypes = require('./ReactPropTypes'); -var ReactVersion = require('./ReactVersion'); - -var onlyChild = require('./onlyChild'); -var warning = require('fbjs/lib/warning'); - -var createElement = ReactElement.createElement; -var createFactory = ReactElement.createFactory; -var cloneElement = ReactElement.cloneElement; - -if (process.env.NODE_ENV !== 'production') { - var ReactElementValidator = require('./ReactElementValidator'); - createElement = ReactElementValidator.createElement; - createFactory = ReactElementValidator.createFactory; - cloneElement = ReactElementValidator.cloneElement; -} - -var __spread = _assign; - -if (process.env.NODE_ENV !== 'production') { - var warned = false; - __spread = function () { - process.env.NODE_ENV !== 'production' ? warning(warned, 'React.__spread is deprecated and should not be used. Use ' + 'Object.assign directly or another helper function with similar ' + 'semantics. You may be seeing this warning due to your compiler. ' + 'See https://fb.me/react-spread-deprecation for more details.') : void 0; - warned = true; - return _assign.apply(null, arguments); - }; -} - -var React = { - - // Modern - - Children: { - map: ReactChildren.map, - forEach: ReactChildren.forEach, - count: ReactChildren.count, - toArray: ReactChildren.toArray, - only: onlyChild - }, - - Component: ReactComponent, - PureComponent: ReactPureComponent, - - createElement: createElement, - cloneElement: cloneElement, - isValidElement: ReactElement.isValidElement, +var EventPluginRegistry = require('./EventPluginRegistry'); +var ReactEventEmitterMixin = require('./ReactEventEmitterMixin'); +var ViewportMetrics = require('./ViewportMetrics'); - // Classic - - PropTypes: ReactPropTypes, - createClass: ReactClass.createClass, - createFactory: createFactory, - createMixin: function (mixin) { - // Currently a noop. Will be used to validate and trace mixins. - return mixin; - }, - - // This looks DOM specific but these are actually isomorphic helpers - // since they are just generating DOM strings. - DOM: ReactDOMFactories, - - version: ReactVersion, - - // Deprecated hook for JSX spread, don't use this for anything. - __spread: __spread -}; - -module.exports = React; -}).call(this,require('_process')) - -},{"./ReactChildren":56,"./ReactClass":58,"./ReactComponent":59,"./ReactDOMFactories":72,"./ReactElement":87,"./ReactElementValidator":88,"./ReactPropTypes":110,"./ReactPureComponent":112,"./ReactVersion":120,"./onlyChild":161,"_process":27,"fbjs/lib/warning":25,"object-assign":26}],54:[function(require,module,exports){ -/** - * Copyright 2013-present, Facebook, Inc. - * All rights reserved. - * - * This source code is licensed under the BSD-style license found in the - * LICENSE file in the root directory of this source tree. An additional grant - * of patent rights can be found in the PATENTS file in the same directory. - * - * @providesModule ReactBrowserEventEmitter - */ - -'use strict'; - -var _assign = require('object-assign'); - -var EventConstants = require('./EventConstants'); -var EventPluginRegistry = require('./EventPluginRegistry'); -var ReactEventEmitterMixin = require('./ReactEventEmitterMixin'); -var ViewportMetrics = require('./ViewportMetrics'); - -var getVendorPrefixedEventName = require('./getVendorPrefixedEventName'); -var isEventSupported = require('./isEventSupported'); +var getVendorPrefixedEventName = require('./getVendorPrefixedEventName'); +var isEventSupported = require('./isEventSupported'); /** * Summary of `ReactBrowserEventEmitter` event handling: @@ -5627,42 +5432,41 @@ var ReactBrowserEventEmitter = _assign({}, ReactEventEmitterMixin, { var isListening = getListeningForDocument(mountAt); var dependencies = EventPluginRegistry.registrationNameDependencies[registrationName]; - var topLevelTypes = EventConstants.topLevelTypes; for (var i = 0; i < dependencies.length; i++) { var dependency = dependencies[i]; if (!(isListening.hasOwnProperty(dependency) && isListening[dependency])) { - if (dependency === topLevelTypes.topWheel) { + if (dependency === 'topWheel') { if (isEventSupported('wheel')) { - ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(topLevelTypes.topWheel, 'wheel', mountAt); + ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent('topWheel', 'wheel', mountAt); } else if (isEventSupported('mousewheel')) { - ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(topLevelTypes.topWheel, 'mousewheel', mountAt); + ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent('topWheel', 'mousewheel', mountAt); } else { // Firefox needs to capture a different mouse scroll event. // @see http://www.quirksmode.org/dom/events/tests/scroll.html - ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(topLevelTypes.topWheel, 'DOMMouseScroll', mountAt); + ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent('topWheel', 'DOMMouseScroll', mountAt); } - } else if (dependency === topLevelTypes.topScroll) { + } else if (dependency === 'topScroll') { if (isEventSupported('scroll', true)) { - ReactBrowserEventEmitter.ReactEventListener.trapCapturedEvent(topLevelTypes.topScroll, 'scroll', mountAt); + ReactBrowserEventEmitter.ReactEventListener.trapCapturedEvent('topScroll', 'scroll', mountAt); } else { - ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(topLevelTypes.topScroll, 'scroll', ReactBrowserEventEmitter.ReactEventListener.WINDOW_HANDLE); + ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent('topScroll', 'scroll', ReactBrowserEventEmitter.ReactEventListener.WINDOW_HANDLE); } - } else if (dependency === topLevelTypes.topFocus || dependency === topLevelTypes.topBlur) { + } else if (dependency === 'topFocus' || dependency === 'topBlur') { if (isEventSupported('focus', true)) { - ReactBrowserEventEmitter.ReactEventListener.trapCapturedEvent(topLevelTypes.topFocus, 'focus', mountAt); - ReactBrowserEventEmitter.ReactEventListener.trapCapturedEvent(topLevelTypes.topBlur, 'blur', mountAt); + ReactBrowserEventEmitter.ReactEventListener.trapCapturedEvent('topFocus', 'focus', mountAt); + ReactBrowserEventEmitter.ReactEventListener.trapCapturedEvent('topBlur', 'blur', mountAt); } else if (isEventSupported('focusin')) { // IE has `focusin` and `focusout` events which bubble. // @see http://www.quirksmode.org/blog/archives/2008/04/delegating_the.html - ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(topLevelTypes.topFocus, 'focusin', mountAt); - ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(topLevelTypes.topBlur, 'focusout', mountAt); + ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent('topFocus', 'focusin', mountAt); + ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent('topBlur', 'focusout', mountAt); } // to make sure blur and focus event listeners are only attached once - isListening[topLevelTypes.topBlur] = true; - isListening[topLevelTypes.topFocus] = true; + isListening.topBlur = true; + isListening.topFocus = true; } else if (topEventMapping.hasOwnProperty(dependency)) { ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(dependency, topEventMapping[dependency], mountAt); } @@ -5718,7 +5522,7 @@ var ReactBrowserEventEmitter = _assign({}, ReactEventEmitterMixin, { }); module.exports = ReactBrowserEventEmitter; -},{"./EventConstants":43,"./EventPluginRegistry":45,"./ReactEventEmitterMixin":91,"./ViewportMetrics":138,"./getVendorPrefixedEventName":157,"./isEventSupported":159,"object-assign":26}],55:[function(require,module,exports){ +},{"./EventPluginRegistry":42,"./ReactEventEmitterMixin":79,"./ViewportMetrics":121,"./getVendorPrefixedEventName":140,"./isEventSupported":142,"object-assign":24}],51:[function(require,module,exports){ (function (process){ /** * Copyright 2014-present, Facebook, Inc. @@ -5728,7 +5532,6 @@ module.exports = ReactBrowserEventEmitter; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule ReactChildReconciler */ 'use strict'; @@ -5749,7 +5552,7 @@ if (typeof process !== 'undefined' && process.env && process.env.NODE_ENV === 't // https://github.com/facebook/react/issues/7240 // Remove the inline requires when we don't need them anymore: // https://github.com/facebook/react/pull/7178 - ReactComponentTreeHook = require('./ReactComponentTreeHook'); + ReactComponentTreeHook = require('react/lib/ReactComponentTreeHook'); } function instantiateChild(childInstances, child, name, selfDebugID) { @@ -5757,7 +5560,7 @@ function instantiateChild(childInstances, child, name, selfDebugID) { var keyUnique = childInstances[name] === undefined; if (process.env.NODE_ENV !== 'production') { if (!ReactComponentTreeHook) { - ReactComponentTreeHook = require('./ReactComponentTreeHook'); + ReactComponentTreeHook = require('react/lib/ReactComponentTreeHook'); } if (!keyUnique) { process.env.NODE_ENV !== 'production' ? warning(false, 'flattenChildren(...): Encountered two children with the same key, ' + '`%s`. Child keys must be unique; when two children share a key, only ' + 'the first child will be used.%s', KeyEscapeUtils.unescape(name), ReactComponentTreeHook.getStackAddendumByID(selfDebugID)) : void 0; @@ -5876,7 +5679,7 @@ var ReactChildReconciler = { module.exports = ReactChildReconciler; }).call(this,require('_process')) -},{"./KeyEscapeUtils":50,"./ReactComponentTreeHook":62,"./ReactReconciler":114,"./instantiateReactComponent":158,"./shouldUpdateReactComponent":167,"./traverseAllChildren":168,"_process":27,"fbjs/lib/warning":25}],56:[function(require,module,exports){ +},{"./KeyEscapeUtils":47,"./ReactReconciler":97,"./instantiateReactComponent":141,"./shouldUpdateReactComponent":149,"./traverseAllChildren":150,"_process":25,"fbjs/lib/warning":23,"react/lib/ReactComponentTreeHook":158}],52:[function(require,module,exports){ /** * Copyright 2013-present, Facebook, Inc. * All rights reserved. @@ -5885,190 +5688,77 @@ module.exports = ReactChildReconciler; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule ReactChildren */ 'use strict'; -var PooledClass = require('./PooledClass'); -var ReactElement = require('./ReactElement'); - -var emptyFunction = require('fbjs/lib/emptyFunction'); -var traverseAllChildren = require('./traverseAllChildren'); - -var twoArgumentPooler = PooledClass.twoArgumentPooler; -var fourArgumentPooler = PooledClass.fourArgumentPooler; - -var userProvidedKeyEscapeRegex = /\/+/g; -function escapeUserProvidedKey(text) { - return ('' + text).replace(userProvidedKeyEscapeRegex, '$&/'); -} +var DOMChildrenOperations = require('./DOMChildrenOperations'); +var ReactDOMIDOperations = require('./ReactDOMIDOperations'); /** - * PooledClass representing the bookkeeping associated with performing a child - * traversal. Allows avoiding binding callbacks. - * - * @constructor ForEachBookKeeping - * @param {!function} forEachFunction Function to perform traversal with. - * @param {?*} forEachContext Context to perform context with. + * Abstracts away all functionality of the reconciler that requires knowledge of + * the browser context. TODO: These callers should be refactored to avoid the + * need for this injection. */ -function ForEachBookKeeping(forEachFunction, forEachContext) { - this.func = forEachFunction; - this.context = forEachContext; - this.count = 0; -} -ForEachBookKeeping.prototype.destructor = function () { - this.func = null; - this.context = null; - this.count = 0; -}; -PooledClass.addPoolingTo(ForEachBookKeeping, twoArgumentPooler); +var ReactComponentBrowserEnvironment = { -function forEachSingleChild(bookKeeping, child, name) { - var func = bookKeeping.func; - var context = bookKeeping.context; + processChildrenUpdates: ReactDOMIDOperations.dangerouslyProcessChildrenUpdates, - func.call(context, child, bookKeeping.count++); -} + replaceNodeWithMarkup: DOMChildrenOperations.dangerouslyReplaceNodeWithMarkup -/** - * Iterates through children that are typically specified as `props.children`. - * - * See https://facebook.github.io/react/docs/top-level-api.html#react.children.foreach - * - * The provided forEachFunc(child, index) will be called for each - * leaf child. - * - * @param {?*} children Children tree container. - * @param {function(*, int)} forEachFunc - * @param {*} forEachContext Context for forEachContext. - */ -function forEachChildren(children, forEachFunc, forEachContext) { - if (children == null) { - return children; - } - var traverseContext = ForEachBookKeeping.getPooled(forEachFunc, forEachContext); - traverseAllChildren(children, forEachSingleChild, traverseContext); - ForEachBookKeeping.release(traverseContext); -} +}; +module.exports = ReactComponentBrowserEnvironment; +},{"./DOMChildrenOperations":33,"./ReactDOMIDOperations":62}],53:[function(require,module,exports){ +(function (process){ /** - * PooledClass representing the bookkeeping associated with performing a child - * mapping. Allows avoiding binding callbacks. + * Copyright 2014-present, Facebook, Inc. + * All rights reserved. * - * @constructor MapBookKeeping - * @param {!*} mapResult Object containing the ordered map of results. - * @param {!function} mapFunction Function to perform mapping with. - * @param {?*} mapContext Context to perform mapping with. + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. An additional grant + * of patent rights can be found in the PATENTS file in the same directory. + * + * */ -function MapBookKeeping(mapResult, keyPrefix, mapFunction, mapContext) { - this.result = mapResult; - this.keyPrefix = keyPrefix; - this.func = mapFunction; - this.context = mapContext; - this.count = 0; -} -MapBookKeeping.prototype.destructor = function () { - this.result = null; - this.keyPrefix = null; - this.func = null; - this.context = null; - this.count = 0; -}; -PooledClass.addPoolingTo(MapBookKeeping, fourArgumentPooler); -function mapSingleChildIntoContext(bookKeeping, child, childKey) { - var result = bookKeeping.result; - var keyPrefix = bookKeeping.keyPrefix; - var func = bookKeeping.func; - var context = bookKeeping.context; +'use strict'; +var _prodInvariant = require('./reactProdInvariant'); - var mappedChild = func.call(context, child, bookKeeping.count++); - if (Array.isArray(mappedChild)) { - mapIntoWithKeyPrefixInternal(mappedChild, result, childKey, emptyFunction.thatReturnsArgument); - } else if (mappedChild != null) { - if (ReactElement.isValidElement(mappedChild)) { - mappedChild = ReactElement.cloneAndReplaceKey(mappedChild, - // Keep both the (mapped) and old keys if they differ, just as - // traverseAllChildren used to do for objects as children - keyPrefix + (mappedChild.key && (!child || child.key !== mappedChild.key) ? escapeUserProvidedKey(mappedChild.key) + '/' : '') + childKey); - } - result.push(mappedChild); - } -} +var invariant = require('fbjs/lib/invariant'); -function mapIntoWithKeyPrefixInternal(children, array, prefix, func, context) { - var escapedPrefix = ''; - if (prefix != null) { - escapedPrefix = escapeUserProvidedKey(prefix) + '/'; - } - var traverseContext = MapBookKeeping.getPooled(array, escapedPrefix, func, context); - traverseAllChildren(children, mapSingleChildIntoContext, traverseContext); - MapBookKeeping.release(traverseContext); -} +var injected = false; -/** - * Maps children that are typically specified as `props.children`. - * - * See https://facebook.github.io/react/docs/top-level-api.html#react.children.map - * - * The provided mapFunction(child, key, index) will be called for each - * leaf child. - * - * @param {?*} children Children tree container. - * @param {function(*, int)} func The map function. - * @param {*} context Context for mapFunction. - * @return {object} Object containing the ordered map of results. - */ -function mapChildren(children, func, context) { - if (children == null) { - return children; - } - var result = []; - mapIntoWithKeyPrefixInternal(children, result, null, func, context); - return result; -} +var ReactComponentEnvironment = { -function forEachSingleChildDummy(traverseContext, child, name) { - return null; -} + /** + * Optionally injectable hook for swapping out mount images in the middle of + * the tree. + */ + replaceNodeWithMarkup: null, -/** - * Count the number of children that are typically specified as - * `props.children`. - * - * See https://facebook.github.io/react/docs/top-level-api.html#react.children.count - * - * @param {?*} children Children tree container. - * @return {number} The number of children. - */ -function countChildren(children, context) { - return traverseAllChildren(children, forEachSingleChildDummy, null); -} + /** + * Optionally injectable hook for processing a queue of child updates. Will + * later move into MultiChildComponents. + */ + processChildrenUpdates: null, -/** - * Flatten a children object (typically specified as `props.children`) and - * return an array with appropriately re-keyed children. - * - * See https://facebook.github.io/react/docs/top-level-api.html#react.children.toarray - */ -function toArray(children) { - var result = []; - mapIntoWithKeyPrefixInternal(children, result, null, emptyFunction.thatReturnsArgument); - return result; -} + injection: { + injectEnvironment: function (environment) { + !!injected ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactCompositeComponent: injectEnvironment() can only be called once.') : _prodInvariant('104') : void 0; + ReactComponentEnvironment.replaceNodeWithMarkup = environment.replaceNodeWithMarkup; + ReactComponentEnvironment.processChildrenUpdates = environment.processChildrenUpdates; + injected = true; + } + } -var ReactChildren = { - forEach: forEachChildren, - map: mapChildren, - mapIntoWithKeyPrefixInternal: mapIntoWithKeyPrefixInternal, - count: countChildren, - toArray: toArray }; -module.exports = ReactChildren; -},{"./PooledClass":52,"./ReactElement":87,"./traverseAllChildren":168,"fbjs/lib/emptyFunction":8}],57:[function(require,module,exports){ +module.exports = ReactComponentEnvironment; +}).call(this,require('_process')) + +},{"./reactProdInvariant":145,"_process":25,"fbjs/lib/invariant":16}],54:[function(require,module,exports){ (function (process){ /** * Copyright 2013-present, Facebook, Inc. @@ -6078,2279 +5768,2032 @@ module.exports = ReactChildren; * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule ReactChildrenMutationWarningHook */ 'use strict'; -var ReactComponentTreeHook = require('./ReactComponentTreeHook'); +var _prodInvariant = require('./reactProdInvariant'), + _assign = require('object-assign'); + +var React = require('react/lib/React'); +var ReactComponentEnvironment = require('./ReactComponentEnvironment'); +var ReactCurrentOwner = require('react/lib/ReactCurrentOwner'); +var ReactErrorUtils = require('./ReactErrorUtils'); +var ReactInstanceMap = require('./ReactInstanceMap'); +var ReactInstrumentation = require('./ReactInstrumentation'); +var ReactNodeTypes = require('./ReactNodeTypes'); +var ReactReconciler = require('./ReactReconciler'); + +if (process.env.NODE_ENV !== 'production') { + var checkReactTypeSpec = require('./checkReactTypeSpec'); +} +var emptyObject = require('fbjs/lib/emptyObject'); +var invariant = require('fbjs/lib/invariant'); +var shallowEqual = require('fbjs/lib/shallowEqual'); +var shouldUpdateReactComponent = require('./shouldUpdateReactComponent'); var warning = require('fbjs/lib/warning'); -function handleElement(debugID, element) { - if (element == null) { - return; - } - if (element._shadowChildren === undefined) { - return; - } - if (element._shadowChildren === element.props.children) { - return; - } - var isMutated = false; - if (Array.isArray(element._shadowChildren)) { - if (element._shadowChildren.length === element.props.children.length) { - for (var i = 0; i < element._shadowChildren.length; i++) { - if (element._shadowChildren[i] !== element.props.children[i]) { - isMutated = true; - } - } - } else { - isMutated = true; - } - } - if (!Array.isArray(element._shadowChildren) || isMutated) { - process.env.NODE_ENV !== 'production' ? warning(false, 'Component\'s children should not be mutated.%s', ReactComponentTreeHook.getStackAddendumByID(debugID)) : void 0; +var CompositeTypes = { + ImpureClass: 0, + PureClass: 1, + StatelessFunctional: 2 +}; + +function StatelessComponent(Component) {} +StatelessComponent.prototype.render = function () { + var Component = ReactInstanceMap.get(this)._currentElement.type; + var element = Component(this.props, this.context, this.updater); + warnIfInvalidElement(Component, element); + return element; +}; + +function warnIfInvalidElement(Component, element) { + if (process.env.NODE_ENV !== 'production') { + process.env.NODE_ENV !== 'production' ? warning(element === null || element === false || React.isValidElement(element), '%s(...): A valid React element (or null) must be returned. You may have ' + 'returned undefined, an array or some other invalid object.', Component.displayName || Component.name || 'Component') : void 0; + process.env.NODE_ENV !== 'production' ? warning(!Component.childContextTypes, '%s(...): childContextTypes cannot be defined on a functional component.', Component.displayName || Component.name || 'Component') : void 0; } } -var ReactChildrenMutationWarningHook = { - onMountComponent: function (debugID) { - handleElement(debugID, ReactComponentTreeHook.getElement(debugID)); - }, - onUpdateComponent: function (debugID) { - handleElement(debugID, ReactComponentTreeHook.getElement(debugID)); +function shouldConstruct(Component) { + return !!(Component.prototype && Component.prototype.isReactComponent); +} + +function isPureComponent(Component) { + return !!(Component.prototype && Component.prototype.isPureReactComponent); +} + +// Separated into a function to contain deoptimizations caused by try/finally. +function measureLifeCyclePerf(fn, debugID, timerType) { + if (debugID === 0) { + // Top-level wrappers (see ReactMount) and empty components (see + // ReactDOMEmptyComponent) are invisible to hooks and devtools. + // Both are implementation details that should go away in the future. + return fn(); } -}; -module.exports = ReactChildrenMutationWarningHook; -}).call(this,require('_process')) + ReactInstrumentation.debugTool.onBeginLifeCycleTimer(debugID, timerType); + try { + return fn(); + } finally { + ReactInstrumentation.debugTool.onEndLifeCycleTimer(debugID, timerType); + } +} -},{"./ReactComponentTreeHook":62,"_process":27,"fbjs/lib/warning":25}],58:[function(require,module,exports){ -(function (process){ /** - * Copyright 2013-present, Facebook, Inc. - * All rights reserved. + * ------------------ The Life-Cycle of a Composite Component ------------------ * - * This source code is licensed under the BSD-style license found in the - * LICENSE file in the root directory of this source tree. An additional grant - * of patent rights can be found in the PATENTS file in the same directory. + * - constructor: Initialization of state. The instance is now retained. + * - componentWillMount + * - render + * - [children's constructors] + * - [children's componentWillMount and render] + * - [children's componentDidMount] + * - componentDidMount + * + * Update Phases: + * - componentWillReceiveProps (only called if parent updated) + * - shouldComponentUpdate + * - componentWillUpdate + * - render + * - [children's constructors or receive props phases] + * - componentDidUpdate + * + * - componentWillUnmount + * - [children's componentWillUnmount] + * - [children destroyed] + * - (destroyed): The instance is now blank, released by React and ready for GC. * - * @providesModule ReactClass + * ----------------------------------------------------------------------------- */ -'use strict'; - -var _prodInvariant = require('./reactProdInvariant'), - _assign = require('object-assign'); - -var ReactComponent = require('./ReactComponent'); -var ReactElement = require('./ReactElement'); -var ReactPropTypeLocations = require('./ReactPropTypeLocations'); -var ReactPropTypeLocationNames = require('./ReactPropTypeLocationNames'); -var ReactNoopUpdateQueue = require('./ReactNoopUpdateQueue'); - -var emptyObject = require('fbjs/lib/emptyObject'); -var invariant = require('fbjs/lib/invariant'); -var keyMirror = require('fbjs/lib/keyMirror'); -var keyOf = require('fbjs/lib/keyOf'); -var warning = require('fbjs/lib/warning'); - -var MIXINS_KEY = keyOf({ mixins: null }); - /** - * Policies that describe methods in `ReactClassInterface`. + * An incrementing ID assigned to each component when it is mounted. This is + * used to enforce the order in which `ReactUpdates` updates dirty components. + * + * @private */ -var SpecPolicy = keyMirror({ - /** - * These methods may be defined only once by the class specification or mixin. - */ - DEFINE_ONCE: null, - /** - * These methods may be defined by both the class specification and mixins. - * Subsequent definitions will be chained. These methods must return void. - */ - DEFINE_MANY: null, - /** - * These methods are overriding the base class. - */ - OVERRIDE_BASE: null, - /** - * These methods are similar to DEFINE_MANY, except we assume they return - * objects. We try to merge the keys of the return values of all the mixed in - * functions. If there is a key conflict we throw. - */ - DEFINE_MANY_MERGED: null -}); - -var injectedMixins = []; +var nextMountID = 1; /** - * Composite components are higher-level components that compose other composite - * or host components. - * - * To create a new type of `ReactClass`, pass a specification of - * your new class to `React.createClass`. The only requirement of your class - * specification is that you implement a `render` method. - * - * var MyComponent = React.createClass({ - * render: function() { - * return
Hello World
; - * } - * }); - * - * The class specification supports a specific protocol of methods that have - * special meaning (e.g. `render`). See `ReactClassInterface` for - * more the comprehensive protocol. Any other properties and methods in the - * class specification will be available on the prototype. - * - * @interface ReactClassInterface - * @internal + * @lends {ReactCompositeComponent.prototype} */ -var ReactClassInterface = { +var ReactCompositeComponent = { /** - * An array of Mixin objects to include when defining your component. + * Base constructor for all composite component. * - * @type {array} - * @optional + * @param {ReactElement} element + * @final + * @internal */ - mixins: SpecPolicy.DEFINE_MANY, + construct: function (element) { + this._currentElement = element; + this._rootNodeID = 0; + this._compositeType = null; + this._instance = null; + this._hostParent = null; + this._hostContainerInfo = null; - /** - * An object containing properties and methods that should be defined on - * the component's constructor instead of its prototype (static methods). - * - * @type {object} - * @optional - */ - statics: SpecPolicy.DEFINE_MANY, + // See ReactUpdateQueue + this._updateBatchNumber = null; + this._pendingElement = null; + this._pendingStateQueue = null; + this._pendingReplaceState = false; + this._pendingForceUpdate = false; - /** - * Definition of prop types for this component. - * - * @type {object} - * @optional - */ - propTypes: SpecPolicy.DEFINE_MANY, + this._renderedNodeType = null; + this._renderedComponent = null; + this._context = null; + this._mountOrder = 0; + this._topLevelWrapper = null; - /** - * Definition of context types for this component. - * - * @type {object} - * @optional - */ - contextTypes: SpecPolicy.DEFINE_MANY, + // See ReactUpdates and ReactUpdateQueue. + this._pendingCallbacks = null; - /** - * Definition of context types this component sets for its children. - * - * @type {object} - * @optional - */ - childContextTypes: SpecPolicy.DEFINE_MANY, + // ComponentWillUnmount shall only be called once + this._calledComponentWillUnmount = false; - // ==== Definition methods ==== + if (process.env.NODE_ENV !== 'production') { + this._warnedAboutRefsInRender = false; + } + }, /** - * Invoked when the component is mounted. Values in the mapping will be set on - * `this.props` if that prop is not specified (i.e. using an `in` check). - * - * This method is invoked before `getInitialState` and therefore cannot rely - * on `this.state` or use `this.setState`. + * Initializes the component, renders markup, and registers event listeners. * - * @return {object} - * @optional + * @param {ReactReconcileTransaction|ReactServerRenderingTransaction} transaction + * @param {?object} hostParent + * @param {?object} hostContainerInfo + * @param {?object} context + * @return {?string} Rendered markup to be inserted into the DOM. + * @final + * @internal */ - getDefaultProps: SpecPolicy.DEFINE_MANY_MERGED, + mountComponent: function (transaction, hostParent, hostContainerInfo, context) { + var _this = this; - /** - * Invoked once before the component is mounted. The return value will be used - * as the initial value of `this.state`. - * - * getInitialState: function() { - * return { - * isOn: false, - * fooBaz: new BazFoo() - * } - * } - * - * @return {object} - * @optional - */ - getInitialState: SpecPolicy.DEFINE_MANY_MERGED, + this._context = context; + this._mountOrder = nextMountID++; + this._hostParent = hostParent; + this._hostContainerInfo = hostContainerInfo; - /** - * @return {object} - * @optional - */ - getChildContext: SpecPolicy.DEFINE_MANY_MERGED, + var publicProps = this._currentElement.props; + var publicContext = this._processContext(context); - /** - * Uses props from `this.props` and state from `this.state` to render the - * structure of the component. - * - * No guarantees are made about when or how often this method is invoked, so - * it must not have side effects. - * - * render: function() { - * var name = this.props.name; - * return
Hello, {name}!
; - * } - * - * @return {ReactComponent} - * @nosideeffects - * @required - */ - render: SpecPolicy.DEFINE_ONCE, + var Component = this._currentElement.type; - // ==== Delegate methods ==== + var updateQueue = transaction.getUpdateQueue(); - /** - * Invoked when the component is initially created and about to be mounted. - * This may have side effects, but any external subscriptions or data created - * by this method must be cleaned up in `componentWillUnmount`. - * - * @optional - */ - componentWillMount: SpecPolicy.DEFINE_MANY, + // Initialize the public class + var doConstruct = shouldConstruct(Component); + var inst = this._constructComponent(doConstruct, publicProps, publicContext, updateQueue); + var renderedElement; - /** - * Invoked when the component has been mounted and has a DOM representation. - * However, there is no guarantee that the DOM node is in the document. - * - * Use this as an opportunity to operate on the DOM when the component has - * been mounted (initialized and rendered) for the first time. - * - * @param {DOMElement} rootNode DOM element representing the component. - * @optional - */ - componentDidMount: SpecPolicy.DEFINE_MANY, + // Support functional components + if (!doConstruct && (inst == null || inst.render == null)) { + renderedElement = inst; + warnIfInvalidElement(Component, renderedElement); + !(inst === null || inst === false || React.isValidElement(inst)) ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s(...): A valid React element (or null) must be returned. You may have returned undefined, an array or some other invalid object.', Component.displayName || Component.name || 'Component') : _prodInvariant('105', Component.displayName || Component.name || 'Component') : void 0; + inst = new StatelessComponent(Component); + this._compositeType = CompositeTypes.StatelessFunctional; + } else { + if (isPureComponent(Component)) { + this._compositeType = CompositeTypes.PureClass; + } else { + this._compositeType = CompositeTypes.ImpureClass; + } + } - /** - * Invoked before the component receives new props. - * - * Use this as an opportunity to react to a prop transition by updating the - * state using `this.setState`. Current props are accessed via `this.props`. - * - * componentWillReceiveProps: function(nextProps, nextContext) { - * this.setState({ - * likesIncreasing: nextProps.likeCount > this.props.likeCount - * }); - * } - * - * NOTE: There is no equivalent `componentWillReceiveState`. An incoming prop - * transition may cause a state change, but the opposite is not true. If you - * need it, you are probably looking for `componentWillUpdate`. - * - * @param {object} nextProps - * @optional - */ - componentWillReceiveProps: SpecPolicy.DEFINE_MANY, + if (process.env.NODE_ENV !== 'production') { + // This will throw later in _renderValidatedComponent, but add an early + // warning now to help debugging + if (inst.render == null) { + process.env.NODE_ENV !== 'production' ? warning(false, '%s(...): No `render` method found on the returned component ' + 'instance: you may have forgotten to define `render`.', Component.displayName || Component.name || 'Component') : void 0; + } - /** - * Invoked while deciding if the component should be updated as a result of - * receiving new props, state and/or context. - * - * Use this as an opportunity to `return false` when you're certain that the - * transition to the new props/state/context will not require a component - * update. - * - * shouldComponentUpdate: function(nextProps, nextState, nextContext) { - * return !equal(nextProps, this.props) || - * !equal(nextState, this.state) || - * !equal(nextContext, this.context); - * } - * - * @param {object} nextProps - * @param {?object} nextState - * @param {?object} nextContext - * @return {boolean} True if the component should update. - * @optional - */ - shouldComponentUpdate: SpecPolicy.DEFINE_ONCE, + var propsMutated = inst.props !== publicProps; + var componentName = Component.displayName || Component.name || 'Component'; - /** - * Invoked when the component is about to update due to a transition from - * `this.props`, `this.state` and `this.context` to `nextProps`, `nextState` - * and `nextContext`. - * - * Use this as an opportunity to perform preparation before an update occurs. - * - * NOTE: You **cannot** use `this.setState()` in this method. - * - * @param {object} nextProps - * @param {?object} nextState - * @param {?object} nextContext - * @param {ReactReconcileTransaction} transaction - * @optional - */ - componentWillUpdate: SpecPolicy.DEFINE_MANY, + process.env.NODE_ENV !== 'production' ? warning(inst.props === undefined || !propsMutated, '%s(...): When calling super() in `%s`, make sure to pass ' + 'up the same props that your component\'s constructor was passed.', componentName, componentName) : void 0; + } - /** - * Invoked when the component's DOM representation has been updated. - * - * Use this as an opportunity to operate on the DOM when the component has - * been updated. - * - * @param {object} prevProps - * @param {?object} prevState - * @param {?object} prevContext - * @param {DOMElement} rootNode DOM element representing the component. - * @optional - */ - componentDidUpdate: SpecPolicy.DEFINE_MANY, + // These should be set up in the constructor, but as a convenience for + // simpler class abstractions, we set them up after the fact. + inst.props = publicProps; + inst.context = publicContext; + inst.refs = emptyObject; + inst.updater = updateQueue; - /** - * Invoked when the component is about to be removed from its parent and have - * its DOM representation destroyed. - * - * Use this as an opportunity to deallocate any external resources. - * - * NOTE: There is no `componentDidUnmount` since your component will have been - * destroyed by that point. - * - * @optional - */ - componentWillUnmount: SpecPolicy.DEFINE_MANY, + this._instance = inst; - // ==== Advanced methods ==== + // Store a reference from the instance back to the internal representation + ReactInstanceMap.set(inst, this); - /** - * Updates the component's currently mounted DOM representation. - * - * By default, this implements React's rendering and reconciliation algorithm. - * Sophisticated clients may wish to override this. - * - * @param {ReactReconcileTransaction} transaction - * @internal - * @overridable - */ - updateComponent: SpecPolicy.OVERRIDE_BASE + if (process.env.NODE_ENV !== 'production') { + // Since plain JS classes are defined without any special initialization + // logic, we can not catch common errors early. Therefore, we have to + // catch them here, at initialization time, instead. + process.env.NODE_ENV !== 'production' ? warning(!inst.getInitialState || inst.getInitialState.isReactClassApproved, 'getInitialState was defined on %s, a plain JavaScript class. ' + 'This is only supported for classes created using React.createClass. ' + 'Did you mean to define a state property instead?', this.getName() || 'a component') : void 0; + process.env.NODE_ENV !== 'production' ? warning(!inst.getDefaultProps || inst.getDefaultProps.isReactClassApproved, 'getDefaultProps was defined on %s, a plain JavaScript class. ' + 'This is only supported for classes created using React.createClass. ' + 'Use a static property to define defaultProps instead.', this.getName() || 'a component') : void 0; + process.env.NODE_ENV !== 'production' ? warning(!inst.propTypes, 'propTypes was defined as an instance property on %s. Use a static ' + 'property to define propTypes instead.', this.getName() || 'a component') : void 0; + process.env.NODE_ENV !== 'production' ? warning(!inst.contextTypes, 'contextTypes was defined as an instance property on %s. Use a ' + 'static property to define contextTypes instead.', this.getName() || 'a component') : void 0; + process.env.NODE_ENV !== 'production' ? warning(typeof inst.componentShouldUpdate !== 'function', '%s has a method called ' + 'componentShouldUpdate(). Did you mean shouldComponentUpdate()? ' + 'The name is phrased as a question because the function is ' + 'expected to return a value.', this.getName() || 'A component') : void 0; + process.env.NODE_ENV !== 'production' ? warning(typeof inst.componentDidUnmount !== 'function', '%s has a method called ' + 'componentDidUnmount(). But there is no such lifecycle method. ' + 'Did you mean componentWillUnmount()?', this.getName() || 'A component') : void 0; + process.env.NODE_ENV !== 'production' ? warning(typeof inst.componentWillRecieveProps !== 'function', '%s has a method called ' + 'componentWillRecieveProps(). Did you mean componentWillReceiveProps()?', this.getName() || 'A component') : void 0; + } -}; + var initialState = inst.state; + if (initialState === undefined) { + inst.state = initialState = null; + } + !(typeof initialState === 'object' && !Array.isArray(initialState)) ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s.state: must be set to an object or null', this.getName() || 'ReactCompositeComponent') : _prodInvariant('106', this.getName() || 'ReactCompositeComponent') : void 0; -/** - * Mapping from class specification keys to special processing functions. - * - * Although these are declared like instance properties in the specification - * when defining classes using `React.createClass`, they are actually static - * and are accessible on the constructor instead of the prototype. Despite - * being static, they must be defined outside of the "statics" key under - * which all other static methods are defined. - */ -var RESERVED_SPEC_KEYS = { - displayName: function (Constructor, displayName) { - Constructor.displayName = displayName; - }, - mixins: function (Constructor, mixins) { - if (mixins) { - for (var i = 0; i < mixins.length; i++) { - mixSpecIntoComponent(Constructor, mixins[i]); - } + this._pendingStateQueue = null; + this._pendingReplaceState = false; + this._pendingForceUpdate = false; + + var markup; + if (inst.unstable_handleError) { + markup = this.performInitialMountWithErrorHandling(renderedElement, hostParent, hostContainerInfo, transaction, context); + } else { + markup = this.performInitialMount(renderedElement, hostParent, hostContainerInfo, transaction, context); } - }, - childContextTypes: function (Constructor, childContextTypes) { - if (process.env.NODE_ENV !== 'production') { - validateTypeDef(Constructor, childContextTypes, ReactPropTypeLocations.childContext); + + if (inst.componentDidMount) { + if (process.env.NODE_ENV !== 'production') { + transaction.getReactMountReady().enqueue(function () { + measureLifeCyclePerf(function () { + return inst.componentDidMount(); + }, _this._debugID, 'componentDidMount'); + }); + } else { + transaction.getReactMountReady().enqueue(inst.componentDidMount, inst); + } } - Constructor.childContextTypes = _assign({}, Constructor.childContextTypes, childContextTypes); + + return markup; }, - contextTypes: function (Constructor, contextTypes) { + + _constructComponent: function (doConstruct, publicProps, publicContext, updateQueue) { if (process.env.NODE_ENV !== 'production') { - validateTypeDef(Constructor, contextTypes, ReactPropTypeLocations.context); - } - Constructor.contextTypes = _assign({}, Constructor.contextTypes, contextTypes); - }, - /** - * Special case getDefaultProps which should move into statics but requires - * automatic merging. - */ - getDefaultProps: function (Constructor, getDefaultProps) { - if (Constructor.getDefaultProps) { - Constructor.getDefaultProps = createMergedResultFunction(Constructor.getDefaultProps, getDefaultProps); + ReactCurrentOwner.current = this; + try { + return this._constructComponentWithoutOwner(doConstruct, publicProps, publicContext, updateQueue); + } finally { + ReactCurrentOwner.current = null; + } } else { - Constructor.getDefaultProps = getDefaultProps; + return this._constructComponentWithoutOwner(doConstruct, publicProps, publicContext, updateQueue); } }, - propTypes: function (Constructor, propTypes) { + + _constructComponentWithoutOwner: function (doConstruct, publicProps, publicContext, updateQueue) { + var Component = this._currentElement.type; + + if (doConstruct) { + if (process.env.NODE_ENV !== 'production') { + return measureLifeCyclePerf(function () { + return new Component(publicProps, publicContext, updateQueue); + }, this._debugID, 'ctor'); + } else { + return new Component(publicProps, publicContext, updateQueue); + } + } + + // This can still be an instance in case of factory components + // but we'll count this as time spent rendering as the more common case. if (process.env.NODE_ENV !== 'production') { - validateTypeDef(Constructor, propTypes, ReactPropTypeLocations.prop); + return measureLifeCyclePerf(function () { + return Component(publicProps, publicContext, updateQueue); + }, this._debugID, 'render'); + } else { + return Component(publicProps, publicContext, updateQueue); } - Constructor.propTypes = _assign({}, Constructor.propTypes, propTypes); }, - statics: function (Constructor, statics) { - mixStaticSpecIntoComponent(Constructor, statics); - }, - autobind: function () {} }; -// noop -function validateTypeDef(Constructor, typeDef, location) { - for (var propName in typeDef) { - if (typeDef.hasOwnProperty(propName)) { - // use a warning instead of an invariant so components - // don't show up in prod but only in __DEV__ - process.env.NODE_ENV !== 'production' ? warning(typeof typeDef[propName] === 'function', '%s: %s type `%s` is invalid; it must be a function, usually from ' + 'React.PropTypes.', Constructor.displayName || 'ReactClass', ReactPropTypeLocationNames[location], propName) : void 0; - } - } -} + performInitialMountWithErrorHandling: function (renderedElement, hostParent, hostContainerInfo, transaction, context) { + var markup; + var checkpoint = transaction.checkpoint(); + try { + markup = this.performInitialMount(renderedElement, hostParent, hostContainerInfo, transaction, context); + } catch (e) { + // Roll back to checkpoint, handle error (which may add items to the transaction), and take a new checkpoint + transaction.rollback(checkpoint); + this._instance.unstable_handleError(e); + if (this._pendingStateQueue) { + this._instance.state = this._processPendingState(this._instance.props, this._instance.context); + } + checkpoint = transaction.checkpoint(); -function validateMethodOverride(isAlreadyDefined, name) { - var specPolicy = ReactClassInterface.hasOwnProperty(name) ? ReactClassInterface[name] : null; + this._renderedComponent.unmountComponent(true); + transaction.rollback(checkpoint); - // Disallow overriding of base class methods unless explicitly allowed. - if (ReactClassMixin.hasOwnProperty(name)) { - !(specPolicy === SpecPolicy.OVERRIDE_BASE) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactClassInterface: You are attempting to override `%s` from your class specification. Ensure that your method names do not overlap with React methods.', name) : _prodInvariant('73', name) : void 0; - } + // Try again - we've informed the component about the error, so they can render an error message this time. + // If this throws again, the error will bubble up (and can be caught by a higher error boundary). + markup = this.performInitialMount(renderedElement, hostParent, hostContainerInfo, transaction, context); + } + return markup; + }, - // Disallow defining methods more than once unless explicitly allowed. - if (isAlreadyDefined) { - !(specPolicy === SpecPolicy.DEFINE_MANY || specPolicy === SpecPolicy.DEFINE_MANY_MERGED) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactClassInterface: You are attempting to define `%s` on your component more than once. This conflict may be due to a mixin.', name) : _prodInvariant('74', name) : void 0; - } -} + performInitialMount: function (renderedElement, hostParent, hostContainerInfo, transaction, context) { + var inst = this._instance; -/** - * Mixin helper which handles policy validation and reserved - * specification keys when building React classes. - */ -function mixSpecIntoComponent(Constructor, spec) { - if (!spec) { + var debugID = 0; if (process.env.NODE_ENV !== 'production') { - var typeofSpec = typeof spec; - var isMixinValid = typeofSpec === 'object' && spec !== null; - - process.env.NODE_ENV !== 'production' ? warning(isMixinValid, '%s: You\'re attempting to include a mixin that is either null ' + 'or not an object. Check the mixins included by the component, ' + 'as well as any mixins they include themselves. ' + 'Expected object but got %s.', Constructor.displayName || 'ReactClass', spec === null ? null : typeofSpec) : void 0; + debugID = this._debugID; } - return; - } + if (inst.componentWillMount) { + if (process.env.NODE_ENV !== 'production') { + measureLifeCyclePerf(function () { + return inst.componentWillMount(); + }, debugID, 'componentWillMount'); + } else { + inst.componentWillMount(); + } + // When mounting, calls to `setState` by `componentWillMount` will set + // `this._pendingStateQueue` without triggering a re-render. + if (this._pendingStateQueue) { + inst.state = this._processPendingState(inst.props, inst.context); + } + } - !(typeof spec !== 'function') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactClass: You\'re attempting to use a component class or function as a mixin. Instead, just use a regular object.') : _prodInvariant('75') : void 0; - !!ReactElement.isValidElement(spec) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactClass: You\'re attempting to use a component as a mixin. Instead, just use a regular object.') : _prodInvariant('76') : void 0; + // If not a stateless component, we now render + if (renderedElement === undefined) { + renderedElement = this._renderValidatedComponent(); + } - var proto = Constructor.prototype; - var autoBindPairs = proto.__reactAutoBindPairs; + var nodeType = ReactNodeTypes.getType(renderedElement); + this._renderedNodeType = nodeType; + var child = this._instantiateReactComponent(renderedElement, nodeType !== ReactNodeTypes.EMPTY /* shouldHaveDebugID */ + ); + this._renderedComponent = child; - // By handling mixins before any other properties, we ensure the same - // chaining order is applied to methods with DEFINE_MANY policy, whether - // mixins are listed before or after these methods in the spec. - if (spec.hasOwnProperty(MIXINS_KEY)) { - RESERVED_SPEC_KEYS.mixins(Constructor, spec.mixins); - } + var markup = ReactReconciler.mountComponent(child, transaction, hostParent, hostContainerInfo, this._processChildContext(context), debugID); - for (var name in spec) { - if (!spec.hasOwnProperty(name)) { - continue; + if (process.env.NODE_ENV !== 'production') { + if (debugID !== 0) { + var childDebugIDs = child._debugID !== 0 ? [child._debugID] : []; + ReactInstrumentation.debugTool.onSetChildren(debugID, childDebugIDs); + } } - if (name === MIXINS_KEY) { - // We have already handled mixins in a special case above. - continue; - } + return markup; + }, - var property = spec[name]; - var isAlreadyDefined = proto.hasOwnProperty(name); - validateMethodOverride(isAlreadyDefined, name); + getHostNode: function () { + return ReactReconciler.getHostNode(this._renderedComponent); + }, - if (RESERVED_SPEC_KEYS.hasOwnProperty(name)) { - RESERVED_SPEC_KEYS[name](Constructor, property); - } else { - // Setup methods on prototype: - // The following member methods should not be automatically bound: - // 1. Expected ReactClass methods (in the "interface"). - // 2. Overridden methods (that were mixed in). - var isReactClassMethod = ReactClassInterface.hasOwnProperty(name); - var isFunction = typeof property === 'function'; - var shouldAutoBind = isFunction && !isReactClassMethod && !isAlreadyDefined && spec.autobind !== false; + /** + * Releases any resources allocated by `mountComponent`. + * + * @final + * @internal + */ + unmountComponent: function (safely) { + if (!this._renderedComponent) { + return; + } - if (shouldAutoBind) { - autoBindPairs.push(name, property); - proto[name] = property; - } else { - if (isAlreadyDefined) { - var specPolicy = ReactClassInterface[name]; + var inst = this._instance; - // These cases should already be caught by validateMethodOverride. - !(isReactClassMethod && (specPolicy === SpecPolicy.DEFINE_MANY_MERGED || specPolicy === SpecPolicy.DEFINE_MANY)) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactClass: Unexpected spec policy %s for key %s when mixing in component specs.', specPolicy, name) : _prodInvariant('77', specPolicy, name) : void 0; + if (inst.componentWillUnmount && !inst._calledComponentWillUnmount) { + inst._calledComponentWillUnmount = true; - // For methods which are defined more than once, call the existing - // methods before calling the new property, merging if appropriate. - if (specPolicy === SpecPolicy.DEFINE_MANY_MERGED) { - proto[name] = createMergedResultFunction(proto[name], property); - } else if (specPolicy === SpecPolicy.DEFINE_MANY) { - proto[name] = createChainedFunction(proto[name], property); - } + if (safely) { + var name = this.getName() + '.componentWillUnmount()'; + ReactErrorUtils.invokeGuardedCallback(name, inst.componentWillUnmount.bind(inst)); + } else { + if (process.env.NODE_ENV !== 'production') { + measureLifeCyclePerf(function () { + return inst.componentWillUnmount(); + }, this._debugID, 'componentWillUnmount'); } else { - proto[name] = property; - if (process.env.NODE_ENV !== 'production') { - // Add verbose displayName to the function, which helps when looking - // at profiling tools. - if (typeof property === 'function' && spec.displayName) { - proto[name].displayName = spec.displayName + '_' + name; - } - } + inst.componentWillUnmount(); } } } - } -} -function mixStaticSpecIntoComponent(Constructor, statics) { - if (!statics) { - return; - } - for (var name in statics) { - var property = statics[name]; - if (!statics.hasOwnProperty(name)) { - continue; + if (this._renderedComponent) { + ReactReconciler.unmountComponent(this._renderedComponent, safely); + this._renderedNodeType = null; + this._renderedComponent = null; + this._instance = null; } - var isReserved = name in RESERVED_SPEC_KEYS; - !!isReserved ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactClass: You are attempting to define a reserved property, `%s`, that shouldn\'t be on the "statics" key. Define it as an instance property instead; it will still be accessible on the constructor.', name) : _prodInvariant('78', name) : void 0; + // Reset pending fields + // Even if this component is scheduled for another update in ReactUpdates, + // it would still be ignored because these fields are reset. + this._pendingStateQueue = null; + this._pendingReplaceState = false; + this._pendingForceUpdate = false; + this._pendingCallbacks = null; + this._pendingElement = null; - var isInherited = name in Constructor; - !!isInherited ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactClass: You are attempting to define `%s` on your component more than once. This conflict may be due to a mixin.', name) : _prodInvariant('79', name) : void 0; - Constructor[name] = property; - } -} + // These fields do not really need to be reset since this object is no + // longer accessible. + this._context = null; + this._rootNodeID = 0; + this._topLevelWrapper = null; -/** - * Merge two objects, but throw if both contain the same key. - * - * @param {object} one The first object, which is mutated. - * @param {object} two The second object - * @return {object} one after it has been mutated to contain everything in two. - */ -function mergeIntoWithNoDuplicateKeys(one, two) { - !(one && two && typeof one === 'object' && typeof two === 'object') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'mergeIntoWithNoDuplicateKeys(): Cannot merge non-objects.') : _prodInvariant('80') : void 0; + // Delete the reference from the instance to this internal representation + // which allow the internals to be properly cleaned up even if the user + // leaks a reference to the public instance. + ReactInstanceMap.remove(inst); - for (var key in two) { - if (two.hasOwnProperty(key)) { - !(one[key] === undefined) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'mergeIntoWithNoDuplicateKeys(): Tried to merge two objects with the same key: `%s`. This conflict may be due to a mixin; in particular, this may be caused by two getInitialState() or getDefaultProps() methods returning objects with clashing keys.', key) : _prodInvariant('81', key) : void 0; - one[key] = two[key]; - } - } - return one; -} + // Some existing components rely on inst.props even after they've been + // destroyed (in event handlers). + // TODO: inst.props = null; + // TODO: inst.state = null; + // TODO: inst.context = null; + }, -/** - * Creates a function that invokes two functions and merges their return values. - * - * @param {function} one Function to invoke first. - * @param {function} two Function to invoke second. - * @return {function} Function that invokes the two argument functions. - * @private - */ -function createMergedResultFunction(one, two) { - return function mergedResult() { - var a = one.apply(this, arguments); - var b = two.apply(this, arguments); - if (a == null) { - return b; - } else if (b == null) { - return a; + /** + * Filters the context object to only contain keys specified in + * `contextTypes` + * + * @param {object} context + * @return {?object} + * @private + */ + _maskContext: function (context) { + var Component = this._currentElement.type; + var contextTypes = Component.contextTypes; + if (!contextTypes) { + return emptyObject; } - var c = {}; - mergeIntoWithNoDuplicateKeys(c, a); - mergeIntoWithNoDuplicateKeys(c, b); - return c; - }; -} + var maskedContext = {}; + for (var contextName in contextTypes) { + maskedContext[contextName] = context[contextName]; + } + return maskedContext; + }, -/** - * Creates a function that invokes two functions and ignores their return vales. - * - * @param {function} one Function to invoke first. - * @param {function} two Function to invoke second. - * @return {function} Function that invokes the two argument functions. - * @private - */ -function createChainedFunction(one, two) { - return function chainedFunction() { - one.apply(this, arguments); - two.apply(this, arguments); - }; -} - -/** - * Binds a method to the component. - * - * @param {object} component Component whose method is going to be bound. - * @param {function} method Method to be bound. - * @return {function} The bound method. - */ -function bindAutoBindMethod(component, method) { - var boundMethod = method.bind(component); - if (process.env.NODE_ENV !== 'production') { - boundMethod.__reactBoundContext = component; - boundMethod.__reactBoundMethod = method; - boundMethod.__reactBoundArguments = null; - var componentName = component.constructor.displayName; - var _bind = boundMethod.bind; - boundMethod.bind = function (newThis) { - for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; + /** + * Filters the context object to only contain keys specified in + * `contextTypes`, and asserts that they are valid. + * + * @param {object} context + * @return {?object} + * @private + */ + _processContext: function (context) { + var maskedContext = this._maskContext(context); + if (process.env.NODE_ENV !== 'production') { + var Component = this._currentElement.type; + if (Component.contextTypes) { + this._checkContextTypes(Component.contextTypes, maskedContext, 'context'); } + } + return maskedContext; + }, - // User is trying to bind() an autobound method; we effectively will - // ignore the value of "this" that the user is trying to use, so - // let's warn. - if (newThis !== component && newThis !== null) { - process.env.NODE_ENV !== 'production' ? warning(false, 'bind(): React component methods may only be bound to the ' + 'component instance. See %s', componentName) : void 0; - } else if (!args.length) { - process.env.NODE_ENV !== 'production' ? warning(false, 'bind(): You are binding a component method to the component. ' + 'React does this for you automatically in a high-performance ' + 'way, so you can safely remove this call. See %s', componentName) : void 0; - return boundMethod; - } - var reboundMethod = _bind.apply(boundMethod, arguments); - reboundMethod.__reactBoundContext = component; - reboundMethod.__reactBoundMethod = method; - reboundMethod.__reactBoundArguments = args; - return reboundMethod; - }; - } - return boundMethod; -} + /** + * @param {object} currentContext + * @return {object} + * @private + */ + _processChildContext: function (currentContext) { + var Component = this._currentElement.type; + var inst = this._instance; + var childContext; -/** - * Binds all auto-bound methods in a component. - * - * @param {object} component Component whose method is going to be bound. - */ -function bindAutoBindMethods(component) { - var pairs = component.__reactAutoBindPairs; - for (var i = 0; i < pairs.length; i += 2) { - var autoBindKey = pairs[i]; - var method = pairs[i + 1]; - component[autoBindKey] = bindAutoBindMethod(component, method); - } -} + if (inst.getChildContext) { + if (process.env.NODE_ENV !== 'production') { + ReactInstrumentation.debugTool.onBeginProcessingChildContext(); + try { + childContext = inst.getChildContext(); + } finally { + ReactInstrumentation.debugTool.onEndProcessingChildContext(); + } + } else { + childContext = inst.getChildContext(); + } + } -/** - * Add more to the ReactClass base class. These are all legacy features and - * therefore not already part of the modern ReactComponent. - */ -var ReactClassMixin = { + if (childContext) { + !(typeof Component.childContextTypes === 'object') ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s.getChildContext(): childContextTypes must be defined in order to use getChildContext().', this.getName() || 'ReactCompositeComponent') : _prodInvariant('107', this.getName() || 'ReactCompositeComponent') : void 0; + if (process.env.NODE_ENV !== 'production') { + this._checkContextTypes(Component.childContextTypes, childContext, 'childContext'); + } + for (var name in childContext) { + !(name in Component.childContextTypes) ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s.getChildContext(): key "%s" is not defined in childContextTypes.', this.getName() || 'ReactCompositeComponent', name) : _prodInvariant('108', this.getName() || 'ReactCompositeComponent', name) : void 0; + } + return _assign({}, currentContext, childContext); + } + return currentContext; + }, /** - * TODO: This will be deprecated because state should always keep a consistent - * type signature and the only use case for this, is to avoid that. + * Assert that the context types are valid + * + * @param {object} typeSpecs Map of context field to a ReactPropType + * @param {object} values Runtime values that need to be type-checked + * @param {string} location e.g. "prop", "context", "child context" + * @private */ - replaceState: function (newState, callback) { - this.updater.enqueueReplaceState(this, newState); - if (callback) { - this.updater.enqueueCallback(this, callback, 'replaceState'); + _checkContextTypes: function (typeSpecs, values, location) { + if (process.env.NODE_ENV !== 'production') { + checkReactTypeSpec(typeSpecs, values, location, this.getName(), null, this._debugID); } }, - /** - * Checks whether or not this composite component is mounted. - * @return {boolean} True if mounted, false otherwise. - * @protected - * @final - */ - isMounted: function () { - return this.updater.isMounted(this); - } -}; + receiveComponent: function (nextElement, transaction, nextContext) { + var prevElement = this._currentElement; + var prevContext = this._context; -var ReactClassComponent = function () {}; -_assign(ReactClassComponent.prototype, ReactComponent.prototype, ReactClassMixin); + this._pendingElement = null; -/** - * Module for creating composite components. - * - * @class ReactClass - */ -var ReactClass = { + this.updateComponent(transaction, prevElement, nextElement, prevContext, nextContext); + }, /** - * Creates a composite component class given a class specification. - * See https://facebook.github.io/react/docs/top-level-api.html#react.createclass + * If any of `_pendingElement`, `_pendingStateQueue`, or `_pendingForceUpdate` + * is set, update the component. * - * @param {object} spec Class specification (which must define `render`). - * @return {function} Component constructor function. - * @public + * @param {ReactReconcileTransaction} transaction + * @internal */ - createClass: function (spec) { - var Constructor = function (props, context, updater) { - // This constructor gets overridden by mocks. The argument is used - // by mocks to assert on what gets mounted. + performUpdateIfNecessary: function (transaction) { + if (this._pendingElement != null) { + ReactReconciler.receiveComponent(this, this._pendingElement, transaction, this._context); + } else if (this._pendingStateQueue !== null || this._pendingForceUpdate) { + this.updateComponent(transaction, this._currentElement, this._currentElement, this._context, this._context); + } else { + this._updateBatchNumber = null; + } + }, - if (process.env.NODE_ENV !== 'production') { - process.env.NODE_ENV !== 'production' ? warning(this instanceof Constructor, 'Something is calling a React component directly. Use a factory or ' + 'JSX instead. See: https://fb.me/react-legacyfactory') : void 0; - } + /** + * Perform an update to a mounted component. The componentWillReceiveProps and + * shouldComponentUpdate methods are called, then (assuming the update isn't + * skipped) the remaining update lifecycle methods are called and the DOM + * representation is updated. + * + * By default, this implements React's rendering and reconciliation algorithm. + * Sophisticated clients may wish to override this. + * + * @param {ReactReconcileTransaction} transaction + * @param {ReactElement} prevParentElement + * @param {ReactElement} nextParentElement + * @internal + * @overridable + */ + updateComponent: function (transaction, prevParentElement, nextParentElement, prevUnmaskedContext, nextUnmaskedContext) { + var inst = this._instance; + !(inst != null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Attempted to update component `%s` that has already been unmounted (or failed to mount).', this.getName() || 'ReactCompositeComponent') : _prodInvariant('136', this.getName() || 'ReactCompositeComponent') : void 0; - // Wire up auto-binding - if (this.__reactAutoBindPairs.length) { - bindAutoBindMethods(this); - } + var willReceive = false; + var nextContext; - this.props = props; - this.context = context; - this.refs = emptyObject; - this.updater = updater || ReactNoopUpdateQueue; + // Determine if the context has changed or not + if (this._context === nextUnmaskedContext) { + nextContext = inst.context; + } else { + nextContext = this._processContext(nextUnmaskedContext); + willReceive = true; + } - this.state = null; + var prevProps = prevParentElement.props; + var nextProps = nextParentElement.props; - // ReactClasses doesn't have constructors. Instead, they use the - // getInitialState and componentWillMount methods for initialization. + // Not a simple state update but a props update + if (prevParentElement !== nextParentElement) { + willReceive = true; + } - var initialState = this.getInitialState ? this.getInitialState() : null; + // An update here will schedule an update but immediately set + // _pendingStateQueue which will ensure that any state updates gets + // immediately reconciled instead of waiting for the next batch. + if (willReceive && inst.componentWillReceiveProps) { if (process.env.NODE_ENV !== 'production') { - // We allow auto-mocks to proceed as if they're returning null. - if (initialState === undefined && this.getInitialState._isMockFunction) { - // This is probably bad practice. Consider warning here and - // deprecating this convenience. - initialState = null; - } + measureLifeCyclePerf(function () { + return inst.componentWillReceiveProps(nextProps, nextContext); + }, this._debugID, 'componentWillReceiveProps'); + } else { + inst.componentWillReceiveProps(nextProps, nextContext); } - !(typeof initialState === 'object' && !Array.isArray(initialState)) ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s.getInitialState(): must return an object or null', Constructor.displayName || 'ReactCompositeComponent') : _prodInvariant('82', Constructor.displayName || 'ReactCompositeComponent') : void 0; - - this.state = initialState; - }; - Constructor.prototype = new ReactClassComponent(); - Constructor.prototype.constructor = Constructor; - Constructor.prototype.__reactAutoBindPairs = []; - - injectedMixins.forEach(mixSpecIntoComponent.bind(null, Constructor)); - - mixSpecIntoComponent(Constructor, spec); - - // Initialize the defaultProps property after all mixins have been merged. - if (Constructor.getDefaultProps) { - Constructor.defaultProps = Constructor.getDefaultProps(); } - if (process.env.NODE_ENV !== 'production') { - // This is a tag to indicate that the use of these method names is ok, - // since it's used with createClass. If it's not, then it's likely a - // mistake so we'll warn you to use the static property, property - // initializer or constructor respectively. - if (Constructor.getDefaultProps) { - Constructor.getDefaultProps.isReactClassApproved = {}; - } - if (Constructor.prototype.getInitialState) { - Constructor.prototype.getInitialState.isReactClassApproved = {}; + var nextState = this._processPendingState(nextProps, nextContext); + var shouldUpdate = true; + + if (!this._pendingForceUpdate) { + if (inst.shouldComponentUpdate) { + if (process.env.NODE_ENV !== 'production') { + shouldUpdate = measureLifeCyclePerf(function () { + return inst.shouldComponentUpdate(nextProps, nextState, nextContext); + }, this._debugID, 'shouldComponentUpdate'); + } else { + shouldUpdate = inst.shouldComponentUpdate(nextProps, nextState, nextContext); + } + } else { + if (this._compositeType === CompositeTypes.PureClass) { + shouldUpdate = !shallowEqual(prevProps, nextProps) || !shallowEqual(inst.state, nextState); + } } } - !Constructor.prototype.render ? process.env.NODE_ENV !== 'production' ? invariant(false, 'createClass(...): Class specification must implement a `render` method.') : _prodInvariant('83') : void 0; - if (process.env.NODE_ENV !== 'production') { - process.env.NODE_ENV !== 'production' ? warning(!Constructor.prototype.componentShouldUpdate, '%s has a method called ' + 'componentShouldUpdate(). Did you mean shouldComponentUpdate()? ' + 'The name is phrased as a question because the function is ' + 'expected to return a value.', spec.displayName || 'A component') : void 0; - process.env.NODE_ENV !== 'production' ? warning(!Constructor.prototype.componentWillRecieveProps, '%s has a method called ' + 'componentWillRecieveProps(). Did you mean componentWillReceiveProps()?', spec.displayName || 'A component') : void 0; + process.env.NODE_ENV !== 'production' ? warning(shouldUpdate !== undefined, '%s.shouldComponentUpdate(): Returned undefined instead of a ' + 'boolean value. Make sure to return true or false.', this.getName() || 'ReactCompositeComponent') : void 0; } - // Reduce time spent doing lookups by setting these on the prototype. - for (var methodName in ReactClassInterface) { - if (!Constructor.prototype[methodName]) { - Constructor.prototype[methodName] = null; - } + this._updateBatchNumber = null; + if (shouldUpdate) { + this._pendingForceUpdate = false; + // Will set `this.props`, `this.state` and `this.context`. + this._performComponentUpdate(nextParentElement, nextProps, nextState, nextContext, transaction, nextUnmaskedContext); + } else { + // If it's determined that a component should not update, we still want + // to set props and state but we shortcut the rest of the update. + this._currentElement = nextParentElement; + this._context = nextUnmaskedContext; + inst.props = nextProps; + inst.state = nextState; + inst.context = nextContext; } - - return Constructor; }, - injection: { - injectMixin: function (mixin) { - injectedMixins.push(mixin); + _processPendingState: function (props, context) { + var inst = this._instance; + var queue = this._pendingStateQueue; + var replace = this._pendingReplaceState; + this._pendingReplaceState = false; + this._pendingStateQueue = null; + + if (!queue) { + return inst.state; } - } -}; + if (replace && queue.length === 1) { + return queue[0]; + } -module.exports = ReactClass; -}).call(this,require('_process')) + var nextState = _assign({}, replace ? queue[0] : inst.state); + for (var i = replace ? 1 : 0; i < queue.length; i++) { + var partial = queue[i]; + _assign(nextState, typeof partial === 'function' ? partial.call(inst, nextState, props, context) : partial); + } -},{"./ReactComponent":59,"./ReactElement":87,"./ReactNoopUpdateQueue":106,"./ReactPropTypeLocationNames":108,"./ReactPropTypeLocations":109,"./reactProdInvariant":163,"_process":27,"fbjs/lib/emptyObject":9,"fbjs/lib/invariant":16,"fbjs/lib/keyMirror":19,"fbjs/lib/keyOf":20,"fbjs/lib/warning":25,"object-assign":26}],59:[function(require,module,exports){ -(function (process){ -/** - * Copyright 2013-present, Facebook, Inc. - * All rights reserved. - * - * This source code is licensed under the BSD-style license found in the - * LICENSE file in the root directory of this source tree. An additional grant - * of patent rights can be found in the PATENTS file in the same directory. - * - * @providesModule ReactComponent - */ + return nextState; + }, -'use strict'; + /** + * Merges new props and state, notifies delegate methods of update and + * performs update. + * + * @param {ReactElement} nextElement Next element + * @param {object} nextProps Next public object to set as properties. + * @param {?object} nextState Next object to set as state. + * @param {?object} nextContext Next public object to set as context. + * @param {ReactReconcileTransaction} transaction + * @param {?object} unmaskedContext + * @private + */ + _performComponentUpdate: function (nextElement, nextProps, nextState, nextContext, transaction, unmaskedContext) { + var _this2 = this; -var _prodInvariant = require('./reactProdInvariant'); + var inst = this._instance; -var ReactNoopUpdateQueue = require('./ReactNoopUpdateQueue'); + var hasComponentDidUpdate = Boolean(inst.componentDidUpdate); + var prevProps; + var prevState; + var prevContext; + if (hasComponentDidUpdate) { + prevProps = inst.props; + prevState = inst.state; + prevContext = inst.context; + } -var canDefineProperty = require('./canDefineProperty'); -var emptyObject = require('fbjs/lib/emptyObject'); -var invariant = require('fbjs/lib/invariant'); -var warning = require('fbjs/lib/warning'); + if (inst.componentWillUpdate) { + if (process.env.NODE_ENV !== 'production') { + measureLifeCyclePerf(function () { + return inst.componentWillUpdate(nextProps, nextState, nextContext); + }, this._debugID, 'componentWillUpdate'); + } else { + inst.componentWillUpdate(nextProps, nextState, nextContext); + } + } -/** - * Base class helpers for the updating state of a component. - */ -function ReactComponent(props, context, updater) { - this.props = props; - this.context = context; - this.refs = emptyObject; - // We initialize the default updater but the real one gets injected by the - // renderer. - this.updater = updater || ReactNoopUpdateQueue; -} + this._currentElement = nextElement; + this._context = unmaskedContext; + inst.props = nextProps; + inst.state = nextState; + inst.context = nextContext; -ReactComponent.prototype.isReactComponent = {}; + this._updateRenderedComponent(transaction, unmaskedContext); -/** - * Sets a subset of the state. Always use this to mutate - * state. You should treat `this.state` as immutable. - * - * There is no guarantee that `this.state` will be immediately updated, so - * accessing `this.state` after calling this method may return the old value. - * - * There is no guarantee that calls to `setState` will run synchronously, - * as they may eventually be batched together. You can provide an optional - * callback that will be executed when the call to setState is actually - * completed. - * - * When a function is provided to setState, it will be called at some point in - * the future (not synchronously). It will be called with the up to date - * component arguments (state, props, context). These values can be different - * from this.* because your function may be called after receiveProps but before - * shouldComponentUpdate, and this new state, props, and context will not yet be - * assigned to this. - * - * @param {object|function} partialState Next partial state or function to - * produce next partial state to be merged with current state. - * @param {?function} callback Called after state is updated. - * @final - * @protected - */ -ReactComponent.prototype.setState = function (partialState, callback) { - !(typeof partialState === 'object' || typeof partialState === 'function' || partialState == null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'setState(...): takes an object of state variables to update or a function which returns an object of state variables.') : _prodInvariant('85') : void 0; - this.updater.enqueueSetState(this, partialState); - if (callback) { - this.updater.enqueueCallback(this, callback, 'setState'); - } -}; + if (hasComponentDidUpdate) { + if (process.env.NODE_ENV !== 'production') { + transaction.getReactMountReady().enqueue(function () { + measureLifeCyclePerf(inst.componentDidUpdate.bind(inst, prevProps, prevState, prevContext), _this2._debugID, 'componentDidUpdate'); + }); + } else { + transaction.getReactMountReady().enqueue(inst.componentDidUpdate.bind(inst, prevProps, prevState, prevContext), inst); + } + } + }, -/** - * Forces an update. This should only be invoked when it is known with - * certainty that we are **not** in a DOM transaction. - * - * You may want to call this when you know that some deeper aspect of the - * component's state has changed but `setState` was not called. - * - * This will not invoke `shouldComponentUpdate`, but it will invoke - * `componentWillUpdate` and `componentDidUpdate`. - * - * @param {?function} callback Called after update is complete. - * @final - * @protected - */ -ReactComponent.prototype.forceUpdate = function (callback) { - this.updater.enqueueForceUpdate(this); - if (callback) { - this.updater.enqueueCallback(this, callback, 'forceUpdate'); - } -}; + /** + * Call the component's `render` method and update the DOM accordingly. + * + * @param {ReactReconcileTransaction} transaction + * @internal + */ + _updateRenderedComponent: function (transaction, context) { + var prevComponentInstance = this._renderedComponent; + var prevRenderedElement = prevComponentInstance._currentElement; + var nextRenderedElement = this._renderValidatedComponent(); -/** - * Deprecated APIs. These APIs used to exist on classic React classes but since - * we would like to deprecate them, we're not going to move them over to this - * modern base class. Instead, we define a getter that warns if it's accessed. - */ -if (process.env.NODE_ENV !== 'production') { - var deprecatedAPIs = { - isMounted: ['isMounted', 'Instead, make sure to clean up subscriptions and pending requests in ' + 'componentWillUnmount to prevent memory leaks.'], - replaceState: ['replaceState', 'Refactor your code to use setState instead (see ' + 'https://github.com/facebook/react/issues/3236).'] - }; - var defineDeprecationWarning = function (methodName, info) { - if (canDefineProperty) { - Object.defineProperty(ReactComponent.prototype, methodName, { - get: function () { - process.env.NODE_ENV !== 'production' ? warning(false, '%s(...) is deprecated in plain JavaScript React classes. %s', info[0], info[1]) : void 0; - return undefined; - } - }); - } - }; - for (var fnName in deprecatedAPIs) { - if (deprecatedAPIs.hasOwnProperty(fnName)) { - defineDeprecationWarning(fnName, deprecatedAPIs[fnName]); + var debugID = 0; + if (process.env.NODE_ENV !== 'production') { + debugID = this._debugID; } - } -} -module.exports = ReactComponent; -}).call(this,require('_process')) + if (shouldUpdateReactComponent(prevRenderedElement, nextRenderedElement)) { + ReactReconciler.receiveComponent(prevComponentInstance, nextRenderedElement, transaction, this._processChildContext(context)); + } else { + var oldHostNode = ReactReconciler.getHostNode(prevComponentInstance); + ReactReconciler.unmountComponent(prevComponentInstance, false); -},{"./ReactNoopUpdateQueue":106,"./canDefineProperty":141,"./reactProdInvariant":163,"_process":27,"fbjs/lib/emptyObject":9,"fbjs/lib/invariant":16,"fbjs/lib/warning":25}],60:[function(require,module,exports){ -/** - * Copyright 2013-present, Facebook, Inc. - * All rights reserved. - * - * This source code is licensed under the BSD-style license found in the - * LICENSE file in the root directory of this source tree. An additional grant - * of patent rights can be found in the PATENTS file in the same directory. - * - * @providesModule ReactComponentBrowserEnvironment - */ - -'use strict'; + var nodeType = ReactNodeTypes.getType(nextRenderedElement); + this._renderedNodeType = nodeType; + var child = this._instantiateReactComponent(nextRenderedElement, nodeType !== ReactNodeTypes.EMPTY /* shouldHaveDebugID */ + ); + this._renderedComponent = child; -var DOMChildrenOperations = require('./DOMChildrenOperations'); -var ReactDOMIDOperations = require('./ReactDOMIDOperations'); + var nextMarkup = ReactReconciler.mountComponent(child, transaction, this._hostParent, this._hostContainerInfo, this._processChildContext(context), debugID); -/** - * Abstracts away all functionality of the reconciler that requires knowledge of - * the browser context. TODO: These callers should be refactored to avoid the - * need for this injection. - */ -var ReactComponentBrowserEnvironment = { + if (process.env.NODE_ENV !== 'production') { + if (debugID !== 0) { + var childDebugIDs = child._debugID !== 0 ? [child._debugID] : []; + ReactInstrumentation.debugTool.onSetChildren(debugID, childDebugIDs); + } + } - processChildrenUpdates: ReactDOMIDOperations.dangerouslyProcessChildrenUpdates, + this._replaceNodeWithMarkup(oldHostNode, nextMarkup, prevComponentInstance); + } + }, - replaceNodeWithMarkup: DOMChildrenOperations.dangerouslyReplaceNodeWithMarkup + /** + * Overridden in shallow rendering. + * + * @protected + */ + _replaceNodeWithMarkup: function (oldHostNode, nextMarkup, prevInstance) { + ReactComponentEnvironment.replaceNodeWithMarkup(oldHostNode, nextMarkup, prevInstance); + }, -}; + /** + * @protected + */ + _renderValidatedComponentWithoutOwnerOrContext: function () { + var inst = this._instance; + var renderedElement; -module.exports = ReactComponentBrowserEnvironment; -},{"./DOMChildrenOperations":34,"./ReactDOMIDOperations":74}],61:[function(require,module,exports){ -(function (process){ -/** - * Copyright 2014-present, Facebook, Inc. - * All rights reserved. - * - * This source code is licensed under the BSD-style license found in the - * LICENSE file in the root directory of this source tree. An additional grant - * of patent rights can be found in the PATENTS file in the same directory. - * - * @providesModule ReactComponentEnvironment - */ + if (process.env.NODE_ENV !== 'production') { + renderedElement = measureLifeCyclePerf(function () { + return inst.render(); + }, this._debugID, 'render'); + } else { + renderedElement = inst.render(); + } -'use strict'; + if (process.env.NODE_ENV !== 'production') { + // We allow auto-mocks to proceed as if they're returning null. + if (renderedElement === undefined && inst.render._isMockFunction) { + // This is probably bad practice. Consider warning here and + // deprecating this convenience. + renderedElement = null; + } + } -var _prodInvariant = require('./reactProdInvariant'); + return renderedElement; + }, -var invariant = require('fbjs/lib/invariant'); + /** + * @private + */ + _renderValidatedComponent: function () { + var renderedElement; + if (process.env.NODE_ENV !== 'production' || this._compositeType !== CompositeTypes.StatelessFunctional) { + ReactCurrentOwner.current = this; + try { + renderedElement = this._renderValidatedComponentWithoutOwnerOrContext(); + } finally { + ReactCurrentOwner.current = null; + } + } else { + renderedElement = this._renderValidatedComponentWithoutOwnerOrContext(); + } + !( + // TODO: An `isValidNode` function would probably be more appropriate + renderedElement === null || renderedElement === false || React.isValidElement(renderedElement)) ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s.render(): A valid React element (or null) must be returned. You may have returned undefined, an array or some other invalid object.', this.getName() || 'ReactCompositeComponent') : _prodInvariant('109', this.getName() || 'ReactCompositeComponent') : void 0; -var injected = false; + return renderedElement; + }, -var ReactComponentEnvironment = { + /** + * Lazily allocates the refs object and stores `component` as `ref`. + * + * @param {string} ref Reference name. + * @param {component} component Component to store as `ref`. + * @final + * @private + */ + attachRef: function (ref, component) { + var inst = this.getPublicInstance(); + !(inst != null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Stateless function components cannot have refs.') : _prodInvariant('110') : void 0; + var publicComponentInstance = component.getPublicInstance(); + if (process.env.NODE_ENV !== 'production') { + var componentName = component && component.getName ? component.getName() : 'a component'; + process.env.NODE_ENV !== 'production' ? warning(publicComponentInstance != null || component._compositeType !== CompositeTypes.StatelessFunctional, 'Stateless function components cannot be given refs ' + '(See ref "%s" in %s created by %s). ' + 'Attempts to access this ref will fail.', ref, componentName, this.getName()) : void 0; + } + var refs = inst.refs === emptyObject ? inst.refs = {} : inst.refs; + refs[ref] = publicComponentInstance; + }, /** - * Optionally injectable hook for swapping out mount images in the middle of - * the tree. + * Detaches a reference name. + * + * @param {string} ref Name to dereference. + * @final + * @private */ - replaceNodeWithMarkup: null, + detachRef: function (ref) { + var refs = this.getPublicInstance().refs; + delete refs[ref]; + }, /** - * Optionally injectable hook for processing a queue of child updates. Will - * later move into MultiChildComponents. + * Get a text description of the component that can be used to identify it + * in error messages. + * @return {string} The name or null. + * @internal */ - processChildrenUpdates: null, + getName: function () { + var type = this._currentElement.type; + var constructor = this._instance && this._instance.constructor; + return type.displayName || constructor && constructor.displayName || type.name || constructor && constructor.name || null; + }, - injection: { - injectEnvironment: function (environment) { - !!injected ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactCompositeComponent: injectEnvironment() can only be called once.') : _prodInvariant('104') : void 0; - ReactComponentEnvironment.replaceNodeWithMarkup = environment.replaceNodeWithMarkup; - ReactComponentEnvironment.processChildrenUpdates = environment.processChildrenUpdates; - injected = true; + /** + * Get the publicly accessible representation of this component - i.e. what + * is exposed by refs and returned by render. Can be null for stateless + * components. + * + * @return {ReactComponent} the public component instance. + * @internal + */ + getPublicInstance: function () { + var inst = this._instance; + if (this._compositeType === CompositeTypes.StatelessFunctional) { + return null; } - } + return inst; + }, + + // Stub + _instantiateReactComponent: null }; -module.exports = ReactComponentEnvironment; +module.exports = ReactCompositeComponent; }).call(this,require('_process')) -},{"./reactProdInvariant":163,"_process":27,"fbjs/lib/invariant":16}],62:[function(require,module,exports){ +},{"./ReactComponentEnvironment":53,"./ReactErrorUtils":78,"./ReactInstanceMap":86,"./ReactInstrumentation":87,"./ReactNodeTypes":92,"./ReactReconciler":97,"./checkReactTypeSpec":124,"./reactProdInvariant":145,"./shouldUpdateReactComponent":149,"_process":25,"fbjs/lib/emptyObject":9,"fbjs/lib/invariant":16,"fbjs/lib/shallowEqual":22,"fbjs/lib/warning":23,"object-assign":24,"react/lib/React":154,"react/lib/ReactCurrentOwner":159}],55:[function(require,module,exports){ (function (process){ /** - * Copyright 2016-present, Facebook, Inc. + * Copyright 2013-present, Facebook, Inc. * All rights reserved. * * This source code is licensed under the BSD-style license found in the * LICENSE file in the root directory of this source tree. An additional grant * of patent rights can be found in the PATENTS file in the same directory. * - * @providesModule ReactComponentTreeHook */ -'use strict'; +/* globals __REACT_DEVTOOLS_GLOBAL_HOOK__*/ -var _prodInvariant = require('./reactProdInvariant'); +'use strict'; -var ReactCurrentOwner = require('./ReactCurrentOwner'); +var ReactDOMComponentTree = require('./ReactDOMComponentTree'); +var ReactDefaultInjection = require('./ReactDefaultInjection'); +var ReactMount = require('./ReactMount'); +var ReactReconciler = require('./ReactReconciler'); +var ReactUpdates = require('./ReactUpdates'); +var ReactVersion = require('./ReactVersion'); -var invariant = require('fbjs/lib/invariant'); +var findDOMNode = require('./findDOMNode'); +var getHostComponentFromComposite = require('./getHostComponentFromComposite'); +var renderSubtreeIntoContainer = require('./renderSubtreeIntoContainer'); var warning = require('fbjs/lib/warning'); -function isNative(fn) { - // Based on isNative() from Lodash - var funcToString = Function.prototype.toString; - var hasOwnProperty = Object.prototype.hasOwnProperty; - var reIsNative = RegExp('^' + funcToString - // Take an example native function source for comparison - .call(hasOwnProperty) - // Strip regex characters so we can use it for regex - .replace(/[\\^$.*+?()[\]{}|]/g, '\\$&') - // Remove hasOwnProperty from the template to make it generic - .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$'); - try { - var source = funcToString.call(fn); - return reIsNative.test(source); - } catch (err) { - return false; - } -} - -var canUseCollections = -// Array.from -typeof Array.from === 'function' && -// Map -typeof Map === 'function' && isNative(Map) && -// Map.prototype.keys -Map.prototype != null && typeof Map.prototype.keys === 'function' && isNative(Map.prototype.keys) && -// Set -typeof Set === 'function' && isNative(Set) && -// Set.prototype.keys -Set.prototype != null && typeof Set.prototype.keys === 'function' && isNative(Set.prototype.keys); +ReactDefaultInjection.inject(); -var itemMap; -var rootIDSet; +var ReactDOM = { + findDOMNode: findDOMNode, + render: ReactMount.render, + unmountComponentAtNode: ReactMount.unmountComponentAtNode, + version: ReactVersion, -var itemByKey; -var rootByKey; + /* eslint-disable camelcase */ + unstable_batchedUpdates: ReactUpdates.batchedUpdates, + unstable_renderSubtreeIntoContainer: renderSubtreeIntoContainer +}; -if (canUseCollections) { - itemMap = new Map(); - rootIDSet = new Set(); -} else { - itemByKey = {}; - rootByKey = {}; +// Inject the runtime into a devtools global hook regardless of browser. +// Allows for debugging when the hook is injected on the page. +if (typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ !== 'undefined' && typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.inject === 'function') { + __REACT_DEVTOOLS_GLOBAL_HOOK__.inject({ + ComponentTree: { + getClosestInstanceFromNode: ReactDOMComponentTree.getClosestInstanceFromNode, + getNodeFromInstance: function (inst) { + // inst is an internal instance (but could be a composite) + if (inst._renderedComponent) { + inst = getHostComponentFromComposite(inst); + } + if (inst) { + return ReactDOMComponentTree.getNodeFromInstance(inst); + } else { + return null; + } + } + }, + Mount: ReactMount, + Reconciler: ReactReconciler + }); } -var unmountedIDs = []; +if (process.env.NODE_ENV !== 'production') { + var ExecutionEnvironment = require('fbjs/lib/ExecutionEnvironment'); + if (ExecutionEnvironment.canUseDOM && window.top === window.self) { -// Use non-numeric keys to prevent V8 performance issues: -// https://github.com/facebook/react/pull/7232 -function getKeyFromID(id) { - return '.' + id; -} -function getIDFromKey(key) { - return parseInt(key.substr(1), 10); -} + // First check if devtools is not installed + if (typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ === 'undefined') { + // If we're in Chrome or Firefox, provide a download link if not installed. + if (navigator.userAgent.indexOf('Chrome') > -1 && navigator.userAgent.indexOf('Edge') === -1 || navigator.userAgent.indexOf('Firefox') > -1) { + // Firefox does not have the issue with devtools loaded over file:// + var showFileUrlMessage = window.location.protocol.indexOf('http') === -1 && navigator.userAgent.indexOf('Firefox') === -1; + console.debug('Download the React DevTools ' + (showFileUrlMessage ? 'and use an HTTP server (instead of a file: URL) ' : '') + 'for a better development experience: ' + 'https://fb.me/react-devtools'); + } + } -function get(id) { - if (canUseCollections) { - return itemMap.get(id); - } else { - var key = getKeyFromID(id); - return itemByKey[key]; + var testFunc = function testFn() {}; + process.env.NODE_ENV !== 'production' ? warning((testFunc.name || testFunc.toString()).indexOf('testFn') !== -1, 'It looks like you\'re using a minified copy of the development build ' + 'of React. When deploying React apps to production, make sure to use ' + 'the production build which skips development warnings and is faster. ' + 'See https://fb.me/react-minification for more details.') : void 0; + + // If we're in IE8, check to see if we are in compatibility mode and provide + // information on preventing compatibility mode + var ieCompatibilityMode = document.documentMode && document.documentMode < 8; + + process.env.NODE_ENV !== 'production' ? warning(!ieCompatibilityMode, 'Internet Explorer is running in compatibility mode; please add the ' + 'following tag to your HTML to prevent this from happening: ' + '') : void 0; + + var expectedFeatures = [ + // shims + Array.isArray, Array.prototype.every, Array.prototype.forEach, Array.prototype.indexOf, Array.prototype.map, Date.now, Function.prototype.bind, Object.keys, String.prototype.trim]; + + for (var i = 0; i < expectedFeatures.length; i++) { + if (!expectedFeatures[i]) { + process.env.NODE_ENV !== 'production' ? warning(false, 'One or more ES5 shims expected by React are not available: ' + 'https://fb.me/react-warning-polyfills') : void 0; + break; + } + } } } -function remove(id) { - if (canUseCollections) { - itemMap['delete'](id); - } else { - var key = getKeyFromID(id); - delete itemByKey[key]; - } +if (process.env.NODE_ENV !== 'production') { + var ReactInstrumentation = require('./ReactInstrumentation'); + var ReactDOMUnknownPropertyHook = require('./ReactDOMUnknownPropertyHook'); + var ReactDOMNullInputValuePropHook = require('./ReactDOMNullInputValuePropHook'); + var ReactDOMInvalidARIAHook = require('./ReactDOMInvalidARIAHook'); + + ReactInstrumentation.debugTool.addHook(ReactDOMUnknownPropertyHook); + ReactInstrumentation.debugTool.addHook(ReactDOMNullInputValuePropHook); + ReactInstrumentation.debugTool.addHook(ReactDOMInvalidARIAHook); } -function create(id, element, parentID) { - var item = { - element: element, - parentID: parentID, - text: null, - childIDs: [], - isMounted: false, - updateCount: 0 - }; +module.exports = ReactDOM; +}).call(this,require('_process')) - if (canUseCollections) { - itemMap.set(id, item); - } else { - var key = getKeyFromID(id); - itemByKey[key] = item; +},{"./ReactDOMComponentTree":58,"./ReactDOMInvalidARIAHook":64,"./ReactDOMNullInputValuePropHook":65,"./ReactDOMUnknownPropertyHook":72,"./ReactDefaultInjection":75,"./ReactInstrumentation":87,"./ReactMount":90,"./ReactReconciler":97,"./ReactUpdates":102,"./ReactVersion":103,"./findDOMNode":128,"./getHostComponentFromComposite":135,"./renderSubtreeIntoContainer":146,"_process":25,"fbjs/lib/ExecutionEnvironment":2,"fbjs/lib/warning":23}],56:[function(require,module,exports){ +(function (process){ +/** + * Copyright 2013-present, Facebook, Inc. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. An additional grant + * of patent rights can be found in the PATENTS file in the same directory. + * + */ + +/* global hasOwnProperty:true */ + +'use strict'; + +var _prodInvariant = require('./reactProdInvariant'), + _assign = require('object-assign'); + +var AutoFocusUtils = require('./AutoFocusUtils'); +var CSSPropertyOperations = require('./CSSPropertyOperations'); +var DOMLazyTree = require('./DOMLazyTree'); +var DOMNamespaces = require('./DOMNamespaces'); +var DOMProperty = require('./DOMProperty'); +var DOMPropertyOperations = require('./DOMPropertyOperations'); +var EventPluginHub = require('./EventPluginHub'); +var EventPluginRegistry = require('./EventPluginRegistry'); +var ReactBrowserEventEmitter = require('./ReactBrowserEventEmitter'); +var ReactDOMComponentFlags = require('./ReactDOMComponentFlags'); +var ReactDOMComponentTree = require('./ReactDOMComponentTree'); +var ReactDOMInput = require('./ReactDOMInput'); +var ReactDOMOption = require('./ReactDOMOption'); +var ReactDOMSelect = require('./ReactDOMSelect'); +var ReactDOMTextarea = require('./ReactDOMTextarea'); +var ReactInstrumentation = require('./ReactInstrumentation'); +var ReactMultiChild = require('./ReactMultiChild'); +var ReactServerRenderingTransaction = require('./ReactServerRenderingTransaction'); + +var emptyFunction = require('fbjs/lib/emptyFunction'); +var escapeTextContentForBrowser = require('./escapeTextContentForBrowser'); +var invariant = require('fbjs/lib/invariant'); +var isEventSupported = require('./isEventSupported'); +var shallowEqual = require('fbjs/lib/shallowEqual'); +var validateDOMNesting = require('./validateDOMNesting'); +var warning = require('fbjs/lib/warning'); + +var Flags = ReactDOMComponentFlags; +var deleteListener = EventPluginHub.deleteListener; +var getNode = ReactDOMComponentTree.getNodeFromInstance; +var listenTo = ReactBrowserEventEmitter.listenTo; +var registrationNameModules = EventPluginRegistry.registrationNameModules; + +// For quickly matching children type, to test if can be treated as content. +var CONTENT_TYPES = { 'string': true, 'number': true }; + +var STYLE = 'style'; +var HTML = '__html'; +var RESERVED_PROPS = { + children: null, + dangerouslySetInnerHTML: null, + suppressContentEditableWarning: null +}; + +// Node type for document fragments (Node.DOCUMENT_FRAGMENT_NODE). +var DOC_FRAGMENT_TYPE = 11; + +function getDeclarationErrorAddendum(internalInstance) { + if (internalInstance) { + var owner = internalInstance._currentElement._owner || null; + if (owner) { + var name = owner.getName(); + if (name) { + return ' This DOM node was rendered by `' + name + '`.'; + } + } } + return ''; } -function addRoot(id) { - if (canUseCollections) { - rootIDSet.add(id); - } else { - var key = getKeyFromID(id); - rootByKey[key] = true; +function friendlyStringify(obj) { + if (typeof obj === 'object') { + if (Array.isArray(obj)) { + return '[' + obj.map(friendlyStringify).join(', ') + ']'; + } else { + var pairs = []; + for (var key in obj) { + if (Object.prototype.hasOwnProperty.call(obj, key)) { + var keyEscaped = /^[a-z$_][\w$_]*$/i.test(key) ? key : JSON.stringify(key); + pairs.push(keyEscaped + ': ' + friendlyStringify(obj[key])); + } + } + return '{' + pairs.join(', ') + '}'; + } + } else if (typeof obj === 'string') { + return JSON.stringify(obj); + } else if (typeof obj === 'function') { + return '[function object]'; } + // Differs from JSON.stringify in that undefined because undefined and that + // inf and nan don't become null + return String(obj); } -function removeRoot(id) { - if (canUseCollections) { - rootIDSet['delete'](id); - } else { - var key = getKeyFromID(id); - delete rootByKey[key]; +var styleMutationWarning = {}; + +function checkAndWarnForMutatedStyle(style1, style2, component) { + if (style1 == null || style2 == null) { + return; + } + if (shallowEqual(style1, style2)) { + return; } -} -function getRegisteredIDs() { - if (canUseCollections) { - return Array.from(itemMap.keys()); - } else { - return Object.keys(itemByKey).map(getIDFromKey); + var componentName = component._tag; + var owner = component._currentElement._owner; + var ownerName; + if (owner) { + ownerName = owner.getName(); } -} -function getRootIDs() { - if (canUseCollections) { - return Array.from(rootIDSet.keys()); - } else { - return Object.keys(rootByKey).map(getIDFromKey); + var hash = ownerName + '|' + componentName; + + if (styleMutationWarning.hasOwnProperty(hash)) { + return; } + + styleMutationWarning[hash] = true; + + process.env.NODE_ENV !== 'production' ? warning(false, '`%s` was passed a style object that has previously been mutated. ' + 'Mutating `style` is deprecated. Consider cloning it beforehand. Check ' + 'the `render` %s. Previous style: %s. Mutated style: %s.', componentName, owner ? 'of `' + ownerName + '`' : 'using <' + componentName + '>', friendlyStringify(style1), friendlyStringify(style2)) : void 0; } -function purgeDeep(id) { - var item = get(id); - if (item) { - var childIDs = item.childIDs; +/** + * @param {object} component + * @param {?object} props + */ +function assertValidProps(component, props) { + if (!props) { + return; + } + // Note the use of `==` which checks for null or undefined. + if (voidElementTags[component._tag]) { + !(props.children == null && props.dangerouslySetInnerHTML == null) ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s is a void element tag and must neither have `children` nor use `dangerouslySetInnerHTML`.%s', component._tag, component._currentElement._owner ? ' Check the render method of ' + component._currentElement._owner.getName() + '.' : '') : _prodInvariant('137', component._tag, component._currentElement._owner ? ' Check the render method of ' + component._currentElement._owner.getName() + '.' : '') : void 0; + } + if (props.dangerouslySetInnerHTML != null) { + !(props.children == null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Can only set one of `children` or `props.dangerouslySetInnerHTML`.') : _prodInvariant('60') : void 0; + !(typeof props.dangerouslySetInnerHTML === 'object' && HTML in props.dangerouslySetInnerHTML) ? process.env.NODE_ENV !== 'production' ? invariant(false, '`props.dangerouslySetInnerHTML` must be in the form `{__html: ...}`. Please visit https://fb.me/react-invariant-dangerously-set-inner-html for more information.') : _prodInvariant('61') : void 0; + } + if (process.env.NODE_ENV !== 'production') { + process.env.NODE_ENV !== 'production' ? warning(props.innerHTML == null, 'Directly setting property `innerHTML` is not permitted. ' + 'For more information, lookup documentation on `dangerouslySetInnerHTML`.') : void 0; + process.env.NODE_ENV !== 'production' ? warning(props.suppressContentEditableWarning || !props.contentEditable || props.children == null, 'A component is `contentEditable` and contains `children` managed by ' + 'React. It is now your responsibility to guarantee that none of ' + 'those nodes are unexpectedly modified or duplicated. This is ' + 'probably not intentional.') : void 0; + process.env.NODE_ENV !== 'production' ? warning(props.onFocusIn == null && props.onFocusOut == null, 'React uses onFocus and onBlur instead of onFocusIn and onFocusOut. ' + 'All React events are normalized to bubble, so onFocusIn and onFocusOut ' + 'are not needed/supported by React.') : void 0; + } + !(props.style == null || typeof props.style === 'object') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'The `style` prop expects a mapping from style properties to values, not a string. For example, style={{marginRight: spacing + \'em\'}} when using JSX.%s', getDeclarationErrorAddendum(component)) : _prodInvariant('62', getDeclarationErrorAddendum(component)) : void 0; +} - remove(id); - childIDs.forEach(purgeDeep); +function enqueuePutListener(inst, registrationName, listener, transaction) { + if (transaction instanceof ReactServerRenderingTransaction) { + return; } + if (process.env.NODE_ENV !== 'production') { + // IE8 has no API for event capturing and the `onScroll` event doesn't + // bubble. + process.env.NODE_ENV !== 'production' ? warning(registrationName !== 'onScroll' || isEventSupported('scroll', true), 'This browser doesn\'t support the `onScroll` event') : void 0; + } + var containerInfo = inst._hostContainerInfo; + var isDocumentFragment = containerInfo._node && containerInfo._node.nodeType === DOC_FRAGMENT_TYPE; + var doc = isDocumentFragment ? containerInfo._node : containerInfo._ownerDocument; + listenTo(registrationName, doc); + transaction.getReactMountReady().enqueue(putListener, { + inst: inst, + registrationName: registrationName, + listener: listener + }); } -function describeComponentFrame(name, source, ownerName) { - return '\n in ' + name + (source ? ' (at ' + source.fileName.replace(/^.*[\\\/]/, '') + ':' + source.lineNumber + ')' : ownerName ? ' (created by ' + ownerName + ')' : ''); +function putListener() { + var listenerToPut = this; + EventPluginHub.putListener(listenerToPut.inst, listenerToPut.registrationName, listenerToPut.listener); } -function getDisplayName(element) { - if (element == null) { - return '#empty'; - } else if (typeof element === 'string' || typeof element === 'number') { - return '#text'; - } else if (typeof element.type === 'string') { - return element.type; - } else { - return element.type.displayName || element.type.name || 'Unknown'; - } +function inputPostMount() { + var inst = this; + ReactDOMInput.postMountWrapper(inst); } -function describeID(id) { - var name = ReactComponentTreeHook.getDisplayName(id); - var element = ReactComponentTreeHook.getElement(id); - var ownerID = ReactComponentTreeHook.getOwnerID(id); - var ownerName; - if (ownerID) { - ownerName = ReactComponentTreeHook.getDisplayName(ownerID); - } - process.env.NODE_ENV !== 'production' ? warning(element, 'ReactComponentTreeHook: Missing React element for debugID %s when ' + 'building stack', id) : void 0; - return describeComponentFrame(name, element && element._source, ownerName); +function textareaPostMount() { + var inst = this; + ReactDOMTextarea.postMountWrapper(inst); } -var ReactComponentTreeHook = { - onSetChildren: function (id, nextChildIDs) { - var item = get(id); - item.childIDs = nextChildIDs; +function optionPostMount() { + var inst = this; + ReactDOMOption.postMountWrapper(inst); +} - for (var i = 0; i < nextChildIDs.length; i++) { - var nextChildID = nextChildIDs[i]; - var nextChild = get(nextChildID); - !nextChild ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Expected hook events to fire for the child before its parent includes it in onSetChildren().') : _prodInvariant('140') : void 0; - !(nextChild.childIDs != null || typeof nextChild.element !== 'object' || nextChild.element == null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Expected onSetChildren() to fire for a container child before its parent includes it in onSetChildren().') : _prodInvariant('141') : void 0; - !nextChild.isMounted ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Expected onMountComponent() to fire for the child before its parent includes it in onSetChildren().') : _prodInvariant('71') : void 0; - if (nextChild.parentID == null) { - nextChild.parentID = id; - // TODO: This shouldn't be necessary but mounting a new root during in - // componentWillMount currently causes not-yet-mounted components to - // be purged from our tree data so their parent ID is missing. - } - !(nextChild.parentID === id) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Expected onBeforeMountComponent() parent and onSetChildren() to be consistent (%s has parents %s and %s).', nextChildID, nextChild.parentID, id) : _prodInvariant('142', nextChildID, nextChild.parentID, id) : void 0; - } - }, - onBeforeMountComponent: function (id, element, parentID) { - create(id, element, parentID); - }, - onBeforeUpdateComponent: function (id, element) { - var item = get(id); - if (!item || !item.isMounted) { - // We may end up here as a result of setState() in componentWillUnmount(). - // In this case, ignore the element. - return; - } - item.element = element; - }, - onMountComponent: function (id) { - var item = get(id); - item.isMounted = true; - var isRoot = item.parentID === 0; - if (isRoot) { - addRoot(id); - } - }, - onUpdateComponent: function (id) { - var item = get(id); - if (!item || !item.isMounted) { - // We may end up here as a result of setState() in componentWillUnmount(). - // In this case, ignore the element. - return; - } - item.updateCount++; - }, - onUnmountComponent: function (id) { - var item = get(id); - if (item) { - // We need to check if it exists. - // `item` might not exist if it is inside an error boundary, and a sibling - // error boundary child threw while mounting. Then this instance never - // got a chance to mount, but it still gets an unmounting event during - // the error boundary cleanup. - item.isMounted = false; - var isRoot = item.parentID === 0; - if (isRoot) { - removeRoot(id); +var setAndValidateContentChildDev = emptyFunction; +if (process.env.NODE_ENV !== 'production') { + setAndValidateContentChildDev = function (content) { + var hasExistingContent = this._contentDebugID != null; + var debugID = this._debugID; + // This ID represents the inlined child that has no backing instance: + var contentDebugID = -debugID; + + if (content == null) { + if (hasExistingContent) { + ReactInstrumentation.debugTool.onUnmountComponent(this._contentDebugID); } - } - unmountedIDs.push(id); - }, - purgeUnmountedComponents: function () { - if (ReactComponentTreeHook._preventPurging) { - // Should only be used for testing. + this._contentDebugID = null; return; } - for (var i = 0; i < unmountedIDs.length; i++) { - var id = unmountedIDs[i]; - purgeDeep(id); - } - unmountedIDs.length = 0; - }, - isMounted: function (id) { - var item = get(id); - return item ? item.isMounted : false; - }, - getCurrentStackAddendum: function (topElement) { - var info = ''; - if (topElement) { - var type = topElement.type; - var name = typeof type === 'function' ? type.displayName || type.name : type; - var owner = topElement._owner; - info += describeComponentFrame(name || 'Unknown', topElement._source, owner && owner.getName()); - } - - var currentOwner = ReactCurrentOwner.current; - var id = currentOwner && currentOwner._debugID; - - info += ReactComponentTreeHook.getStackAddendumByID(id); - return info; - }, - getStackAddendumByID: function (id) { - var info = ''; - while (id) { - info += describeID(id); - id = ReactComponentTreeHook.getParentID(id); - } - return info; - }, - getChildIDs: function (id) { - var item = get(id); - return item ? item.childIDs : []; - }, - getDisplayName: function (id) { - var element = ReactComponentTreeHook.getElement(id); - if (!element) { - return null; - } - return getDisplayName(element); - }, - getElement: function (id) { - var item = get(id); - return item ? item.element : null; - }, - getOwnerID: function (id) { - var element = ReactComponentTreeHook.getElement(id); - if (!element || !element._owner) { - return null; - } - return element._owner._debugID; - }, - getParentID: function (id) { - var item = get(id); - return item ? item.parentID : null; - }, - getSource: function (id) { - var item = get(id); - var element = item ? item.element : null; - var source = element != null ? element._source : null; - return source; - }, - getText: function (id) { - var element = ReactComponentTreeHook.getElement(id); - if (typeof element === 'string') { - return element; - } else if (typeof element === 'number') { - return '' + element; + validateDOMNesting(null, String(content), this, this._ancestorInfo); + this._contentDebugID = contentDebugID; + if (hasExistingContent) { + ReactInstrumentation.debugTool.onBeforeUpdateComponent(contentDebugID, content); + ReactInstrumentation.debugTool.onUpdateComponent(contentDebugID); } else { - return null; + ReactInstrumentation.debugTool.onBeforeMountComponent(contentDebugID, content, debugID); + ReactInstrumentation.debugTool.onMountComponent(contentDebugID); + ReactInstrumentation.debugTool.onSetChildren(debugID, [contentDebugID]); } - }, - getUpdateCount: function (id) { - var item = get(id); - return item ? item.updateCount : 0; - }, - - - getRegisteredIDs: getRegisteredIDs, + }; +} - getRootIDs: getRootIDs +// There are so many media events, it makes sense to just +// maintain a list rather than create a `trapBubbledEvent` for each +var mediaEvents = { + topAbort: 'abort', + topCanPlay: 'canplay', + topCanPlayThrough: 'canplaythrough', + topDurationChange: 'durationchange', + topEmptied: 'emptied', + topEncrypted: 'encrypted', + topEnded: 'ended', + topError: 'error', + topLoadedData: 'loadeddata', + topLoadedMetadata: 'loadedmetadata', + topLoadStart: 'loadstart', + topPause: 'pause', + topPlay: 'play', + topPlaying: 'playing', + topProgress: 'progress', + topRateChange: 'ratechange', + topSeeked: 'seeked', + topSeeking: 'seeking', + topStalled: 'stalled', + topSuspend: 'suspend', + topTimeUpdate: 'timeupdate', + topVolumeChange: 'volumechange', + topWaiting: 'waiting' }; -module.exports = ReactComponentTreeHook; -}).call(this,require('_process')) - -},{"./ReactCurrentOwner":64,"./reactProdInvariant":163,"_process":27,"fbjs/lib/invariant":16,"fbjs/lib/warning":25}],63:[function(require,module,exports){ -(function (process){ -/** - * Copyright 2013-present, Facebook, Inc. - * All rights reserved. - * - * This source code is licensed under the BSD-style license found in the - * LICENSE file in the root directory of this source tree. An additional grant - * of patent rights can be found in the PATENTS file in the same directory. - * - * @providesModule ReactCompositeComponent - */ - -'use strict'; - -var _prodInvariant = require('./reactProdInvariant'), - _assign = require('object-assign'); - -var ReactComponentEnvironment = require('./ReactComponentEnvironment'); -var ReactCurrentOwner = require('./ReactCurrentOwner'); -var ReactElement = require('./ReactElement'); -var ReactErrorUtils = require('./ReactErrorUtils'); -var ReactInstanceMap = require('./ReactInstanceMap'); -var ReactInstrumentation = require('./ReactInstrumentation'); -var ReactNodeTypes = require('./ReactNodeTypes'); -var ReactPropTypeLocations = require('./ReactPropTypeLocations'); -var ReactReconciler = require('./ReactReconciler'); - -var checkReactTypeSpec = require('./checkReactTypeSpec'); -var emptyObject = require('fbjs/lib/emptyObject'); -var invariant = require('fbjs/lib/invariant'); -var shallowEqual = require('fbjs/lib/shallowEqual'); -var shouldUpdateReactComponent = require('./shouldUpdateReactComponent'); -var warning = require('fbjs/lib/warning'); - -var CompositeTypes = { - ImpureClass: 0, - PureClass: 1, - StatelessFunctional: 2 -}; +function trapBubbledEventsLocal() { + var inst = this; + // If a component renders to null or if another component fatals and causes + // the state of the tree to be corrupted, `node` here can be null. + !inst._rootNodeID ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Must be mounted to trap events') : _prodInvariant('63') : void 0; + var node = getNode(inst); + !node ? process.env.NODE_ENV !== 'production' ? invariant(false, 'trapBubbledEvent(...): Requires node to be rendered.') : _prodInvariant('64') : void 0; -function StatelessComponent(Component) {} -StatelessComponent.prototype.render = function () { - var Component = ReactInstanceMap.get(this)._currentElement.type; - var element = Component(this.props, this.context, this.updater); - warnIfInvalidElement(Component, element); - return element; -}; + switch (inst._tag) { + case 'iframe': + case 'object': + inst._wrapperState.listeners = [ReactBrowserEventEmitter.trapBubbledEvent('topLoad', 'load', node)]; + break; + case 'video': + case 'audio': -function warnIfInvalidElement(Component, element) { - if (process.env.NODE_ENV !== 'production') { - process.env.NODE_ENV !== 'production' ? warning(element === null || element === false || ReactElement.isValidElement(element), '%s(...): A valid React element (or null) must be returned. You may have ' + 'returned undefined, an array or some other invalid object.', Component.displayName || Component.name || 'Component') : void 0; - process.env.NODE_ENV !== 'production' ? warning(!Component.childContextTypes, '%s(...): childContextTypes cannot be defined on a functional component.', Component.displayName || Component.name || 'Component') : void 0; + inst._wrapperState.listeners = []; + // Create listener for each media event + for (var event in mediaEvents) { + if (mediaEvents.hasOwnProperty(event)) { + inst._wrapperState.listeners.push(ReactBrowserEventEmitter.trapBubbledEvent(event, mediaEvents[event], node)); + } + } + break; + case 'source': + inst._wrapperState.listeners = [ReactBrowserEventEmitter.trapBubbledEvent('topError', 'error', node)]; + break; + case 'img': + inst._wrapperState.listeners = [ReactBrowserEventEmitter.trapBubbledEvent('topError', 'error', node), ReactBrowserEventEmitter.trapBubbledEvent('topLoad', 'load', node)]; + break; + case 'form': + inst._wrapperState.listeners = [ReactBrowserEventEmitter.trapBubbledEvent('topReset', 'reset', node), ReactBrowserEventEmitter.trapBubbledEvent('topSubmit', 'submit', node)]; + break; + case 'input': + case 'select': + case 'textarea': + inst._wrapperState.listeners = [ReactBrowserEventEmitter.trapBubbledEvent('topInvalid', 'invalid', node)]; + break; } } -function shouldConstruct(Component) { - return !!(Component.prototype && Component.prototype.isReactComponent); -} - -function isPureComponent(Component) { - return !!(Component.prototype && Component.prototype.isPureReactComponent); +function postUpdateSelectWrapper() { + ReactDOMSelect.postUpdateWrapper(this); } -// Separated into a function to contain deoptimizations caused by try/finally. -function measureLifeCyclePerf(fn, debugID, timerType) { - if (debugID === 0) { - // Top-level wrappers (see ReactMount) and empty components (see - // ReactDOMEmptyComponent) are invisible to hooks and devtools. - // Both are implementation details that should go away in the future. - return fn(); - } +// For HTML, certain tags should omit their close tag. We keep a whitelist for +// those special-case tags. - ReactInstrumentation.debugTool.onBeginLifeCycleTimer(debugID, timerType); - try { - return fn(); - } finally { - ReactInstrumentation.debugTool.onEndLifeCycleTimer(debugID, timerType); +var omittedCloseTags = { + 'area': true, + 'base': true, + 'br': true, + 'col': true, + 'embed': true, + 'hr': true, + 'img': true, + 'input': true, + 'keygen': true, + 'link': true, + 'meta': true, + 'param': true, + 'source': true, + 'track': true, + 'wbr': true +}; + +var newlineEatingTags = { + 'listing': true, + 'pre': true, + 'textarea': true +}; + +// For HTML, certain tags cannot have children. This has the same purpose as +// `omittedCloseTags` except that `menuitem` should still have its closing tag. + +var voidElementTags = _assign({ + 'menuitem': true +}, omittedCloseTags); + +// We accept any tag to be rendered but since this gets injected into arbitrary +// HTML, we want to make sure that it's a safe tag. +// http://www.w3.org/TR/REC-xml/#NT-Name + +var VALID_TAG_REGEX = /^[a-zA-Z][a-zA-Z:_\.\-\d]*$/; // Simplified subset +var validatedTagCache = {}; +var hasOwnProperty = {}.hasOwnProperty; + +function validateDangerousTag(tag) { + if (!hasOwnProperty.call(validatedTagCache, tag)) { + !VALID_TAG_REGEX.test(tag) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Invalid tag: %s', tag) : _prodInvariant('65', tag) : void 0; + validatedTagCache[tag] = true; } } +function isCustomComponent(tagName, props) { + return tagName.indexOf('-') >= 0 || props.is != null; +} + +var globalIdCounter = 1; + /** - * ------------------ The Life-Cycle of a Composite Component ------------------ - * - * - constructor: Initialization of state. The instance is now retained. - * - componentWillMount - * - render - * - [children's constructors] - * - [children's componentWillMount and render] - * - [children's componentDidMount] - * - componentDidMount + * Creates a new React class that is idempotent and capable of containing other + * React components. It accepts event listeners and DOM properties that are + * valid according to `DOMProperty`. * - * Update Phases: - * - componentWillReceiveProps (only called if parent updated) - * - shouldComponentUpdate - * - componentWillUpdate - * - render - * - [children's constructors or receive props phases] - * - componentDidUpdate + * - Event listeners: `onClick`, `onMouseDown`, etc. + * - DOM properties: `className`, `name`, `title`, etc. * - * - componentWillUnmount - * - [children's componentWillUnmount] - * - [children destroyed] - * - (destroyed): The instance is now blank, released by React and ready for GC. + * The `style` property functions differently from the DOM API. It accepts an + * object mapping of style properties to values. * - * ----------------------------------------------------------------------------- + * @constructor ReactDOMComponent + * @extends ReactMultiChild */ +function ReactDOMComponent(element) { + var tag = element.type; + validateDangerousTag(tag); + this._currentElement = element; + this._tag = tag.toLowerCase(); + this._namespaceURI = null; + this._renderedChildren = null; + this._previousStyle = null; + this._previousStyleCopy = null; + this._hostNode = null; + this._hostParent = null; + this._rootNodeID = 0; + this._domID = 0; + this._hostContainerInfo = null; + this._wrapperState = null; + this._topLevelWrapper = null; + this._flags = 0; + if (process.env.NODE_ENV !== 'production') { + this._ancestorInfo = null; + setAndValidateContentChildDev.call(this, null); + } +} -/** - * An incrementing ID assigned to each component when it is mounted. This is - * used to enforce the order in which `ReactUpdates` updates dirty components. - * - * @private - */ -var nextMountID = 1; +ReactDOMComponent.displayName = 'ReactDOMComponent'; -/** - * @lends {ReactCompositeComponent.prototype} - */ -var ReactCompositeComponentMixin = { +ReactDOMComponent.Mixin = { /** - * Base constructor for all composite component. + * Generates root tag markup then recurses. This method has side effects and + * is not idempotent. * - * @param {ReactElement} element - * @final * @internal - */ - construct: function (element) { - this._currentElement = element; - this._rootNodeID = 0; - this._compositeType = null; - this._instance = null; - this._hostParent = null; - this._hostContainerInfo = null; - - // See ReactUpdateQueue - this._updateBatchNumber = null; - this._pendingElement = null; - this._pendingStateQueue = null; - this._pendingReplaceState = false; - this._pendingForceUpdate = false; - - this._renderedNodeType = null; - this._renderedComponent = null; - this._context = null; - this._mountOrder = 0; - this._topLevelWrapper = null; - - // See ReactUpdates and ReactUpdateQueue. - this._pendingCallbacks = null; - - // ComponentWillUnmount shall only be called once - this._calledComponentWillUnmount = false; - - if (process.env.NODE_ENV !== 'production') { - this._warnedAboutRefsInRender = false; - } - }, - - /** - * Initializes the component, renders markup, and registers event listeners. - * * @param {ReactReconcileTransaction|ReactServerRenderingTransaction} transaction - * @param {?object} hostParent - * @param {?object} hostContainerInfo - * @param {?object} context - * @return {?string} Rendered markup to be inserted into the DOM. - * @final - * @internal + * @param {?ReactDOMComponent} the parent component instance + * @param {?object} info about the host container + * @param {object} context + * @return {string} The computed markup. */ mountComponent: function (transaction, hostParent, hostContainerInfo, context) { - var _this = this; - - this._context = context; - this._mountOrder = nextMountID++; + this._rootNodeID = globalIdCounter++; + this._domID = hostContainerInfo._idCounter++; this._hostParent = hostParent; this._hostContainerInfo = hostContainerInfo; - var publicProps = this._currentElement.props; - var publicContext = this._processContext(context); - - var Component = this._currentElement.type; - - var updateQueue = transaction.getUpdateQueue(); - - // Initialize the public class - var doConstruct = shouldConstruct(Component); - var inst = this._constructComponent(doConstruct, publicProps, publicContext, updateQueue); - var renderedElement; + var props = this._currentElement.props; - // Support functional components - if (!doConstruct && (inst == null || inst.render == null)) { - renderedElement = inst; - warnIfInvalidElement(Component, renderedElement); - !(inst === null || inst === false || ReactElement.isValidElement(inst)) ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s(...): A valid React element (or null) must be returned. You may have returned undefined, an array or some other invalid object.', Component.displayName || Component.name || 'Component') : _prodInvariant('105', Component.displayName || Component.name || 'Component') : void 0; - inst = new StatelessComponent(Component); - this._compositeType = CompositeTypes.StatelessFunctional; - } else { - if (isPureComponent(Component)) { - this._compositeType = CompositeTypes.PureClass; - } else { - this._compositeType = CompositeTypes.ImpureClass; - } + switch (this._tag) { + case 'audio': + case 'form': + case 'iframe': + case 'img': + case 'link': + case 'object': + case 'source': + case 'video': + this._wrapperState = { + listeners: null + }; + transaction.getReactMountReady().enqueue(trapBubbledEventsLocal, this); + break; + case 'input': + ReactDOMInput.mountWrapper(this, props, hostParent); + props = ReactDOMInput.getHostProps(this, props); + transaction.getReactMountReady().enqueue(trapBubbledEventsLocal, this); + break; + case 'option': + ReactDOMOption.mountWrapper(this, props, hostParent); + props = ReactDOMOption.getHostProps(this, props); + break; + case 'select': + ReactDOMSelect.mountWrapper(this, props, hostParent); + props = ReactDOMSelect.getHostProps(this, props); + transaction.getReactMountReady().enqueue(trapBubbledEventsLocal, this); + break; + case 'textarea': + ReactDOMTextarea.mountWrapper(this, props, hostParent); + props = ReactDOMTextarea.getHostProps(this, props); + transaction.getReactMountReady().enqueue(trapBubbledEventsLocal, this); + break; } - if (process.env.NODE_ENV !== 'production') { - // This will throw later in _renderValidatedComponent, but add an early - // warning now to help debugging - if (inst.render == null) { - process.env.NODE_ENV !== 'production' ? warning(false, '%s(...): No `render` method found on the returned component ' + 'instance: you may have forgotten to define `render`.', Component.displayName || Component.name || 'Component') : void 0; - } - - var propsMutated = inst.props !== publicProps; - var componentName = Component.displayName || Component.name || 'Component'; - - process.env.NODE_ENV !== 'production' ? warning(inst.props === undefined || !propsMutated, '%s(...): When calling super() in `%s`, make sure to pass ' + 'up the same props that your component\'s constructor was passed.', componentName, componentName) : void 0; - } + assertValidProps(this, props); - // These should be set up in the constructor, but as a convenience for - // simpler class abstractions, we set them up after the fact. - inst.props = publicProps; - inst.context = publicContext; - inst.refs = emptyObject; - inst.updater = updateQueue; - - this._instance = inst; - - // Store a reference from the instance back to the internal representation - ReactInstanceMap.set(inst, this); - - if (process.env.NODE_ENV !== 'production') { - // Since plain JS classes are defined without any special initialization - // logic, we can not catch common errors early. Therefore, we have to - // catch them here, at initialization time, instead. - process.env.NODE_ENV !== 'production' ? warning(!inst.getInitialState || inst.getInitialState.isReactClassApproved, 'getInitialState was defined on %s, a plain JavaScript class. ' + 'This is only supported for classes created using React.createClass. ' + 'Did you mean to define a state property instead?', this.getName() || 'a component') : void 0; - process.env.NODE_ENV !== 'production' ? warning(!inst.getDefaultProps || inst.getDefaultProps.isReactClassApproved, 'getDefaultProps was defined on %s, a plain JavaScript class. ' + 'This is only supported for classes created using React.createClass. ' + 'Use a static property to define defaultProps instead.', this.getName() || 'a component') : void 0; - process.env.NODE_ENV !== 'production' ? warning(!inst.propTypes, 'propTypes was defined as an instance property on %s. Use a static ' + 'property to define propTypes instead.', this.getName() || 'a component') : void 0; - process.env.NODE_ENV !== 'production' ? warning(!inst.contextTypes, 'contextTypes was defined as an instance property on %s. Use a ' + 'static property to define contextTypes instead.', this.getName() || 'a component') : void 0; - process.env.NODE_ENV !== 'production' ? warning(typeof inst.componentShouldUpdate !== 'function', '%s has a method called ' + 'componentShouldUpdate(). Did you mean shouldComponentUpdate()? ' + 'The name is phrased as a question because the function is ' + 'expected to return a value.', this.getName() || 'A component') : void 0; - process.env.NODE_ENV !== 'production' ? warning(typeof inst.componentDidUnmount !== 'function', '%s has a method called ' + 'componentDidUnmount(). But there is no such lifecycle method. ' + 'Did you mean componentWillUnmount()?', this.getName() || 'A component') : void 0; - process.env.NODE_ENV !== 'production' ? warning(typeof inst.componentWillRecieveProps !== 'function', '%s has a method called ' + 'componentWillRecieveProps(). Did you mean componentWillReceiveProps()?', this.getName() || 'A component') : void 0; - } - - var initialState = inst.state; - if (initialState === undefined) { - inst.state = initialState = null; + // We create tags in the namespace of their parent container, except HTML + // tags get no namespace. + var namespaceURI; + var parentTag; + if (hostParent != null) { + namespaceURI = hostParent._namespaceURI; + parentTag = hostParent._tag; + } else if (hostContainerInfo._tag) { + namespaceURI = hostContainerInfo._namespaceURI; + parentTag = hostContainerInfo._tag; } - !(typeof initialState === 'object' && !Array.isArray(initialState)) ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s.state: must be set to an object or null', this.getName() || 'ReactCompositeComponent') : _prodInvariant('106', this.getName() || 'ReactCompositeComponent') : void 0; - - this._pendingStateQueue = null; - this._pendingReplaceState = false; - this._pendingForceUpdate = false; - - var markup; - if (inst.unstable_handleError) { - markup = this.performInitialMountWithErrorHandling(renderedElement, hostParent, hostContainerInfo, transaction, context); - } else { - markup = this.performInitialMount(renderedElement, hostParent, hostContainerInfo, transaction, context); + if (namespaceURI == null || namespaceURI === DOMNamespaces.svg && parentTag === 'foreignobject') { + namespaceURI = DOMNamespaces.html; } - - if (inst.componentDidMount) { - if (process.env.NODE_ENV !== 'production') { - transaction.getReactMountReady().enqueue(function () { - measureLifeCyclePerf(function () { - return inst.componentDidMount(); - }, _this._debugID, 'componentDidMount'); - }); - } else { - transaction.getReactMountReady().enqueue(inst.componentDidMount, inst); + if (namespaceURI === DOMNamespaces.html) { + if (this._tag === 'svg') { + namespaceURI = DOMNamespaces.svg; + } else if (this._tag === 'math') { + namespaceURI = DOMNamespaces.mathml; } } + this._namespaceURI = namespaceURI; - return markup; - }, - - _constructComponent: function (doConstruct, publicProps, publicContext, updateQueue) { if (process.env.NODE_ENV !== 'production') { - ReactCurrentOwner.current = this; - try { - return this._constructComponentWithoutOwner(doConstruct, publicProps, publicContext, updateQueue); - } finally { - ReactCurrentOwner.current = null; + var parentInfo; + if (hostParent != null) { + parentInfo = hostParent._ancestorInfo; + } else if (hostContainerInfo._tag) { + parentInfo = hostContainerInfo._ancestorInfo; } - } else { - return this._constructComponentWithoutOwner(doConstruct, publicProps, publicContext, updateQueue); + if (parentInfo) { + // parentInfo should always be present except for the top-level + // component when server rendering + validateDOMNesting(this._tag, null, this, parentInfo); + } + this._ancestorInfo = validateDOMNesting.updatedAncestorInfo(parentInfo, this._tag, this); } - }, - - _constructComponentWithoutOwner: function (doConstruct, publicProps, publicContext, updateQueue) { - var Component = this._currentElement.type; - if (doConstruct) { - if (process.env.NODE_ENV !== 'production') { - return measureLifeCyclePerf(function () { - return new Component(publicProps, publicContext, updateQueue); - }, this._debugID, 'ctor'); + var mountImage; + if (transaction.useCreateElement) { + var ownerDocument = hostContainerInfo._ownerDocument; + var el; + if (namespaceURI === DOMNamespaces.html) { + if (this._tag === 'script') { + // Create the script via .innerHTML so its "parser-inserted" flag is + // set to true and it does not execute + var div = ownerDocument.createElement('div'); + var type = this._currentElement.type; + div.innerHTML = '<' + type + '>'; + el = div.removeChild(div.firstChild); + } else if (props.is) { + el = ownerDocument.createElement(this._currentElement.type, props.is); + } else { + // Separate else branch instead of using `props.is || undefined` above becuase of a Firefox bug. + // See discussion in https://github.com/facebook/react/pull/6896 + // and discussion in https://bugzilla.mozilla.org/show_bug.cgi?id=1276240 + el = ownerDocument.createElement(this._currentElement.type); + } } else { - return new Component(publicProps, publicContext, updateQueue); + el = ownerDocument.createElementNS(namespaceURI, this._currentElement.type); } - } - - // This can still be an instance in case of factory components - // but we'll count this as time spent rendering as the more common case. - if (process.env.NODE_ENV !== 'production') { - return measureLifeCyclePerf(function () { - return Component(publicProps, publicContext, updateQueue); - }, this._debugID, 'render'); - } else { - return Component(publicProps, publicContext, updateQueue); - } - }, - - performInitialMountWithErrorHandling: function (renderedElement, hostParent, hostContainerInfo, transaction, context) { - var markup; - var checkpoint = transaction.checkpoint(); - try { - markup = this.performInitialMount(renderedElement, hostParent, hostContainerInfo, transaction, context); - } catch (e) { - // Roll back to checkpoint, handle error (which may add items to the transaction), and take a new checkpoint - transaction.rollback(checkpoint); - this._instance.unstable_handleError(e); - if (this._pendingStateQueue) { - this._instance.state = this._processPendingState(this._instance.props, this._instance.context); + ReactDOMComponentTree.precacheNode(this, el); + this._flags |= Flags.hasCachedChildNodes; + if (!this._hostParent) { + DOMPropertyOperations.setAttributeForRoot(el); } - checkpoint = transaction.checkpoint(); - - this._renderedComponent.unmountComponent(true); - transaction.rollback(checkpoint); - - // Try again - we've informed the component about the error, so they can render an error message this time. - // If this throws again, the error will bubble up (and can be caught by a higher error boundary). - markup = this.performInitialMount(renderedElement, hostParent, hostContainerInfo, transaction, context); - } - return markup; - }, - - performInitialMount: function (renderedElement, hostParent, hostContainerInfo, transaction, context) { - var inst = this._instance; - - var debugID = 0; - if (process.env.NODE_ENV !== 'production') { - debugID = this._debugID; - } - - if (inst.componentWillMount) { - if (process.env.NODE_ENV !== 'production') { - measureLifeCyclePerf(function () { - return inst.componentWillMount(); - }, debugID, 'componentWillMount'); + this._updateDOMProperties(null, props, transaction); + var lazyTree = DOMLazyTree(el); + this._createInitialChildren(transaction, props, context, lazyTree); + mountImage = lazyTree; + } else { + var tagOpen = this._createOpenTagMarkupAndPutListeners(transaction, props); + var tagContent = this._createContentMarkup(transaction, props, context); + if (!tagContent && omittedCloseTags[this._tag]) { + mountImage = tagOpen + '/>'; } else { - inst.componentWillMount(); - } - // When mounting, calls to `setState` by `componentWillMount` will set - // `this._pendingStateQueue` without triggering a re-render. - if (this._pendingStateQueue) { - inst.state = this._processPendingState(inst.props, inst.context); + mountImage = tagOpen + '>' + tagContent + ''; } } - // If not a stateless component, we now render - if (renderedElement === undefined) { - renderedElement = this._renderValidatedComponent(); - } - - var nodeType = ReactNodeTypes.getType(renderedElement); - this._renderedNodeType = nodeType; - var child = this._instantiateReactComponent(renderedElement, nodeType !== ReactNodeTypes.EMPTY /* shouldHaveDebugID */ - ); - this._renderedComponent = child; - - var markup = ReactReconciler.mountComponent(child, transaction, hostParent, hostContainerInfo, this._processChildContext(context), debugID); - - if (process.env.NODE_ENV !== 'production') { - if (debugID !== 0) { - var childDebugIDs = child._debugID !== 0 ? [child._debugID] : []; - ReactInstrumentation.debugTool.onSetChildren(debugID, childDebugIDs); - } + switch (this._tag) { + case 'input': + transaction.getReactMountReady().enqueue(inputPostMount, this); + if (props.autoFocus) { + transaction.getReactMountReady().enqueue(AutoFocusUtils.focusDOMComponent, this); + } + break; + case 'textarea': + transaction.getReactMountReady().enqueue(textareaPostMount, this); + if (props.autoFocus) { + transaction.getReactMountReady().enqueue(AutoFocusUtils.focusDOMComponent, this); + } + break; + case 'select': + if (props.autoFocus) { + transaction.getReactMountReady().enqueue(AutoFocusUtils.focusDOMComponent, this); + } + break; + case 'button': + if (props.autoFocus) { + transaction.getReactMountReady().enqueue(AutoFocusUtils.focusDOMComponent, this); + } + break; + case 'option': + transaction.getReactMountReady().enqueue(optionPostMount, this); + break; } - return markup; - }, - - getHostNode: function () { - return ReactReconciler.getHostNode(this._renderedComponent); + return mountImage; }, /** - * Releases any resources allocated by `mountComponent`. + * Creates markup for the open tag and all attributes. * - * @final - * @internal + * This method has side effects because events get registered. + * + * Iterating over object properties is faster than iterating over arrays. + * @see http://jsperf.com/obj-vs-arr-iteration + * + * @private + * @param {ReactReconcileTransaction|ReactServerRenderingTransaction} transaction + * @param {object} props + * @return {string} Markup of opening tag. */ - unmountComponent: function (safely) { - if (!this._renderedComponent) { - return; - } - - var inst = this._instance; - - if (inst.componentWillUnmount && !inst._calledComponentWillUnmount) { - inst._calledComponentWillUnmount = true; + _createOpenTagMarkupAndPutListeners: function (transaction, props) { + var ret = '<' + this._currentElement.type; - if (safely) { - var name = this.getName() + '.componentWillUnmount()'; - ReactErrorUtils.invokeGuardedCallback(name, inst.componentWillUnmount.bind(inst)); + for (var propKey in props) { + if (!props.hasOwnProperty(propKey)) { + continue; + } + var propValue = props[propKey]; + if (propValue == null) { + continue; + } + if (registrationNameModules.hasOwnProperty(propKey)) { + if (propValue) { + enqueuePutListener(this, propKey, propValue, transaction); + } } else { - if (process.env.NODE_ENV !== 'production') { - measureLifeCyclePerf(function () { - return inst.componentWillUnmount(); - }, this._debugID, 'componentWillUnmount'); + if (propKey === STYLE) { + if (propValue) { + if (process.env.NODE_ENV !== 'production') { + // See `_updateDOMProperties`. style block + this._previousStyle = propValue; + } + propValue = this._previousStyleCopy = _assign({}, props.style); + } + propValue = CSSPropertyOperations.createMarkupForStyles(propValue, this); + } + var markup = null; + if (this._tag != null && isCustomComponent(this._tag, props)) { + if (!RESERVED_PROPS.hasOwnProperty(propKey)) { + markup = DOMPropertyOperations.createMarkupForCustomAttribute(propKey, propValue); + } } else { - inst.componentWillUnmount(); + markup = DOMPropertyOperations.createMarkupForProperty(propKey, propValue); + } + if (markup) { + ret += ' ' + markup; } } } - if (this._renderedComponent) { - ReactReconciler.unmountComponent(this._renderedComponent, safely); - this._renderedNodeType = null; - this._renderedComponent = null; - this._instance = null; + // For static pages, no need to put React ID and checksum. Saves lots of + // bytes. + if (transaction.renderToStaticMarkup) { + return ret; } - // Reset pending fields - // Even if this component is scheduled for another update in ReactUpdates, - // it would still be ignored because these fields are reset. - this._pendingStateQueue = null; - this._pendingReplaceState = false; - this._pendingForceUpdate = false; - this._pendingCallbacks = null; - this._pendingElement = null; - - // These fields do not really need to be reset since this object is no - // longer accessible. - this._context = null; - this._rootNodeID = 0; - this._topLevelWrapper = null; - - // Delete the reference from the instance to this internal representation - // which allow the internals to be properly cleaned up even if the user - // leaks a reference to the public instance. - ReactInstanceMap.remove(inst); - - // Some existing components rely on inst.props even after they've been - // destroyed (in event handlers). - // TODO: inst.props = null; - // TODO: inst.state = null; - // TODO: inst.context = null; - }, - - /** - * Filters the context object to only contain keys specified in - * `contextTypes` - * - * @param {object} context - * @return {?object} - * @private - */ - _maskContext: function (context) { - var Component = this._currentElement.type; - var contextTypes = Component.contextTypes; - if (!contextTypes) { - return emptyObject; - } - var maskedContext = {}; - for (var contextName in contextTypes) { - maskedContext[contextName] = context[contextName]; + if (!this._hostParent) { + ret += ' ' + DOMPropertyOperations.createMarkupForRoot(); } - return maskedContext; + ret += ' ' + DOMPropertyOperations.createMarkupForID(this._domID); + return ret; }, /** - * Filters the context object to only contain keys specified in - * `contextTypes`, and asserts that they are valid. + * Creates markup for the content between the tags. * - * @param {object} context - * @return {?object} - * @private - */ - _processContext: function (context) { - var maskedContext = this._maskContext(context); - if (process.env.NODE_ENV !== 'production') { - var Component = this._currentElement.type; - if (Component.contextTypes) { - this._checkContextTypes(Component.contextTypes, maskedContext, ReactPropTypeLocations.context); - } - } - return maskedContext; - }, - - /** - * @param {object} currentContext - * @return {object} * @private + * @param {ReactReconcileTransaction|ReactServerRenderingTransaction} transaction + * @param {object} props + * @param {object} context + * @return {string} Content markup. */ - _processChildContext: function (currentContext) { - var Component = this._currentElement.type; - var inst = this._instance; - var childContext; + _createContentMarkup: function (transaction, props, context) { + var ret = ''; - if (inst.getChildContext) { - if (process.env.NODE_ENV !== 'production') { - ReactInstrumentation.debugTool.onBeginProcessingChildContext(); - try { - childContext = inst.getChildContext(); - } finally { - ReactInstrumentation.debugTool.onEndProcessingChildContext(); + // Intentional use of != to avoid catching zero/false. + var innerHTML = props.dangerouslySetInnerHTML; + if (innerHTML != null) { + if (innerHTML.__html != null) { + ret = innerHTML.__html; + } + } else { + var contentToUse = CONTENT_TYPES[typeof props.children] ? props.children : null; + var childrenToUse = contentToUse != null ? null : props.children; + if (contentToUse != null) { + // TODO: Validate that text is allowed as a child of this node + ret = escapeTextContentForBrowser(contentToUse); + if (process.env.NODE_ENV !== 'production') { + setAndValidateContentChildDev.call(this, contentToUse); } - } else { - childContext = inst.getChildContext(); + } else if (childrenToUse != null) { + var mountImages = this.mountChildren(childrenToUse, transaction, context); + ret = mountImages.join(''); } } + if (newlineEatingTags[this._tag] && ret.charAt(0) === '\n') { + // text/html ignores the first character in these tags if it's a newline + // Prefer to break application/xml over text/html (for now) by adding + // a newline specifically to get eaten by the parser. (Alternately for + // textareas, replacing "^\n" with "\r\n" doesn't get eaten, and the first + // \r is normalized out by HTMLTextAreaElement#value.) + // See: + // See: + // See: + // See: Parsing of "textarea" "listing" and "pre" elements + // from + return '\n' + ret; + } else { + return ret; + } + }, - if (childContext) { - !(typeof Component.childContextTypes === 'object') ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s.getChildContext(): childContextTypes must be defined in order to use getChildContext().', this.getName() || 'ReactCompositeComponent') : _prodInvariant('107', this.getName() || 'ReactCompositeComponent') : void 0; - if (process.env.NODE_ENV !== 'production') { - this._checkContextTypes(Component.childContextTypes, childContext, ReactPropTypeLocations.childContext); + _createInitialChildren: function (transaction, props, context, lazyTree) { + // Intentional use of != to avoid catching zero/false. + var innerHTML = props.dangerouslySetInnerHTML; + if (innerHTML != null) { + if (innerHTML.__html != null) { + DOMLazyTree.queueHTML(lazyTree, innerHTML.__html); } - for (var name in childContext) { - !(name in Component.childContextTypes) ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s.getChildContext(): key "%s" is not defined in childContextTypes.', this.getName() || 'ReactCompositeComponent', name) : _prodInvariant('108', this.getName() || 'ReactCompositeComponent', name) : void 0; + } else { + var contentToUse = CONTENT_TYPES[typeof props.children] ? props.children : null; + var childrenToUse = contentToUse != null ? null : props.children; + if (contentToUse != null) { + // TODO: Validate that text is allowed as a child of this node + if (process.env.NODE_ENV !== 'production') { + setAndValidateContentChildDev.call(this, contentToUse); + } + DOMLazyTree.queueText(lazyTree, contentToUse); + } else if (childrenToUse != null) { + var mountImages = this.mountChildren(childrenToUse, transaction, context); + for (var i = 0; i < mountImages.length; i++) { + DOMLazyTree.queueChild(lazyTree, mountImages[i]); + } } - return _assign({}, currentContext, childContext); } - return currentContext; - }, - - /** - * Assert that the context types are valid - * - * @param {object} typeSpecs Map of context field to a ReactPropType - * @param {object} values Runtime values that need to be type-checked - * @param {string} location e.g. "prop", "context", "child context" - * @private - */ - _checkContextTypes: function (typeSpecs, values, location) { - checkReactTypeSpec(typeSpecs, values, location, this.getName(), null, this._debugID); - }, - - receiveComponent: function (nextElement, transaction, nextContext) { - var prevElement = this._currentElement; - var prevContext = this._context; - - this._pendingElement = null; - - this.updateComponent(transaction, prevElement, nextElement, prevContext, nextContext); }, /** - * If any of `_pendingElement`, `_pendingStateQueue`, or `_pendingForceUpdate` - * is set, update the component. + * Receives a next element and updates the component. * - * @param {ReactReconcileTransaction} transaction * @internal + * @param {ReactElement} nextElement + * @param {ReactReconcileTransaction|ReactServerRenderingTransaction} transaction + * @param {object} context */ - performUpdateIfNecessary: function (transaction) { - if (this._pendingElement != null) { - ReactReconciler.receiveComponent(this, this._pendingElement, transaction, this._context); - } else if (this._pendingStateQueue !== null || this._pendingForceUpdate) { - this.updateComponent(transaction, this._currentElement, this._currentElement, this._context, this._context); - } else { - this._updateBatchNumber = null; - } + receiveComponent: function (nextElement, transaction, context) { + var prevElement = this._currentElement; + this._currentElement = nextElement; + this.updateComponent(transaction, prevElement, nextElement, context); }, /** - * Perform an update to a mounted component. The componentWillReceiveProps and - * shouldComponentUpdate methods are called, then (assuming the update isn't - * skipped) the remaining update lifecycle methods are called and the DOM - * representation is updated. - * - * By default, this implements React's rendering and reconciliation algorithm. - * Sophisticated clients may wish to override this. + * Updates a DOM component after it has already been allocated and + * attached to the DOM. Reconciles the root DOM node, then recurses. * * @param {ReactReconcileTransaction} transaction - * @param {ReactElement} prevParentElement - * @param {ReactElement} nextParentElement + * @param {ReactElement} prevElement + * @param {ReactElement} nextElement * @internal * @overridable */ - updateComponent: function (transaction, prevParentElement, nextParentElement, prevUnmaskedContext, nextUnmaskedContext) { - var inst = this._instance; - !(inst != null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Attempted to update component `%s` that has already been unmounted (or failed to mount).', this.getName() || 'ReactCompositeComponent') : _prodInvariant('136', this.getName() || 'ReactCompositeComponent') : void 0; - - var willReceive = false; - var nextContext; + updateComponent: function (transaction, prevElement, nextElement, context) { + var lastProps = prevElement.props; + var nextProps = this._currentElement.props; - // Determine if the context has changed or not - if (this._context === nextUnmaskedContext) { - nextContext = inst.context; - } else { - nextContext = this._processContext(nextUnmaskedContext); - willReceive = true; + switch (this._tag) { + case 'input': + lastProps = ReactDOMInput.getHostProps(this, lastProps); + nextProps = ReactDOMInput.getHostProps(this, nextProps); + break; + case 'option': + lastProps = ReactDOMOption.getHostProps(this, lastProps); + nextProps = ReactDOMOption.getHostProps(this, nextProps); + break; + case 'select': + lastProps = ReactDOMSelect.getHostProps(this, lastProps); + nextProps = ReactDOMSelect.getHostProps(this, nextProps); + break; + case 'textarea': + lastProps = ReactDOMTextarea.getHostProps(this, lastProps); + nextProps = ReactDOMTextarea.getHostProps(this, nextProps); + break; } - var prevProps = prevParentElement.props; - var nextProps = nextParentElement.props; + assertValidProps(this, nextProps); + this._updateDOMProperties(lastProps, nextProps, transaction); + this._updateDOMChildren(lastProps, nextProps, transaction, context); - // Not a simple state update but a props update - if (prevParentElement !== nextParentElement) { - willReceive = true; + switch (this._tag) { + case 'input': + // Update the wrapper around inputs *after* updating props. This has to + // happen after `_updateDOMProperties`. Otherwise HTML5 input validations + // raise warnings and prevent the new value from being assigned. + ReactDOMInput.updateWrapper(this); + break; + case 'textarea': + ReactDOMTextarea.updateWrapper(this); + break; + case 'select': + // host component that allows setting these optional + * props: `checked`, `value`, `defaultChecked`, and `defaultValue`. + * + * If `checked` or `value` are not supplied (or null/undefined), user actions + * that affect the checked state or value will trigger updates to the element. + * + * If they are supplied (and not null/undefined), the rendered element will not + * trigger updates to the element. Instead, the props must change in order for + * the rendered element to be updated. + * + * The rendered element will be initialized as unchecked (or `defaultChecked`) + * with an empty value (or `defaultValue`). + * + * @see http://www.w3.org/TR/2012/WD-html5-20121025/the-input-element.html + */ +var ReactDOMInput = { + getHostProps: function (inst, props) { + var value = LinkedValueUtils.getValue(props); + var checked = LinkedValueUtils.getChecked(props); - validateDOMNesting(null, String(content), this, this._ancestorInfo); - this._contentDebugID = contentDebugID; - if (hasExistingContent) { - ReactInstrumentation.debugTool.onBeforeUpdateComponent(contentDebugID, content); - ReactInstrumentation.debugTool.onUpdateComponent(contentDebugID); - } else { - ReactInstrumentation.debugTool.onBeforeMountComponent(contentDebugID, content, debugID); - ReactInstrumentation.debugTool.onMountComponent(contentDebugID); - ReactInstrumentation.debugTool.onSetChildren(debugID, [contentDebugID]); - } - }; -} + var hostProps = _assign({ + // Make sure we set .type before any other properties (setting .value + // before .type means .value is lost in IE11 and below) + type: undefined, + // Make sure we set .step before .value (setting .value before .step + // means .value is rounded on mount, based upon step precision) + step: undefined, + // Make sure we set .min & .max before .value (to ensure proper order + // in corner cases such as min or max deriving from value, e.g. Issue #7170) + min: undefined, + max: undefined + }, props, { + defaultChecked: undefined, + defaultValue: undefined, + value: value != null ? value : inst._wrapperState.initialValue, + checked: checked != null ? checked : inst._wrapperState.initialChecked, + onChange: inst._wrapperState.onChange + }); -// There are so many media events, it makes sense to just -// maintain a list rather than create a `trapBubbledEvent` for each -var mediaEvents = { - topAbort: 'abort', - topCanPlay: 'canplay', - topCanPlayThrough: 'canplaythrough', - topDurationChange: 'durationchange', - topEmptied: 'emptied', - topEncrypted: 'encrypted', - topEnded: 'ended', - topError: 'error', - topLoadedData: 'loadeddata', - topLoadedMetadata: 'loadedmetadata', - topLoadStart: 'loadstart', - topPause: 'pause', - topPlay: 'play', - topPlaying: 'playing', - topProgress: 'progress', - topRateChange: 'ratechange', - topSeeked: 'seeked', - topSeeking: 'seeking', - topStalled: 'stalled', - topSuspend: 'suspend', - topTimeUpdate: 'timeupdate', - topVolumeChange: 'volumechange', - topWaiting: 'waiting' -}; + return hostProps; + }, -function trapBubbledEventsLocal() { - var inst = this; - // If a component renders to null or if another component fatals and causes - // the state of the tree to be corrupted, `node` here can be null. - !inst._rootNodeID ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Must be mounted to trap events') : _prodInvariant('63') : void 0; - var node = getNode(inst); - !node ? process.env.NODE_ENV !== 'production' ? invariant(false, 'trapBubbledEvent(...): Requires node to be rendered.') : _prodInvariant('64') : void 0; + mountWrapper: function (inst, props) { + if (process.env.NODE_ENV !== 'production') { + LinkedValueUtils.checkPropTypes('input', props, inst._currentElement._owner); - switch (inst._tag) { - case 'iframe': - case 'object': - inst._wrapperState.listeners = [ReactBrowserEventEmitter.trapBubbledEvent(EventConstants.topLevelTypes.topLoad, 'load', node)]; - break; - case 'video': - case 'audio': + var owner = inst._currentElement._owner; - inst._wrapperState.listeners = []; - // Create listener for each media event - for (var event in mediaEvents) { - if (mediaEvents.hasOwnProperty(event)) { - inst._wrapperState.listeners.push(ReactBrowserEventEmitter.trapBubbledEvent(EventConstants.topLevelTypes[event], mediaEvents[event], node)); - } + if (props.valueLink !== undefined && !didWarnValueLink) { + process.env.NODE_ENV !== 'production' ? warning(false, '`valueLink` prop on `input` is deprecated; set `value` and `onChange` instead.') : void 0; + didWarnValueLink = true; } - break; - case 'source': - inst._wrapperState.listeners = [ReactBrowserEventEmitter.trapBubbledEvent(EventConstants.topLevelTypes.topError, 'error', node)]; - break; - case 'img': - inst._wrapperState.listeners = [ReactBrowserEventEmitter.trapBubbledEvent(EventConstants.topLevelTypes.topError, 'error', node), ReactBrowserEventEmitter.trapBubbledEvent(EventConstants.topLevelTypes.topLoad, 'load', node)]; - break; - case 'form': - inst._wrapperState.listeners = [ReactBrowserEventEmitter.trapBubbledEvent(EventConstants.topLevelTypes.topReset, 'reset', node), ReactBrowserEventEmitter.trapBubbledEvent(EventConstants.topLevelTypes.topSubmit, 'submit', node)]; - break; - case 'input': - case 'select': - case 'textarea': - inst._wrapperState.listeners = [ReactBrowserEventEmitter.trapBubbledEvent(EventConstants.topLevelTypes.topInvalid, 'invalid', node)]; - break; - } -} + if (props.checkedLink !== undefined && !didWarnCheckedLink) { + process.env.NODE_ENV !== 'production' ? warning(false, '`checkedLink` prop on `input` is deprecated; set `value` and `onChange` instead.') : void 0; + didWarnCheckedLink = true; + } + if (props.checked !== undefined && props.defaultChecked !== undefined && !didWarnCheckedDefaultChecked) { + process.env.NODE_ENV !== 'production' ? warning(false, '%s contains an input of type %s with both checked and defaultChecked props. ' + 'Input elements must be either controlled or uncontrolled ' + '(specify either the checked prop, or the defaultChecked prop, but not ' + 'both). Decide between using a controlled or uncontrolled input ' + 'element and remove one of these props. More info: ' + 'https://fb.me/react-controlled-components', owner && owner.getName() || 'A component', props.type) : void 0; + didWarnCheckedDefaultChecked = true; + } + if (props.value !== undefined && props.defaultValue !== undefined && !didWarnValueDefaultValue) { + process.env.NODE_ENV !== 'production' ? warning(false, '%s contains an input of type %s with both value and defaultValue props. ' + 'Input elements must be either controlled or uncontrolled ' + '(specify either the value prop, or the defaultValue prop, but not ' + 'both). Decide between using a controlled or uncontrolled input ' + 'element and remove one of these props. More info: ' + 'https://fb.me/react-controlled-components', owner && owner.getName() || 'A component', props.type) : void 0; + didWarnValueDefaultValue = true; + } + } -function postUpdateSelectWrapper() { - ReactDOMSelect.postUpdateWrapper(this); -} + var defaultValue = props.defaultValue; + inst._wrapperState = { + initialChecked: props.checked != null ? props.checked : props.defaultChecked, + initialValue: props.value != null ? props.value : defaultValue, + listeners: null, + onChange: _handleChange.bind(inst) + }; -// For HTML, certain tags should omit their close tag. We keep a whitelist for -// those special-case tags. + if (process.env.NODE_ENV !== 'production') { + inst._wrapperState.controlled = isControlled(props); + } + }, -var omittedCloseTags = { - 'area': true, - 'base': true, - 'br': true, - 'col': true, - 'embed': true, - 'hr': true, - 'img': true, - 'input': true, - 'keygen': true, - 'link': true, - 'meta': true, - 'param': true, - 'source': true, - 'track': true, - 'wbr': true -}; + updateWrapper: function (inst) { + var props = inst._currentElement.props; -// NOTE: menuitem's close tag should be omitted, but that causes problems. -var newlineEatingTags = { - 'listing': true, - 'pre': true, - 'textarea': true -}; + if (process.env.NODE_ENV !== 'production') { + var controlled = isControlled(props); + var owner = inst._currentElement._owner; -// For HTML, certain tags cannot have children. This has the same purpose as -// `omittedCloseTags` except that `menuitem` should still have its closing tag. + if (!inst._wrapperState.controlled && controlled && !didWarnUncontrolledToControlled) { + process.env.NODE_ENV !== 'production' ? warning(false, '%s is changing an uncontrolled input of type %s to be controlled. ' + 'Input elements should not switch from uncontrolled to controlled (or vice versa). ' + 'Decide between using a controlled or uncontrolled input ' + 'element for the lifetime of the component. More info: https://fb.me/react-controlled-components', owner && owner.getName() || 'A component', props.type) : void 0; + didWarnUncontrolledToControlled = true; + } + if (inst._wrapperState.controlled && !controlled && !didWarnControlledToUncontrolled) { + process.env.NODE_ENV !== 'production' ? warning(false, '%s is changing a controlled input of type %s to be uncontrolled. ' + 'Input elements should not switch from controlled to uncontrolled (or vice versa). ' + 'Decide between using a controlled or uncontrolled input ' + 'element for the lifetime of the component. More info: https://fb.me/react-controlled-components', owner && owner.getName() || 'A component', props.type) : void 0; + didWarnControlledToUncontrolled = true; + } + } -var voidElementTags = _assign({ - 'menuitem': true -}, omittedCloseTags); + // TODO: Shouldn't this be getChecked(props)? + var checked = props.checked; + if (checked != null) { + DOMPropertyOperations.setValueForProperty(ReactDOMComponentTree.getNodeFromInstance(inst), 'checked', checked || false); + } -// We accept any tag to be rendered but since this gets injected into arbitrary -// HTML, we want to make sure that it's a safe tag. -// http://www.w3.org/TR/REC-xml/#NT-Name + var node = ReactDOMComponentTree.getNodeFromInstance(inst); + var value = LinkedValueUtils.getValue(props); + if (value != null) { -var VALID_TAG_REGEX = /^[a-zA-Z][a-zA-Z:_\.\-\d]*$/; // Simplified subset -var validatedTagCache = {}; -var hasOwnProperty = {}.hasOwnProperty; + // Cast `value` to a string to ensure the value is set correctly. While + // browsers typically do this as necessary, jsdom doesn't. + var newValue = '' + value; -function validateDangerousTag(tag) { - if (!hasOwnProperty.call(validatedTagCache, tag)) { - !VALID_TAG_REGEX.test(tag) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Invalid tag: %s', tag) : _prodInvariant('65', tag) : void 0; - validatedTagCache[tag] = true; - } -} + // To avoid side effects (such as losing text selection), only set value if changed + if (newValue !== node.value) { + node.value = newValue; + } + } else { + if (props.value == null && props.defaultValue != null) { + node.defaultValue = '' + props.defaultValue; + } + if (props.checked == null && props.defaultChecked != null) { + node.defaultChecked = !!props.defaultChecked; + } + } + }, -function isCustomComponent(tagName, props) { - return tagName.indexOf('-') >= 0 || props.is != null; -} + postMountWrapper: function (inst) { + var props = inst._currentElement.props; -var globalIdCounter = 1; + // This is in postMount because we need access to the DOM node, which is not + // available until after the component has mounted. + var node = ReactDOMComponentTree.getNodeFromInstance(inst); -/** - * Creates a new React class that is idempotent and capable of containing other - * React components. It accepts event listeners and DOM properties that are - * valid according to `DOMProperty`. - * - * - Event listeners: `onClick`, `onMouseDown`, etc. - * - DOM properties: `className`, `name`, `title`, etc. - * - * The `style` property functions differently from the DOM API. It accepts an - * object mapping of style properties to values. - * - * @constructor ReactDOMComponent - * @extends ReactMultiChild - */ -function ReactDOMComponent(element) { - var tag = element.type; - validateDangerousTag(tag); - this._currentElement = element; - this._tag = tag.toLowerCase(); - this._namespaceURI = null; - this._renderedChildren = null; - this._previousStyle = null; - this._previousStyleCopy = null; - this._hostNode = null; - this._hostParent = null; - this._rootNodeID = 0; - this._domID = 0; - this._hostContainerInfo = null; - this._wrapperState = null; - this._topLevelWrapper = null; - this._flags = 0; - if (process.env.NODE_ENV !== 'production') { - this._ancestorInfo = null; - setAndValidateContentChildDev.call(this, null); + // Detach value from defaultValue. We won't do anything if we're working on + // submit or reset inputs as those values & defaultValues are linked. They + // are not resetable nodes so this operation doesn't matter and actually + // removes browser-default values (eg "Submit Query") when no value is + // provided. + + switch (props.type) { + case 'submit': + case 'reset': + break; + case 'color': + case 'date': + case 'datetime': + case 'datetime-local': + case 'month': + case 'time': + case 'week': + // This fixes the no-show issue on iOS Safari and Android Chrome: + // https://github.com/facebook/react/issues/7233 + node.value = ''; + node.value = node.defaultValue; + break; + default: + node.value = node.value; + break; + } + + // Normally, we'd just do `node.checked = node.checked` upon initial mount, less this bug + // this is needed to work around a chrome bug where setting defaultChecked + // will sometimes influence the value of checked (even after detachment). + // Reference: https://bugs.chromium.org/p/chromium/issues/detail?id=608416 + // We need to temporarily unset name to avoid disrupting radio button groups. + var name = node.name; + if (name !== '') { + node.name = ''; + } + node.defaultChecked = !node.defaultChecked; + node.defaultChecked = !node.defaultChecked; + if (name !== '') { + node.name = name; + } } -} +}; -ReactDOMComponent.displayName = 'ReactDOMComponent'; +function _handleChange(event) { + var props = this._currentElement.props; -ReactDOMComponent.Mixin = { + var returnValue = LinkedValueUtils.executeOnChange(props, event); - /** - * Generates root tag markup then recurses. This method has side effects and - * is not idempotent. - * - * @internal - * @param {ReactReconcileTransaction|ReactServerRenderingTransaction} transaction - * @param {?ReactDOMComponent} the parent component instance - * @param {?object} info about the host container - * @param {object} context - * @return {string} The computed markup. - */ - mountComponent: function (transaction, hostParent, hostContainerInfo, context) { - this._rootNodeID = globalIdCounter++; - this._domID = hostContainerInfo._idCounter++; - this._hostParent = hostParent; - this._hostContainerInfo = hostContainerInfo; + // Here we use asap to wait until all updates have propagated, which + // is important when using controlled components within layers: + // https://github.com/facebook/react/issues/1698 + ReactUpdates.asap(forceUpdateIfMounted, this); - var props = this._currentElement.props; + var name = props.name; + if (props.type === 'radio' && name != null) { + var rootNode = ReactDOMComponentTree.getNodeFromInstance(this); + var queryRoot = rootNode; - switch (this._tag) { - case 'audio': - case 'form': - case 'iframe': - case 'img': - case 'link': - case 'object': - case 'source': - case 'video': - this._wrapperState = { - listeners: null - }; - transaction.getReactMountReady().enqueue(trapBubbledEventsLocal, this); - break; - case 'button': - props = ReactDOMButton.getHostProps(this, props, hostParent); - break; - case 'input': - ReactDOMInput.mountWrapper(this, props, hostParent); - props = ReactDOMInput.getHostProps(this, props); - transaction.getReactMountReady().enqueue(trapBubbledEventsLocal, this); - break; - case 'option': - ReactDOMOption.mountWrapper(this, props, hostParent); - props = ReactDOMOption.getHostProps(this, props); - break; - case 'select': - ReactDOMSelect.mountWrapper(this, props, hostParent); - props = ReactDOMSelect.getHostProps(this, props); - transaction.getReactMountReady().enqueue(trapBubbledEventsLocal, this); - break; - case 'textarea': - ReactDOMTextarea.mountWrapper(this, props, hostParent); - props = ReactDOMTextarea.getHostProps(this, props); - transaction.getReactMountReady().enqueue(trapBubbledEventsLocal, this); - break; + while (queryRoot.parentNode) { + queryRoot = queryRoot.parentNode; } - assertValidProps(this, props); + // If `rootNode.form` was non-null, then we could try `form.elements`, + // but that sometimes behaves strangely in IE8. We could also try using + // `form.getElementsByName`, but that will only return direct children + // and won't include inputs that use the HTML5 `form=` attribute. Since + // the input might not even be in a form, let's just use the global + // `querySelectorAll` to ensure we don't miss anything. + var group = queryRoot.querySelectorAll('input[name=' + JSON.stringify('' + name) + '][type="radio"]'); - // We create tags in the namespace of their parent container, except HTML - // tags get no namespace. - var namespaceURI; - var parentTag; - if (hostParent != null) { - namespaceURI = hostParent._namespaceURI; - parentTag = hostParent._tag; - } else if (hostContainerInfo._tag) { - namespaceURI = hostContainerInfo._namespaceURI; - parentTag = hostContainerInfo._tag; + for (var i = 0; i < group.length; i++) { + var otherNode = group[i]; + if (otherNode === rootNode || otherNode.form !== rootNode.form) { + continue; + } + // This will throw if radio buttons rendered by different copies of React + // and the same name are rendered into the same form (same as #1939). + // That's probably okay; we don't support it just as we don't support + // mixing React radio buttons with non-React ones. + var otherInstance = ReactDOMComponentTree.getInstanceFromNode(otherNode); + !otherInstance ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactDOMInput: Mixing React and non-React radio inputs with the same `name` is not supported.') : _prodInvariant('90') : void 0; + // If this is a controlled radio button group, forcing the input that + // was previously checked to update will cause it to be come re-checked + // as appropriate. + ReactUpdates.asap(forceUpdateIfMounted, otherInstance); } - if (namespaceURI == null || namespaceURI === DOMNamespaces.svg && parentTag === 'foreignobject') { - namespaceURI = DOMNamespaces.html; + } + + return returnValue; +} + +module.exports = ReactDOMInput; +}).call(this,require('_process')) + +},{"./DOMPropertyOperations":37,"./LinkedValueUtils":48,"./ReactDOMComponentTree":58,"./ReactUpdates":102,"./reactProdInvariant":145,"_process":25,"fbjs/lib/invariant":16,"fbjs/lib/warning":23,"object-assign":24}],64:[function(require,module,exports){ +(function (process){ +/** + * Copyright 2013-present, Facebook, Inc. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. An additional grant + * of patent rights can be found in the PATENTS file in the same directory. + * + */ + +'use strict'; + +var DOMProperty = require('./DOMProperty'); +var ReactComponentTreeHook = require('react/lib/ReactComponentTreeHook'); + +var warning = require('fbjs/lib/warning'); + +var warnedProperties = {}; +var rARIA = new RegExp('^(aria)-[' + DOMProperty.ATTRIBUTE_NAME_CHAR + ']*$'); + +function validateProperty(tagName, name, debugID) { + if (warnedProperties.hasOwnProperty(name) && warnedProperties[name]) { + return true; + } + + if (rARIA.test(name)) { + var lowerCasedName = name.toLowerCase(); + var standardName = DOMProperty.getPossibleStandardName.hasOwnProperty(lowerCasedName) ? DOMProperty.getPossibleStandardName[lowerCasedName] : null; + + // If this is an aria-* attribute, but is not listed in the known DOM + // DOM properties, then it is an invalid aria-* attribute. + if (standardName == null) { + warnedProperties[name] = true; + return false; } - if (namespaceURI === DOMNamespaces.html) { - if (this._tag === 'svg') { - namespaceURI = DOMNamespaces.svg; - } else if (this._tag === 'math') { - namespaceURI = DOMNamespaces.mathml; - } + // aria-* attributes should be lowercase; suggest the lowercase version. + if (name !== standardName) { + process.env.NODE_ENV !== 'production' ? warning(false, 'Unknown ARIA attribute %s. Did you mean %s?%s', name, standardName, ReactComponentTreeHook.getStackAddendumByID(debugID)) : void 0; + warnedProperties[name] = true; + return true; } - this._namespaceURI = namespaceURI; + } + + return true; +} + +function warnInvalidARIAProps(debugID, element) { + var invalidProps = []; + + for (var key in element.props) { + var isValid = validateProperty(element.type, key, debugID); + if (!isValid) { + invalidProps.push(key); + } + } + + var unknownPropString = invalidProps.map(function (prop) { + return '`' + prop + '`'; + }).join(', '); + + if (invalidProps.length === 1) { + process.env.NODE_ENV !== 'production' ? warning(false, 'Invalid aria prop %s on <%s> tag. ' + 'For details, see https://fb.me/invalid-aria-prop%s', unknownPropString, element.type, ReactComponentTreeHook.getStackAddendumByID(debugID)) : void 0; + } else if (invalidProps.length > 1) { + process.env.NODE_ENV !== 'production' ? warning(false, 'Invalid aria props %s on <%s> tag. ' + 'For details, see https://fb.me/invalid-aria-prop%s', unknownPropString, element.type, ReactComponentTreeHook.getStackAddendumByID(debugID)) : void 0; + } +} +function handleElement(debugID, element) { + if (element == null || typeof element.type !== 'string') { + return; + } + if (element.type.indexOf('-') >= 0 || element.props.is) { + return; + } + + warnInvalidARIAProps(debugID, element); +} + +var ReactDOMInvalidARIAHook = { + onBeforeMountComponent: function (debugID, element) { if (process.env.NODE_ENV !== 'production') { - var parentInfo; - if (hostParent != null) { - parentInfo = hostParent._ancestorInfo; - } else if (hostContainerInfo._tag) { - parentInfo = hostContainerInfo._ancestorInfo; - } - if (parentInfo) { - // parentInfo should always be present except for the top-level - // component when server rendering - validateDOMNesting(this._tag, null, this, parentInfo); - } - this._ancestorInfo = validateDOMNesting.updatedAncestorInfo(parentInfo, this._tag, this); + handleElement(debugID, element); + } + }, + onBeforeUpdateComponent: function (debugID, element) { + if (process.env.NODE_ENV !== 'production') { + handleElement(debugID, element); } + } +}; - var mountImage; - if (transaction.useCreateElement) { - var ownerDocument = hostContainerInfo._ownerDocument; - var el; - if (namespaceURI === DOMNamespaces.html) { - if (this._tag === 'script') { - // Create the script via .innerHTML so its "parser-inserted" flag is - // set to true and it does not execute - var div = ownerDocument.createElement('div'); - var type = this._currentElement.type; - div.innerHTML = '<' + type + '>'; - el = div.removeChild(div.firstChild); - } else if (props.is) { - el = ownerDocument.createElement(this._currentElement.type, props.is); - } else { - // Separate else branch instead of using `props.is || undefined` above becuase of a Firefox bug. - // See discussion in https://github.com/facebook/react/pull/6896 - // and discussion in https://bugzilla.mozilla.org/show_bug.cgi?id=1276240 - el = ownerDocument.createElement(this._currentElement.type); - } - } else { - el = ownerDocument.createElementNS(namespaceURI, this._currentElement.type); - } - ReactDOMComponentTree.precacheNode(this, el); - this._flags |= Flags.hasCachedChildNodes; - if (!this._hostParent) { - DOMPropertyOperations.setAttributeForRoot(el); - } - this._updateDOMProperties(null, props, transaction); - var lazyTree = DOMLazyTree(el); - this._createInitialChildren(transaction, props, context, lazyTree); - mountImage = lazyTree; - } else { - var tagOpen = this._createOpenTagMarkupAndPutListeners(transaction, props); - var tagContent = this._createContentMarkup(transaction, props, context); - if (!tagContent && omittedCloseTags[this._tag]) { - mountImage = tagOpen + '/>'; - } else { - mountImage = tagOpen + '>' + tagContent + ''; - } - } +module.exports = ReactDOMInvalidARIAHook; +}).call(this,require('_process')) - switch (this._tag) { - case 'input': - transaction.getReactMountReady().enqueue(inputPostMount, this); - if (props.autoFocus) { - transaction.getReactMountReady().enqueue(AutoFocusUtils.focusDOMComponent, this); - } - break; - case 'textarea': - transaction.getReactMountReady().enqueue(textareaPostMount, this); - if (props.autoFocus) { - transaction.getReactMountReady().enqueue(AutoFocusUtils.focusDOMComponent, this); - } - break; - case 'select': - if (props.autoFocus) { - transaction.getReactMountReady().enqueue(AutoFocusUtils.focusDOMComponent, this); - } - break; - case 'button': - if (props.autoFocus) { - transaction.getReactMountReady().enqueue(AutoFocusUtils.focusDOMComponent, this); - } - break; - case 'option': - transaction.getReactMountReady().enqueue(optionPostMount, this); - break; - } +},{"./DOMProperty":36,"_process":25,"fbjs/lib/warning":23,"react/lib/ReactComponentTreeHook":158}],65:[function(require,module,exports){ +(function (process){ +/** + * Copyright 2013-present, Facebook, Inc. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. An additional grant + * of patent rights can be found in the PATENTS file in the same directory. + * + */ - return mountImage; +'use strict'; + +var ReactComponentTreeHook = require('react/lib/ReactComponentTreeHook'); + +var warning = require('fbjs/lib/warning'); + +var didWarnValueNull = false; + +function handleElement(debugID, element) { + if (element == null) { + return; + } + if (element.type !== 'input' && element.type !== 'textarea' && element.type !== 'select') { + return; + } + if (element.props != null && element.props.value === null && !didWarnValueNull) { + process.env.NODE_ENV !== 'production' ? warning(false, '`value` prop on `%s` should not be null. ' + 'Consider using the empty string to clear the component or `undefined` ' + 'for uncontrolled components.%s', element.type, ReactComponentTreeHook.getStackAddendumByID(debugID)) : void 0; + + didWarnValueNull = true; + } +} + +var ReactDOMNullInputValuePropHook = { + onBeforeMountComponent: function (debugID, element) { + handleElement(debugID, element); }, + onBeforeUpdateComponent: function (debugID, element) { + handleElement(debugID, element); + } +}; - /** - * Creates markup for the open tag and all attributes. - * - * This method has side effects because events get registered. - * - * Iterating over object properties is faster than iterating over arrays. - * @see http://jsperf.com/obj-vs-arr-iteration - * - * @private - * @param {ReactReconcileTransaction|ReactServerRenderingTransaction} transaction - * @param {object} props - * @return {string} Markup of opening tag. - */ - _createOpenTagMarkupAndPutListeners: function (transaction, props) { - var ret = '<' + this._currentElement.type; +module.exports = ReactDOMNullInputValuePropHook; +}).call(this,require('_process')) - for (var propKey in props) { - if (!props.hasOwnProperty(propKey)) { - continue; +},{"_process":25,"fbjs/lib/warning":23,"react/lib/ReactComponentTreeHook":158}],66:[function(require,module,exports){ +(function (process){ +/** + * Copyright 2013-present, Facebook, Inc. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. An additional grant + * of patent rights can be found in the PATENTS file in the same directory. + * + */ + +'use strict'; + +var _assign = require('object-assign'); + +var React = require('react/lib/React'); +var ReactDOMComponentTree = require('./ReactDOMComponentTree'); +var ReactDOMSelect = require('./ReactDOMSelect'); + +var warning = require('fbjs/lib/warning'); +var didWarnInvalidOptionChildren = false; + +function flattenChildren(children) { + var content = ''; + + // Flatten children and warn if they aren't strings or numbers; + // invalid types are ignored. + React.Children.forEach(children, function (child) { + if (child == null) { + return; + } + if (typeof child === 'string' || typeof child === 'number') { + content += child; + } else if (!didWarnInvalidOptionChildren) { + didWarnInvalidOptionChildren = true; + process.env.NODE_ENV !== 'production' ? warning(false, 'Only strings and numbers are supported as