diff --git a/HISTORY.md b/HISTORY.md
index 9878d3d51d..708369a5f5 100644
--- a/HISTORY.md
+++ b/HISTORY.md
@@ -1,8 +1,32 @@
# React-Select
+## v1.0.0-beta13 / 2016-05-30
+
+* added; `inputRenderer` prop, allows you to override the input component, thanks [Sean Burke](https://github.com/leftmostcat)
+* added; `openOnFocus` prop, causes the menu to always open when the select control is focused, thanks [HuysentruytRuben](https://github.com/HuysentruytRuben)
+* added; `react-virtualised-select` HOC example, thanks [Brian Vaughn](https://github.com/bvaughn)
+* added; `tabSelectsValue` prop can be set to false to prevent selection of focused option when tab is pressed, thanks [Byron Anderson](https://github.com/byronanderson)
+* added; ability to override `resetValue` when clearing the control, thanks [Alexander Luberg](https://github.com/LubergAlexander)
+* added; input can be updated with `onInputChange`, thanks [Brett DeWoody](https://github.com/brettdewoody)
+* added; Styles for .is-selected class, thanks [Danny Herran](https://github.com/dherran)
+* fixed; `noResultsText` prop type is now `stringOrNode` for Async component, thanks [Michael Groeneman](https://github.com/mgroeneman)
+* fixed; `onInputChange` is wrapped by Async component, thanks [Eric O'Connell](https://github.com/drd)
+* fixed; `scrollMenuIntoView` behaviour in IE10, thanks [Ivan Jager](https://github.com/aij)
+* fixed; isEqualNode replaced with strict equality check, thanks [Alexandre Balhier](https://github.com/abalhier)
+* fixed; issue with value object not being passed to `handleRequired`, thanks [Andrew Hite](https://github.com/andyhite)
+* fixed; the menu-outer container is no longer rendered when it does not contain anything, thanks [Kuan](https://github.com/khankuan)
+* improved; better support for IE8 in styles, thanks [Rockallite Wulf](https://github.com/rockallite)
+
+## v1.0.0-beta12 / 2016-04-02
+
+* added; `menuRenderer` method and example for effeciently rendering thousands of options, thanks [Brian Vaughn](https://github.com/bvaughn)
+* added; `optionClassName` prop, thanks [Max Tyler](https://github.com/iam4x)
+
## v1.0.0-beta11 / 2016-03-09
* updated dependencies to allow use with React 15.x
+* changed; multiple selected values are now submitted using multiple inputs, thanks [Trinh Hoang Nhu](https://github.com/james4388)
+* added; `joinValues` prop to revert the above change and submit multiple values in a single field with the delimiter
## v1.0.0-beta10 / 2016-02-23
diff --git a/README.md b/README.md
index c429b28469..37b5b81a7f 100644
--- a/README.md
+++ b/README.md
@@ -85,8 +85,9 @@ function logChange(val) {
You can enable multi-value selection by setting `multi={true}`. In this mode:
* Selected options will be removed from the dropdown menu
-* The values of the selected items are joined using the `delimiter` property to create the input value
-* A simple value, if provided, will be split using the `delimiter` property
+* The selected values are submitted in multiple `` fields, use `joinValues` to submit joined values in a single field instead
+* The values of the selected items are joined using the `delimiter` prop to create the input value when `joinValues` is true
+* A simple value, if provided, will be split using the `delimiter` prop
* The `onChange` event provides an array of the selected options as the second argument
* The first argument to `onChange` is always a string, regardless of whether the values of the selected options are numbers or strings
* By default, only options in the `options` array can be selected. Setting `allowCreate` to true allows new options to be created if they do not already exist.
@@ -251,22 +252,39 @@ menuRenderer({ focusedOption, focusOption, labelKey, options, selectValue, value
Check out the demo site for a more complete example of this.
+### Updating input values with onInputChange
+
+You can manipulate the input using the onInputChange and returning a new value.
+
+```js
+function cleanInput(inputValue) {
+ // Strip all non-number characters from the input
+ return inputValue.replace(/[^0-9]/g, "");
+}
+
+
+```
+
### Further options
Property | Type | Default | Description
:-----------------------|:--------------|:--------------|:--------------------------------
addLabelText | string | 'Add "{label}"?' | text to display when `allowCreate` is true
- autosize | bool | true | If enabled, the input will expand as the length of its value increases
- autoBlur | bool | false | Blurs the input element after a selection has been made. Handy for lowering the keyboard on mobile devices
allowCreate | bool | false | allow new options to be created in multi mode (displays an "Add \ elements
optionComponent: _react2['default'].PropTypes.func, // option component to render in dropdown
optionRenderer: _react2['default'].PropTypes.func, // optionRenderer: function (option) {}
options: _react2['default'].PropTypes.array, // array of options
placeholder: stringOrNode, // field placeholder, displayed when there's no value
required: _react2['default'].PropTypes.bool, // applies HTML5 required attribute when needed
+ resetValue: _react2['default'].PropTypes.any, // value to use when you clear the control
scrollMenuIntoView: _react2['default'].PropTypes.bool, // boolean to enable the viewport to shift so that the full menu fully visible when engaged
searchable: _react2['default'].PropTypes.bool, // whether to enable searching feature or not
simpleValue: _react2['default'].PropTypes.bool, // pass the value to onChange as a simple value (legacy pre 1.0 mode), defaults to false
style: _react2['default'].PropTypes.object, // optional style to apply to the control
tabIndex: _react2['default'].PropTypes.string, // optional tab index of the control
+ tabSelectsValue: _react2['default'].PropTypes.bool, // whether to treat tabbing out while focused to be value selection
value: _react2['default'].PropTypes.any, // initial field value
valueComponent: _react2['default'].PropTypes.func, // value component to render
valueKey: _react2['default'].PropTypes.string, // path of the label value in option objects
@@ -396,6 +413,7 @@ var Select = _react2['default'].createClass({
getDefaultProps: function getDefaultProps() {
return {
addLabelText: 'Add "{label}"?',
+ autosize: true,
allowCreate: false,
backspaceRemoves: true,
clearable: true,
@@ -409,6 +427,7 @@ var Select = _react2['default'].createClass({
ignoreCase: true,
inputProps: {},
isLoading: false,
+ joinValues: false,
labelKey: 'label',
matchPos: 'any',
matchProp: 'any',
@@ -416,12 +435,15 @@ var Select = _react2['default'].createClass({
multi: false,
noResultsText: 'No results found',
onBlurResetsInput: true,
+ openAfterFocus: false,
optionComponent: _Option2['default'],
placeholder: 'Select...',
required: false,
+ resetValue: null,
scrollMenuIntoView: true,
searchable: true,
simpleValue: false,
+ tabSelectsValue: true,
valueComponent: _Value2['default'],
valueKey: 'value'
};
@@ -434,16 +456,36 @@ var Select = _react2['default'].createClass({
isLoading: false,
isOpen: false,
isPseudoFocused: false,
- required: this.props.required && this.handleRequired(this.props.value, this.props.multi)
+ required: false
};
},
+ componentWillMount: function componentWillMount() {
+ var valueArray = this.getValueArray(this.props.value);
+
+ if (this.props.required) {
+ this.setState({
+ required: this.handleRequired(valueArray[0], this.props.multi)
+ });
+ }
+ },
+
componentDidMount: function componentDidMount() {
if (this.props.autofocus) {
this.focus();
}
},
+ componentWillReceiveProps: function componentWillReceiveProps(nextProps) {
+ var valueArray = this.getValueArray(nextProps.value);
+
+ if (nextProps.required) {
+ this.setState({
+ required: this.handleRequired(valueArray[0], nextProps.multi)
+ });
+ }
+ },
+
componentWillUpdate: function componentWillUpdate(nextProps, nextState) {
if (nextState.isOpen !== this.state.isOpen) {
var handler = nextState.isOpen ? nextProps.onOpen : nextProps.onClose;
@@ -462,9 +504,6 @@ var Select = _react2['default'].createClass({
this.hasScrolledToOption = false;
}
- if (prevState.inputValue !== this.state.inputValue && this.props.onInputChange) {
- this.props.onInputChange(this.state.inputValue);
- }
if (this._scrollToFocusedOptionOnUpdate && this.refs.focused && this.refs.menu) {
this._scrollToFocusedOptionOnUpdate = false;
var focusedDOM = _reactDom2['default'].findDOMNode(this.refs.focused);
@@ -478,7 +517,7 @@ var Select = _react2['default'].createClass({
if (this.props.scrollMenuIntoView && this.refs.menuContainer) {
var menuContainerRect = this.refs.menuContainer.getBoundingClientRect();
if (window.innerHeight < menuContainerRect.bottom + this.props.menuBuffer) {
- window.scrollTo(0, window.scrollY + menuContainerRect.bottom + this.props.menuBuffer - window.innerHeight);
+ window.scrollBy(0, menuContainerRect.bottom + this.props.menuBuffer - window.innerHeight);
}
}
if (prevProps.disabled !== this.props.disabled) {
@@ -489,6 +528,12 @@ var Select = _react2['default'].createClass({
focus: function focus() {
if (!this.refs.input) return;
this.refs.input.focus();
+
+ if (this.props.openAfterFocus) {
+ this.setState({
+ isOpen: true
+ });
+ }
},
blurInput: function blurInput() {
@@ -596,7 +641,7 @@ var Select = _react2['default'].createClass({
},
handleInputFocus: function handleInputFocus(event) {
- var isOpen = this.state.isOpen || this._openAfterFocus;
+ var isOpen = this.state.isOpen || this._openAfterFocus || this.props.openOnFocus;
if (this.props.onFocus) {
this.props.onFocus(event);
}
@@ -608,7 +653,8 @@ var Select = _react2['default'].createClass({
},
handleInputBlur: function handleInputBlur(event) {
- if (this.refs.menu && document.activeElement.isEqualNode(this.refs.menu)) {
+ if (this.refs.menu && document.activeElement === this.refs.menu) {
+ this.focus();
return;
}
@@ -627,10 +673,18 @@ var Select = _react2['default'].createClass({
},
handleInputChange: function handleInputChange(event) {
+ var newInputValue = event.target.value;
+ if (this.state.inputValue !== event.target.value && this.props.onInputChange) {
+ var nextState = this.props.onInputChange(newInputValue);
+ // Note: != used deliberately here to catch undefined and null
+ if (nextState != null) {
+ newInputValue = '' + nextState;
+ }
+ }
this.setState({
isOpen: true,
isPseudoFocused: false,
- inputValue: event.target.value
+ inputValue: newInputValue
});
},
@@ -646,7 +700,7 @@ var Select = _react2['default'].createClass({
return;
case 9:
// tab
- if (event.shiftKey || !this.state.isOpen) {
+ if (event.shiftKey || !this.state.isOpen || !this.props.tabSelectsValue) {
return;
}
this.selectFocusedOption();
@@ -711,8 +765,7 @@ var Select = _react2['default'].createClass({
return op[this.props.labelKey];
},
- getValueArray: function getValueArray() {
- var value = this.props.value;
+ getValueArray: function getValueArray(value) {
if (this.props.multi) {
if (typeof value === 'string') value = value.split(this.props.delimiter);
if (!Array.isArray(value)) {
@@ -776,19 +829,19 @@ var Select = _react2['default'].createClass({
},
addValue: function addValue(value) {
- var valueArray = this.getValueArray();
+ var valueArray = this.getValueArray(this.props.value);
this.setValue(valueArray.concat(value));
},
popValue: function popValue() {
- var valueArray = this.getValueArray();
+ var valueArray = this.getValueArray(this.props.value);
if (!valueArray.length) return;
if (valueArray[valueArray.length - 1].clearableValue === false) return;
this.setValue(valueArray.slice(0, valueArray.length - 1));
},
removeValue: function removeValue(value) {
- var valueArray = this.getValueArray();
+ var valueArray = this.getValueArray(this.props.value);
this.setValue(valueArray.filter(function (i) {
return i !== value;
}));
@@ -803,7 +856,7 @@ var Select = _react2['default'].createClass({
}
event.stopPropagation();
event.preventDefault();
- this.setValue(null);
+ this.setValue(this.props.resetValue);
this.setState({
isOpen: false,
inputValue: ''
@@ -920,27 +973,46 @@ var Select = _react2['default'].createClass({
},
renderInput: function renderInput(valueArray) {
- var className = (0, _classnames2['default'])('Select-input', this.props.inputProps.className);
- if (this.props.disabled || !this.props.searchable) {
- return _react2['default'].createElement('div', _extends({}, this.props.inputProps, {
- className: className,
- tabIndex: this.props.tabIndex || 0,
- onBlur: this.handleInputBlur,
- onFocus: this.handleInputFocus,
- ref: 'input',
- style: { border: 0, width: 1, display: 'inline-block' } }));
+ if (this.props.inputRenderer) {
+ return this.props.inputRenderer();
+ } else {
+ var className = (0, _classnames2['default'])('Select-input', this.props.inputProps.className);
+ if (this.props.disabled || !this.props.searchable) {
+ return _react2['default'].createElement('div', _extends({}, this.props.inputProps, {
+ className: className,
+ tabIndex: this.props.tabIndex || 0,
+ onBlur: this.handleInputBlur,
+ onFocus: this.handleInputFocus,
+ ref: 'input',
+ style: { border: 0, width: 1, display: 'inline-block' } }));
+ }
+ if (this.props.autosize) {
+ return _react2['default'].createElement(_reactInputAutosize2['default'], _extends({}, this.props.inputProps, {
+ className: className,
+ tabIndex: this.props.tabIndex,
+ onBlur: this.handleInputBlur,
+ onChange: this.handleInputChange,
+ onFocus: this.handleInputFocus,
+ minWidth: '5',
+ ref: 'input',
+ required: this.state.required,
+ value: this.state.inputValue
+ }));
+ }
+ return _react2['default'].createElement(
+ 'div',
+ { className: className },
+ _react2['default'].createElement('input', _extends({}, this.props.inputProps, {
+ tabIndex: this.props.tabIndex,
+ onBlur: this.handleInputBlur,
+ onChange: this.handleInputChange,
+ onFocus: this.handleInputFocus,
+ ref: 'input',
+ required: this.state.required,
+ value: this.state.inputValue
+ }))
+ );
}
- return _react2['default'].createElement(_reactInputAutosize2['default'], _extends({}, this.props.inputProps, {
- className: className,
- tabIndex: this.props.tabIndex,
- onBlur: this.handleInputBlur,
- onChange: this.handleInputChange,
- onFocus: this.handleInputFocus,
- minWidth: '5',
- ref: 'input',
- required: this.state.required,
- value: this.state.inputValue
- }));
},
renderClear: function renderClear() {
@@ -1007,42 +1079,53 @@ var Select = _react2['default'].createClass({
var _this4 = this;
if (options && options.length) {
- var _ret = (function () {
- var Option = _this4.props.optionComponent;
- var renderLabel = _this4.props.optionRenderer || _this4.getOptionLabel;
-
- return {
- v: options.map(function (option, i) {
- var isSelected = valueArray && valueArray.indexOf(option) > -1;
- var isFocused = option === focusedOption;
- var optionRef = isFocused ? 'focused' : null;
- var optionClass = (0, _classnames2['default'])({
- 'Select-option': true,
- 'is-selected': isSelected,
- 'is-focused': isFocused,
- 'is-disabled': option.disabled
- });
-
- return _react2['default'].createElement(
- Option,
- {
- className: optionClass,
- isDisabled: option.disabled,
- isFocused: isFocused,
- key: 'option-' + i + '-' + option[_this4.props.valueKey],
- onSelect: _this4.selectValue,
- onFocus: _this4.focusOption,
- option: option,
- isSelected: isSelected,
- ref: optionRef
- },
- renderLabel(option)
- );
- })
- };
- })();
-
- if (typeof _ret === 'object') return _ret.v;
+ if (this.props.menuRenderer) {
+ return this.props.menuRenderer({
+ focusedOption: focusedOption,
+ focusOption: this.focusOption,
+ labelKey: this.props.labelKey,
+ options: options,
+ selectValue: this.selectValue,
+ valueArray: valueArray
+ });
+ } else {
+ var _ret = (function () {
+ var Option = _this4.props.optionComponent;
+ var renderLabel = _this4.props.optionRenderer || _this4.getOptionLabel;
+
+ return {
+ v: options.map(function (option, i) {
+ var isSelected = valueArray && valueArray.indexOf(option) > -1;
+ var isFocused = option === focusedOption;
+ var optionRef = isFocused ? 'focused' : null;
+ var optionClass = (0, _classnames2['default'])(_this4.props.optionClassName, {
+ 'Select-option': true,
+ 'is-selected': isSelected,
+ 'is-focused': isFocused,
+ 'is-disabled': option.disabled
+ });
+
+ return _react2['default'].createElement(
+ Option,
+ {
+ className: optionClass,
+ isDisabled: option.disabled,
+ isFocused: isFocused,
+ key: 'option-' + i + '-' + option[_this4.props.valueKey],
+ onSelect: _this4.selectValue,
+ onFocus: _this4.focusOption,
+ option: option,
+ isSelected: isSelected,
+ ref: optionRef
+ },
+ renderLabel(option)
+ );
+ })
+ };
+ })();
+
+ if (typeof _ret === 'object') return _ret.v;
+ }
} else if (this.props.noResultsText) {
return _react2['default'].createElement(
'div',
@@ -1058,10 +1141,25 @@ var Select = _react2['default'].createClass({
var _this5 = this;
if (!this.props.name) return;
- var value = valueArray.map(function (i) {
- return stringifyValue(i[_this5.props.valueKey]);
- }).join(this.props.delimiter);
- return _react2['default'].createElement('input', { type: 'hidden', ref: 'value', name: this.props.name, value: value, disabled: this.props.disabled });
+ if (this.props.joinValues) {
+ var value = valueArray.map(function (i) {
+ return stringifyValue(i[_this5.props.valueKey]);
+ }).join(this.props.delimiter);
+ return _react2['default'].createElement('input', {
+ type: 'hidden',
+ ref: 'value',
+ name: this.props.name,
+ value: value,
+ disabled: this.props.disabled });
+ }
+ return valueArray.map(function (item, index) {
+ return _react2['default'].createElement('input', { key: 'hidden.' + index,
+ type: 'hidden',
+ ref: 'value' + index,
+ name: _this5.props.name,
+ value: stringifyValue(item[_this5.props.valueKey]),
+ disabled: _this5.props.disabled });
+ });
},
getFocusableOption: function getFocusableOption(selectedOption) {
@@ -1074,14 +1172,35 @@ var Select = _react2['default'].createClass({
}
},
+ renderOuter: function renderOuter(options, valueArray, focusedOption) {
+ var menu = this.renderMenu(options, valueArray, focusedOption);
+ if (!menu) {
+ return null;
+ }
+
+ return _react2['default'].createElement(
+ 'div',
+ { ref: 'menuContainer', className: 'Select-menu-outer', style: this.props.menuContainerStyle },
+ _react2['default'].createElement(
+ 'div',
+ { ref: 'menu', className: 'Select-menu',
+ style: this.props.menuStyle,
+ onScroll: this.handleMenuScroll,
+ onMouseDown: this.handleMouseDownOnMenu },
+ menu
+ )
+ );
+ },
+
render: function render() {
- var valueArray = this.getValueArray();
+ var valueArray = this.getValueArray(this.props.value);
var options = this._visibleOptions = this.filterOptions(this.props.multi ? valueArray : null);
var isOpen = this.state.isOpen;
if (this.props.multi && !options.length && valueArray.length && !this.state.inputValue) isOpen = false;
var focusedOption = this._focusedOption = this.getFocusableOption(valueArray[0]);
var className = (0, _classnames2['default'])('Select', this.props.className, {
'Select--multi': this.props.multi,
+ 'Select--single': !this.props.multi,
'is-disabled': this.props.disabled,
'is-focused': this.state.isFocused,
'is-loading': this.props.isLoading,
@@ -1090,6 +1209,7 @@ var Select = _react2['default'].createClass({
'is-searchable': this.props.searchable,
'has-value': valueArray.length
});
+
return _react2['default'].createElement(
'div',
{ ref: 'wrapper', className: className, style: this.props.wrapperStyle },
@@ -1110,18 +1230,7 @@ var Select = _react2['default'].createClass({
this.renderClear(),
this.renderArrow()
),
- isOpen ? _react2['default'].createElement(
- 'div',
- { ref: 'menuContainer', className: 'Select-menu-outer', style: this.props.menuContainerStyle },
- _react2['default'].createElement(
- 'div',
- { ref: 'menu', className: 'Select-menu',
- style: this.props.menuStyle,
- onScroll: this.handleMenuScroll,
- onMouseDown: this.handleMouseDownOnMenu },
- this.renderMenu(options, !this.props.multi ? valueArray : null, focusedOption)
- )
- ) : null
+ isOpen ? this.renderOuter(options, !this.props.multi ? valueArray : null, focusedOption) : null
);
}
diff --git a/dist/react-select.min.css b/dist/react-select.min.css
index f882afeaf7..c3b07ec434 100644
--- a/dist/react-select.min.css
+++ b/dist/react-select.min.css
@@ -1 +1 @@
-.Select,.Select-control{position:relative}.Select-arrow-zone,.Select-clear-zone,.Select-loading-zone{text-align:center;cursor:pointer}.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}.Select-control{background-color:#fff;border-radius:4px;border:1px solid #ccc;color:#333;cursor:default;display:table;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)}.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-placeholder,:not(.Select--multi)>.Select-control .Select-value{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}.Select-arrow-zone,.Select-clear-zone,.Select-loading,.Select-loading-zone{position:relative;vertical-align:middle}.has-value.is-pseudo-focused:not(.Select--multi)>.Select-control>.Select-value .Select-value-label,.has-value:not(.Select--multi)>.Select-control>.Select-value .Select-value-label{color:#333}.has-value.is-pseudo-focused:not(.Select--multi)>.Select-control>.Select-value a.Select-value-label,.has-value:not(.Select--multi)>.Select-control>.Select-value a.Select-value-label{cursor:pointer;text-decoration:none}.has-value.is-pseudo-focused:not(.Select--multi)>.Select-control>.Select-value a.Select-value-label:focus,.has-value.is-pseudo-focused:not(.Select--multi)>.Select-control>.Select-value a.Select-value-label:hover,.has-value:not(.Select--multi)>.Select-control>.Select-value a.Select-value-label:focus,.has-value:not(.Select--multi)>.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{background:none;border:0;box-shadow:none;cursor:default;display:inline-block;font-family:inherit;font-size:inherit;height:34px;margin:0;outline:0;padding:0;-webkit-appearance:none}.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{display:table-cell;width:16px}.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;width:16px;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;display:table-cell;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{display:table-cell;width:25px;padding-right:5px}.Select-arrow{border-color:#999 transparent transparent;border-style:solid;border-width:5px 5px 2.5px;display:inline-block;height:0;width:0}.Select-noresults,.Select-option{box-sizing:border-box;display:block;padding:8px 10px}.Select-arrow-zone:hover>.Select-arrow,.is-open .Select-arrow{border-top-color:#666}@-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-focused{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:rgba(0,126,255,.08);border-radius:2px;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 rgba(0,126,255,.24);padding:1px 5px 3px}.Select--multi .Select-value-icon:focus,.Select--multi .Select-value-icon:hover{background-color:rgba(0,113,230,.08);color:#0071e6}.Select--multi .Select-value-icon:active{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-arrow-zone,.Select-clear-zone,.Select-loading-zone{text-align:center;cursor:pointer}.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}.Select-control{background-color:#fff;border-radius:4px;border:1px solid #ccc;color:#333;cursor:default;display:table;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)}.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{display:table-cell}.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;display:table-cell;position:relative;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{display:table-cell;position:relative;vertical-align:middle;width:25px;padding-right:5px}.Select-arrow{border-color:#999 transparent transparent;border-style:solid;border-width:5px 5px 2.5px;display:inline-block;height:0;width:0}.Select-noresults,.Select-option{box-sizing:border-box;display:block;padding:8px 10px}.Select-arrow-zone:hover>.Select-arrow,.is-open .Select-arrow{border-top-color:#666}@-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 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 888ecdbfbb..78c58da33a 100644
--- a/dist/react-select.min.js
+++ b/dist/react-select.min.js
@@ -1 +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 u;u="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:this,u.Select=e()}}(function(){return function e(u,t,s){function o(i,r){if(!t[i]){if(!u[i]){var a="function"==typeof require&&require;if(!r&&a)return a(i,!0);if(n)return n(i,!0);var l=new Error("Cannot find module '"+i+"'");throw l.code="MODULE_NOT_FOUND",l}var p=t[i]={exports:{}};u[i][0].call(p.exports,function(e){var t=u[i][1][e];return o(t?t:e)},p,p.exports,e,u,t,s)}return t[i].exports}for(var n="function"==typeof require&&require,i=0;i=0;--t){var s=u.slice(0,t);if(e[s]&&(u===s||e[s].complete))return e[s]}}function r(e,u){return e&&"function"==typeof e.then?e.then(function(e){u(null,e)},function(e){u(e)}):void 0}var a=Object.assign||function(e){for(var u=1;ur.bottom||i.topu.offsetHeight&&!(u.scrollHeight-u.offsetHeight-u.scrollTop)&&this.props.onMenuScrollToBottom()}},handleRequired:function(e,u){return e?u?0===e.length:0===Object.keys(e).length:!0},getOptionLabel:function(e){return e[this.props.labelKey]},getValueArray:function(){var e=this.props.value;if(this.props.multi){if("string"==typeof e&&(e=e.split(this.props.delimiter)),!Array.isArray(e)){if(null===e||void 0===e)return[];e=[e]}return e.map(this.expandValue).filter(function(e){return e})}var u=this.expandValue(e);return u?[u]:[]},expandValue:function(e){if("string"!=typeof e&&"number"!=typeof e)return e;var u=this.props,t=u.options,s=u.valueKey;if(t)for(var o=0;o-1&&t0?u[t-1]:u[u.length-1]),this.setState({focusedOption:o})}},selectFocusedOption:function(){return this._focusedOption?this.selectValue(this._focusedOption):void 0},renderLoading:function(){return this.props.isLoading?a["default"].createElement("span",{className:"Select-loading-zone","aria-hidden":"true"},a["default"].createElement("span",{className:"Select-loading"})):void 0},renderValue:function(e,u){var t=this,s=this.props.valueRenderer||this.getOptionLabel,o=this.props.valueComponent;if(!e.length)return this.state.inputValue?null:a["default"].createElement("div",{className:"Select-placeholder"},this.props.placeholder);var n=this.props.onValueClick?this.handleValueClick:null;return this.props.multi?e.map(function(e,u){return a["default"].createElement(o,{disabled:t.props.disabled||e.clearableValue===!1,key:"value-"+u+"-"+e[t.props.valueKey],onClick:n,onRemove:t.removeValue,value:e},s(e))}):this.state.inputValue?void 0:(u&&(n=null),a["default"].createElement(o,{disabled:this.props.disabled,onClick:n,value:e[0]},s(e[0])))},renderInput:function(e){var u=(0,f["default"])("Select-input",this.props.inputProps.className);return this.props.disabled||!this.props.searchable?a["default"].createElement("div",i({},this.props.inputProps,{className:u,tabIndex:this.props.tabIndex||0,onBlur:this.handleInputBlur,onFocus:this.handleInputFocus,ref:"input",style:{border:0,width:1,display:"inline-block"}})):a["default"].createElement(c["default"],i({},this.props.inputProps,{className:u,tabIndex:this.props.tabIndex,onBlur:this.handleInputBlur,onChange:this.handleInputChange,onFocus:this.handleInputFocus,minWidth:"5",ref:"input",required:this.state.required,value:this.state.inputValue}))},renderClear:function(){return!this.props.clearable||!this.props.value||this.props.multi&&!this.props.value.length||this.props.disabled||this.props.isLoading?void 0:a["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},a["default"].createElement("span",{className:"Select-clear",dangerouslySetInnerHTML:{__html:"×"}}))},renderArrow:function(){return a["default"].createElement("span",{className:"Select-arrow-zone",onMouseDown:this.handleMouseDownOnArrow},a["default"].createElement("span",{className:"Select-arrow",onMouseDown:this.handleMouseDownOnArrow}))},filterOptions:function(e){var u=this,t=this.state.inputValue,s=this.props.options||[];return"function"==typeof this.props.filterOptions?this.props.filterOptions.call(this,s,t,e):this.props.filterOptions?(this.props.ignoreAccents&&(t=(0,g["default"])(t)),this.props.ignoreCase&&(t=t.toLowerCase()),e&&(e=e.map(function(e){return e[u.props.valueKey]})),s.filter(function(s){if(e&&e.indexOf(s[u.props.valueKey])>-1)return!1;if(u.props.filterOption)return u.props.filterOption.call(u,s,t);if(!t)return!0;var o=String(s[u.props.valueKey]),n=String(s[u.props.labelKey]);return u.props.ignoreAccents&&("label"!==u.props.matchProp&&(o=(0,g["default"])(o)),"value"!==u.props.matchProp&&(n=(0,g["default"])(n))),u.props.ignoreCase&&("label"!==u.props.matchProp&&(o=o.toLowerCase()),"value"!==u.props.matchProp&&(n=n.toLowerCase())),"start"===u.props.matchPos?"label"!==u.props.matchProp&&o.substr(0,t.length)===t||"value"!==u.props.matchProp&&n.substr(0,t.length)===t:"label"!==u.props.matchProp&&o.indexOf(t)>=0||"value"!==u.props.matchProp&&n.indexOf(t)>=0})):s},renderMenu:function(e,u,t){var s=this;if(!e||!e.length)return this.props.noResultsText?a["default"].createElement("div",{className:"Select-noresults"},this.props.noResultsText):null;var o=function(){var o=s.props.optionComponent,n=s.props.optionRenderer||s.getOptionLabel;return{v:e.map(function(e,i){var r=u&&u.indexOf(e)>-1,l=e===t,p=l?"focused":null,d=(0,f["default"])({"Select-option":!0,"is-selected":r,"is-focused":l,"is-disabled":e.disabled});return a["default"].createElement(o,{className:d,isDisabled:e.disabled,isFocused:l,key:"option-"+i+"-"+e[s.props.valueKey],onSelect:s.selectValue,onFocus:s.focusOption,option:e,isSelected:r,ref:p},n(e))})}}();return"object"==typeof o?o.v:void 0},renderHiddenField:function(e){var u=this;if(this.props.name){var t=e.map(function(e){return n(e[u.props.valueKey])}).join(this.props.delimiter);return a["default"].createElement("input",{type:"hidden",ref:"value",name:this.props.name,value:t,disabled:this.props.disabled})}},getFocusableOption:function(e){var u=this._visibleOptions;if(u.length){var t=this.state.focusedOption||e;if(t&&u.indexOf(t)>-1)return t;for(var s=0;s=0;--t){var s=u.slice(0,t);if(e[s]&&(u===s||e[s].complete))return e[s]}}function r(e,u){return e&&"function"==typeof e.then?e.then(function(e){u(null,e)},function(e){u(e)}):void 0}var a=Object.assign||function(e){for(var u=1;ur.bottom||i.topu.offsetHeight&&!(u.scrollHeight-u.offsetHeight-u.scrollTop)&&this.props.onMenuScrollToBottom()}},handleRequired:function(e,u){return e?u?0===e.length:0===Object.keys(e).length:!0},getOptionLabel:function(e){return e[this.props.labelKey]},getValueArray:function(e){if(this.props.multi){if("string"==typeof e&&(e=e.split(this.props.delimiter)),!Array.isArray(e)){if(null===e||void 0===e)return[];e=[e]}return e.map(this.expandValue).filter(function(e){return e})}var u=this.expandValue(e);return u?[u]:[]},expandValue:function(e){if("string"!=typeof e&&"number"!=typeof e)return e;var u=this.props,t=u.options,s=u.valueKey;if(t)for(var o=0;o-1&&t0?u[t-1]:u[u.length-1]),this.setState({focusedOption:o})}},selectFocusedOption:function(){return this._focusedOption?this.selectValue(this._focusedOption):void 0},renderLoading:function(){return this.props.isLoading?a["default"].createElement("span",{className:"Select-loading-zone","aria-hidden":"true"},a["default"].createElement("span",{className:"Select-loading"})):void 0},renderValue:function(e,u){var t=this,s=this.props.valueRenderer||this.getOptionLabel,o=this.props.valueComponent;if(!e.length)return this.state.inputValue?null:a["default"].createElement("div",{className:"Select-placeholder"},this.props.placeholder);var n=this.props.onValueClick?this.handleValueClick:null;return this.props.multi?e.map(function(e,u){return a["default"].createElement(o,{disabled:t.props.disabled||e.clearableValue===!1,key:"value-"+u+"-"+e[t.props.valueKey],onClick:n,onRemove:t.removeValue,value:e},s(e))}):this.state.inputValue?void 0:(u&&(n=null),a["default"].createElement(o,{disabled:this.props.disabled,onClick:n,value:e[0]},s(e[0])))},renderInput:function(e){if(this.props.inputRenderer)return this.props.inputRenderer();var u=(0,f["default"])("Select-input",this.props.inputProps.className);return this.props.disabled||!this.props.searchable?a["default"].createElement("div",i({},this.props.inputProps,{className:u,tabIndex:this.props.tabIndex||0,onBlur:this.handleInputBlur,onFocus:this.handleInputFocus,ref:"input",style:{border:0,width:1,display:"inline-block"}})):this.props.autosize?a["default"].createElement(c["default"],i({},this.props.inputProps,{className:u,tabIndex:this.props.tabIndex,onBlur:this.handleInputBlur,onChange:this.handleInputChange,onFocus:this.handleInputFocus,minWidth:"5",ref:"input",required:this.state.required,value:this.state.inputValue})):a["default"].createElement("div",{className:u},a["default"].createElement("input",i({},this.props.inputProps,{tabIndex:this.props.tabIndex,onBlur:this.handleInputBlur,onChange:this.handleInputChange,onFocus:this.handleInputFocus,ref:"input",required:this.state.required,value:this.state.inputValue})))},renderClear:function(){return!this.props.clearable||!this.props.value||this.props.multi&&!this.props.value.length||this.props.disabled||this.props.isLoading?void 0:a["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},a["default"].createElement("span",{className:"Select-clear",dangerouslySetInnerHTML:{__html:"×"}}))},renderArrow:function(){return a["default"].createElement("span",{className:"Select-arrow-zone",onMouseDown:this.handleMouseDownOnArrow},a["default"].createElement("span",{className:"Select-arrow",onMouseDown:this.handleMouseDownOnArrow}))},filterOptions:function(e){var u=this,t=this.state.inputValue,s=this.props.options||[];return"function"==typeof this.props.filterOptions?this.props.filterOptions.call(this,s,t,e):this.props.filterOptions?(this.props.ignoreAccents&&(t=(0,g["default"])(t)),this.props.ignoreCase&&(t=t.toLowerCase()),e&&(e=e.map(function(e){return e[u.props.valueKey]})),s.filter(function(s){if(e&&e.indexOf(s[u.props.valueKey])>-1)return!1;if(u.props.filterOption)return u.props.filterOption.call(u,s,t);if(!t)return!0;var o=String(s[u.props.valueKey]),n=String(s[u.props.labelKey]);return u.props.ignoreAccents&&("label"!==u.props.matchProp&&(o=(0,g["default"])(o)),"value"!==u.props.matchProp&&(n=(0,g["default"])(n))),u.props.ignoreCase&&("label"!==u.props.matchProp&&(o=o.toLowerCase()),"value"!==u.props.matchProp&&(n=n.toLowerCase())),"start"===u.props.matchPos?"label"!==u.props.matchProp&&o.substr(0,t.length)===t||"value"!==u.props.matchProp&&n.substr(0,t.length)===t:"label"!==u.props.matchProp&&o.indexOf(t)>=0||"value"!==u.props.matchProp&&n.indexOf(t)>=0})):s},renderMenu:function(e,u,t){var s=this;if(!e||!e.length)return this.props.noResultsText?a["default"].createElement("div",{className:"Select-noresults"},this.props.noResultsText):null;if(this.props.menuRenderer)return this.props.menuRenderer({focusedOption:t,focusOption:this.focusOption,labelKey:this.props.labelKey,options:e,selectValue:this.selectValue,valueArray:u});var o=function(){var o=s.props.optionComponent,n=s.props.optionRenderer||s.getOptionLabel;return{v:e.map(function(e,i){var r=u&&u.indexOf(e)>-1,l=e===t,p=l?"focused":null,d=(0,f["default"])(s.props.optionClassName,{"Select-option":!0,"is-selected":r,"is-focused":l,"is-disabled":e.disabled});return a["default"].createElement(o,{className:d,isDisabled:e.disabled,isFocused:l,key:"option-"+i+"-"+e[s.props.valueKey],onSelect:s.selectValue,onFocus:s.focusOption,option:e,isSelected:r,ref:p},n(e))})}}();return"object"==typeof o?o.v:void 0},renderHiddenField:function(e){var u=this;if(this.props.name){if(this.props.joinValues){var t=e.map(function(e){return n(e[u.props.valueKey])}).join(this.props.delimiter);return a["default"].createElement("input",{type:"hidden",ref:"value",name:this.props.name,value:t,disabled:this.props.disabled})}return e.map(function(e,t){return a["default"].createElement("input",{key:"hidden."+t,type:"hidden",ref:"value"+t,name:u.props.name,value:n(e[u.props.valueKey]),disabled:u.props.disabled})})}},getFocusableOption:function(e){var u=this._visibleOptions;if(u.length){var t=this.state.focusedOption||e;if(t&&u.indexOf(t)>-1)return t;for(var s=0;s
*/
-},{"./components/Contributors":2,"./components/CustomComponents":3,"./components/CustomRender":4,"./components/Multiselect":5,"./components/NumericSelect":6,"./components/States":7,"react":undefined,"react-dom":undefined,"react-select":undefined}],2:[function(require,module,exports){
+},{"./components/Contributors":2,"./components/CustomComponents":3,"./components/CustomRender":4,"./components/Multiselect":5,"./components/NumericSelect":6,"./components/States":7,"./components/Virtualized":8,"react":undefined,"react-dom":undefined,"react-select":undefined}],2:[function(require,module,exports){
'use strict';
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
@@ -161,7 +166,7 @@ var Contributors = _react2['default'].createClass({
module.exports = Contributors;
-},{"../data/contributors":8,"react":undefined,"react-select":undefined}],3:[function(require,module,exports){
+},{"../data/contributors":10,"react":undefined,"react-select":undefined}],3:[function(require,module,exports){
'use strict';
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
@@ -310,7 +315,7 @@ var UsersField = _react2['default'].createClass({
module.exports = UsersField;
-},{"../data/users":10,"react":undefined,"react-gravatar":19,"react-select":undefined}],4:[function(require,module,exports){
+},{"../data/users":12,"react":undefined,"react-gravatar":28,"react-select":undefined}],4:[function(require,module,exports){
'use strict';
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
@@ -740,24 +745,98 @@ var StatesField = _react2['default'].createClass({
module.exports = StatesField;
-},{"../data/states":9,"react":undefined,"react-select":undefined}],8:[function(require,module,exports){
+},{"../data/states":11,"react":undefined,"react-select":undefined}],8:[function(require,module,exports){
+'use strict';
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _reactVirtualizedSelect = require('react-virtualized-select');
+
+var _reactVirtualizedSelect2 = _interopRequireDefault(_reactVirtualizedSelect);
+
+var DATA = require('../data/cities');
+
+var CitiesField = _react2['default'].createClass({
+ displayName: 'CitiesField',
+ getInitialState: function getInitialState() {
+ return {};
+ },
+ updateValue: function updateValue(newValue) {
+ this.setState({
+ selectValue: newValue
+ });
+ },
+ render: function render() {
+ var options = DATA.CITIES;
+ return _react2['default'].createElement(
+ 'div',
+ { className: 'section' },
+ _react2['default'].createElement(
+ 'h3',
+ { className: 'section-heading' },
+ 'Cities (Large Dataset)'
+ ),
+ _react2['default'].createElement(_reactVirtualizedSelect2['default'], { ref: 'citySelect',
+ options: options,
+ simpleValue: true,
+ clearable: true,
+ name: 'select-city',
+ value: this.state.selectValue,
+ onChange: this.updateValue,
+ searchable: true,
+ labelKey: 'name',
+ valueKey: 'name'
+ }),
+ _react2['default'].createElement(
+ 'div',
+ { className: 'hint' },
+ 'Uses ',
+ _react2['default'].createElement(
+ 'a',
+ { href: 'https://github.com/bvaughn/react-virtualized' },
+ 'react-virtualized'
+ ),
+ ' and ',
+ _react2['default'].createElement(
+ 'a',
+ { href: 'https://github.com/bvaughn/react-virtualized-select/' },
+ 'react-virtualized-select'
+ ),
+ ' to display a list of the world\'s 1,000 largest cities.'
+ )
+ );
+ }
+});
+
+module.exports = CitiesField;
+
+},{"../data/cities":9,"react":undefined,"react-virtualized-select":31}],9:[function(require,module,exports){
+'use strict';
+
+exports.CITIES = [{ name: 'Abilene' }, { name: 'Addison' }, { name: 'Akron' }, { name: 'Alameda' }, { name: 'Albany' }, { name: 'Albany' }, { name: 'Albany' }, { name: 'Albuquerque' }, { name: 'Alexandria' }, { name: 'Alexandria' }, { name: 'Alhambra' }, { name: 'Aliso Viejo' }, { name: 'Allen' }, { name: 'Allentown' }, { name: 'Alpharetta' }, { name: 'Altamonte Springs' }, { name: 'Altoona' }, { name: 'Amarillo' }, { name: 'Ames' }, { name: 'Anaheim' }, { name: 'Anchorage' }, { name: 'Anderson' }, { name: 'Ankeny' }, { name: 'Ann Arbor' }, { name: 'Annapolis' }, { name: 'Antioch' }, { name: 'Apache Junction' }, { name: 'Apex' }, { name: 'Apopka' }, { name: 'Apple Valley' }, { name: 'Apple Valley' }, { name: 'Appleton' }, { name: 'Arcadia' }, { name: 'Arlington' }, { name: 'Arlington Heights' }, { name: 'Arvada' }, { name: 'Asheville' }, { name: 'Athens-Clarke County' }, { name: 'Atlanta' }, { name: 'Atlantic City' }, { name: 'Attleboro' }, { name: 'Auburn' }, { name: 'Auburn' }, { name: 'Augusta-Richmond County' }, { name: 'Aurora' }, { name: 'Aurora' }, { name: 'Austin' }, { name: 'Aventura' }, { name: 'Avondale' }, { name: 'Azusa' }, { name: 'Bakersfield' }, { name: 'Baldwin Park' }, { name: 'Baltimore' }, { name: 'Barnstable Town' }, { name: 'Bartlett' }, { name: 'Bartlett' }, { name: 'Baton Rouge' }, { name: 'Battle Creek' }, { name: 'Bayonne' }, { name: 'Baytown' }, { name: 'Beaumont' }, { name: 'Beaumont' }, { name: 'Beavercreek' }, { name: 'Beaverton' }, { name: 'Bedford' }, { name: 'Bell Gardens' }, { name: 'Belleville' }, { name: 'Bellevue' }, { name: 'Bellevue' }, { name: 'Bellflower' }, { name: 'Bellingham' }, { name: 'Beloit' }, { name: 'Bend' }, { name: 'Bentonville' }, { name: 'Berkeley' }, { name: 'Berwyn' }, { name: 'Bethlehem' }, { name: 'Beverly' }, { name: 'Billings' }, { name: 'Biloxi' }, { name: 'Binghamton' }, { name: 'Birmingham' }, { name: 'Bismarck' }, { name: 'Blacksburg' }, { name: 'Blaine' }, { name: 'Bloomington' }, { name: 'Bloomington' }, { name: 'Bloomington' }, { name: 'Blue Springs' }, { name: 'Boca Raton' }, { name: 'Boise City' }, { name: 'Bolingbrook' }, { name: 'Bonita Springs' }, { name: 'Bossier City' }, { name: 'Boston' }, { name: 'Boulder' }, { name: 'Bountiful' }, { name: 'Bowie' }, { name: 'Bowling Green' }, { name: 'Boynton Beach' }, { name: 'Bozeman' }, { name: 'Bradenton' }, { name: 'Brea' }, { name: 'Bremerton' }, { name: 'Brentwood' }, { name: 'Brentwood' }, { name: 'Bridgeport' }, { name: 'Bristol' }, { name: 'Brockton' }, { name: 'Broken Arrow' }, { name: 'Brookfield' }, { name: 'Brookhaven' }, { name: 'Brooklyn Park' }, { name: 'Broomfield' }, { name: 'Brownsville' }, { name: 'Bryan' }, { name: 'Buckeye' }, { name: 'Buena Park' }, { name: 'Buffalo' }, { name: 'Buffalo Grove' }, { name: 'Bullhead City' }, { name: 'Burbank' }, { name: 'Burien' }, { name: 'Burleson' }, { name: 'Burlington' }, { name: 'Burlington' }, { name: 'Burnsville' }, { name: 'Caldwell' }, { name: 'Calexico' }, { name: 'Calumet City' }, { name: 'Camarillo' }, { name: 'Cambridge' }, { name: 'Camden' }, { name: 'Campbell' }, { name: 'Canton' }, { name: 'Cape Coral' }, { name: 'Cape Girardeau' }, { name: 'Carlsbad' }, { name: 'Carmel' }, { name: 'Carol Stream' }, { name: 'Carpentersville' }, { name: 'Carrollton' }, { name: 'Carson' }, { name: 'Carson City' }, { name: 'Cary' }, { name: 'Casa Grande' }, { name: 'Casper' }, { name: 'Castle Rock' }, { name: 'Cathedral City' }, { name: 'Cedar Falls' }, { name: 'Cedar Hill' }, { name: 'Cedar Park' }, { name: 'Cedar Rapids' }, { name: 'Centennial' }, { name: 'Ceres' }, { name: 'Cerritos' }, { name: 'Champaign' }, { name: 'Chandler' }, { name: 'Chapel Hill' }, { name: 'Charleston' }, { name: 'Charleston' }, { name: 'Charlotte' }, { name: 'Charlottesville' }, { name: 'Chattanooga' }, { name: 'Chelsea' }, { name: 'Chesapeake' }, { name: 'Chesterfield' }, { name: 'Cheyenne' }, { name: 'Chicago' }, { name: 'Chico' }, { name: 'Chicopee' }, { name: 'Chino' }, { name: 'Chino Hills' }, { name: 'Chula Vista' }, { name: 'Cicero' }, { name: 'Cincinnati' }, { name: 'Citrus Heights' }, { name: 'Clarksville' }, { name: 'Clearwater' }, { name: 'Cleveland' }, { name: 'Cleveland' }, { name: 'Cleveland Heights' }, { name: 'Clifton' }, { name: 'Clovis' }, { name: 'Clovis' }, { name: 'Coachella' }, { name: 'Coconut Creek' }, { name: 'Coeur d\'Alene' }, { name: 'College Station' }, { name: 'Collierville' }, { name: 'Colorado Springs' }, { name: 'Colton' }, { name: 'Columbia' }, { name: 'Columbia' }, { name: 'Columbus' }, { name: 'Columbus' }, { name: 'Columbus' }, { name: 'Commerce City' }, { name: 'Compton' }, { name: 'Concord' }, { name: 'Concord' }, { name: 'Concord' }, { name: 'Conroe' }, { name: 'Conway' }, { name: 'Coon Rapids' }, { name: 'Coppell' }, { name: 'Coral Gables' }, { name: 'Coral Springs' }, { name: 'Corona' }, { name: 'Corpus Christi' }, { name: 'Corvallis' }, { name: 'Costa Mesa' }, { name: 'Council Bluffs' }, { name: 'Covina' }, { name: 'Covington' }, { name: 'Cranston' }, { name: 'Crystal Lake' }, { name: 'Culver City' }, { name: 'Cupertino' }, { name: 'Cutler Bay' }, { name: 'Cuyahoga Falls' }, { name: 'Cypress' }, { name: 'Dallas' }, { name: 'Daly City' }, { name: 'Danbury' }, { name: 'Danville' }, { name: 'Danville' }, { name: 'Davenport' }, { name: 'Davie' }, { name: 'Davis' }, { name: 'Dayton' }, { name: 'Daytona Beach' }, { name: 'DeKalb' }, { name: 'DeSoto' }, { name: 'Dearborn' }, { name: 'Dearborn Heights' }, { name: 'Decatur' }, { name: 'Decatur' }, { name: 'Deerfield Beach' }, { name: 'Delano' }, { name: 'Delray Beach' }, { name: 'Deltona' }, { name: 'Denton' }, { name: 'Denver' }, { name: 'Des Moines' }, { name: 'Des Plaines' }, { name: 'Detroit' }, { name: 'Diamond Bar' }, { name: 'Doral' }, { name: 'Dothan' }, { name: 'Dover' }, { name: 'Downers Grove' }, { name: 'Downey' }, { name: 'Draper' }, { name: 'Dublin' }, { name: 'Dublin' }, { name: 'Dubuque' }, { name: 'Duluth' }, { name: 'Duncanville' }, { name: 'Dunwoody' }, { name: 'Durham' }, { name: 'Eagan' }, { name: 'East Lansing' }, { name: 'East Orange' }, { name: 'East Providence' }, { name: 'Eastvale' }, { name: 'Eau Claire' }, { name: 'Eden Prairie' }, { name: 'Edina' }, { name: 'Edinburg' }, { name: 'Edmond' }, { name: 'Edmonds' }, { name: 'El Cajon' }, { name: 'El Centro' }, { name: 'El Monte' }, { name: 'El Paso' }, { name: 'Elgin' }, { name: 'Elizabeth' }, { name: 'Elk Grove' }, { name: 'Elkhart' }, { name: 'Elmhurst' }, { name: 'Elyria' }, { name: 'Encinitas' }, { name: 'Enid' }, { name: 'Erie' }, { name: 'Escondido' }, { name: 'Euclid' }, { name: 'Eugene' }, { name: 'Euless' }, { name: 'Evanston' }, { name: 'Evansville' }, { name: 'Everett' }, { name: 'Everett' }, { name: 'Fairfield' }, { name: 'Fairfield' }, { name: 'Fall River' }, { name: 'Fargo' }, { name: 'Farmington' }, { name: 'Farmington Hills' }, { name: 'Fayetteville' }, { name: 'Fayetteville' }, { name: 'Federal Way' }, { name: 'Findlay' }, { name: 'Fishers' }, { name: 'Fitchburg' }, { name: 'Flagstaff' }, { name: 'Flint' }, { name: 'Florence' }, { name: 'Florence' }, { name: 'Florissant' }, { name: 'Flower Mound' }, { name: 'Folsom' }, { name: 'Fond du Lac' }, { name: 'Fontana' }, { name: 'Fort Collins' }, { name: 'Fort Lauderdale' }, { name: 'Fort Myers' }, { name: 'Fort Pierce' }, { name: 'Fort Smith' }, { name: 'Fort Wayne' }, { name: 'Fort Worth' }, { name: 'Fountain Valley' }, { name: 'Franklin' }, { name: 'Frederick' }, { name: 'Freeport' }, { name: 'Fremont' }, { name: 'Fresno' }, { name: 'Friendswood' }, { name: 'Frisco' }, { name: 'Fullerton' }, { name: 'Gainesville' }, { name: 'Gaithersburg' }, { name: 'Galveston' }, { name: 'Garden Grove' }, { name: 'Gardena' }, { name: 'Garland' }, { name: 'Gary' }, { name: 'Gastonia' }, { name: 'Georgetown' }, { name: 'Germantown' }, { name: 'Gilbert' }, { name: 'Gilroy' }, { name: 'Glendale' }, { name: 'Glendale' }, { name: 'Glendora' }, { name: 'Glenview' }, { name: 'Goodyear' }, { name: 'Goose Creek' }, { name: 'Grand Forks' }, { name: 'Grand Island' }, { name: 'Grand Junction' }, { name: 'Grand Prairie' }, { name: 'Grand Rapids' }, { name: 'Grapevine' }, { name: 'Great Falls' }, { name: 'Greeley' }, { name: 'Green Bay' }, { name: 'Greenacres' }, { name: 'Greenfield' }, { name: 'Greensboro' }, { name: 'Greenville' }, { name: 'Greenville' }, { name: 'Greenwood' }, { name: 'Gresham' }, { name: 'Grove City' }, { name: 'Gulfport' }, { name: 'Hackensack' }, { name: 'Hagerstown' }, { name: 'Hallandale Beach' }, { name: 'Haltom City' }, { name: 'Hamilton' }, { name: 'Hammond' }, { name: 'Hampton' }, { name: 'Hanford' }, { name: 'Hanover Park' }, { name: 'Harlingen' }, { name: 'Harrisburg' }, { name: 'Harrisonburg' }, { name: 'Hartford' }, { name: 'Hattiesburg' }, { name: 'Haverhill' }, { name: 'Hawthorne' }, { name: 'Hayward' }, { name: 'Hemet' }, { name: 'Hempstead' }, { name: 'Henderson' }, { name: 'Hendersonville' }, { name: 'Hesperia' }, { name: 'Hialeah' }, { name: 'Hickory' }, { name: 'High Point' }, { name: 'Highland' }, { name: 'Hillsboro' }, { name: 'Hilton Head Island' }, { name: 'Hoboken' }, { name: 'Hoffman Estates' }, { name: 'Hollywood' }, { name: 'Holyoke' }, { name: 'Homestead' }, { name: 'Honolulu' }, { name: 'Hoover' }, { name: 'Houston' }, { name: 'Huber Heights' }, { name: 'Huntersville' }, { name: 'Huntington' }, { name: 'Huntington Beach' }, { name: 'Huntington Park' }, { name: 'Huntsville' }, { name: 'Huntsville' }, { name: 'Hurst' }, { name: 'Hutchinson' }, { name: 'Idaho Falls' }, { name: 'Independence' }, { name: 'Indianapolis' }, { name: 'Indio' }, { name: 'Inglewood' }, { name: 'Iowa City' }, { name: 'Irvine' }, { name: 'Irving' }, { name: 'Jackson' }, { name: 'Jackson' }, { name: 'Jacksonville' }, { name: 'Jacksonville' }, { name: 'Janesville' }, { name: 'Jefferson City' }, { name: 'Jeffersonville' }, { name: 'Jersey City' }, { name: 'Johns Creek' }, { name: 'Johnson City' }, { name: 'Joliet' }, { name: 'Jonesboro' }, { name: 'Joplin' }, { name: 'Jupiter' }, { name: 'Jurupa Valley' }, { name: 'Kalamazoo' }, { name: 'Kannapolis' }, { name: 'Kansas City' }, { name: 'Kansas City' }, { name: 'Kearny' }, { name: 'Keizer' }, { name: 'Keller' }, { name: 'Kenner' }, { name: 'Kennewick' }, { name: 'Kenosha' }, { name: 'Kent' }, { name: 'Kentwood' }, { name: 'Kettering' }, { name: 'Killeen' }, { name: 'Kingsport' }, { name: 'Kirkland' }, { name: 'Kissimmee' }, { name: 'Knoxville' }, { name: 'Kokomo' }, { name: 'La Crosse' }, { name: 'La Habra' }, { name: 'La Mesa' }, { name: 'La Mirada' }, { name: 'La Puente' }, { name: 'La Quinta' }, { name: 'Lacey' }, { name: 'Lafayette' }, { name: 'Lafayette' }, { name: 'Laguna Niguel' }, { name: 'Lake Charles' }, { name: 'Lake Elsinore' }, { name: 'Lake Forest' }, { name: 'Lake Havasu City' }, { name: 'Lake Oswego' }, { name: 'Lakeland' }, { name: 'Lakeville' }, { name: 'Lakewood' }, { name: 'Lakewood' }, { name: 'Lakewood' }, { name: 'Lakewood' }, { name: 'Lancaster' }, { name: 'Lancaster' }, { name: 'Lancaster' }, { name: 'Lancaster' }, { name: 'Lansing' }, { name: 'Laredo' }, { name: 'Largo' }, { name: 'Las Cruces' }, { name: 'Las Vegas' }, { name: 'Lauderhill' }, { name: 'Lawrence' }, { name: 'Lawrence' }, { name: 'Lawrence' }, { name: 'Lawton' }, { name: 'Layton' }, { name: 'League City' }, { name: 'Lee\'s Summit' }, { name: 'Leesburg' }, { name: 'Lehi' }, { name: 'Lenexa' }, { name: 'Leominster' }, { name: 'Lewisville' }, { name: 'Lexington-Fayette' }, { name: 'Lima' }, { name: 'Lincoln' }, { name: 'Lincoln' }, { name: 'Lincoln Park' }, { name: 'Linden' }, { name: 'Little Rock' }, { name: 'Littleton' }, { name: 'Livermore' }, { name: 'Livonia' }, { name: 'Lodi' }, { name: 'Logan' }, { name: 'Lombard' }, { name: 'Lompoc' }, { name: 'Long Beach' }, { name: 'Longmont' }, { name: 'Longview' }, { name: 'Lorain' }, { name: 'Los Angeles' }, { name: 'Louisville/Jefferson County' }, { name: 'Loveland' }, { name: 'Lowell' }, { name: 'Lubbock' }, { name: 'Lynchburg' }, { name: 'Lynn' }, { name: 'Lynwood' }, { name: 'Macon' }, { name: 'Madera' }, { name: 'Madison' }, { name: 'Madison' }, { name: 'Malden' }, { name: 'Manassas' }, { name: 'Manchester' }, { name: 'Manhattan' }, { name: 'Mankato' }, { name: 'Mansfield' }, { name: 'Mansfield' }, { name: 'Manteca' }, { name: 'Maple Grove' }, { name: 'Maplewood' }, { name: 'Marana' }, { name: 'Margate' }, { name: 'Maricopa' }, { name: 'Marietta' }, { name: 'Marlborough' }, { name: 'Martinez' }, { name: 'Marysville' }, { name: 'McAllen' }, { name: 'McKinney' }, { name: 'Medford' }, { name: 'Medford' }, { name: 'Melbourne' }, { name: 'Memphis' }, { name: 'Menifee' }, { name: 'Mentor' }, { name: 'Merced' }, { name: 'Meriden' }, { name: 'Meridian' }, { name: 'Meridian' }, { name: 'Mesa' }, { name: 'Mesquite' }, { name: 'Methuen' }, { name: 'Miami' }, { name: 'Miami Beach' }, { name: 'Miami Gardens' }, { name: 'Middletown' }, { name: 'Middletown' }, { name: 'Midland' }, { name: 'Midland' }, { name: 'Midwest City' }, { name: 'Milford' }, { name: 'Milpitas' }, { name: 'Milwaukee' }, { name: 'Minneapolis' }, { name: 'Minnetonka' }, { name: 'Minot' }, { name: 'Miramar' }, { name: 'Mishawaka' }, { name: 'Mission' }, { name: 'Mission Viejo' }, { name: 'Missoula' }, { name: 'Missouri City' }, { name: 'Mobile' }, { name: 'Modesto' }, { name: 'Moline' }, { name: 'Monroe' }, { name: 'Monrovia' }, { name: 'Montclair' }, { name: 'Montebello' }, { name: 'Monterey Park' }, { name: 'Montgomery' }, { name: 'Moore' }, { name: 'Moorhead' }, { name: 'Moreno Valley' }, { name: 'Morgan Hill' }, { name: 'Mount Pleasant' }, { name: 'Mount Prospect' }, { name: 'Mount Vernon' }, { name: 'Mountain View' }, { name: 'Muncie' }, { name: 'Murfreesboro' }, { name: 'Murray' }, { name: 'Murrieta' }, { name: 'Muskegon' }, { name: 'Muskogee' }, { name: 'Nampa' }, { name: 'Napa' }, { name: 'Naperville' }, { name: 'Nashua' }, { name: 'Nashville-Davidson' }, { name: 'National City' }, { name: 'New Bedford' }, { name: 'New Berlin' }, { name: 'New Braunfels' }, { name: 'New Britain' }, { name: 'New Brunswick' }, { name: 'New Haven' }, { name: 'New Orleans' }, { name: 'New Rochelle' }, { name: 'New York' }, { name: 'Newark' }, { name: 'Newark' }, { name: 'Newark' }, { name: 'Newport Beach' }, { name: 'Newport News' }, { name: 'Newton' }, { name: 'Niagara Falls' }, { name: 'Noblesville' }, { name: 'Norfolk' }, { name: 'Normal' }, { name: 'Norman' }, { name: 'North Charleston' }, { name: 'North Las Vegas' }, { name: 'North Lauderdale' }, { name: 'North Little Rock' }, { name: 'North Miami' }, { name: 'North Miami Beach' }, { name: 'North Port' }, { name: 'North Richland Hills' }, { name: 'Northglenn' }, { name: 'Norwalk' }, { name: 'Norwalk' }, { name: 'Norwich' }, { name: 'Novato' }, { name: 'Novi' }, { name: 'O\'Fallon' }, { name: 'Oak Lawn' }, { name: 'Oak Park' }, { name: 'Oakland' }, { name: 'Oakland Park' }, { name: 'Oakley' }, { name: 'Ocala' }, { name: 'Oceanside' }, { name: 'Ocoee' }, { name: 'Odessa' }, { name: 'Ogden' }, { name: 'Oklahoma City' }, { name: 'Olathe' }, { name: 'Olympia' }, { name: 'Omaha' }, { name: 'Ontario' }, { name: 'Orange' }, { name: 'Orem' }, { name: 'Orland Park' }, { name: 'Orlando' }, { name: 'Ormond Beach' }, { name: 'Oro Valley' }, { name: 'Oshkosh' }, { name: 'Overland Park' }, { name: 'Owensboro' }, { name: 'Oxnard' }, { name: 'Pacifica' }, { name: 'Palatine' }, { name: 'Palm Bay' }, { name: 'Palm Beach Gardens' }, { name: 'Palm Coast' }, { name: 'Palm Desert' }, { name: 'Palm Springs' }, { name: 'Palmdale' }, { name: 'Palo Alto' }, { name: 'Panama City' }, { name: 'Paramount' }, { name: 'Park Ridge' }, { name: 'Parker' }, { name: 'Parma' }, { name: 'Pasadena' }, { name: 'Pasadena' }, { name: 'Pasco' }, { name: 'Passaic' }, { name: 'Paterson' }, { name: 'Pawtucket' }, { name: 'Peabody' }, { name: 'Peachtree Corners' }, { name: 'Pearland' }, { name: 'Pembroke Pines' }, { name: 'Pensacola' }, { name: 'Peoria' }, { name: 'Peoria' }, { name: 'Perris' }, { name: 'Perth Amboy' }, { name: 'Petaluma' }, { name: 'Pflugerville' }, { name: 'Pharr' }, { name: 'Phenix City' }, { name: 'Philadelphia' }, { name: 'Phoenix' }, { name: 'Pico Rivera' }, { name: 'Pine Bluff' }, { name: 'Pinellas Park' }, { name: 'Pittsburg' }, { name: 'Pittsburgh' }, { name: 'Pittsfield' }, { name: 'Placentia' }, { name: 'Plainfield' }, { name: 'Plainfield' }, { name: 'Plano' }, { name: 'Plantation' }, { name: 'Pleasanton' }, { name: 'Plymouth' }, { name: 'Pocatello' }, { name: 'Pomona' }, { name: 'Pompano Beach' }, { name: 'Pontiac' }, { name: 'Port Arthur' }, { name: 'Port Orange' }, { name: 'Port St. Lucie' }, { name: 'Portage' }, { name: 'Porterville' }, { name: 'Portland' }, { name: 'Portland' }, { name: 'Portsmouth' }, { name: 'Poway' }, { name: 'Prescott' }, { name: 'Prescott Valley' }, { name: 'Providence' }, { name: 'Provo' }, { name: 'Pueblo' }, { name: 'Puyallup' }, { name: 'Quincy' }, { name: 'Quincy' }, { name: 'Racine' }, { name: 'Raleigh' }, { name: 'Rancho Cordova' }, { name: 'Rancho Cucamonga' }, { name: 'Rancho Palos Verdes' }, { name: 'Rancho Santa Margarita' }, { name: 'Rapid City' }, { name: 'Reading' }, { name: 'Redding' }, { name: 'Redlands' }, { name: 'Redmond' }, { name: 'Redondo Beach' }, { name: 'Redwood City' }, { name: 'Reno' }, { name: 'Renton' }, { name: 'Revere' }, { name: 'Rialto' }, { name: 'Richardson' }, { name: 'Richland' }, { name: 'Richmond' }, { name: 'Richmond' }, { name: 'Rio Rancho' }, { name: 'Riverside' }, { name: 'Riverton' }, { name: 'Roanoke' }, { name: 'Rochester' }, { name: 'Rochester' }, { name: 'Rochester Hills' }, { name: 'Rock Hill' }, { name: 'Rock Island' }, { name: 'Rockford' }, { name: 'Rocklin' }, { name: 'Rockville' }, { name: 'Rockwall' }, { name: 'Rocky Mount' }, { name: 'Rogers' }, { name: 'Rohnert Park' }, { name: 'Romeoville' }, { name: 'Rosemead' }, { name: 'Roseville' }, { name: 'Roseville' }, { name: 'Roswell' }, { name: 'Roswell' }, { name: 'Round Rock' }, { name: 'Rowlett' }, { name: 'Roy' }, { name: 'Royal Oak' }, { name: 'Sacramento' }, { name: 'Saginaw' }, { name: 'Salem' }, { name: 'Salem' }, { name: 'Salina' }, { name: 'Salinas' }, { name: 'Salt Lake City' }, { name: 'Sammamish' }, { name: 'San Angelo' }, { name: 'San Antonio' }, { name: 'San Bernardino' }, { name: 'San Bruno' }, { name: 'San Buenaventura (Ventura)' }, { name: 'San Clemente' }, { name: 'San Diego' }, { name: 'San Francisco' }, { name: 'San Gabriel' }, { name: 'San Jacinto' }, { name: 'San Jose' }, { name: 'San Leandro' }, { name: 'San Luis Obispo' }, { name: 'San Marcos' }, { name: 'San Marcos' }, { name: 'San Mateo' }, { name: 'San Rafael' }, { name: 'San Ramon' }, { name: 'Sandy' }, { name: 'Sandy Springs' }, { name: 'Sanford' }, { name: 'Santa Ana' }, { name: 'Santa Barbara' }, { name: 'Santa Clara' }, { name: 'Santa Clarita' }, { name: 'Santa Cruz' }, { name: 'Santa Fe' }, { name: 'Santa Maria' }, { name: 'Santa Monica' }, { name: 'Santa Rosa' }, { name: 'Santee' }, { name: 'Sarasota' }, { name: 'Savannah' }, { name: 'Sayreville' }, { name: 'Schaumburg' }, { name: 'Schenectady' }, { name: 'Scottsdale' }, { name: 'Scranton' }, { name: 'Seattle' }, { name: 'Shakopee' }, { name: 'Shawnee' }, { name: 'Sheboygan' }, { name: 'Shelton' }, { name: 'Sherman' }, { name: 'Shoreline' }, { name: 'Shreveport' }, { name: 'Sierra Vista' }, { name: 'Simi Valley' }, { name: 'Sioux City' }, { name: 'Sioux Falls' }, { name: 'Skokie' }, { name: 'Smyrna' }, { name: 'Smyrna' }, { name: 'Somerville' }, { name: 'South Bend' }, { name: 'South Gate' }, { name: 'South Jordan' }, { name: 'South San Francisco' }, { name: 'Southaven' }, { name: 'Southfield' }, { name: 'Spanish Fork' }, { name: 'Sparks' }, { name: 'Spartanburg' }, { name: 'Spokane' }, { name: 'Spokane Valley' }, { name: 'Springdale' }, { name: 'Springfield' }, { name: 'Springfield' }, { name: 'Springfield' }, { name: 'Springfield' }, { name: 'Springfield' }, { name: 'St. Charles' }, { name: 'St. Clair Shores' }, { name: 'St. Cloud' }, { name: 'St. Cloud' }, { name: 'St. George' }, { name: 'St. Joseph' }, { name: 'St. Louis' }, { name: 'St. Louis Park' }, { name: 'St. Paul' }, { name: 'St. Peters' }, { name: 'St. Petersburg' }, { name: 'Stamford' }, { name: 'Stanton' }, { name: 'State College' }, { name: 'Sterling Heights' }, { name: 'Stillwater' }, { name: 'Stockton' }, { name: 'Streamwood' }, { name: 'Strongsville' }, { name: 'Suffolk' }, { name: 'Sugar Land' }, { name: 'Summerville' }, { name: 'Sumter' }, { name: 'Sunnyvale' }, { name: 'Sunrise' }, { name: 'Surprise' }, { name: 'Syracuse' }, { name: 'Tacoma' }, { name: 'Tallahassee' }, { name: 'Tamarac' }, { name: 'Tampa' }, { name: 'Taunton' }, { name: 'Taylor' }, { name: 'Taylorsville' }, { name: 'Temecula' }, { name: 'Tempe' }, { name: 'Temple' }, { name: 'Terre Haute' }, { name: 'Texarkana' }, { name: 'Texas City' }, { name: 'The Colony' }, { name: 'Thornton' }, { name: 'Thousand Oaks' }, { name: 'Tigard' }, { name: 'Tinley Park' }, { name: 'Titusville' }, { name: 'Toledo' }, { name: 'Topeka' }, { name: 'Torrance' }, { name: 'Tracy' }, { name: 'Trenton' }, { name: 'Troy' }, { name: 'Troy' }, { name: 'Tucson' }, { name: 'Tulare' }, { name: 'Tulsa' }, { name: 'Turlock' }, { name: 'Tuscaloosa' }, { name: 'Tustin' }, { name: 'Twin Falls' }, { name: 'Tyler' }, { name: 'Union City' }, { name: 'Union City' }, { name: 'Upland' }, { name: 'Urbana' }, { name: 'Urbandale' }, { name: 'Utica' }, { name: 'Vacaville' }, { name: 'Valdosta' }, { name: 'Vallejo' }, { name: 'Valley Stream' }, { name: 'Vancouver' }, { name: 'Victoria' }, { name: 'Victorville' }, { name: 'Vineland' }, { name: 'Virginia Beach' }, { name: 'Visalia' }, { name: 'Vista' }, { name: 'Waco' }, { name: 'Walnut Creek' }, { name: 'Waltham' }, { name: 'Warner Robins' }, { name: 'Warren' }, { name: 'Warren' }, { name: 'Warwick' }, { name: 'Washington' }, { name: 'Waterbury' }, { name: 'Waterloo' }, { name: 'Watsonville' }, { name: 'Waukegan' }, { name: 'Waukesha' }, { name: 'Wausau' }, { name: 'Wauwatosa' }, { name: 'Wellington' }, { name: 'Weslaco' }, { name: 'West Allis' }, { name: 'West Covina' }, { name: 'West Des Moines' }, { name: 'West Haven' }, { name: 'West Jordan' }, { name: 'West New York' }, { name: 'West Palm Beach' }, { name: 'West Sacramento' }, { name: 'West Valley City' }, { name: 'Westerville' }, { name: 'Westfield' }, { name: 'Westland' }, { name: 'Westminster' }, { name: 'Westminster' }, { name: 'Weston' }, { name: 'Weymouth Town' }, { name: 'Wheaton' }, { name: 'Wheeling' }, { name: 'White Plains' }, { name: 'Whittier' }, { name: 'Wichita' }, { name: 'Wichita Falls' }, { name: 'Wilkes-Barre' }, { name: 'Wilmington' }, { name: 'Wilmington' }, { name: 'Wilson' }, { name: 'Winston-Salem' }, { name: 'Winter Garden' }, { name: 'Woburn' }, { name: 'Woodbury' }, { name: 'Woodland' }, { name: 'Woonsocket' }, { name: 'Worcester' }, { name: 'Wylie' }, { name: 'Wyoming' }, { name: 'Yakima' }, { name: 'Yonkers' }, { name: 'Yorba Linda' }, { name: 'York' }, { name: 'Youngstown' }, { name: 'Yuba City' }, { name: 'Yucaipa' }, { name: 'Yuma' }];
+
+},{}],10:[function(require,module,exports){
'use strict';
module.exports = [{ github: 'jedwatson', name: 'Jed Watson' }, { github: 'bruderstein', name: 'Dave Brotherstone' }, { github: 'jossmac', name: 'Joss Mackison' }, { github: 'jniechcial', name: 'Jakub Niechciał' }, { github: 'craigdallimore', name: 'Craig Dallimore' }, { github: 'julen', name: 'Julen Ruiz Aizpuru' }, { github: 'dcousens', name: 'Daniel Cousens' }, { github: 'jgautsch', name: 'Jon Gautsch' }, { github: 'dmitry-smirnov', name: 'Dmitry Smirnov' }];
-},{}],9:[function(require,module,exports){
+},{}],11:[function(require,module,exports){
'use strict';
exports.AU = [{ value: 'australian-capital-territory', label: 'Australian Capital Territory', className: 'State-ACT' }, { value: 'new-south-wales', label: 'New South Wales', className: 'State-NSW' }, { value: 'victoria', label: 'Victoria', className: 'State-Vic' }, { value: 'queensland', label: 'Queensland', className: 'State-Qld' }, { value: 'western-australia', label: 'Western Australia', className: 'State-WA' }, { value: 'south-australia', label: 'South Australia', className: 'State-SA' }, { value: 'tasmania', label: 'Tasmania', className: 'State-Tas' }, { value: 'northern-territory', label: 'Northern Territory', className: 'State-NT' }];
exports.US = [{ value: 'AL', label: 'Alabama', disabled: true }, { value: 'AK', label: 'Alaska' }, { value: 'AS', label: 'American Samoa' }, { value: 'AZ', label: 'Arizona' }, { value: 'AR', label: 'Arkansas' }, { value: 'CA', label: 'California' }, { value: 'CO', label: 'Colorado' }, { value: 'CT', label: 'Connecticut' }, { value: 'DE', label: 'Delaware' }, { value: 'DC', label: 'District Of Columbia' }, { value: 'FM', label: 'Federated States Of Micronesia' }, { value: 'FL', label: 'Florida' }, { value: 'GA', label: 'Georgia' }, { value: 'GU', label: 'Guam' }, { value: 'HI', label: 'Hawaii' }, { value: 'ID', label: 'Idaho' }, { value: 'IL', label: 'Illinois' }, { value: 'IN', label: 'Indiana' }, { value: 'IA', label: 'Iowa' }, { value: 'KS', label: 'Kansas' }, { value: 'KY', label: 'Kentucky' }, { value: 'LA', label: 'Louisiana' }, { value: 'ME', label: 'Maine' }, { value: 'MH', label: 'Marshall Islands' }, { value: 'MD', label: 'Maryland' }, { value: 'MA', label: 'Massachusetts' }, { value: 'MI', label: 'Michigan' }, { value: 'MN', label: 'Minnesota' }, { value: 'MS', label: 'Mississippi' }, { value: 'MO', label: 'Missouri' }, { value: 'MT', label: 'Montana' }, { value: 'NE', label: 'Nebraska' }, { value: 'NV', label: 'Nevada' }, { value: 'NH', label: 'New Hampshire' }, { value: 'NJ', label: 'New Jersey' }, { value: 'NM', label: 'New Mexico' }, { value: 'NY', label: 'New York' }, { value: 'NC', label: 'North Carolina' }, { value: 'ND', label: 'North Dakota' }, { value: 'MP', label: 'Northern Mariana Islands' }, { value: 'OH', label: 'Ohio' }, { value: 'OK', label: 'Oklahoma' }, { value: 'OR', label: 'Oregon' }, { value: 'PW', label: 'Palau' }, { value: 'PA', label: 'Pennsylvania' }, { value: 'PR', label: 'Puerto Rico' }, { value: 'RI', label: 'Rhode Island' }, { value: 'SC', label: 'South Carolina' }, { value: 'SD', label: 'South Dakota' }, { value: 'TN', label: 'Tennessee' }, { value: 'TX', label: 'Texas' }, { value: 'UT', label: 'Utah' }, { value: 'VT', label: 'Vermont' }, { value: 'VI', label: 'Virgin Islands' }, { value: 'VA', label: 'Virginia' }, { value: 'WA', label: 'Washington' }, { value: 'WV', label: 'West Virginia' }, { value: 'WI', label: 'Wisconsin' }, { value: 'WY', label: 'Wyoming' }];
-},{}],10:[function(require,module,exports){
+},{}],12:[function(require,module,exports){
'use strict';
module.exports = [{ value: 'John Smith', label: 'John Smith', email: 'john@smith.com' }, { value: 'Merry Jane', label: 'Merry Jane', email: 'merry@jane.com' }, { value: 'Stan Hoper', label: 'Stan Hoper', email: 'stan@hoper.com' }];
-},{}],11:[function(require,module,exports){
+},{}],13:[function(require,module,exports){
var charenc = {
// UTF-8 encoding
utf8: {
@@ -792,7 +871,7 @@ var charenc = {
module.exports = charenc;
-},{}],12:[function(require,module,exports){
+},{}],14:[function(require,module,exports){
(function() {
var base64map
= 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/',
@@ -890,7 +969,103 @@ module.exports = charenc;
module.exports = crypt;
})();
-},{}],13:[function(require,module,exports){
+},{}],15:[function(require,module,exports){
+'use strict';
+module.exports = !!(typeof window !== 'undefined' && window.document && window.document.createElement);
+},{}],16:[function(require,module,exports){
+'use strict';
+
+var canUseDOM = require('./inDOM');
+
+var size;
+
+module.exports = function (recalc) {
+ if (!size || recalc) {
+ if (canUseDOM) {
+ var scrollDiv = document.createElement('div');
+
+ scrollDiv.style.position = 'absolute';
+ scrollDiv.style.top = '-9999px';
+ scrollDiv.style.width = '50px';
+ scrollDiv.style.height = '50px';
+ scrollDiv.style.overflow = 'scroll';
+
+ document.body.appendChild(scrollDiv);
+ size = scrollDiv.offsetWidth - scrollDiv.clientWidth;
+ document.body.removeChild(scrollDiv);
+ }
+ }
+
+ return size;
+};
+},{"./inDOM":15}],17:[function(require,module,exports){
+/**
+ * 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
+ *
+ */
+
+/*eslint-disable no-self-compare */
+
+'use strict';
+
+var hasOwnProperty = Object.prototype.hasOwnProperty;
+
+/**
+ * inlined Object.is polyfill to avoid requiring consumers ship their own
+ * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is
+ */
+function is(x, y) {
+ // SameValue algorithm
+ if (x === y) {
+ // Steps 1-5, 7-10
+ // Steps 6.b-6.e: +0 != -0
+ return x !== 0 || 1 / x === 1 / y;
+ } else {
+ // Step 6.a: NaN == NaN
+ return x !== x && y !== y;
+ }
+}
+
+/**
+ * Performs equality by iterating through keys on an object and returning false
+ * when any key has values which are not strictly equal between the arguments.
+ * Returns true when the values of all keys are strictly equal.
+ */
+function shallowEqual(objA, objB) {
+ if (is(objA, objB)) {
+ return true;
+ }
+
+ if (typeof objA !== 'object' || objA === null || typeof objB !== 'object' || objB === null) {
+ return false;
+ }
+
+ var keysA = Object.keys(objA);
+ var keysB = Object.keys(objB);
+
+ if (keysA.length !== keysB.length) {
+ return false;
+ }
+
+ // Test for A's keys different from B.
+ for (var i = 0; i < keysA.length; i++) {
+ if (!hasOwnProperty.call(objB, keysA[i]) || !is(objA[keysA[i]], objB[keysA[i]])) {
+ return false;
+ }
+ }
+
+ return true;
+}
+
+module.exports = shallowEqual;
+},{}],18:[function(require,module,exports){
/**
* Determine if an object is Buffer
*
@@ -909,7 +1084,7 @@ module.exports = function (obj) {
))
}
-},{}],14:[function(require,module,exports){
+},{}],19:[function(require,module,exports){
module.exports = function() {
var mediaQuery;
if (typeof window !== "undefined" && window !== null) {
@@ -924,7 +1099,7 @@ module.exports = function() {
return false;
};
-},{}],15:[function(require,module,exports){
+},{}],20:[function(require,module,exports){
(function(){
var crypt = require('crypt'),
utf8 = require('charenc').utf8,
@@ -1086,7 +1261,136 @@ module.exports = function() {
})();
-},{"charenc":11,"crypt":12,"is-buffer":13}],16:[function(require,module,exports){
+},{"charenc":13,"crypt":14,"is-buffer":18}],21:[function(require,module,exports){
+(function (process){
+// Generated by CoffeeScript 1.7.1
+(function() {
+ var getNanoSeconds, hrtime, loadTime;
+
+ if ((typeof performance !== "undefined" && performance !== null) && performance.now) {
+ module.exports = function() {
+ return performance.now();
+ };
+ } else if ((typeof process !== "undefined" && process !== null) && process.hrtime) {
+ module.exports = function() {
+ return (getNanoSeconds() - loadTime) / 1e6;
+ };
+ hrtime = process.hrtime;
+ getNanoSeconds = function() {
+ var hr;
+ hr = hrtime();
+ return hr[0] * 1e9 + hr[1];
+ };
+ loadTime = getNanoSeconds();
+ } else if (Date.now) {
+ module.exports = function() {
+ return Date.now() - loadTime;
+ };
+ loadTime = Date.now();
+ } else {
+ module.exports = function() {
+ return new Date().getTime() - loadTime;
+ };
+ loadTime = new Date().getTime();
+ }
+
+}).call(this);
+
+}).call(this,require('_process'))
+},{"_process":22}],22:[function(require,module,exports){
+// shim for using process in browser
+
+var process = module.exports = {};
+var queue = [];
+var draining = false;
+var currentQueue;
+var queueIndex = -1;
+
+function cleanUpNextTick() {
+ draining = false;
+ if (currentQueue.length) {
+ queue = currentQueue.concat(queue);
+ } else {
+ queueIndex = -1;
+ }
+ if (queue.length) {
+ drainQueue();
+ }
+}
+
+function drainQueue() {
+ if (draining) {
+ return;
+ }
+ var timeout = setTimeout(cleanUpNextTick);
+ draining = true;
+
+ var len = queue.length;
+ while(len) {
+ currentQueue = queue;
+ queue = [];
+ while (++queueIndex < len) {
+ if (currentQueue) {
+ currentQueue[queueIndex].run();
+ }
+ }
+ queueIndex = -1;
+ len = queue.length;
+ }
+ currentQueue = null;
+ draining = false;
+ clearTimeout(timeout);
+}
+
+process.nextTick = function (fun) {
+ var args = new Array(arguments.length - 1);
+ if (arguments.length > 1) {
+ for (var i = 1; i < arguments.length; i++) {
+ args[i - 1] = arguments[i];
+ }
+ }
+ queue.push(new Item(fun, args));
+ if (queue.length === 1 && !draining) {
+ setTimeout(drainQueue, 0);
+ }
+};
+
+// v8 likes predictible objects
+function Item(fun, array) {
+ this.fun = fun;
+ this.array = array;
+}
+Item.prototype.run = function () {
+ this.fun.apply(null, this.array);
+};
+process.title = 'browser';
+process.browser = true;
+process.env = {};
+process.argv = [];
+process.version = ''; // empty string to avoid regexp issues
+process.versions = {};
+
+function noop() {}
+
+process.on = noop;
+process.addListener = noop;
+process.once = noop;
+process.off = noop;
+process.removeListener = noop;
+process.removeAllListeners = noop;
+process.emit = noop;
+
+process.binding = function (name) {
+ throw new Error('process.binding is not supported');
+};
+
+process.cwd = function () { return '/' };
+process.chdir = function (dir) {
+ throw new Error('process.chdir is not supported');
+};
+process.umask = function() { return 0; };
+
+},{}],23:[function(require,module,exports){
// Copyright Joyent, Inc. and other Node contributors.
//
// Permission is hereby granted, free of charge, to any person obtaining a
@@ -1172,7 +1476,7 @@ var isArray = Array.isArray || function (xs) {
return Object.prototype.toString.call(xs) === '[object Array]';
};
-},{}],17:[function(require,module,exports){
+},{}],24:[function(require,module,exports){
// Copyright Joyent, Inc. and other Node contributors.
//
// Permission is hereby granted, free of charge, to any person obtaining a
@@ -1259,13 +1563,91 @@ var objectKeys = Object.keys || function (obj) {
return res;
};
-},{}],18:[function(require,module,exports){
+},{}],25:[function(require,module,exports){
'use strict';
exports.decode = exports.parse = require('./decode');
exports.encode = exports.stringify = require('./encode');
-},{"./decode":16,"./encode":17}],19:[function(require,module,exports){
+},{"./decode":23,"./encode":24}],26:[function(require,module,exports){
+(function (global){
+var now = require('performance-now')
+ , root = typeof window === 'undefined' ? global : window
+ , vendors = ['moz', 'webkit']
+ , suffix = 'AnimationFrame'
+ , raf = root['request' + suffix]
+ , caf = root['cancel' + suffix] || root['cancelRequest' + suffix]
+
+for(var i = 0; !raf && i < vendors.length; i++) {
+ raf = root[vendors[i] + 'Request' + suffix]
+ caf = root[vendors[i] + 'Cancel' + suffix]
+ || root[vendors[i] + 'CancelRequest' + suffix]
+}
+
+// Some versions of FF have rAF but not cAF
+if(!raf || !caf) {
+ var last = 0
+ , id = 0
+ , queue = []
+ , frameDuration = 1000 / 60
+
+ raf = function(callback) {
+ if(queue.length === 0) {
+ var _now = now()
+ , next = Math.max(0, frameDuration - (_now - last))
+ last = next + _now
+ setTimeout(function() {
+ var cp = queue.slice(0)
+ // Clear queue here to prevent
+ // callbacks from appending listeners
+ // to the current frame's queue
+ queue.length = 0
+ for(var i = 0; i < cp.length; i++) {
+ if(!cp[i].cancelled) {
+ try{
+ cp[i].callback(last)
+ } catch(e) {
+ setTimeout(function() { throw e }, 0)
+ }
+ }
+ }
+ }, Math.round(next))
+ }
+ queue.push({
+ handle: ++id,
+ callback: callback,
+ cancelled: false
+ })
+ return id
+ }
+
+ caf = function(handle) {
+ for(var i = 0; i < queue.length; i++) {
+ if(queue[i].handle === handle) {
+ queue[i].cancelled = true
+ }
+ }
+ }
+}
+
+module.exports = function(fn) {
+ // Wrap in a new function to prevent
+ // `cancel` potentially being assigned
+ // to the native rAF function
+ return raf.call(root, fn)
+}
+module.exports.cancel = function() {
+ caf.apply(root, arguments)
+}
+module.exports.polyfill = function() {
+ root.requestAnimationFrame = raf
+ root.cancelAnimationFrame = caf
+}
+
+}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
+},{"performance-now":21}],27:[function(require,module,exports){
+module.exports = require('react/lib/shallowCompare');
+},{"react/lib/shallowCompare":67}],28:[function(require,module,exports){
// Generated by CoffeeScript 1.10.0
var React, isRetina, md5, querystring;
@@ -1297,7 +1679,7 @@ module.exports = React.createClass({
};
},
render: function() {
- var base, hash, modernBrowser, query, retinaQuery, retinaSrc, src;
+ var base, className, hash, modernBrowser, query, retinaQuery, retinaSrc, src;
base = this.props.https ? "https://secure.gravatar.com/avatar/" : 'http://www.gravatar.com/avatar/';
query = querystring.stringify({
s: this.props.size,
@@ -1323,26 +1705,4790 @@ module.exports = React.createClass({
if (typeof window !== "undefined" && window !== null) {
modernBrowser = 'srcset' in document.createElement('img');
}
+ className = 'react-gravatar';
+ if (this.props.className) {
+ className = className + " " + this.props.className;
+ }
if (!modernBrowser && isRetina()) {
- return React.createElement("img", React.__spread({
+ return React.createElement("img", Object.assign({
"style": this.props.style,
- "className": "react-gravatar " + this.props.className,
"src": retinaSrc,
"height": this.props.size,
"width": this.props.size
- }, this.props));
+ }, this.props, {
+ "className": className
+ }));
} else {
- return React.createElement("img", React.__spread({
+ return React.createElement("img", Object.assign({
"style": this.props.style,
- "className": "react-gravatar " + this.props.className,
"src": src,
"srcSet": retinaSrc + " 2x",
"height": this.props.size,
"width": this.props.size
- }, this.props));
+ }, this.props, {
+ "className": className
+ }));
+ }
+ }
+});
+
+},{"is-retina":19,"md5":20,"querystring":25,"react":undefined}],29:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+
+var _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; };
+
+var _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; }; }();
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _reactSelect = require('react-select');
+
+var _reactSelect2 = _interopRequireDefault(_reactSelect);
+
+var _reactVirtualized = require('react-virtualized');
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _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; }
+
+function _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; }
+
+var VirtualizedSelect = function (_Component) {
+ _inherits(VirtualizedSelect, _Component);
+
+ function VirtualizedSelect(props, context) {
+ _classCallCheck(this, VirtualizedSelect);
+
+ var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(VirtualizedSelect).call(this, props, context));
+
+ _this._renderMenu = _this._renderMenu.bind(_this);
+ _this._optionRenderer = _this._optionRenderer.bind(_this);
+ return _this;
+ }
+
+ _createClass(VirtualizedSelect, [{
+ key: 'render',
+ value: function render() {
+ return _react2.default.createElement(_reactSelect2.default, _extends({}, this.props, {
+ menuRenderer: this._renderMenu,
+ menuStyle: { overflow: 'hidden' }
+ }));
+ }
+
+ // See https://github.com/JedWatson/react-select/#effeciently-rendering-large-lists-with-windowing
+
+ }, {
+ key: '_renderMenu',
+ value: function _renderMenu(_ref) {
+ var focusedOption = _ref.focusedOption;
+ var focusOption = _ref.focusOption;
+ var labelKey = _ref.labelKey;
+ var options = _ref.options;
+ var selectValue = _ref.selectValue;
+ var valueArray = _ref.valueArray;
+ var _props = this.props;
+ var maxHeight = _props.maxHeight;
+ var optionHeight = _props.optionHeight;
+ var optionRenderer = _props.optionRenderer;
+
+ var focusedOptionIndex = options.indexOf(focusedOption);
+ var height = Math.min(maxHeight, options.length * optionHeight);
+ var innerRowRenderer = optionRenderer || this._optionRenderer;
+
+ function wrappedRowRenderer(index) {
+ var option = options[index];
+
+ return innerRowRenderer({ focusedOption: focusedOption, focusedOptionIndex: focusedOptionIndex, focusOption: focusOption, labelKey: labelKey, option: option, options: options, selectValue: selectValue, valueArray: valueArray });
+ }
+
+ return _react2.default.createElement(
+ _reactVirtualized.AutoSizer,
+ { disableHeight: true },
+ function (_ref2) {
+ var width = _ref2.width;
+ return _react2.default.createElement(_reactVirtualized.VirtualScroll, {
+ className: 'VirtualSelectGrid',
+ height: height,
+ rowHeight: optionHeight,
+ rowRenderer: wrappedRowRenderer,
+ rowsCount: options.length,
+ scrollToIndex: focusedOptionIndex,
+ width: width
+ });
+ }
+ );
+ }
+ }, {
+ key: '_optionRenderer',
+ value: function _optionRenderer(_ref3) {
+ var focusedOption = _ref3.focusedOption;
+ var focusOption = _ref3.focusOption;
+ var labelKey = _ref3.labelKey;
+ var option = _ref3.option;
+ var selectValue = _ref3.selectValue;
+ var optionHeight = this.props.optionHeight;
+
+
+ var className = option === focusedOption ? 'VirtualizedSelectOption VirtualizedSelectFocusedOption' : 'VirtualizedSelectOption';
+
+ return _react2.default.createElement(
+ 'div',
+ {
+ className: className,
+ onClick: function onClick() {
+ return selectValue(option);
+ },
+ onMouseOver: function onMouseOver() {
+ return focusOption(option);
+ },
+ style: {
+ height: optionHeight
+ }
+ },
+ option[labelKey]
+ );
}
+ }]);
+
+ return VirtualizedSelect;
+}(_react.Component);
+
+VirtualizedSelect.propTypes = {
+ maxHeight: _react.PropTypes.number.isRequired,
+ optionHeight: _react.PropTypes.number.isRequired,
+ optionRenderer: _react.PropTypes.func
+};
+VirtualizedSelect.defaultProps = {
+ maxHeight: 200,
+ optionHeight: 35
+};
+exports.default = VirtualizedSelect;
+},{"react":undefined,"react-select":undefined,"react-virtualized":62}],30:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = undefined;
+
+var _VirtualizedSelect = require('./VirtualizedSelect');
+
+var _VirtualizedSelect2 = _interopRequireDefault(_VirtualizedSelect);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+exports.default = _VirtualizedSelect2.default;
+},{"./VirtualizedSelect":29}],31:[function(require,module,exports){
+arguments[4][30][0].apply(exports,arguments)
+},{"./VirtualizedSelect":30,"dup":30}],32:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+
+var _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; }; }();
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _reactAddonsShallowCompare = require('react-addons-shallow-compare');
+
+var _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _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; }
+
+function _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; }
+
+/**
+ * This HOC decorates a virtualized component and responds to arrow-key events by scrolling one row or column at a time.
+ */
+
+var ArrowKeyStepper = function (_Component) {
+ _inherits(ArrowKeyStepper, _Component);
+
+ function ArrowKeyStepper(props, context) {
+ _classCallCheck(this, ArrowKeyStepper);
+
+ var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(ArrowKeyStepper).call(this, props, context));
+
+ _this.state = {
+ scrollToColumn: 0,
+ scrollToRow: 0
+ };
+
+ _this._columnStartIndex = 0;
+ _this._columnStopIndex = 0;
+ _this._rowStartIndex = 0;
+ _this._rowStopIndex = 0;
+
+ _this._onKeyDown = _this._onKeyDown.bind(_this);
+ _this._onSectionRendered = _this._onSectionRendered.bind(_this);
+ return _this;
}
+
+ _createClass(ArrowKeyStepper, [{
+ key: 'render',
+ value: function render() {
+ var _props = this.props;
+ var className = _props.className;
+ var children = _props.children;
+ var _state = this.state;
+ var scrollToColumn = _state.scrollToColumn;
+ var scrollToRow = _state.scrollToRow;
+
+
+ return _react2.default.createElement(
+ 'div',
+ {
+ className: className,
+ onKeyDown: this._onKeyDown
+ },
+ children({
+ onSectionRendered: this._onSectionRendered,
+ scrollToColumn: scrollToColumn,
+ scrollToRow: scrollToRow
+ })
+ );
+ }
+ }, {
+ key: 'shouldComponentUpdate',
+ value: function shouldComponentUpdate(nextProps, nextState) {
+ return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);
+ }
+ }, {
+ key: '_onKeyDown',
+ value: function _onKeyDown(event) {
+ var _props2 = this.props;
+ var columnsCount = _props2.columnsCount;
+ var rowsCount = _props2.rowsCount;
+
+ // The above cases all prevent default event event behavior.
+ // This is to keep the grid from scrolling after the snap-to update.
+
+ switch (event.key) {
+ case 'ArrowDown':
+ event.preventDefault();
+ this.setState({
+ scrollToRow: Math.min(this._rowStopIndex + 1, rowsCount - 1)
+ });
+ break;
+ case 'ArrowLeft':
+ event.preventDefault();
+ this.setState({
+ scrollToColumn: Math.max(this._columnStartIndex - 1, 0)
+ });
+ break;
+ case 'ArrowRight':
+ event.preventDefault();
+ this.setState({
+ scrollToColumn: Math.min(this._columnStopIndex + 1, columnsCount - 1)
+ });
+ break;
+ case 'ArrowUp':
+ event.preventDefault();
+ this.setState({
+ scrollToRow: Math.max(this._rowStartIndex - 1, 0)
+ });
+ break;
+ }
+ }
+ }, {
+ key: '_onSectionRendered',
+ value: function _onSectionRendered(_ref) {
+ var columnStartIndex = _ref.columnStartIndex;
+ var columnStopIndex = _ref.columnStopIndex;
+ var rowStartIndex = _ref.rowStartIndex;
+ var rowStopIndex = _ref.rowStopIndex;
+
+ this._columnStartIndex = columnStartIndex;
+ this._columnStopIndex = columnStopIndex;
+ this._rowStartIndex = rowStartIndex;
+ this._rowStopIndex = rowStopIndex;
+ }
+ }]);
+
+ return ArrowKeyStepper;
+}(_react.Component);
+
+ArrowKeyStepper.propTypes = {
+ children: _react.PropTypes.func.isRequired,
+ className: _react.PropTypes.string,
+ columnsCount: _react.PropTypes.number.isRequired,
+ rowsCount: _react.PropTypes.number.isRequired
+};
+exports.default = ArrowKeyStepper;
+},{"react":undefined,"react-addons-shallow-compare":27}],33:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.ArrowKeyStepper = exports.default = undefined;
+
+var _ArrowKeyStepper2 = require('./ArrowKeyStepper');
+
+var _ArrowKeyStepper3 = _interopRequireDefault(_ArrowKeyStepper2);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+exports.default = _ArrowKeyStepper3.default;
+exports.ArrowKeyStepper = _ArrowKeyStepper3.default;
+},{"./ArrowKeyStepper":32}],34:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
});
-},{"is-retina":14,"md5":15,"querystring":18,"react":undefined}]},{},[1])
-//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","/Users/Jed/Development/packages/react-select/examples/src/app.js","/Users/Jed/Development/packages/react-select/examples/src/components/Contributors.js","/Users/Jed/Development/packages/react-select/examples/src/components/CustomComponents.js","/Users/Jed/Development/packages/react-select/examples/src/components/CustomRender.js","/Users/Jed/Development/packages/react-select/examples/src/components/Multiselect.js","/Users/Jed/Development/packages/react-select/examples/src/components/NumericSelect.js","/Users/Jed/Development/packages/react-select/examples/src/components/States.js","/Users/Jed/Development/packages/react-select/examples/src/data/contributors.js","/Users/Jed/Development/packages/react-select/examples/src/data/states.js","/Users/Jed/Development/packages/react-select/examples/src/data/users.js","node_modules/charenc/charenc.js","node_modules/crypt/crypt.js","node_modules/is-buffer/index.js","node_modules/is-retina/index.js","node_modules/md5/md5.js","node_modules/querystring-es3/decode.js","node_modules/querystring-es3/encode.js","node_modules/querystring-es3/index.js","node_modules/react-gravatar/dist/index.js"],"names":[],"mappings":"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AE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,EAC9B,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,EACjC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,gBAAgB,EAAE,EACxC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,EAClC,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,YAAY,EAAE,EACpC,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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;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;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;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrFA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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 Contributors from './components/Contributors';\nimport CustomComponents from './components/CustomComponents';\nimport CustomRender from './components/CustomRender';\nimport Multiselect from './components/Multiselect';\nimport NumericSelect from './components/NumericSelect';\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<Contributors label=\"Contributors (Async)\" />\n\t\t<NumericSelect label=\"Numeric Values\" />\n\t\t<CustomRender label=\"Custom Render Methods\"/>\n\t\t<CustomComponents label=\"Custom Placeholder, Option and Value Components\" />\n\t\t{/*\n\t\t<SelectedValuesField label=\"Option Creation (tags mode)\" options={FLAVOURS} allowCreate hint=\"Enter a value that's NOT in the list, then hit return\" />\n\t\t*/}\n\t</div>,\n\tdocument.getElementById('example')\n);\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';\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\tonUnfocus: 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\thandleMouseLeave (event) {\n\t\tthis.props.onUnfocus(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\tonMouseLeave={this.handleMouseLeave}\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\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\nmodule.exports = UsersField;\n","import React from 'react';\nimport Select from 'react-select';\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 <span style={{ color: option.color }}>{option.label} {option.link}</span>;\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\tplaceholder=\"Select your support level\"\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';\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 only</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 only</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","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","/**\n * Determine if an object is Buffer\n *\n * Author:   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * License:  MIT\n *\n * `npm install is-buffer`\n */\n\nmodule.exports = function (obj) {\n  return !!(obj != null &&\n    (obj._isBuffer || // For Safari 5-7 (missing Object.prototype.constructor)\n      (obj.constructor &&\n      typeof obj.constructor.isBuffer === 'function' &&\n      obj.constructor.isBuffer(obj))\n    ))\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","(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(typeof message == 'undefined')\r\n      return;\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","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n// If obj.hasOwnProperty has been overridden, then calling\n// obj.hasOwnProperty(prop) will break.\n// See: https://github.com/joyent/node/issues/1707\nfunction hasOwnProperty(obj, prop) {\n  return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nmodule.exports = function(qs, sep, eq, options) {\n  sep = sep || '&';\n  eq = eq || '=';\n  var obj = {};\n\n  if (typeof qs !== 'string' || qs.length === 0) {\n    return obj;\n  }\n\n  var regexp = /\\+/g;\n  qs = qs.split(sep);\n\n  var maxKeys = 1000;\n  if (options && typeof options.maxKeys === 'number') {\n    maxKeys = options.maxKeys;\n  }\n\n  var len = qs.length;\n  // maxKeys <= 0 means that we should not limit keys count\n  if (maxKeys > 0 && len > maxKeys) {\n    len = maxKeys;\n  }\n\n  for (var i = 0; i < len; ++i) {\n    var x = qs[i].replace(regexp, '%20'),\n        idx = x.indexOf(eq),\n        kstr, vstr, k, v;\n\n    if (idx >= 0) {\n      kstr = x.substr(0, idx);\n      vstr = x.substr(idx + 1);\n    } else {\n      kstr = x;\n      vstr = '';\n    }\n\n    k = decodeURIComponent(kstr);\n    v = decodeURIComponent(vstr);\n\n    if (!hasOwnProperty(obj, k)) {\n      obj[k] = v;\n    } else if (isArray(obj[k])) {\n      obj[k].push(v);\n    } else {\n      obj[k] = [obj[k], v];\n    }\n  }\n\n  return obj;\n};\n\nvar isArray = Array.isArray || function (xs) {\n  return Object.prototype.toString.call(xs) === '[object Array]';\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar stringifyPrimitive = function(v) {\n  switch (typeof v) {\n    case 'string':\n      return v;\n\n    case 'boolean':\n      return v ? 'true' : 'false';\n\n    case 'number':\n      return isFinite(v) ? v : '';\n\n    default:\n      return '';\n  }\n};\n\nmodule.exports = function(obj, sep, eq, name) {\n  sep = sep || '&';\n  eq = eq || '=';\n  if (obj === null) {\n    obj = undefined;\n  }\n\n  if (typeof obj === 'object') {\n    return map(objectKeys(obj), function(k) {\n      var ks = encodeURIComponent(stringifyPrimitive(k)) + eq;\n      if (isArray(obj[k])) {\n        return map(obj[k], function(v) {\n          return ks + encodeURIComponent(stringifyPrimitive(v));\n        }).join(sep);\n      } else {\n        return ks + encodeURIComponent(stringifyPrimitive(obj[k]));\n      }\n    }).join(sep);\n\n  }\n\n  if (!name) return '';\n  return encodeURIComponent(stringifyPrimitive(name)) + eq +\n         encodeURIComponent(stringifyPrimitive(obj));\n};\n\nvar isArray = Array.isArray || function (xs) {\n  return Object.prototype.toString.call(xs) === '[object Array]';\n};\n\nfunction map (xs, f) {\n  if (xs.map) return xs.map(f);\n  var res = [];\n  for (var i = 0; i < xs.length; i++) {\n    res.push(f(xs[i], i));\n  }\n  return res;\n}\n\nvar objectKeys = Object.keys || function (obj) {\n  var res = [];\n  for (var key in obj) {\n    if (Object.prototype.hasOwnProperty.call(obj, key)) res.push(key);\n  }\n  return res;\n};\n","'use strict';\n\nexports.decode = exports.parse = require('./decode');\nexports.encode = exports.stringify = require('./encode');\n","// Generated by CoffeeScript 1.10.0\nvar React, isRetina, md5, querystring;\n\nReact = require('react');\n\nmd5 = require('md5');\n\nquerystring = require('querystring');\n\nisRetina = require('is-retina');\n\nmodule.exports = React.createClass({\n  displayName: 'Gravatar',\n  propTypes: {\n    email: React.PropTypes.string,\n    md5: React.PropTypes.string,\n    size: React.PropTypes.number,\n    rating: React.PropTypes.string,\n    https: React.PropTypes.bool,\n    \"default\": React.PropTypes.string,\n    className: React.PropTypes.string\n  },\n  getDefaultProps: function() {\n    return {\n      size: 50,\n      rating: 'g',\n      https: false,\n      \"default\": \"retro\"\n    };\n  },\n  render: function() {\n    var base, hash, modernBrowser, query, retinaQuery, retinaSrc, src;\n    base = this.props.https ? \"https://secure.gravatar.com/avatar/\" : 'http://www.gravatar.com/avatar/';\n    query = querystring.stringify({\n      s: this.props.size,\n      r: this.props.rating,\n      d: this.props[\"default\"]\n    });\n    retinaQuery = querystring.stringify({\n      s: this.props.size * 2,\n      r: this.props.rating,\n      d: this.props[\"default\"]\n    });\n    if (this.props.md5) {\n      hash = this.props.md5;\n    } else if (this.props.email) {\n      hash = md5(this.props.email);\n    } else {\n      console.warn('Gravatar image can not be fetched. Either the \"email\" or \"md5\" prop must be specified.');\n      return React.createElement(\"script\", null);\n    }\n    src = base + hash + \"?\" + query;\n    retinaSrc = base + hash + \"?\" + retinaQuery;\n    modernBrowser = true;\n    if (typeof window !== \"undefined\" && window !== null) {\n      modernBrowser = 'srcset' in document.createElement('img');\n    }\n    if (!modernBrowser && isRetina()) {\n      return React.createElement(\"img\", React.__spread({\n        \"style\": this.props.style,\n        \"className\": \"react-gravatar \" + this.props.className,\n        \"src\": retinaSrc,\n        \"height\": this.props.size,\n        \"width\": this.props.size\n      }, this.props));\n    } else {\n      return React.createElement(\"img\", React.__spread({\n        \"style\": this.props.style,\n        \"className\": \"react-gravatar \" + this.props.className,\n        \"src\": src,\n        \"srcSet\": retinaSrc + \" 2x\",\n        \"height\": this.props.size,\n        \"width\": this.props.size\n      }, this.props));\n    }\n  }\n});\n"]}
+var _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; }; }();
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _reactAddonsShallowCompare = require('react-addons-shallow-compare');
+
+var _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _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; }
+
+function _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; }
+
+/**
+ * Decorator component that automatically adjusts the width and height of a single child.
+ * Child component should not be declared as a child but should rather be specified by a `ChildComponent` property.
+ * All other properties will be passed through to the child component.
+ */
+
+var AutoSizer = function (_Component) {
+ _inherits(AutoSizer, _Component);
+
+ function AutoSizer(props) {
+ _classCallCheck(this, AutoSizer);
+
+ var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(AutoSizer).call(this, props));
+
+ _this.state = {
+ height: 0,
+ width: 0
+ };
+
+ _this._onResize = _this._onResize.bind(_this);
+ _this._onScroll = _this._onScroll.bind(_this);
+ _this._setRef = _this._setRef.bind(_this);
+ return _this;
+ }
+
+ _createClass(AutoSizer, [{
+ key: 'componentDidMount',
+ value: function componentDidMount() {
+ // Defer requiring resize handler in order to support server-side rendering.
+ // See issue #41
+ this._detectElementResize = require('../vendor/detectElementResize');
+ this._detectElementResize.addResizeListener(this._parentNode, this._onResize);
+
+ this._onResize();
+ }
+ }, {
+ key: 'componentWillUnmount',
+ value: function componentWillUnmount() {
+ if (this._detectElementResize) {
+ this._detectElementResize.removeResizeListener(this._parentNode, this._onResize);
+ }
+ }
+ }, {
+ key: 'render',
+ value: function render() {
+ var _props = this.props;
+ var children = _props.children;
+ var disableHeight = _props.disableHeight;
+ var disableWidth = _props.disableWidth;
+ var _state = this.state;
+ var height = _state.height;
+ var width = _state.width;
+
+ // Outer div should not force width/height since that may prevent containers from shrinking.
+ // Inner component should overflow and use calculated width/height.
+ // See issue #68 for more information.
+
+ var outerStyle = { overflow: 'visible' };
+
+ if (!disableHeight) {
+ outerStyle.height = 0;
+ }
+
+ if (!disableWidth) {
+ outerStyle.width = 0;
+ }
+
+ return _react2.default.createElement(
+ 'div',
+ {
+ ref: this._setRef,
+ onScroll: this._onScroll,
+ style: outerStyle
+ },
+ children({ height: height, width: width })
+ );
+ }
+ }, {
+ key: 'shouldComponentUpdate',
+ value: function shouldComponentUpdate(nextProps, nextState) {
+ return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);
+ }
+ }, {
+ key: '_onResize',
+ value: function _onResize() {
+ var onResize = this.props.onResize;
+
+ var _parentNode$getBoundi = this._parentNode.getBoundingClientRect();
+
+ var height = _parentNode$getBoundi.height;
+ var width = _parentNode$getBoundi.width;
+
+
+ var style = getComputedStyle(this._parentNode);
+ var paddingLeft = parseInt(style.paddingLeft, 10);
+ var paddingRight = parseInt(style.paddingRight, 10);
+ var paddingTop = parseInt(style.paddingTop, 10);
+ var paddingBottom = parseInt(style.paddingBottom, 10);
+
+ this.setState({
+ height: height - paddingTop - paddingBottom,
+ width: width - paddingLeft - paddingRight
+ });
+
+ onResize({ height: height, width: width });
+ }
+ }, {
+ key: '_onScroll',
+ value: function _onScroll(event) {
+ // Prevent detectElementResize library from being triggered by this scroll event.
+ event.stopPropagation();
+ }
+ }, {
+ key: '_setRef',
+ value: function _setRef(autoSizer) {
+ // In case the component has been unmounted
+ this._parentNode = autoSizer && autoSizer.parentNode;
+ }
+ }]);
+
+ return AutoSizer;
+}(_react.Component);
+
+AutoSizer.propTypes = {
+ /**
+ * Function respondible for rendering children.
+ * This function should implement the following signature:
+ * ({ height, width }) => PropTypes.element
+ */
+ children: _react.PropTypes.func.isRequired,
+
+ /** Disable dynamic :height property */
+ disableHeight: _react.PropTypes.bool,
+
+ /** Disable dynamic :width property */
+ disableWidth: _react.PropTypes.bool,
+
+ /** Callback to be invoked on-resize: ({ height, width }) */
+ onResize: _react.PropTypes.func.isRequired
+};
+AutoSizer.defaultProps = {
+ onResize: function onResize() {}
+};
+exports.default = AutoSizer;
+},{"../vendor/detectElementResize":66,"react":undefined,"react-addons-shallow-compare":27}],35:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.AutoSizer = exports.default = undefined;
+
+var _AutoSizer2 = require('./AutoSizer');
+
+var _AutoSizer3 = _interopRequireDefault(_AutoSizer2);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+exports.default = _AutoSizer3.default;
+exports.AutoSizer = _AutoSizer3.default;
+},{"./AutoSizer":34}],36:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+
+var _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; };
+
+var _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; }; }();
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _CollectionView = require('./CollectionView');
+
+var _CollectionView2 = _interopRequireDefault(_CollectionView);
+
+var _calculateSizeAndPositionData2 = require('./utils/calculateSizeAndPositionData');
+
+var _calculateSizeAndPositionData3 = _interopRequireDefault(_calculateSizeAndPositionData2);
+
+var _getUpdatedOffsetForIndex = require('../utils/getUpdatedOffsetForIndex');
+
+var _getUpdatedOffsetForIndex2 = _interopRequireDefault(_getUpdatedOffsetForIndex);
+
+var _reactAddonsShallowCompare = require('react-addons-shallow-compare');
+
+var _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _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; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _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; }
+
+function _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; }
+
+/**
+ * Renders scattered or non-linear data.
+ * Unlike Grid, which renders checkerboard data, Collection can render arbitrarily positioned- even overlapping- data.
+ */
+
+var Collection = function (_Component) {
+ _inherits(Collection, _Component);
+
+ function Collection(props, context) {
+ _classCallCheck(this, Collection);
+
+ var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(Collection).call(this, props, context));
+
+ _this._cellMetadata = [];
+ _this._lastRenderedCellIndices = [];
+ return _this;
+ }
+
+ /** React lifecycle methods */
+
+ _createClass(Collection, [{
+ key: 'render',
+ value: function render() {
+ var props = _objectWithoutProperties(this.props, []);
+
+ return _react2.default.createElement(_CollectionView2.default, _extends({
+ cellLayoutManager: this,
+ ref: 'CollectionView'
+ }, props));
+ }
+ }, {
+ key: 'shouldComponentUpdate',
+ value: function shouldComponentUpdate(nextProps, nextState) {
+ return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);
+ }
+
+ /** CellLayoutManager interface */
+
+ }, {
+ key: 'calculateSizeAndPositionData',
+ value: function calculateSizeAndPositionData() {
+ var _props = this.props;
+ var cellCount = _props.cellCount;
+ var cellSizeAndPositionGetter = _props.cellSizeAndPositionGetter;
+ var sectionSize = _props.sectionSize;
+
+
+ var data = (0, _calculateSizeAndPositionData3.default)({
+ cellCount: cellCount,
+ cellSizeAndPositionGetter: cellSizeAndPositionGetter,
+ sectionSize: sectionSize
+ });
+
+ this._cellMetadata = data.cellMetadata;
+ this._sectionManager = data.sectionManager;
+ this._height = data.height;
+ this._width = data.width;
+ }
+
+ /**
+ * Returns the most recently rendered set of cell indices.
+ */
+
+ }, {
+ key: 'getLastRenderedIndices',
+ value: function getLastRenderedIndices() {
+ return this._lastRenderedCellIndices;
+ }
+
+ /**
+ * Calculates the minimum amount of change from the current scroll position to ensure the specified cell is (fully) visible.
+ */
+
+ }, {
+ key: 'getScrollPositionForCell',
+ value: function getScrollPositionForCell(_ref) {
+ var cellIndex = _ref.cellIndex;
+ var height = _ref.height;
+ var scrollLeft = _ref.scrollLeft;
+ var scrollTop = _ref.scrollTop;
+ var width = _ref.width;
+ var cellCount = this.props.cellCount;
+
+
+ if (cellIndex >= 0 && cellIndex < cellCount) {
+ var cellMetadata = this._cellMetadata[cellIndex];
+
+ scrollLeft = (0, _getUpdatedOffsetForIndex2.default)({
+ cellOffset: cellMetadata.x,
+ cellSize: cellMetadata.width,
+ containerSize: width,
+ currentOffset: scrollLeft,
+ targetIndex: cellIndex
+ });
+
+ scrollTop = (0, _getUpdatedOffsetForIndex2.default)({
+ cellOffset: cellMetadata.y,
+ cellSize: cellMetadata.height,
+ containerSize: height,
+ currentOffset: scrollTop,
+ targetIndex: cellIndex
+ });
+ }
+
+ return {
+ scrollLeft: scrollLeft,
+ scrollTop: scrollTop
+ };
+ }
+ }, {
+ key: 'getTotalSize',
+ value: function getTotalSize() {
+ return {
+ height: this._height,
+ width: this._width
+ };
+ }
+ }, {
+ key: 'renderCells',
+ value: function renderCells(_ref2) {
+ var _this2 = this;
+
+ var height = _ref2.height;
+ var isScrolling = _ref2.isScrolling;
+ var width = _ref2.width;
+ var x = _ref2.x;
+ var y = _ref2.y;
+ var _props2 = this.props;
+ var cellGroupRenderer = _props2.cellGroupRenderer;
+ var cellRenderer = _props2.cellRenderer;
+
+ // Store for later calls to getLastRenderedIndices()
+
+ this._lastRenderedCellIndices = this._sectionManager.getCellIndices({
+ height: height,
+ width: width,
+ x: x,
+ y: y
+ });
+
+ return cellGroupRenderer({
+ cellRenderer: cellRenderer,
+ cellSizeAndPositionGetter: function cellSizeAndPositionGetter(index) {
+ return _this2._sectionManager.getCellMetadata(index);
+ },
+ indices: this._lastRenderedCellIndices
+ });
+ }
+ }]);
+
+ return Collection;
+}(_react.Component);
+
+Collection.propTypes = {
+ 'aria-label': _react.PropTypes.string,
+
+ /**
+ * Number of cells in Collection.
+ */
+ cellCount: _react.PropTypes.number.isRequired,
+
+ /**
+ * Responsible for rendering a group of cells given their indices.
+ * Should implement the following interface: ({
+ * cellSizeAndPositionGetter:Function,
+ * indices: Array,
+ * cellRenderer: Function
+ * }): Array
+ */
+ cellGroupRenderer: _react.PropTypes.func.isRequired,
+
+ /**
+ * Responsible for rendering a cell given an row and column index.
+ * Should implement the following interface: (index: number): PropTypes.node
+ */
+ cellRenderer: _react.PropTypes.func.isRequired,
+
+ /**
+ * Callback responsible for returning size and offset/position information for a given cell (index).
+ * (index): { height: number, width: number, x: number, y: number }
+ */
+ cellSizeAndPositionGetter: _react.PropTypes.func.isRequired,
+
+ /**
+ * Optionally override the size of the sections a Collection's cells are split into.
+ */
+ sectionSize: _react.PropTypes.number
+};
+Collection.defaultProps = {
+ 'aria-label': 'grid',
+ cellGroupRenderer: defaultCellGroupRenderer
+};
+exports.default = Collection;
+
+
+function defaultCellGroupRenderer(_ref3) {
+ var cellRenderer = _ref3.cellRenderer;
+ var cellSizeAndPositionGetter = _ref3.cellSizeAndPositionGetter;
+ var indices = _ref3.indices;
+
+ return indices.map(function (index) {
+ var cellMetadata = cellSizeAndPositionGetter(index);
+ var renderedCell = cellRenderer(index);
+
+ if (renderedCell == null || renderedCell === false) {
+ return null;
+ }
+
+ return _react2.default.createElement(
+ 'div',
+ {
+ className: 'Collection__cell',
+ key: index,
+ style: {
+ height: cellMetadata.height,
+ left: cellMetadata.x,
+ top: cellMetadata.y,
+ width: cellMetadata.width
+ }
+ },
+ renderedCell
+ );
+ }).filter(function (renderedCell) {
+ return !!renderedCell;
+ });
+}
+},{"../utils/getUpdatedOffsetForIndex":64,"./CollectionView":37,"./utils/calculateSizeAndPositionData":41,"react":undefined,"react-addons-shallow-compare":27}],37:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+
+var _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; }; }();
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _classnames = require('classnames');
+
+var _classnames2 = _interopRequireDefault(_classnames);
+
+var _createCallbackMemoizer = require('../utils/createCallbackMemoizer');
+
+var _createCallbackMemoizer2 = _interopRequireDefault(_createCallbackMemoizer);
+
+var _scrollbarSize = require('dom-helpers/util/scrollbarSize');
+
+var _scrollbarSize2 = _interopRequireDefault(_scrollbarSize);
+
+var _raf = require('raf');
+
+var _raf2 = _interopRequireDefault(_raf);
+
+var _reactAddonsShallowCompare = require('react-addons-shallow-compare');
+
+var _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _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; }
+
+function _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; }
+
+// @TODO It would be nice to refactor Grid to use this code as well.
+
+/**
+ * Specifies the number of miliseconds during which to disable pointer events while a scroll is in progress.
+ * This improves performance and makes scrolling smoother.
+ */
+var IS_SCROLLING_TIMEOUT = 150;
+
+/**
+ * Controls whether the Grid updates the DOM element's scrollLeft/scrollTop based on the current state or just observes it.
+ * This prevents Grid from interrupting mouse-wheel animations (see issue #2).
+ */
+var SCROLL_POSITION_CHANGE_REASONS = {
+ OBSERVED: 'observed',
+ REQUESTED: 'requested'
+};
+
+/**
+ * Monitors changes in properties (eg. cellCount) and state (eg. scroll offsets) to determine when rendering needs to occur.
+ * This component does not render any visible content itself; it defers to the specified :cellLayoutManager.
+ */
+
+var CollectionView = function (_Component) {
+ _inherits(CollectionView, _Component);
+
+ function CollectionView(props, context) {
+ _classCallCheck(this, CollectionView);
+
+ var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(CollectionView).call(this, props, context));
+
+ _this.state = {
+ calculateSizeAndPositionDataOnNextUpdate: false,
+ isScrolling: false,
+ scrollLeft: 0,
+ scrollTop: 0
+ };
+
+ // Invokes callbacks only when their values have changed.
+ _this._onSectionRenderedMemoizer = (0, _createCallbackMemoizer2.default)();
+ _this._onScrollMemoizer = (0, _createCallbackMemoizer2.default)(false);
+
+ // Bind functions to instance so they don't lose context when passed around.
+ _this._invokeOnSectionRenderedHelper = _this._invokeOnSectionRenderedHelper.bind(_this);
+ _this._onScroll = _this._onScroll.bind(_this);
+ _this._updateScrollPositionForScrollToCell = _this._updateScrollPositionForScrollToCell.bind(_this);
+ return _this;
+ }
+
+ /**
+ * Forced recompute of cell sizes and positions.
+ * This function should be called if cell sizes have changed but nothing else has.
+ * Since cell positions are calculated by callbacks, the collection view has no way of detecting when the underlying data has changed.
+ */
+
+
+ _createClass(CollectionView, [{
+ key: 'recomputeCellSizesAndPositions',
+ value: function recomputeCellSizesAndPositions() {
+ this.setState({
+ calculateSizeAndPositionDataOnNextUpdate: true
+ });
+ }
+
+ /* ---------------------------- Component lifecycle methods ---------------------------- */
+
+ }, {
+ key: 'componentDidMount',
+ value: function componentDidMount() {
+ var _props = this.props;
+ var cellLayoutManager = _props.cellLayoutManager;
+ var scrollLeft = _props.scrollLeft;
+ var scrollToCell = _props.scrollToCell;
+ var scrollTop = _props.scrollTop;
+
+
+ this._scrollbarSize = (0, _scrollbarSize2.default)();
+
+ // Update onSectionRendered callback.
+ this._invokeOnSectionRenderedHelper();
+
+ var _cellLayoutManager$ge = cellLayoutManager.getTotalSize();
+
+ var totalHeight = _cellLayoutManager$ge.height;
+ var totalWidth = _cellLayoutManager$ge.width;
+
+
+ if (scrollToCell >= 0) {
+ this._updateScrollPositionForScrollToCell();
+ }
+
+ // Initialize onScroll callback.
+ this._invokeOnScrollMemoizer({
+ scrollLeft: scrollLeft || 0,
+ scrollTop: scrollTop || 0,
+ totalHeight: totalHeight,
+ totalWidth: totalWidth
+ });
+ }
+ }, {
+ key: 'componentDidUpdate',
+ value: function componentDidUpdate(prevProps, prevState) {
+ var _props2 = this.props;
+ var height = _props2.height;
+ var scrollToCell = _props2.scrollToCell;
+ var width = _props2.width;
+ var _state = this.state;
+ var scrollLeft = _state.scrollLeft;
+ var scrollPositionChangeReason = _state.scrollPositionChangeReason;
+ var scrollTop = _state.scrollTop;
+
+ // Make sure requested changes to :scrollLeft or :scrollTop get applied.
+ // Assigning to scrollLeft/scrollTop tells the browser to interrupt any running scroll animations,
+ // 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).
+ // So we only set these when we require an adjustment of the scroll position.
+ // See issue #2 for more information.
+
+ if (scrollPositionChangeReason === SCROLL_POSITION_CHANGE_REASONS.REQUESTED) {
+ if (scrollLeft >= 0 && scrollLeft !== prevState.scrollLeft && scrollLeft !== this.refs.scrollingContainer.scrollLeft) {
+ this.refs.scrollingContainer.scrollLeft = scrollLeft;
+ }
+ if (scrollTop >= 0 && scrollTop !== prevState.scrollTop && scrollTop !== this.refs.scrollingContainer.scrollTop) {
+ this.refs.scrollingContainer.scrollTop = scrollTop;
+ }
+ }
+
+ // Update scroll offsets if the current :scrollToCell values requires it
+ if (height !== prevProps.height || scrollToCell !== prevProps.scrollToCell || width !== prevProps.width) {
+ this._updateScrollPositionForScrollToCell();
+ }
+
+ // Update onRowsRendered callback if start/stop indices have changed
+ this._invokeOnSectionRenderedHelper();
+ }
+ }, {
+ key: 'componentWillMount',
+ value: function componentWillMount() {
+ var _props3 = this.props;
+ var cellLayoutManager = _props3.cellLayoutManager;
+ var scrollLeft = _props3.scrollLeft;
+ var scrollTop = _props3.scrollTop;
+
+
+ cellLayoutManager.calculateSizeAndPositionData();
+
+ if (scrollLeft >= 0 || scrollTop >= 0) {
+ this._setScrollPosition({ scrollLeft: scrollLeft, scrollTop: scrollTop });
+ }
+ }
+ }, {
+ key: 'componentWillUnmount',
+ value: function componentWillUnmount() {
+ if (this._disablePointerEventsTimeoutId) {
+ clearTimeout(this._disablePointerEventsTimeoutId);
+ }
+
+ if (this._setNextStateAnimationFrameId) {
+ _raf2.default.cancel(this._setNextStateAnimationFrameId);
+ }
+ }
+
+ /**
+ * @private
+ * This method updates scrollLeft/scrollTop in state for the following conditions:
+ * 1) Empty content (0 rows or columns)
+ * 2) New scroll props overriding the current state
+ * 3) Cells-count or cells-size has changed, making previous scroll offsets invalid
+ */
+
+ }, {
+ key: 'componentWillUpdate',
+ value: function componentWillUpdate(nextProps, nextState) {
+ if (nextProps.cellCount === 0 && (nextState.scrollLeft !== 0 || nextState.scrollTop !== 0)) {
+ this._setScrollPosition({
+ scrollLeft: 0,
+ scrollTop: 0
+ });
+ } else if (nextProps.scrollLeft !== this.props.scrollLeft || nextProps.scrollTop !== this.props.scrollTop) {
+ this._setScrollPosition({
+ scrollLeft: nextProps.scrollLeft,
+ scrollTop: nextProps.scrollTop
+ });
+ }
+
+ if (nextProps.cellCount !== this.props.cellCount || nextProps.cellLayoutManager !== this.props.cellLayoutManager || nextState.calculateSizeAndPositionDataOnNextUpdate) {
+ nextProps.cellLayoutManager.calculateSizeAndPositionData();
+ }
+
+ if (nextState.calculateSizeAndPositionDataOnNextUpdate) {
+ this.setState({
+ calculateSizeAndPositionDataOnNextUpdate: false
+ });
+ }
+ }
+ }, {
+ key: 'render',
+ value: function render() {
+ var _props4 = this.props;
+ var cellLayoutManager = _props4.cellLayoutManager;
+ var className = _props4.className;
+ var height = _props4.height;
+ var noContentRenderer = _props4.noContentRenderer;
+ var width = _props4.width;
+ var _state2 = this.state;
+ var isScrolling = _state2.isScrolling;
+ var scrollLeft = _state2.scrollLeft;
+ var scrollTop = _state2.scrollTop;
+
+
+ var childrenToDisplay = height > 0 && width > 0 ? cellLayoutManager.renderCells({
+ height: height,
+ isScrolling: isScrolling,
+ width: width,
+ x: scrollLeft,
+ y: scrollTop
+ }) : [];
+
+ var _cellLayoutManager$ge2 = cellLayoutManager.getTotalSize();
+
+ var totalHeight = _cellLayoutManager$ge2.height;
+ var totalWidth = _cellLayoutManager$ge2.width;
+
+
+ var gridStyle = {
+ height: height,
+ width: width
+ };
+
+ // Force browser to hide scrollbars when we know they aren't necessary.
+ // Otherwise once scrollbars appear they may not disappear again.
+ // For more info see issue #116
+ if (totalHeight <= height) {
+ gridStyle.overflowY = 'hidden';
+ }
+ if (totalWidth <= width) {
+ gridStyle.overflowX = 'hidden';
+ }
+
+ return _react2.default.createElement(
+ 'div',
+ {
+ ref: 'scrollingContainer',
+ 'aria-label': this.props['aria-label'],
+ className: (0, _classnames2.default)('Collection', className),
+ onScroll: this._onScroll,
+ role: 'grid',
+ style: gridStyle,
+ tabIndex: 0
+ },
+ childrenToDisplay.length > 0 && _react2.default.createElement(
+ 'div',
+ {
+ className: 'Collection__innerScrollContainer',
+ style: {
+ height: totalHeight,
+ maxHeight: totalHeight,
+ maxWidth: totalWidth,
+ pointerEvents: isScrolling ? 'none' : 'auto',
+ width: totalWidth
+ }
+ },
+ childrenToDisplay
+ ),
+ childrenToDisplay.length === 0 && noContentRenderer()
+ );
+ }
+ }, {
+ key: 'shouldComponentUpdate',
+ value: function shouldComponentUpdate(nextProps, nextState) {
+ return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);
+ }
+
+ /* ---------------------------- Helper methods ---------------------------- */
+
+ /**
+ * Sets an :isScrolling flag for a small window of time.
+ * This flag is used to disable pointer events on the scrollable portion of the Collection.
+ * This prevents jerky/stuttery mouse-wheel scrolling.
+ */
+
+ }, {
+ key: '_enablePointerEventsAfterDelay',
+ value: function _enablePointerEventsAfterDelay() {
+ var _this2 = this;
+
+ if (this._disablePointerEventsTimeoutId) {
+ clearTimeout(this._disablePointerEventsTimeoutId);
+ }
+
+ this._disablePointerEventsTimeoutId = setTimeout(function () {
+ _this2._disablePointerEventsTimeoutId = null;
+ _this2.setState({
+ isScrolling: false
+ });
+ }, IS_SCROLLING_TIMEOUT);
+ }
+ }, {
+ key: '_invokeOnSectionRenderedHelper',
+ value: function _invokeOnSectionRenderedHelper() {
+ var _props5 = this.props;
+ var cellLayoutManager = _props5.cellLayoutManager;
+ var onSectionRendered = _props5.onSectionRendered;
+
+
+ this._onSectionRenderedMemoizer({
+ callback: onSectionRendered,
+ indices: cellLayoutManager.getLastRenderedIndices()
+ });
+ }
+ }, {
+ key: '_invokeOnScrollMemoizer',
+ value: function _invokeOnScrollMemoizer(_ref) {
+ var _this3 = this;
+
+ var scrollLeft = _ref.scrollLeft;
+ var scrollTop = _ref.scrollTop;
+ var totalHeight = _ref.totalHeight;
+ var totalWidth = _ref.totalWidth;
+
+ this._onScrollMemoizer({
+ callback: function callback(_ref2) {
+ var scrollLeft = _ref2.scrollLeft;
+ var scrollTop = _ref2.scrollTop;
+ var _props6 = _this3.props;
+ var height = _props6.height;
+ var onScroll = _props6.onScroll;
+ var width = _props6.width;
+
+
+ onScroll({
+ clientHeight: height,
+ clientWidth: width,
+ scrollHeight: totalHeight,
+ scrollLeft: scrollLeft,
+ scrollTop: scrollTop,
+ scrollWidth: totalWidth
+ });
+ },
+ indices: {
+ scrollLeft: scrollLeft,
+ scrollTop: scrollTop
+ }
+ });
+ }
+
+ /**
+ * Updates the state during the next animation frame.
+ * Use this method to avoid multiple renders in a small span of time.
+ * This helps performance for bursty events (like onScroll).
+ */
+
+ }, {
+ key: '_setNextState',
+ value: function _setNextState(state) {
+ var _this4 = this;
+
+ if (this._setNextStateAnimationFrameId) {
+ _raf2.default.cancel(this._setNextStateAnimationFrameId);
+ }
+
+ this._setNextStateAnimationFrameId = (0, _raf2.default)(function () {
+ _this4._setNextStateAnimationFrameId = null;
+ _this4.setState(state);
+ });
+ }
+ }, {
+ key: '_setScrollPosition',
+ value: function _setScrollPosition(_ref3) {
+ var scrollLeft = _ref3.scrollLeft;
+ var scrollTop = _ref3.scrollTop;
+
+ var newState = {
+ scrollPositionChangeReason: SCROLL_POSITION_CHANGE_REASONS.REQUESTED
+ };
+
+ if (scrollLeft >= 0) {
+ newState.scrollLeft = scrollLeft;
+ }
+
+ if (scrollTop >= 0) {
+ newState.scrollTop = scrollTop;
+ }
+
+ if (scrollLeft >= 0 && scrollLeft !== this.state.scrollLeft || scrollTop >= 0 && scrollTop !== this.state.scrollTop) {
+ this.setState(newState);
+ }
+ }
+ }, {
+ key: '_updateScrollPositionForScrollToCell',
+ value: function _updateScrollPositionForScrollToCell() {
+ var _props7 = this.props;
+ var cellLayoutManager = _props7.cellLayoutManager;
+ var height = _props7.height;
+ var scrollToCell = _props7.scrollToCell;
+ var width = _props7.width;
+ var _state3 = this.state;
+ var scrollLeft = _state3.scrollLeft;
+ var scrollTop = _state3.scrollTop;
+
+
+ if (scrollToCell >= 0) {
+ var scrollPosition = cellLayoutManager.getScrollPositionForCell({
+ cellIndex: scrollToCell,
+ height: height,
+ scrollLeft: scrollLeft,
+ scrollTop: scrollTop,
+ width: width
+ });
+
+ if (scrollPosition.scrollLeft !== scrollLeft || scrollPosition.scrollTop !== scrollTop) {
+ this._setScrollPosition(scrollPosition);
+ }
+ }
+ }
+ }, {
+ key: '_onScroll',
+ value: function _onScroll(event) {
+ // In certain edge-cases React dispatches an onScroll event with an invalid target.scrollLeft / target.scrollTop.
+ // This invalid event can be detected by comparing event.target to this component's scrollable DOM element.
+ // See issue #404 for more information.
+ if (event.target !== this.refs.scrollingContainer) {
+ return;
+ }
+
+ // Prevent pointer events from interrupting a smooth scroll
+ this._enablePointerEventsAfterDelay();
+
+ // When this component is shrunk drastically, React dispatches a series of back-to-back scroll events,
+ // Gradually converging on a scrollTop that is within the bounds of the new, smaller height.
+ // This causes a series of rapid renders that is slow for long lists.
+ // We can avoid that by doing some simple bounds checking to ensure that scrollTop never exceeds the total height.
+ var _props8 = this.props;
+ var cellLayoutManager = _props8.cellLayoutManager;
+ var height = _props8.height;
+ var width = _props8.width;
+
+ var scrollbarSize = this._scrollbarSize;
+
+ var _cellLayoutManager$ge3 = cellLayoutManager.getTotalSize();
+
+ var totalHeight = _cellLayoutManager$ge3.height;
+ var totalWidth = _cellLayoutManager$ge3.width;
+
+ var scrollLeft = Math.min(totalWidth - width + scrollbarSize, event.target.scrollLeft);
+ var scrollTop = Math.min(totalHeight - height + scrollbarSize, event.target.scrollTop);
+
+ // Certain devices (like Apple touchpad) rapid-fire duplicate events.
+ // Don't force a re-render if this is the case.
+ // The mouse may move faster then the animation frame does.
+ // Use requestAnimationFrame to avoid over-updating.
+ if (this.state.scrollLeft !== scrollLeft || this.state.scrollTop !== scrollTop) {
+ // Browsers with cancelable scroll events (eg. Firefox) interrupt scrolling animations if scrollTop/scrollLeft is set.
+ // Other browsers (eg. Safari) don't scroll as well without the help under certain conditions (DOM or style changes during scrolling).
+ // All things considered, this seems to be the best current work around that I'm aware of.
+ // For more information see https://github.com/bvaughn/react-virtualized/pull/124
+ var scrollPositionChangeReason = event.cancelable ? SCROLL_POSITION_CHANGE_REASONS.OBSERVED : SCROLL_POSITION_CHANGE_REASONS.REQUESTED;
+
+ // Synchronously set :isScrolling the first time (since _setNextState will reschedule its animation frame each time it's called)
+ if (!this.state.isScrolling) {
+ this.setState({
+ isScrolling: true
+ });
+ }
+
+ this._setNextState({
+ isScrolling: true,
+ scrollLeft: scrollLeft,
+ scrollPositionChangeReason: scrollPositionChangeReason,
+ scrollTop: scrollTop
+ });
+ }
+
+ this._invokeOnScrollMemoizer({
+ scrollLeft: scrollLeft,
+ scrollTop: scrollTop,
+ totalWidth: totalWidth,
+ totalHeight: totalHeight
+ });
+ }
+ }]);
+
+ return CollectionView;
+}(_react.Component);
+
+CollectionView.propTypes = {
+ 'aria-label': _react.PropTypes.string,
+
+ /**
+ * Number of cells in collection.
+ */
+ cellCount: _react.PropTypes.number.isRequired,
+
+ /**
+ * Calculates cell sizes and positions and manages rendering the appropriate cells given a specified window.
+ */
+ cellLayoutManager: _react.PropTypes.object.isRequired,
+
+ /**
+ * Optional custom CSS class name to attach to root Collection element.
+ */
+ className: _react.PropTypes.string,
+
+ /**
+ * Height of Collection; this property determines the number of visible (vs virtualized) rows.
+ */
+ height: _react.PropTypes.number.isRequired,
+
+ /**
+ * Optional renderer to be used in place of rows when either :rowsCount or :cellCount is 0.
+ */
+ noContentRenderer: _react.PropTypes.func.isRequired,
+
+ /**
+ * Callback invoked whenever the scroll offset changes within the inner scrollable region.
+ * This callback can be used to sync scrolling between lists, tables, or grids.
+ * ({ clientHeight, clientWidth, scrollHeight, scrollLeft, scrollTop, scrollWidth }): void
+ */
+ onScroll: _react.PropTypes.func.isRequired,
+
+ /**
+ * Callback invoked with information about the section of the Collection that was just rendered.
+ * This callback is passed an array of the most recently rendered section indices.
+ */
+ onSectionRendered: _react.PropTypes.func.isRequired,
+
+ /**
+ * Horizontal offset.
+ */
+ scrollLeft: _react.PropTypes.number,
+
+ /**
+ * Cell index to ensure visible (by forcefully scrolling if necessary).
+ */
+ scrollToCell: _react.PropTypes.number,
+
+ /**
+ * Vertical offset.
+ */
+ scrollTop: _react.PropTypes.number,
+
+ /**
+ * Width of Collection; this property determines the number of visible (vs virtualized) columns.
+ */
+ width: _react.PropTypes.number.isRequired
+};
+CollectionView.defaultProps = {
+ 'aria-label': 'grid',
+ noContentRenderer: function noContentRenderer() {
+ return null;
+ },
+ onScroll: function onScroll() {
+ return null;
+ },
+ onSectionRendered: function onSectionRendered() {
+ return null;
+ }
+};
+exports.default = CollectionView;
+},{"../utils/createCallbackMemoizer":63,"classnames":undefined,"dom-helpers/util/scrollbarSize":16,"raf":26,"react":undefined,"react-addons-shallow-compare":27}],38:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+
+var _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; }; }();
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+/**
+ * A section of the Window.
+ * Window Sections are used to group nearby cells.
+ * This enables us to more quickly determine which cells to display in a given region of the Window.
+ * Sections have a fixed size and contain 0 to many cells (tracked by their indices).
+ */
+
+var Section = function () {
+ function Section(_ref) {
+ var height = _ref.height;
+ var width = _ref.width;
+ var x = _ref.x;
+ var y = _ref.y;
+
+ _classCallCheck(this, Section);
+
+ this.height = height;
+ this.width = width;
+ this.x = x;
+ this.y = y;
+
+ this._indexMap = {};
+ this._indices = [];
+ }
+
+ /** Add a cell to this section. */
+
+
+ _createClass(Section, [{
+ key: 'addCellIndex',
+ value: function addCellIndex(index) {
+ if (!this._indexMap[index]) {
+ this._indexMap[index] = true;
+ this._indices.push(index);
+ }
+ }
+
+ /** Get all cell indices that have been added to this section. */
+
+ }, {
+ key: 'getCellIndices',
+ value: function getCellIndices() {
+ return this._indices;
+ }
+
+ /** Intended for debugger/test purposes only */
+
+ }, {
+ key: 'toString',
+ value: function toString() {
+ return this.x + ',' + this.y + ' ' + this.width + 'x' + this.height;
+ }
+ }]);
+
+ return Section;
+}(); /** @rlow */
+
+
+exports.default = Section;
+},{}],39:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+
+var _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; }; }(); /**
+ * Window Sections are used to group nearby cells.
+ * This enables us to more quickly determine which cells to display in a given region of the Window.
+ *
+ */
+
+
+var _Section = require('./Section');
+
+var _Section2 = _interopRequireDefault(_Section);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+var SECTION_SIZE = 100;
+
+/**
+ * Contains 0 to many Sections.
+ * Grows (and adds Sections) dynamically as cells are registered.
+ * Automatically adds cells to the appropriate Section(s).
+ */
+
+var SectionManager = function () {
+ function SectionManager() {
+ var sectionSize = arguments.length <= 0 || arguments[0] === undefined ? SECTION_SIZE : arguments[0];
+
+ _classCallCheck(this, SectionManager);
+
+ this._sectionSize = sectionSize;
+
+ this._cellMetadata = [];
+ this._sections = {};
+ }
+
+ /**
+ * Gets all cell indices contained in the specified region.
+ * A region may encompass 1 or more Sections.
+ */
+
+
+ _createClass(SectionManager, [{
+ key: 'getCellIndices',
+ value: function getCellIndices(_ref) {
+ var height = _ref.height;
+ var width = _ref.width;
+ var x = _ref.x;
+ var y = _ref.y;
+
+ var indices = {};
+
+ this.getSections({ height: height, width: width, x: x, y: y }).forEach(function (section) {
+ return section.getCellIndices().forEach(function (index) {
+ return indices[index] = index;
+ });
+ });
+
+ // Object keys are strings; this function returns numbers
+ return Object.keys(indices).map(function (index) {
+ return indices[index];
+ });
+ }
+
+ /** Get size and position information for the cell specified. */
+
+ }, {
+ key: 'getCellMetadata',
+ value: function getCellMetadata(index) {
+ return this._cellMetadata[index];
+ }
+
+ /** Get all Sections overlapping the specified region. */
+
+ }, {
+ key: 'getSections',
+ value: function getSections(_ref2) {
+ var height = _ref2.height;
+ var width = _ref2.width;
+ var x = _ref2.x;
+ var y = _ref2.y;
+
+ var sectionXStart = Math.floor(x / this._sectionSize);
+ var sectionXStop = Math.floor((x + width - 1) / this._sectionSize);
+ var sectionYStart = Math.floor(y / this._sectionSize);
+ var sectionYStop = Math.floor((y + height - 1) / this._sectionSize);
+
+ var sections = [];
+
+ for (var sectionX = sectionXStart; sectionX <= sectionXStop; sectionX++) {
+ for (var sectionY = sectionYStart; sectionY <= sectionYStop; sectionY++) {
+ var key = sectionX + '.' + sectionY;
+
+ if (!this._sections[key]) {
+ this._sections[key] = new _Section2.default({
+ height: this._sectionSize,
+ width: this._sectionSize,
+ x: sectionX * this._sectionSize,
+ y: sectionY * this._sectionSize
+ });
+ }
+
+ sections.push(this._sections[key]);
+ }
+ }
+
+ return sections;
+ }
+
+ /** Total number of Sections based on the currently registered cells. */
+
+ }, {
+ key: 'getTotalSectionCount',
+ value: function getTotalSectionCount() {
+ return Object.keys(this._sections).length;
+ }
+
+ /** Intended for debugger/test purposes only */
+
+ }, {
+ key: 'toString',
+ value: function toString() {
+ var _this = this;
+
+ return Object.keys(this._sections).map(function (index) {
+ return _this._sections[index].toString();
+ });
+ }
+
+ /** Adds a cell to the appropriate Sections and registers it metadata for later retrievable. */
+
+ }, {
+ key: 'registerCell',
+ value: function registerCell(_ref3) {
+ var cellMetadatum = _ref3.cellMetadatum;
+ var index = _ref3.index;
+
+ this._cellMetadata[index] = cellMetadatum;
+
+ this.getSections(cellMetadatum).forEach(function (section) {
+ return section.addCellIndex(index);
+ });
+ }
+ }]);
+
+ return SectionManager;
+}();
+
+exports.default = SectionManager;
+},{"./Section":38}],40:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.Collection = exports.default = undefined;
+
+var _Collection2 = require('./Collection');
+
+var _Collection3 = _interopRequireDefault(_Collection2);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+exports.default = _Collection3.default;
+exports.Collection = _Collection3.default;
+},{"./Collection":36}],41:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = calculateSizeAndPositionData;
+
+var _SectionManager = require('../SectionManager');
+
+var _SectionManager2 = _interopRequireDefault(_SectionManager);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function calculateSizeAndPositionData(_ref) {
+ var cellCount = _ref.cellCount;
+ var cellSizeAndPositionGetter = _ref.cellSizeAndPositionGetter;
+ var sectionSize = _ref.sectionSize;
+
+ var cellMetadata = [];
+ var sectionManager = new _SectionManager2.default(sectionSize);
+ var height = 0;
+ var width = 0;
+
+ for (var index = 0; index < cellCount; index++) {
+ var cellMetadatum = cellSizeAndPositionGetter(index);
+
+ 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)) {
+ throw Error('Invalid metadata returned for cell ' + index + ':\n x:' + cellMetadatum.x + ', y:' + cellMetadatum.y + ', width:' + cellMetadatum.width + ', height:' + cellMetadatum.height);
+ }
+
+ height = Math.max(height, cellMetadatum.y + cellMetadatum.height);
+ width = Math.max(width, cellMetadatum.x + cellMetadatum.width);
+
+ cellMetadata[index] = cellMetadatum;
+ sectionManager.registerCell({
+ cellMetadatum: cellMetadatum,
+ index: index
+ });
+ }
+
+ return {
+ cellMetadata: cellMetadata,
+ height: height,
+ sectionManager: sectionManager,
+ width: width
+ };
+}
+},{"../SectionManager":39}],42:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+
+var _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; }; }();
+
+var _react = require('react');
+
+var _reactAddonsShallowCompare = require('react-addons-shallow-compare');
+
+var _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);
+
+var _Grid = require('../Grid');
+
+var _Grid2 = _interopRequireDefault(_Grid);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _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; }
+
+function _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; }
+
+/**
+ * High-order component that auto-calculates column-widths for `Grid` cells.
+ */
+
+var ColumnSizer = function (_Component) {
+ _inherits(ColumnSizer, _Component);
+
+ function ColumnSizer(props, context) {
+ _classCallCheck(this, ColumnSizer);
+
+ var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(ColumnSizer).call(this, props, context));
+
+ _this._registerChild = _this._registerChild.bind(_this);
+ return _this;
+ }
+
+ _createClass(ColumnSizer, [{
+ key: 'componentDidUpdate',
+ value: function componentDidUpdate(prevProps, prevState) {
+ var _props = this.props;
+ var columnMaxWidth = _props.columnMaxWidth;
+ var columnMinWidth = _props.columnMinWidth;
+ var columnsCount = _props.columnsCount;
+ var width = _props.width;
+
+
+ if (columnMaxWidth !== prevProps.columnMaxWidth || columnMinWidth !== prevProps.columnMinWidth || columnsCount !== prevProps.columnsCount || width !== prevProps.width) {
+ if (this._registeredChild) {
+ this._registeredChild.recomputeGridSize();
+ }
+ }
+ }
+ }, {
+ key: 'render',
+ value: function render() {
+ var _props2 = this.props;
+ var children = _props2.children;
+ var columnMaxWidth = _props2.columnMaxWidth;
+ var columnMinWidth = _props2.columnMinWidth;
+ var columnsCount = _props2.columnsCount;
+ var width = _props2.width;
+
+
+ var safeColumnMinWidth = columnMinWidth || 1;
+
+ var safeColumnMaxWidth = columnMaxWidth ? Math.min(columnMaxWidth, width) : width;
+
+ var columnWidth = width / columnsCount;
+ columnWidth = Math.max(safeColumnMinWidth, columnWidth);
+ columnWidth = Math.min(safeColumnMaxWidth, columnWidth);
+ columnWidth = Math.floor(columnWidth);
+
+ var adjustedWidth = Math.min(width, columnWidth * columnsCount);
+
+ return children({
+ adjustedWidth: adjustedWidth,
+ getColumnWidth: function getColumnWidth() {
+ return columnWidth;
+ },
+ registerChild: this._registerChild
+ });
+ }
+ }, {
+ key: 'shouldComponentUpdate',
+ value: function shouldComponentUpdate(nextProps, nextState) {
+ return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);
+ }
+ }, {
+ key: '_registerChild',
+ value: function _registerChild(child) {
+ if (child !== null && !(child instanceof _Grid2.default)) {
+ throw Error('Unexpected child type registered; only Grid children are supported.');
+ }
+
+ this._registeredChild = child;
+
+ if (this._registeredChild) {
+ this._registeredChild.recomputeGridSize();
+ }
+ }
+ }]);
+
+ return ColumnSizer;
+}(_react.Component);
+
+ColumnSizer.propTypes = {
+ /**
+ * Function respondible for rendering a virtualized Grid.
+ * This function should implement the following signature:
+ * ({ adjustedWidth, getColumnWidth, registerChild }) => PropTypes.element
+ *
+ * The specified :getColumnWidth function should be passed to the Grid's :columnWidth property.
+ * The :registerChild should be passed to the Grid's :ref property.
+ * The :adjustedWidth property is optional; it reflects the lesser of the overall width or the width of all columns.
+ */
+ children: _react.PropTypes.func.isRequired,
+
+ /** Optional maximum allowed column width */
+ columnMaxWidth: _react.PropTypes.number,
+
+ /** Optional minimum allowed column width */
+ columnMinWidth: _react.PropTypes.number,
+
+ /** Number of columns in Grid or FlexTable child */
+ columnsCount: _react.PropTypes.number.isRequired,
+
+ /** Width of Grid or FlexTable child */
+ width: _react.PropTypes.number.isRequired
+};
+exports.default = ColumnSizer;
+},{"../Grid":50,"react":undefined,"react-addons-shallow-compare":27}],43:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.ColumnSizer = exports.default = undefined;
+
+var _ColumnSizer2 = require('./ColumnSizer');
+
+var _ColumnSizer3 = _interopRequireDefault(_ColumnSizer2);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+exports.default = _ColumnSizer3.default;
+exports.ColumnSizer = _ColumnSizer3.default;
+},{"./ColumnSizer":42}],44:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.defaultCellRenderer = defaultCellRenderer;
+exports.defaultCellDataGetter = defaultCellDataGetter;
+exports.defaultHeaderRenderer = defaultHeaderRenderer;
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _SortIndicator = require('./SortIndicator');
+
+var _SortIndicator2 = _interopRequireDefault(_SortIndicator);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _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; }
+
+function _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; }
+
+/**
+ * Default cell renderer that displays an attribute as a simple string
+ * You should override the column's cellRenderer if your data is some other type of object.
+ */
+function defaultCellRenderer(cellData, cellDataKey, rowData, rowIndex, columnData) {
+ if (cellData === null || cellData === undefined) {
+ return '';
+ } else {
+ return String(cellData);
+ }
+}
+
+/**
+ * Default accessor for returning a cell value for a given attribute.
+ * This function expects to operate on either a vanilla Object or an Immutable Map.
+ * You should override the column's cellDataGetter if your data is some other type of object.
+ */
+function defaultCellDataGetter(dataKey, rowData, columnData) {
+ if (rowData.get instanceof Function) {
+ return rowData.get(dataKey);
+ } else {
+ return rowData[dataKey];
+ }
+}
+
+/**
+ * Default table header renderer.
+ */
+function defaultHeaderRenderer(_ref) {
+ var columnData = _ref.columnData;
+ var dataKey = _ref.dataKey;
+ var disableSort = _ref.disableSort;
+ var label = _ref.label;
+ var sortBy = _ref.sortBy;
+ var sortDirection = _ref.sortDirection;
+
+ var showSortIndicator = sortBy === dataKey;
+ var children = [_react2.default.createElement(
+ 'div',
+ {
+ className: 'FlexTable__headerTruncatedText',
+ key: 'label',
+ title: label
+ },
+ label
+ )];
+
+ if (showSortIndicator) {
+ children.push(_react2.default.createElement(_SortIndicator2.default, {
+ key: 'SortIndicator',
+ sortDirection: sortDirection
+ }));
+ }
+
+ return children;
+}
+
+/**
+ * Describes the header and cell contents of a table column.
+ */
+
+var Column = function (_Component) {
+ _inherits(Column, _Component);
+
+ function Column() {
+ _classCallCheck(this, Column);
+
+ return _possibleConstructorReturn(this, Object.getPrototypeOf(Column).apply(this, arguments));
+ }
+
+ return Column;
+}(_react.Component);
+
+Column.defaultProps = {
+ cellDataGetter: defaultCellDataGetter,
+ cellRenderer: defaultCellRenderer,
+ flexGrow: 0,
+ flexShrink: 1,
+ headerRenderer: defaultHeaderRenderer
+};
+Column.propTypes = {
+ /** Optional aria-label value to set on the column header */
+ 'aria-label': _react.PropTypes.string,
+
+ /** Optional CSS class to apply to cell */
+ cellClassName: _react.PropTypes.string,
+
+ /**
+ * Callback responsible for returning a cell's data, given its :dataKey
+ * (dataKey: string, rowData: any): any
+ */
+ cellDataGetter: _react.PropTypes.func,
+
+ /**
+ * Callback responsible for rendering a cell's contents.
+ * (cellData: any, cellDataKey: string, rowData: any, rowIndex: number, columnData: any): element
+ */
+ cellRenderer: _react.PropTypes.func,
+
+ /** Optional additional data passed to this column's :cellDataGetter */
+ columnData: _react.PropTypes.object,
+
+ /** Uniquely identifies the row-data attribute correspnding to this cell */
+ dataKey: _react.PropTypes.any.isRequired,
+
+ /** If sort is enabled for the table at large, disable it for this column */
+ disableSort: _react.PropTypes.bool,
+
+ /** Flex grow style; defaults to 0 */
+ flexGrow: _react.PropTypes.number,
+
+ /** Flex shrink style; defaults to 1 */
+ flexShrink: _react.PropTypes.number,
+
+ /** Optional CSS class to apply to this column's header */
+ headerClassName: _react.PropTypes.string,
+
+ /**
+ * Optional callback responsible for rendering a column header contents.
+ * ({ columnData: object, dataKey: string, disableSort: boolean, label: string, sortBy: string, sortDirection: string }): PropTypes.node
+ */
+ headerRenderer: _react.PropTypes.func.isRequired,
+
+ /** Header label for this column */
+ label: _react.PropTypes.string,
+
+ /** Maximum width of column; this property will only be used if :flexGrow is > 0. */
+ maxWidth: _react.PropTypes.number,
+
+ /** Minimum width of column. */
+ minWidth: _react.PropTypes.number,
+
+ /** Flex basis (width) for this column; This value can grow or shrink based on :flexGrow and :flexShrink properties. */
+ width: _react.PropTypes.number.isRequired
+};
+exports.default = Column;
+},{"./SortIndicator":47,"react":undefined}],45:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+
+var _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; };
+
+var _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; }; }();
+
+var _classnames = require('classnames');
+
+var _classnames2 = _interopRequireDefault(_classnames);
+
+var _FlexColumn = require('./FlexColumn');
+
+var _FlexColumn2 = _interopRequireDefault(_FlexColumn);
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _reactDom = require('react-dom');
+
+var _reactAddonsShallowCompare = require('react-addons-shallow-compare');
+
+var _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);
+
+var _Grid = require('../Grid');
+
+var _Grid2 = _interopRequireDefault(_Grid);
+
+var _SortDirection = require('./SortDirection');
+
+var _SortDirection2 = _interopRequireDefault(_SortDirection);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _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; }
+
+function _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; }
+
+/**
+ * Table component with fixed headers and virtualized rows for improved performance with large data sets.
+ * This component expects explicit width, height, and padding parameters.
+ */
+
+var FlexTable = function (_Component) {
+ _inherits(FlexTable, _Component);
+
+ function FlexTable(props) {
+ _classCallCheck(this, FlexTable);
+
+ var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(FlexTable).call(this, props));
+
+ _this.state = {
+ scrollbarWidth: 0
+ };
+
+ _this._createRow = _this._createRow.bind(_this);
+ return _this;
+ }
+
+ /**
+ * See Grid#recomputeGridSize
+ */
+
+
+ _createClass(FlexTable, [{
+ key: 'recomputeRowHeights',
+ value: function recomputeRowHeights() {
+ this.refs.Grid.recomputeGridSize();
+ }
+ }, {
+ key: 'componentDidMount',
+ value: function componentDidMount() {
+ this._setScrollbarWidth();
+ }
+ }, {
+ key: 'componentDidUpdate',
+ value: function componentDidUpdate() {
+ this._setScrollbarWidth();
+ }
+ }, {
+ key: 'render',
+ value: function render() {
+ var _this2 = this;
+
+ var _props = this.props;
+ var className = _props.className;
+ var disableHeader = _props.disableHeader;
+ var headerHeight = _props.headerHeight;
+ var height = _props.height;
+ var noRowsRenderer = _props.noRowsRenderer;
+ var onRowsRendered = _props.onRowsRendered;
+ var _onScroll = _props.onScroll;
+ var overscanRowsCount = _props.overscanRowsCount;
+ var rowClassName = _props.rowClassName;
+ var rowHeight = _props.rowHeight;
+ var rowsCount = _props.rowsCount;
+ var scrollToIndex = _props.scrollToIndex;
+ var scrollTop = _props.scrollTop;
+ var width = _props.width;
+ var scrollbarWidth = this.state.scrollbarWidth;
+
+
+ var availableRowsHeight = height - headerHeight;
+
+ // This row-renderer wrapper function is necessary in order to trigger re-render when the
+ // sort-by or sort-direction have changed (else Grid will not see any props changes)
+ var rowRenderer = function rowRenderer(index) {
+ return _this2._createRow(index);
+ };
+
+ var rowClass = rowClassName instanceof Function ? rowClassName(-1) : rowClassName;
+
+ return _react2.default.createElement(
+ 'div',
+ {
+ className: (0, _classnames2.default)('FlexTable', className)
+ },
+ !disableHeader && _react2.default.createElement(
+ 'div',
+ {
+ className: (0, _classnames2.default)('FlexTable__headerRow', rowClass),
+ style: {
+ height: headerHeight,
+ paddingRight: scrollbarWidth,
+ width: width
+ }
+ },
+ this._getRenderedHeaderRow()
+ ),
+ _react2.default.createElement(_Grid2.default, {
+ 'aria-label': this.props['aria-label'],
+ ref: 'Grid',
+ className: 'FlexTable__Grid',
+ columnWidth: width,
+ columnsCount: 1,
+ height: availableRowsHeight,
+ noContentRenderer: noRowsRenderer,
+ onScroll: function onScroll(_ref) {
+ var clientHeight = _ref.clientHeight;
+ var scrollHeight = _ref.scrollHeight;
+ var scrollTop = _ref.scrollTop;
+ return _onScroll({ clientHeight: clientHeight, scrollHeight: scrollHeight, scrollTop: scrollTop });
+ },
+ onSectionRendered: function onSectionRendered(_ref2) {
+ var rowOverscanStartIndex = _ref2.rowOverscanStartIndex;
+ var rowOverscanStopIndex = _ref2.rowOverscanStopIndex;
+ var rowStartIndex = _ref2.rowStartIndex;
+ var rowStopIndex = _ref2.rowStopIndex;
+ return onRowsRendered({
+ overscanStartIndex: rowOverscanStartIndex,
+ overscanStopIndex: rowOverscanStopIndex,
+ startIndex: rowStartIndex,
+ stopIndex: rowStopIndex
+ });
+ },
+ overscanRowsCount: overscanRowsCount,
+ renderCell: function renderCell(_ref3) {
+ var columnIndex = _ref3.columnIndex;
+ var rowIndex = _ref3.rowIndex;
+ return rowRenderer(rowIndex);
+ },
+ rowHeight: rowHeight,
+ rowsCount: rowsCount,
+ scrollToRow: scrollToIndex,
+ scrollTop: scrollTop,
+ width: width
+ })
+ );
+ }
+ }, {
+ key: 'shouldComponentUpdate',
+ value: function shouldComponentUpdate(nextProps, nextState) {
+ return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);
+ }
+ }, {
+ key: '_createColumn',
+ value: function _createColumn(column, columnIndex, rowData, rowIndex) {
+ var _column$props = column.props;
+ var cellClassName = _column$props.cellClassName;
+ var cellDataGetter = _column$props.cellDataGetter;
+ var columnData = _column$props.columnData;
+ var dataKey = _column$props.dataKey;
+ var cellRenderer = _column$props.cellRenderer;
+
+ var cellData = cellDataGetter(dataKey, rowData, columnData);
+ var renderedCell = cellRenderer(cellData, dataKey, rowData, rowIndex, columnData);
+
+ var style = this._getFlexStyleForColumn(column);
+
+ var title = typeof renderedCell === 'string' ? renderedCell : null;
+
+ return _react2.default.createElement(
+ 'div',
+ {
+ key: 'Row' + rowIndex + '-Col' + columnIndex,
+ className: (0, _classnames2.default)('FlexTable__rowColumn', cellClassName),
+ style: style
+ },
+ _react2.default.createElement(
+ 'div',
+ {
+ className: 'FlexTable__truncatedColumnText',
+ title: title
+ },
+ renderedCell
+ )
+ );
+ }
+ }, {
+ key: '_createHeader',
+ value: function _createHeader(column, columnIndex) {
+ var _props2 = this.props;
+ var headerClassName = _props2.headerClassName;
+ var onHeaderClick = _props2.onHeaderClick;
+ var sort = _props2.sort;
+ var sortBy = _props2.sortBy;
+ var sortDirection = _props2.sortDirection;
+ var _column$props2 = column.props;
+ var dataKey = _column$props2.dataKey;
+ var disableSort = _column$props2.disableSort;
+ var headerRenderer = _column$props2.headerRenderer;
+ var label = _column$props2.label;
+ var columnData = _column$props2.columnData;
+
+ var sortEnabled = !disableSort && sort;
+
+ var classNames = (0, _classnames2.default)('FlexTable__headerColumn', headerClassName, column.props.headerClassName, {
+ 'FlexTable__sortableHeaderColumn': sortEnabled
+ });
+ var style = this._getFlexStyleForColumn(column);
+
+ var renderedHeader = headerRenderer({
+ columnData: columnData,
+ dataKey: dataKey,
+ disableSort: disableSort,
+ label: label,
+ sortBy: sortBy,
+ sortDirection: sortDirection
+ });
+
+ var a11yProps = {};
+
+ if (sortEnabled || onHeaderClick) {
+ (function () {
+ // If this is a sortable header, clicking it should update the table data's sorting.
+ var newSortDirection = sortBy !== dataKey || sortDirection === _SortDirection2.default.DESC ? _SortDirection2.default.ASC : _SortDirection2.default.DESC;
+
+ var onClick = function onClick() {
+ sortEnabled && sort(dataKey, newSortDirection);
+ onHeaderClick && onHeaderClick(dataKey, columnData);
+ };
+
+ var onKeyDown = function onKeyDown(event) {
+ if (event.key === 'Enter' || event.key === ' ') {
+ onClick();
+ }
+ };
+
+ a11yProps['aria-label'] = column.props['aria-label'] || label || dataKey;
+ a11yProps.role = 'rowheader';
+ a11yProps.tabIndex = 0;
+ a11yProps.onClick = onClick;
+ a11yProps.onKeyDown = onKeyDown;
+ })();
+ }
+
+ return _react2.default.createElement(
+ 'div',
+ _extends({}, a11yProps, {
+ key: 'Header-Col' + columnIndex,
+ className: classNames,
+ style: style
+ }),
+ renderedHeader
+ );
+ }
+ }, {
+ key: '_createRow',
+ value: function _createRow(rowIndex) {
+ var _this3 = this;
+
+ var _props3 = this.props;
+ var children = _props3.children;
+ var onRowClick = _props3.onRowClick;
+ var rowClassName = _props3.rowClassName;
+ var rowGetter = _props3.rowGetter;
+ var scrollbarWidth = this.state.scrollbarWidth;
+
+
+ var rowClass = rowClassName instanceof Function ? rowClassName(rowIndex) : rowClassName;
+ var rowData = rowGetter(rowIndex);
+
+ var renderedRow = _react2.default.Children.toArray(children).map(function (column, columnIndex) {
+ return _this3._createColumn(column, columnIndex, rowData, rowIndex);
+ });
+
+ var a11yProps = {};
+
+ if (onRowClick) {
+ a11yProps['aria-label'] = 'row';
+ a11yProps.role = 'row';
+ a11yProps.tabIndex = 0;
+ a11yProps.onClick = function () {
+ return onRowClick(rowIndex);
+ };
+ }
+
+ return _react2.default.createElement(
+ 'div',
+ _extends({}, a11yProps, {
+ key: rowIndex,
+ className: (0, _classnames2.default)('FlexTable__row', rowClass),
+ style: {
+ height: this._getRowHeight(rowIndex),
+ paddingRight: scrollbarWidth
+ }
+ }),
+ renderedRow
+ );
+ }
+
+ /**
+ * Determines the flex-shrink, flex-grow, and width values for a cell (header or column).
+ */
+
+ }, {
+ key: '_getFlexStyleForColumn',
+ value: function _getFlexStyleForColumn(column) {
+ var flexValue = column.props.flexGrow + ' ' + column.props.flexShrink + ' ' + column.props.width + 'px';
+
+ var style = {
+ flex: flexValue,
+ msFlex: flexValue,
+ WebkitFlex: flexValue
+ };
+
+ if (column.props.maxWidth) {
+ style.maxWidth = column.props.maxWidth;
+ }
+
+ if (column.props.minWidth) {
+ style.minWidth = column.props.minWidth;
+ }
+
+ return style;
+ }
+ }, {
+ key: '_getRenderedHeaderRow',
+ value: function _getRenderedHeaderRow() {
+ var _this4 = this;
+
+ var _props4 = this.props;
+ var children = _props4.children;
+ var disableHeader = _props4.disableHeader;
+
+ var items = disableHeader ? [] : _react2.default.Children.toArray(children);
+
+ return items.map(function (column, index) {
+ return _this4._createHeader(column, index);
+ });
+ }
+ }, {
+ key: '_getRowHeight',
+ value: function _getRowHeight(rowIndex) {
+ var rowHeight = this.props.rowHeight;
+
+
+ return rowHeight instanceof Function ? rowHeight(rowIndex) : rowHeight;
+ }
+ }, {
+ key: '_setScrollbarWidth',
+ value: function _setScrollbarWidth() {
+ var Grid = (0, _reactDom.findDOMNode)(this.refs.Grid);
+ var clientWidth = Grid.clientWidth || 0;
+ var offsetWidth = Grid.offsetWidth || 0;
+ var scrollbarWidth = offsetWidth - clientWidth;
+
+ this.setState({ scrollbarWidth: scrollbarWidth });
+ }
+ }]);
+
+ return FlexTable;
+}(_react.Component);
+
+FlexTable.propTypes = {
+ 'aria-label': _react.PropTypes.string,
+
+ /** One or more FlexColumns describing the data displayed in this row */
+ children: function children(props, propName, componentName) {
+ var children = _react2.default.Children.toArray(props.children);
+ for (var i = 0; i < children.length; i++) {
+ if (children[i].type !== _FlexColumn2.default) {
+ return new Error('FlexTable only accepts children of type FlexColumn');
+ }
+ }
+ },
+
+ /** Optional CSS class name */
+ className: _react.PropTypes.string,
+
+ /** Disable rendering the header at all */
+ disableHeader: _react.PropTypes.bool,
+
+ /** Optional CSS class to apply to all column headers */
+ headerClassName: _react.PropTypes.string,
+
+ /** Fixed height of header row */
+ headerHeight: _react.PropTypes.number.isRequired,
+
+ /** Fixed/available height for out DOM element */
+ height: _react.PropTypes.number.isRequired,
+
+ /** Optional renderer to be used in place of table body rows when rowsCount is 0 */
+ noRowsRenderer: _react.PropTypes.func,
+
+ /**
+ * Optional callback when a column's header is clicked.
+ * (dataKey: string): void
+ */
+ onHeaderClick: _react.PropTypes.func,
+
+ /**
+ * Callback invoked when a user clicks on a table row.
+ * (rowIndex: number): void
+ */
+ onRowClick: _react.PropTypes.func,
+
+ /**
+ * Callback invoked with information about the slice of rows that were just rendered.
+ * ({ startIndex, stopIndex }): void
+ */
+ onRowsRendered: _react.PropTypes.func,
+
+ /**
+ * Callback invoked whenever the scroll offset changes within the inner scrollable region.
+ * This callback can be used to sync scrolling between lists, tables, or grids.
+ * ({ clientHeight, scrollHeight, scrollTop }): void
+ */
+ onScroll: _react.PropTypes.func.isRequired,
+
+ /**
+ * Number of rows to render above/below the visible bounds of the list.
+ * These rows can help for smoother scrolling on touch devices.
+ */
+ overscanRowsCount: _react.PropTypes.number.isRequired,
+
+ /**
+ * Optional CSS class to apply to all table rows (including the header row).
+ * This property can be a CSS class name (string) or a function that returns a class name.
+ * If a function is provided its signature should be: (rowIndex: number): string
+ */
+ rowClassName: _react.PropTypes.oneOfType([_react.PropTypes.string, _react.PropTypes.func]),
+
+ /**
+ * Callback responsible for returning a data row given an index.
+ * (index: number): any
+ */
+ rowGetter: _react.PropTypes.func.isRequired,
+
+ /**
+ * Either a fixed row height (number) or a function that returns the height of a row given its index.
+ * (index: number): number
+ */
+ rowHeight: _react.PropTypes.oneOfType([_react.PropTypes.number, _react.PropTypes.func]).isRequired,
+
+ /** Number of rows in table. */
+ rowsCount: _react.PropTypes.number.isRequired,
+
+ /** Row index to ensure visible (by forcefully scrolling if necessary) */
+ scrollToIndex: _react.PropTypes.number,
+
+ /** Vertical offset. */
+ scrollTop: _react.PropTypes.number,
+
+ /**
+ * Sort function to be called if a sortable header is clicked.
+ * (dataKey: string, sortDirection: SortDirection): void
+ */
+ sort: _react.PropTypes.func,
+
+ /** FlexTable data is currently sorted by this :dataKey (if it is sorted at all) */
+ sortBy: _react.PropTypes.string,
+
+ /** FlexTable data is currently sorted in this direction (if it is sorted at all) */
+ sortDirection: _react.PropTypes.oneOf([_SortDirection2.default.ASC, _SortDirection2.default.DESC]),
+
+ /** Width of list */
+ width: _react.PropTypes.number.isRequired
+};
+FlexTable.defaultProps = {
+ disableHeader: false,
+ headerHeight: 0,
+ noRowsRenderer: function noRowsRenderer() {
+ return null;
+ },
+ onRowsRendered: function onRowsRendered() {
+ return null;
+ },
+ onScroll: function onScroll() {
+ return null;
+ },
+ overscanRowsCount: 10
+};
+exports.default = FlexTable;
+},{"../Grid":50,"./FlexColumn":44,"./SortDirection":46,"classnames":undefined,"react":undefined,"react-addons-shallow-compare":27,"react-dom":undefined}],46:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+var SortDirection = {
+ /**
+ * Sort items in ascending order.
+ * This means arranging from the lowest value to the highest (e.g. a-z, 0-9).
+ */
+ ASC: 'ASC',
+
+ /**
+ * Sort items in descending order.
+ * This means arranging from the highest value to the lowest (e.g. z-a, 9-0).
+ */
+ DESC: 'DESC'
+};
+
+exports.default = SortDirection;
+},{}],47:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = SortIndicator;
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _classnames = require('classnames');
+
+var _classnames2 = _interopRequireDefault(_classnames);
+
+var _SortDirection = require('./SortDirection');
+
+var _SortDirection2 = _interopRequireDefault(_SortDirection);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Displayed beside a header to indicate that a FlexTable is currently sorted by this column.
+ */
+function SortIndicator(_ref) {
+ var sortDirection = _ref.sortDirection;
+
+ var classNames = (0, _classnames2.default)('FlexTable__sortableHeaderIcon', {
+ 'FlexTable__sortableHeaderIcon--ASC': sortDirection === _SortDirection2.default.ASC,
+ 'FlexTable__sortableHeaderIcon--DESC': sortDirection === _SortDirection2.default.DESC
+ });
+
+ return _react2.default.createElement(
+ 'svg',
+ {
+ className: classNames,
+ width: 18,
+ height: 18,
+ viewBox: '0 0 24 24',
+ xmlns: 'http://www.w3.org/2000/svg'
+ },
+ sortDirection === _SortDirection2.default.ASC ? _react2.default.createElement('path', { d: 'M7 14l5-5 5 5z' }) : _react2.default.createElement('path', { d: 'M7 10l5 5 5-5z' }),
+ _react2.default.createElement('path', { d: 'M0 0h24v24H0z', fill: 'none' })
+ );
+}
+SortIndicator.propTypes = {
+ sortDirection: _react.PropTypes.oneOf([_SortDirection2.default.ASC, _SortDirection2.default.DESC])
+};
+},{"./SortDirection":46,"classnames":undefined,"react":undefined}],48:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.SortIndicator = exports.SortDirection = exports.FlexColumn = exports.FlexTable = exports.default = undefined;
+
+var _FlexTable2 = require('./FlexTable');
+
+var _FlexTable3 = _interopRequireDefault(_FlexTable2);
+
+var _FlexColumn2 = require('./FlexColumn');
+
+var _FlexColumn3 = _interopRequireDefault(_FlexColumn2);
+
+var _SortDirection2 = require('./SortDirection');
+
+var _SortDirection3 = _interopRequireDefault(_SortDirection2);
+
+var _SortIndicator2 = require('./SortIndicator');
+
+var _SortIndicator3 = _interopRequireDefault(_SortIndicator2);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+exports.default = _FlexTable3.default;
+exports.FlexTable = _FlexTable3.default;
+exports.FlexColumn = _FlexColumn3.default;
+exports.SortDirection = _SortDirection3.default;
+exports.SortIndicator = _SortIndicator3.default;
+},{"./FlexColumn":44,"./FlexTable":45,"./SortDirection":46,"./SortIndicator":47}],49:[function(require,module,exports){
+'use strict';
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+
+var _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; };
+
+var _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; }; }();
+
+var _react = require('react');
+
+var _react2 = _interopRequireDefault(_react);
+
+var _classnames = require('classnames');
+
+var _classnames2 = _interopRequireDefault(_classnames);
+
+var _calculateSizeAndPositionDataAndUpdateScrollOffset = require('./utils/calculateSizeAndPositionDataAndUpdateScrollOffset');
+
+var _calculateSizeAndPositionDataAndUpdateScrollOffset2 = _interopRequireDefault(_calculateSizeAndPositionDataAndUpdateScrollOffset);
+
+var _createCallbackMemoizer = require('../utils/createCallbackMemoizer');
+
+var _createCallbackMemoizer2 = _interopRequireDefault(_createCallbackMemoizer);
+
+var _getNearestIndex = require('./utils/getNearestIndex');
+
+var _getNearestIndex2 = _interopRequireDefault(_getNearestIndex);
+
+var _getOverscanIndices = require('./utils/getOverscanIndices');
+
+var _getOverscanIndices2 = _interopRequireDefault(_getOverscanIndices);
+
+var _scrollbarSize = require('dom-helpers/util/scrollbarSize');
+
+var _scrollbarSize2 = _interopRequireDefault(_scrollbarSize);
+
+var _getUpdatedOffsetForIndex = require('../utils/getUpdatedOffsetForIndex');
+
+var _getUpdatedOffsetForIndex2 = _interopRequireDefault(_getUpdatedOffsetForIndex);
+
+var _getVisibleCellIndices = require('./utils/getVisibleCellIndices');
+
+var _getVisibleCellIndices2 = _interopRequireDefault(_getVisibleCellIndices);
+
+var _initCellMetadata = require('../utils/initCellMetadata');
+
+var _initCellMetadata2 = _interopRequireDefault(_initCellMetadata);
+
+var _raf = require('raf');
+
+var _raf2 = _interopRequireDefault(_raf);
+
+var _reactAddonsShallowCompare = require('react-addons-shallow-compare');
+
+var _reactAddonsShallowCompare2 = _interopRequireDefault(_reactAddonsShallowCompare);
+
+var _updateScrollIndexHelper = require('./utils/updateScrollIndexHelper');
+
+var _updateScrollIndexHelper2 = _interopRequireDefault(_updateScrollIndexHelper);
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+
+function _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; }
+
+function _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; }
+
+/**
+ * Specifies the number of miliseconds during which to disable pointer events while a scroll is in progress.
+ * This improves performance and makes scrolling smoother.
+ */
+var IS_SCROLLING_TIMEOUT = 150;
+
+/**
+ * Controls whether the Grid updates the DOM element's scrollLeft/scrollTop based on the current state or just observes it.
+ * This prevents Grid from interrupting mouse-wheel animations (see issue #2).
+ */
+var SCROLL_POSITION_CHANGE_REASONS = {
+ OBSERVED: 'observed',
+ REQUESTED: 'requested'
+};
+
+/**
+ * Renders tabular data with virtualization along the vertical and horizontal axes.
+ * Row heights and column widths must be known ahead of time and specified as properties.
+ */
+
+var Grid = function (_Component) {
+ _inherits(Grid, _Component);
+
+ function Grid(props, context) {
+ _classCallCheck(this, Grid);
+
+ var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(Grid).call(this, props, context));
+
+ _this.state = {
+ computeGridMetadataOnNextUpdate: false,
+ isScrolling: false,
+ scrollLeft: 0,
+ scrollTop: 0
+ };
+
+ // Invokes onSectionRendered callback only when start/stop row or column indices change
+ _this._onGridRenderedMemoizer = (0, _createCallbackMemoizer2.default)();
+ _this._onScrollMemoizer = (0, _createCallbackMemoizer2.default)(false);
+
+ // Bind functions to instance so they don't lose context when passed around
+ _this._computeColumnMetadata = _this._computeColumnMetadata.bind(_this);
+ _this._computeRowMetadata = _this._computeRowMetadata.bind(_this);
+ _this._invokeOnGridRenderedHelper = _this._invokeOnGridRenderedHelper.bind(_this);
+ _this._onScroll = _this._onScroll.bind(_this);
+ _this._updateScrollLeftForScrollToColumn = _this._updateScrollLeftForScrollToColumn.bind(_this);
+ _this._updateScrollTopForScrollToRow = _this._updateScrollTopForScrollToRow.bind(_this);
+ return _this;
+ }
+
+ /**
+ * Forced recompute of row heights and column widths.
+ * This function should be called if dynamic column or row sizes have changed but nothing else has.
+ * Since Grid only receives :columnsCount and :rowsCount it has no way of detecting when the underlying data changes.
+ */
+
+
+ _createClass(Grid, [{
+ key: 'recomputeGridSize',
+ value: function recomputeGridSize() {
+ this.setState({
+ computeGridMetadataOnNextUpdate: true
+ });
+ }
+ }, {
+ key: 'componentDidMount',
+ value: function componentDidMount() {
+ var _props = this.props;
+ var scrollLeft = _props.scrollLeft;
+ var scrollToColumn = _props.scrollToColumn;
+ var scrollTop = _props.scrollTop;
+ var scrollToRow = _props.scrollToRow;
+
+
+ this._scrollbarSize = (0, _scrollbarSize2.default)();
+
+ if (scrollLeft >= 0 || scrollTop >= 0) {
+ this._setScrollPosition({ scrollLeft: scrollLeft, scrollTop: scrollTop });
+ }
+
+ if (scrollToColumn >= 0 || scrollToRow >= 0) {
+ this._updateScrollLeftForScrollToColumn();
+ this._updateScrollTopForScrollToRow();
+ }
+
+ // Update onRowsRendered callback
+ this._invokeOnGridRenderedHelper();
+
+ // Initialize onScroll callback
+ this._invokeOnScrollMemoizer({
+ scrollLeft: scrollLeft || 0,
+ scrollTop: scrollTop || 0,
+ totalColumnsWidth: this._getTotalColumnsWidth(),
+ totalRowsHeight: this._getTotalRowsHeight()
+ });
+ }
+
+ /**
+ * @private
+ * This method updates scrollLeft/scrollTop in state for the following conditions:
+ * 1) New scroll-to-cell props have been set
+ */
+
+ }, {
+ key: 'componentDidUpdate',
+ value: function componentDidUpdate(prevProps, prevState) {
+ var _this2 = this;
+
+ var _props2 = this.props;
+ var columnsCount = _props2.columnsCount;
+ var columnWidth = _props2.columnWidth;
+ var height = _props2.height;
+ var rowHeight = _props2.rowHeight;
+ var rowsCount = _props2.rowsCount;
+ var scrollToColumn = _props2.scrollToColumn;
+ var scrollToRow = _props2.scrollToRow;
+ var width = _props2.width;
+ var _state = this.state;
+ var scrollLeft = _state.scrollLeft;
+ var scrollPositionChangeReason = _state.scrollPositionChangeReason;
+ var scrollTop = _state.scrollTop;
+
+ // Make sure requested changes to :scrollLeft or :scrollTop get applied.
+ // Assigning to scrollLeft/scrollTop tells the browser to interrupt any running scroll animations,
+ // 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).
+ // So we only set these when we require an adjustment of the scroll position.
+ // See issue #2 for more information.
+
+ if (scrollPositionChangeReason === SCROLL_POSITION_CHANGE_REASONS.REQUESTED) {
+ if (scrollLeft >= 0 && scrollLeft !== prevState.scrollLeft && scrollLeft !== this.refs.scrollingContainer.scrollLeft) {
+ this.refs.scrollingContainer.scrollLeft = scrollLeft;
+ }
+ if (scrollTop >= 0 && scrollTop !== prevState.scrollTop && scrollTop !== this.refs.scrollingContainer.scrollTop) {
+ this.refs.scrollingContainer.scrollTop = scrollTop;
+ }
+ }
+
+ // Update scroll offsets if the current :scrollToColumn or :scrollToRow values requires it
+ // @TODO Do we also need this check or can the one in componentWillUpdate() suffice?
+ (0, _updateScrollIndexHelper2.default)({
+ cellCount: columnsCount,
+ cellMetadata: this._columnMetadata,
+ cellSize: columnWidth,
+ previousCellsCount: prevProps.columnsCount,
+ previousCellSize: prevProps.columnWidth,
+ previousScrollToIndex: prevProps.scrollToColumn,
+ previousSize: prevProps.width,
+ scrollOffset: scrollLeft,
+ scrollToIndex: scrollToColumn,
+ size: width,
+ updateScrollIndexCallback: function updateScrollIndexCallback(scrollToColumn) {
+ return _this2._updateScrollLeftForScrollToColumn(_extends({}, _this2.props, { scrollToColumn: scrollToColumn }));
+ }
+ });
+ (0, _updateScrollIndexHelper2.default)({
+ cellCount: rowsCount,
+ cellMetadata: this._rowMetadata,
+ cellSize: rowHeight,
+ previousCellsCount: prevProps.rowsCount,
+ previousCellSize: prevProps.rowHeight,
+ previousScrollToIndex: prevProps.scrollToRow,
+ previousSize: prevProps.height,
+ scrollOffset: scrollTop,
+ scrollToIndex: scrollToRow,
+ size: height,
+ updateScrollIndexCallback: function updateScrollIndexCallback(scrollToRow) {
+ return _this2._updateScrollTopForScrollToRow(_extends({}, _this2.props, { scrollToRow: scrollToRow }));
+ }
+ });
+
+ // Update onRowsRendered callback if start/stop indices have changed
+ this._invokeOnGridRenderedHelper();
+ }
+ }, {
+ key: 'componentWillMount',
+ value: function componentWillMount() {
+ this._computeColumnMetadata(this.props);
+ this._computeRowMetadata(this.props);
+ }
+ }, {
+ key: 'componentWillUnmount',
+ value: function componentWillUnmount() {
+ if (this._disablePointerEventsTimeoutId) {
+ clearTimeout(this._disablePointerEventsTimeoutId);
+ }
+
+ if (this._setNextStateAnimationFrameId) {
+ _raf2.default.cancel(this._setNextStateAnimationFrameId);
+ }
+ }
+
+ /**
+ * @private
+ * This method updates scrollLeft/scrollTop in state for the following conditions:
+ * 1) Empty content (0 rows or columns)
+ * 2) New scroll props overriding the current state
+ * 3) Cells-count or cells-size has changed, making previous scroll offsets invalid
+ */
+
+ }, {
+ key: 'componentWillUpdate',
+ value: function componentWillUpdate(nextProps, nextState) {
+ var _this3 = this;
+
+ if (nextProps.columnsCount === 0 && nextState.scrollLeft !== 0 || nextProps.rowsCount === 0 && nextState.scrollTop !== 0) {
+ this._setScrollPosition({
+ scrollLeft: 0,
+ scrollTop: 0
+ });
+ } else if (nextProps.scrollLeft !== this.props.scrollLeft || nextProps.scrollTop !== this.props.scrollTop) {
+ this._setScrollPosition({
+ scrollLeft: nextProps.scrollLeft,
+ scrollTop: nextProps.scrollTop
+ });
+ }
+
+ // Update scroll offsets if the size or number of cells have changed, invalidating the previous value
+ (0, _calculateSizeAndPositionDataAndUpdateScrollOffset2.default)({
+ cellCount: this.props.columnsCount,
+ cellSize: this.props.columnWidth,
+ computeMetadataCallback: this._computeColumnMetadata,
+ computeMetadataCallbackProps: nextProps,
+ computeMetadataOnNextUpdate: nextState.computeGridMetadataOnNextUpdate,
+ nextCellsCount: nextProps.columnsCount,
+ nextCellSize: nextProps.columnWidth,
+ nextScrollToIndex: nextProps.scrollToColumn,
+ scrollToIndex: this.props.scrollToColumn,
+ updateScrollOffsetForScrollToIndex: function updateScrollOffsetForScrollToIndex() {
+ return _this3._updateScrollLeftForScrollToColumn(nextProps, nextState);
+ }
+ });
+ (0, _calculateSizeAndPositionDataAndUpdateScrollOffset2.default)({
+ cellCount: this.props.rowsCount,
+ cellSize: this.props.rowHeight,
+ computeMetadataCallback: this._computeRowMetadata,
+ computeMetadataCallbackProps: nextProps,
+ computeMetadataOnNextUpdate: nextState.computeGridMetadataOnNextUpdate,
+ nextCellsCount: nextProps.rowsCount,
+ nextCellSize: nextProps.rowHeight,
+ nextScrollToIndex: nextProps.scrollToRow,
+ scrollToIndex: this.props.scrollToRow,
+ updateScrollOffsetForScrollToIndex: function updateScrollOffsetForScrollToIndex() {
+ return _this3._updateScrollTopForScrollToRow(nextProps, nextState);
+ }
+ });
+
+ this.setState({
+ computeGridMetadataOnNextUpdate: false
+ });
+ }
+ }, {
+ key: 'render',
+ value: function render() {
+ var _props3 = this.props;
+ var className = _props3.className;
+ var columnsCount = _props3.columnsCount;
+ var height = _props3.height;
+ var noContentRenderer = _props3.noContentRenderer;
+ var overscanColumnsCount = _props3.overscanColumnsCount;
+ var overscanRowsCount = _props3.overscanRowsCount;
+ var renderCell = _props3.renderCell;
+ var renderCellRanges = _props3.renderCellRanges;
+ var rowsCount = _props3.rowsCount;
+ var width = _props3.width;
+ var _state2 = this.state;
+ var isScrolling = _state2.isScrolling;
+ var scrollLeft = _state2.scrollLeft;
+ var scrollTop = _state2.scrollTop;
+
+
+ var childrenToDisplay = [];
+
+ // Render only enough columns and rows to cover the visible area of the grid.
+ if (height > 0 && width > 0) {
+ var visibleColumnIndices = (0, _getVisibleCellIndices2.default)({
+ cellMetadata: this._columnMetadata,
+ containerSize: width,
+ currentOffset: scrollLeft
+ });
+
+ var visibleRowIndices = (0, _getVisibleCellIndices2.default)({
+ cellMetadata: this._rowMetadata,
+ containerSize: height,
+ currentOffset: scrollTop
+ });
+
+ // Store for _invokeOnGridRenderedHelper()
+ this._renderedColumnStartIndex = visibleColumnIndices.start;
+ this._renderedColumnStopIndex = visibleColumnIndices.stop;
+ this._renderedRowStartIndex = visibleRowIndices.start;
+ this._renderedRowStopIndex = visibleRowIndices.stop;
+
+ var overscanColumnIndices = (0, _getOverscanIndices2.default)({
+ cellCount: columnsCount,
+ overscanCellsCount: overscanColumnsCount,
+ startIndex: this._renderedColumnStartIndex,
+ stopIndex: this._renderedColumnStopIndex
+ });
+
+ var overscanRowIndices = (0, _getOverscanIndices2.default)({
+ cellCount: rowsCount,
+ overscanCellsCount: overscanRowsCount,
+ startIndex: this._renderedRowStartIndex,
+ stopIndex: this._renderedRowStopIndex
+ });
+
+ // Store for _invokeOnGridRenderedHelper()
+ this._columnStartIndex = overscanColumnIndices.overscanStartIndex;
+ this._columnStopIndex = overscanColumnIndices.overscanStopIndex;
+ this._rowStartIndex = overscanRowIndices.overscanStartIndex;
+ this._rowStopIndex = overscanRowIndices.overscanStopIndex;
+
+ childrenToDisplay = renderCellRanges({
+ columnMetadata: this._columnMetadata,
+ columnStartIndex: this._columnStartIndex,
+ columnStopIndex: this._columnStopIndex,
+ renderCell: renderCell,
+ rowMetadata: this._rowMetadata,
+ rowStartIndex: this._rowStartIndex,
+ rowStopIndex: this._rowStopIndex
+ });
+ }
+
+ var gridStyle = {
+ height: height,
+ width: width
+ };
+
+ var totalColumnsWidth = this._getTotalColumnsWidth();
+ var totalRowsHeight = this._getTotalRowsHeight();
+
+ // Force browser to hide scrollbars when we know they aren't necessary.
+ // Otherwise once scrollbars appear they may not disappear again.
+ // For more info see issue #116
+ if (totalColumnsWidth <= width) {
+ gridStyle.overflowX = 'hidden';
+ }
+
+ if (totalRowsHeight <= height) {
+ gridStyle.overflowY = 'hidden';
+ }
+
+ return _react2.default.createElement(
+ 'div',
+ {
+ ref: 'scrollingContainer',
+ 'aria-label': this.props['aria-label'],
+ className: (0, _classnames2.default)('Grid', className),
+ onScroll: this._onScroll,
+ role: 'grid',
+ style: gridStyle,
+ tabIndex: 0
+ },
+ childrenToDisplay.length > 0 && _react2.default.createElement(
+ 'div',
+ {
+ className: 'Grid__innerScrollContainer',
+ style: {
+ width: totalColumnsWidth,
+ height: totalRowsHeight,
+ maxWidth: totalColumnsWidth,
+ maxHeight: totalRowsHeight,
+ pointerEvents: isScrolling ? 'none' : 'auto'
+ }
+ },
+ childrenToDisplay
+ ),
+ childrenToDisplay.length === 0 && noContentRenderer()
+ );
+ }
+ }, {
+ key: 'shouldComponentUpdate',
+ value: function shouldComponentUpdate(nextProps, nextState) {
+ return (0, _reactAddonsShallowCompare2.default)(this, nextProps, nextState);
+ }
+
+ /* ---------------------------- Helper methods ---------------------------- */
+
+ }, {
+ key: '_computeColumnMetadata',
+ value: function _computeColumnMetadata(props) {
+ var columnsCount = props.columnsCount;
+ var columnWidth = props.columnWidth;
+
+
+ this._columnMetadata = (0, _initCellMetadata2.default)({
+ cellCount: columnsCount,
+ size: columnWidth
+ });
+ }
+ }, {
+ key: '_computeRowMetadata',
+ value: function _computeRowMetadata(props) {
+ var rowHeight = props.rowHeight;
+ var rowsCount = props.rowsCount;
+
+
+ this._rowMetadata = (0, _initCellMetadata2.default)({
+ cellCount: rowsCount,
+ size: rowHeight
+ });
+ }
+
+ /**
+ * Sets an :isScrolling flag for a small window of time.
+ * This flag is used to disable pointer events on the scrollable portion of the Grid.
+ * This prevents jerky/stuttery mouse-wheel scrolling.
+ */
+
+ }, {
+ key: '_enablePointerEventsAfterDelay',
+ value: function _enablePointerEventsAfterDelay() {
+ var _this4 = this;
+
+ if (this._disablePointerEventsTimeoutId) {
+ clearTimeout(this._disablePointerEventsTimeoutId);
+ }
+
+ this._disablePointerEventsTimeoutId = setTimeout(function () {
+ _this4._disablePointerEventsTimeoutId = null;
+ _this4.setState({
+ isScrolling: false
+ });
+ }, IS_SCROLLING_TIMEOUT);
+ }
+ }, {
+ key: '_getTotalColumnsWidth',
+ value: function _getTotalColumnsWidth() {
+ if (this._columnMetadata.length === 0) {
+ return 0;
+ }
+
+ var datum = this._columnMetadata[this._columnMetadata.length - 1];
+ return datum.offset + datum.size;
+ }
+ }, {
+ key: '_getTotalRowsHeight',
+ value: function _getTotalRowsHeight() {
+ if (this._rowMetadata.length === 0) {
+ return 0;
+ }
+
+ var datum = this._rowMetadata[this._rowMetadata.length - 1];
+ return datum.offset + datum.size;
+ }
+ }, {
+ key: '_invokeOnGridRenderedHelper',
+ value: function _invokeOnGridRenderedHelper() {
+ var onSectionRendered = this.props.onSectionRendered;
+
+
+ this._onGridRenderedMemoizer({
+ callback: onSectionRendered,
+ indices: {
+ columnOverscanStartIndex: this._columnStartIndex,
+ columnOverscanStopIndex: this._columnStopIndex,
+ columnStartIndex: this._renderedColumnStartIndex,
+ columnStopIndex: this._renderedColumnStopIndex,
+ rowOverscanStartIndex: this._rowStartIndex,
+ rowOverscanStopIndex: this._rowStopIndex,
+ rowStartIndex: this._renderedRowStartIndex,
+ rowStopIndex: this._renderedRowStopIndex
+ }
+ });
+ }
+ }, {
+ key: '_invokeOnScrollMemoizer',
+ value: function _invokeOnScrollMemoizer(_ref) {
+ var _this5 = this;
+
+ var scrollLeft = _ref.scrollLeft;
+ var scrollTop = _ref.scrollTop;
+ var totalColumnsWidth = _ref.totalColumnsWidth;
+ var totalRowsHeight = _ref.totalRowsHeight;
+
+ this._onScrollMemoizer({
+ callback: function callback(_ref2) {
+ var scrollLeft = _ref2.scrollLeft;
+ var scrollTop = _ref2.scrollTop;
+ var _props4 = _this5.props;
+ var height = _props4.height;
+ var onScroll = _props4.onScroll;
+ var width = _props4.width;
+
+
+ onScroll({
+ clientHeight: height,
+ clientWidth: width,
+ scrollHeight: totalRowsHeight,
+ scrollLeft: scrollLeft,
+ scrollTop: scrollTop,
+ scrollWidth: totalColumnsWidth
+ });
+ },
+ indices: {
+ scrollLeft: scrollLeft,
+ scrollTop: scrollTop
+ }
+ });
+ }
+
+ /**
+ * Updates the state during the next animation frame.
+ * Use this method to avoid multiple renders in a small span of time.
+ * This helps performance for bursty events (like onScroll).
+ */
+
+ }, {
+ key: '_setNextState',
+ value: function _setNextState(state) {
+ var _this6 = this;
+
+ if (this._setNextStateAnimationFrameId) {
+ _raf2.default.cancel(this._setNextStateAnimationFrameId);
+ }
+
+ this._setNextStateAnimationFrameId = (0, _raf2.default)(function () {
+ _this6._setNextStateAnimationFrameId = null;
+ _this6.setState(state);
+ });
+ }
+ }, {
+ key: '_setScrollPosition',
+ value: function _setScrollPosition(_ref3) {
+ var scrollLeft = _ref3.scrollLeft;
+ var scrollTop = _ref3.scrollTop;
+
+ var newState = {
+ scrollPositionChangeReason: SCROLL_POSITION_CHANGE_REASONS.REQUESTED
+ };
+
+ if (scrollLeft >= 0) {
+ newState.scrollLeft = scrollLeft;
+ }
+
+ if (scrollTop >= 0) {
+ newState.scrollTop = scrollTop;
+ }
+
+ if (scrollLeft >= 0 && scrollLeft !== this.state.scrollLeft || scrollTop >= 0 && scrollTop !== this.state.scrollTop) {
+ this.setState(newState);
+ }
+ }
+ }, {
+ key: '_updateScrollLeftForScrollToColumn',
+ value: function _updateScrollLeftForScrollToColumn() {
+ var props = arguments.length <= 0 || arguments[0] === undefined ? null : arguments[0];
+ var state = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1];
+
+ var _ref4 = props || this.props;
+
+ var columnsCount = _ref4.columnsCount;
+ var scrollToColumn = _ref4.scrollToColumn;
+ var width = _ref4.width;
+
+ var _ref5 = state || this.state;
+
+ var scrollLeft = _ref5.scrollLeft;
+
+
+ if (scrollToColumn >= 0 && columnsCount > 0) {
+ var targetIndex = (0, _getNearestIndex2.default)({
+ cellCount: this._columnMetadata.length,
+ targetIndex: scrollToColumn
+ });
+
+ var columnMetadata = this._columnMetadata[targetIndex];
+
+ var calculatedScrollLeft = (0, _getUpdatedOffsetForIndex2.default)({
+ cellOffset: columnMetadata.offset,
+ cellSize: columnMetadata.size,
+ containerSize: width,
+ currentOffset: scrollLeft,
+ targetIndex: scrollToColumn
+ });
+
+ if (scrollLeft !== calculatedScrollLeft) {
+ this._setScrollPosition({
+ scrollLeft: calculatedScrollLeft
+ });
+ }
+ }
+ }
+ }, {
+ key: '_updateScrollTopForScrollToRow',
+ value: function _updateScrollTopForScrollToRow() {
+ var props = arguments.length <= 0 || arguments[0] === undefined ? null : arguments[0];
+ var state = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1];
+
+ var _ref6 = props || this.props;
+
+ var height = _ref6.height;
+ var rowsCount = _ref6.rowsCount;
+ var scrollToRow = _ref6.scrollToRow;
+
+ var _ref7 = state || this.state;
+
+ var scrollTop = _ref7.scrollTop;
+
+
+ if (scrollToRow >= 0 && rowsCount > 0) {
+ var targetIndex = (0, _getNearestIndex2.default)({
+ cellCount: this._rowMetadata.length,
+ targetIndex: scrollToRow
+ });
+
+ var rowMetadata = this._rowMetadata[targetIndex];
+
+ var calculatedScrollTop = (0, _getUpdatedOffsetForIndex2.default)({
+ cellOffset: rowMetadata.offset,
+ cellSize: rowMetadata.size,
+ containerSize: height,
+ currentOffset: scrollTop,
+ targetIndex: scrollToRow
+ });
+
+ if (scrollTop !== calculatedScrollTop) {
+ this._setScrollPosition({
+ scrollTop: calculatedScrollTop
+ });
+ }
+ }
+ }
+ }, {
+ key: '_onScroll',
+ value: function _onScroll(event) {
+ // In certain edge-cases React dispatches an onScroll event with an invalid target.scrollLeft / target.scrollTop.
+ // This invalid event can be detected by comparing event.target to this component's scrollable DOM element.
+ // See issue #404 for more information.
+ if (event.target !== this.refs.scrollingContainer) {
+ return;
+ }
+
+ // Prevent pointer events from interrupting a smooth scroll
+ this._enablePointerEventsAfterDelay();
+
+ // When this component is shrunk drastically, React dispatches a series of back-to-back scroll events,
+ // Gradually converging on a scrollTop that is within the bounds of the new, smaller height.
+ // This causes a series of rapid renders that is slow for long lists.
+ // We can avoid that by doing some simple bounds checking to ensure that scrollTop never exceeds the total height.
+ var _props5 = this.props;
+ var height = _props5.height;
+ var width = _props5.width;
+
+ var scrollbarSize = this._scrollbarSize;
+ var totalRowsHeight = this._getTotalRowsHeight();
+ var totalColumnsWidth = this._getTotalColumnsWidth();
+ var scrollLeft = Math.min(totalColumnsWidth - width + scrollbarSize, event.target.scrollLeft);
+ var scrollTop = Math.min(totalRowsHeight - height + scrollbarSize, event.target.scrollTop);
+
+ // Certain devices (like Apple touchpad) rapid-fire duplicate events.
+ // Don't force a re-render if this is the case.
+ // The mouse may move faster then the animation frame does.
+ // Use requestAnimationFrame to avoid over-updating.
+ if (this.state.scrollLeft !== scrollLeft || this.state.scrollTop !== scrollTop) {
+ // Browsers with cancelable scroll events (eg. Firefox) interrupt scrolling animations if scrollTop/scrollLeft is set.
+ // Other browsers (eg. Safari) don't scroll as well without the help under certain conditions (DOM or style changes during scrolling).
+ // All things considered, this seems to be the best current work around that I'm aware of.
+ // For more information see https://github.com/bvaughn/react-virtualized/pull/124
+ var scrollPositionChangeReason = event.cancelable ? SCROLL_POSITION_CHANGE_REASONS.OBSERVED : SCROLL_POSITION_CHANGE_REASONS.REQUESTED;
+
+ if (!this.state.isScrolling) {
+ this.setState({
+ isScrolling: true
+ });
+ }
+
+ this._setNextState({
+ isScrolling: true,
+ scrollLeft: scrollLeft,
+ scrollPositionChangeReason: scrollPositionChangeReason,
+ scrollTop: scrollTop
+ });
+ }
+
+ this._invokeOnScrollMemoizer({ scrollLeft: scrollLeft, scrollTop: scrollTop, totalColumnsWidth: totalColumnsWidth, totalRowsHeight: totalRowsHeight });
+ }
+ }]);
+
+ return Grid;
+}(_react.Component);
+
+Grid.propTypes = {
+ 'aria-label': _react.PropTypes.string,
+
+ /**
+ * Optional custom CSS class name to attach to root Grid element.
+ */
+ className: _react.PropTypes.string,
+
+ /**
+ * Number of columns in grid.
+ */
+ columnsCount: _react.PropTypes.number.isRequired,
+
+ /**
+ * Either a fixed column width (number) or a function that returns the width of a column given its index.
+ * Should implement the following interface: (index: number): number
+ */
+ columnWidth: _react.PropTypes.oneOfType([_react.PropTypes.number, _react.PropTypes.func]).isRequired,
+
+ /**
+ * Height of Grid; this property determines the number of visible (vs virtualized) rows.
+ */
+ height: _react.PropTypes.number.isRequired,
+
+ /**
+ * Optional renderer to be used in place of rows when either :rowsCount or :columnsCount is 0.
+ */
+ noContentRenderer: _react.PropTypes.func.isRequired,
+
+ /**
+ * Callback invoked whenever the scroll offset changes within the inner scrollable region.
+ * This callback can be used to sync scrolling between lists, tables, or grids.
+ * ({ clientHeight, clientWidth, scrollHeight, scrollLeft, scrollTop, scrollWidth }): void
+ */
+ onScroll: _react.PropTypes.func.isRequired,
+
+ /**
+ * Callback invoked with information about the section of the Grid that was just rendered.
+ * ({ columnStartIndex, columnStopIndex, rowStartIndex, rowStopIndex }): void
+ */
+ onSectionRendered: _react.PropTypes.func.isRequired,
+
+ /**
+ * Number of columns to render before/after the visible section of the grid.
+ * These columns can help for smoother scrolling on touch devices or browsers that send scroll events infrequently.
+ */
+ overscanColumnsCount: _react.PropTypes.number.isRequired,
+
+ /**
+ * Number of rows to render above/below the visible section of the grid.
+ * These rows can help for smoother scrolling on touch devices or browsers that send scroll events infrequently.
+ */
+ overscanRowsCount: _react.PropTypes.number.isRequired,
+
+ /**
+ * Responsible for rendering a cell given an row and column index.
+ * Should implement the following interface: ({ columnIndex: number, rowIndex: number }): PropTypes.node
+ */
+ renderCell: _react.PropTypes.func.isRequired,
+
+ /**
+ * Responsible for rendering a group of cells given their index ranges.
+ * Should implement the following interface: ({
+ * columnMetadata:Array