vue-antd-ui
Version:
An enterprise-class UI design language and Vue-based implementation
83 lines (80 loc) • 3.4 kB
JavaScript
import PropTypes from '../../_util/vue-types';
import { SHOW_ALL, SHOW_PARENT, SHOW_CHILD } from './strategies';
function nonEmptyStringType(props, propsName) {
var value = props[propsName];
if (typeof value !== 'string' || !value) {
return new Error(); // Just a flag, so don't need message.
}
}
function valueType(props, propName, componentName) {
var labelInValueShape = PropTypes.shape({
value: nonEmptyStringType,
label: PropTypes.node
});
if (props.labelInValue) {
var validate = PropTypes.oneOfType([PropTypes.arrayOf(labelInValueShape), labelInValueShape]);
var error = validate.apply(undefined, arguments);
if (error) {
return new Error('Invalid prop `' + propName + '` supplied to `' + componentName + '`, ' + ('when `labelInValue` is `true`, `' + propName + '` should in ') + 'shape of `{ value: string, label?: string }`.');
}
} else if (props.treeCheckable && props.treeCheckStrictly) {
var _validate = PropTypes.oneOfType([PropTypes.arrayOf(labelInValueShape), labelInValueShape]);
var _error = _validate.apply(undefined, arguments);
if (_error) {
return new Error('Invalid prop `' + propName + '` supplied to `' + componentName + '`, ' + 'when `treeCheckable` and `treeCheckStrictly` are `true`, ' + ('`' + propName + '` should in shape of `{ value: string, label?: string }`.'));
}
} else if (props.multiple && props[propName] === '') {
return new Error('Invalid prop `' + propName + '` of type `string` supplied to `' + componentName + '`, ' + 'expected `array` when `multiple` is `true`.');
} else {
var _validate2 = PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.string), PropTypes.string]);
return _validate2.apply(undefined, arguments);
}
}
export var SelectPropTypes = {
// className: PropTypes.string,
prefixCls: PropTypes.string,
multiple: PropTypes.bool,
filterTreeNode: PropTypes.any,
showSearch: PropTypes.bool,
disabled: PropTypes.bool,
showArrow: PropTypes.bool,
allowClear: PropTypes.bool,
defaultOpen: PropTypes.bool,
open: PropTypes.bool,
transitionName: PropTypes.string,
animation: PropTypes.string,
choiceTransitionName: PropTypes.string,
// onClick: PropTypes.func,
// onChange: PropTypes.func,
// onSelect: PropTypes.func,
// onDeselect: PropTypes.func,
// onSearch: PropTypes.func,
searchPlaceholder: PropTypes.string,
placeholder: PropTypes.any,
inputValue: PropTypes.any,
value: PropTypes.any,
defaultValue: PropTypes.any,
label: PropTypes.any, // vnode
defaultLabel: PropTypes.any,
labelInValue: PropTypes.bool,
dropdownClassName: PropTypes.string,
dropdownStyle: PropTypes.object,
dropdownPopupAlign: PropTypes.object,
dropdownVisibleChange: PropTypes.func,
maxTagTextLength: PropTypes.number,
showCheckedStrategy: PropTypes.oneOf([SHOW_ALL, SHOW_PARENT, SHOW_CHILD]),
treeCheckStrictly: PropTypes.bool,
treeIcon: PropTypes.bool,
treeLine: PropTypes.bool,
treeDefaultExpandAll: PropTypes.bool,
treeCheckable: PropTypes.any, // bool vnode
treeNodeLabelProp: PropTypes.string,
treeNodeFilterProp: PropTypes.string,
treeData: PropTypes.array,
treeDataSimpleMode: PropTypes.oneOfType([PropTypes.bool, PropTypes.object]),
loadData: PropTypes.func,
dropdownMatchSelectWidth: PropTypes.bool,
notFoundContent: PropTypes.any,
children: PropTypes.any,
autoFocus: PropTypes.bool
};