UNPKG

rc-select

Version:
71 lines (64 loc) 3.32 kB
'use strict'; exports.__esModule = true; exports.SelectPropTypes = undefined; var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function valueType(props, propName, componentName) { var basicType = _propTypes2['default'].oneOfType([_propTypes2['default'].string, _propTypes2['default'].number]); var labelInValueShape = _propTypes2['default'].shape({ key: basicType.isRequired, label: _propTypes2['default'].node }); if (props.labelInValue) { var validate = _propTypes2['default'].oneOfType([_propTypes2['default'].arrayOf(labelInValueShape), labelInValueShape]); var error = validate.apply(undefined, arguments); if (error) { return new Error('Invalid prop `' + propName + '` supplied to `' + componentName + '`, ' + ('when you set `labelInValue` to `true`, `' + propName + '` should in ') + 'shape of `{ key: string | number, label?: ReactNode }`.'); } } else if ((props.mode === 'multiple' || props.mode === 'tags' || props.multiple || props.tags) && props[propName] === '') { return new Error('Invalid prop `' + propName + '` of type `string` supplied to `' + componentName + '`, ' + 'expected `array` when `multiple` or `tags` is `true`.'); } else { var _validate = _propTypes2['default'].oneOfType([_propTypes2['default'].arrayOf(basicType), basicType]); return _validate.apply(undefined, arguments); } } var SelectPropTypes = exports.SelectPropTypes = { defaultActiveFirstOption: _propTypes2['default'].bool, multiple: _propTypes2['default'].bool, filterOption: _propTypes2['default'].any, children: _propTypes2['default'].any, showSearch: _propTypes2['default'].bool, disabled: _propTypes2['default'].bool, allowClear: _propTypes2['default'].bool, showArrow: _propTypes2['default'].bool, tags: _propTypes2['default'].bool, prefixCls: _propTypes2['default'].string, className: _propTypes2['default'].string, transitionName: _propTypes2['default'].string, optionLabelProp: _propTypes2['default'].string, optionFilterProp: _propTypes2['default'].string, animation: _propTypes2['default'].string, choiceTransitionName: _propTypes2['default'].string, onChange: _propTypes2['default'].func, onBlur: _propTypes2['default'].func, onFocus: _propTypes2['default'].func, onSelect: _propTypes2['default'].func, onSearch: _propTypes2['default'].func, onPopupScroll: _propTypes2['default'].func, onMouseEnter: _propTypes2['default'].func, onMouseLeave: _propTypes2['default'].func, onInputKeyDown: _propTypes2['default'].func, placeholder: _propTypes2['default'].any, onDeselect: _propTypes2['default'].func, labelInValue: _propTypes2['default'].bool, value: valueType, defaultValue: valueType, dropdownStyle: _propTypes2['default'].object, maxTagTextLength: _propTypes2['default'].number, maxTagCount: _propTypes2['default'].number, maxTagPlaceholder: _propTypes2['default'].oneOfType([_propTypes2['default'].node, _propTypes2['default'].func]), tokenSeparators: _propTypes2['default'].arrayOf(_propTypes2['default'].string), getInputElement: _propTypes2['default'].func, showAction: _propTypes2['default'].arrayOf(_propTypes2['default'].string) };