bee-select
Version:
select ui component for react
99 lines (95 loc) • 2.92 kB
JavaScript
/**
* This source code is quoted from rc-select.
* homepage: https://github.com/react-component/select
*/
import PropTypes from 'prop-types';
function valueType(props, propName, componentName) {
const basicType = PropTypes.oneOfType([
PropTypes.string,
PropTypes.number,
]);
const labelInValueShape = PropTypes.shape({
key: basicType.isRequired,
label: PropTypes.node,
});
if (props.labelInValue) {
const validate = PropTypes.oneOfType([
PropTypes.arrayOf(labelInValueShape),
labelInValueShape,
]);
const error = validate(...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 {
const validate = PropTypes.oneOfType([
PropTypes.arrayOf(basicType),
basicType,
]);
return validate(...arguments);
}
}
export const SelectPropTypes = {
id: PropTypes.string,
defaultActiveFirstOption: PropTypes.bool,
multiple: PropTypes.bool,
filterOption: PropTypes.any,
children: PropTypes.any,
showSearch: PropTypes.bool,
disabled: PropTypes.bool,
allowClear: PropTypes.bool,
showArrow: PropTypes.bool,
tags: PropTypes.bool,
prefixCls: PropTypes.string,
className: PropTypes.string,
transitionName: PropTypes.string,
optionLabelProp: PropTypes.string,
optionFilterProp: PropTypes.string,
animation: PropTypes.string,
choiceTransitionName: PropTypes.string,
open: PropTypes.bool,
defaultOpen: PropTypes.bool,
onChange: PropTypes.func,
onBlur: PropTypes.func,
onFocus: PropTypes.func,
onSelect: PropTypes.func,
onSearch: PropTypes.func,
onPopupScroll: PropTypes.func,
onMouseEnter: PropTypes.func,
onMouseLeave: PropTypes.func,
onInputKeyDown: PropTypes.func,
placeholder: PropTypes.any,
onDeselect: PropTypes.func,
labelInValue: PropTypes.bool,
value: valueType,
defaultValue: valueType,
dropdownStyle: PropTypes.object,
maxTagTextLength: PropTypes.number,
maxTagCount: PropTypes.number,
maxTagPlaceholder: PropTypes.oneOfType([
PropTypes.node,
PropTypes.func,
]),
tokenSeparators: PropTypes.arrayOf(PropTypes.string),
getInputElement: PropTypes.func,
showAction: PropTypes.arrayOf(PropTypes.string),
clearIcon: PropTypes.node,
inputIcon: PropTypes.node,
removeIcon: PropTypes.node,
menuItemSelectedIcon: PropTypes.oneOfType([
PropTypes.func,
PropTypes.node,
]),
};