UNPKG

ant-design-vue

Version:

An enterprise-class UI design language and Vue-based implementation

54 lines (42 loc) 1.76 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.genArrProps = genArrProps; exports.valueProp = valueProp; var _vueTypes = require('../../_util/vue-types'); var _vueTypes2 = _interopRequireDefault(_vueTypes); var _util = require('./util'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var internalValProp = _vueTypes2['default'].oneOfType([_vueTypes2['default'].string, _vueTypes2['default'].number]); function genArrProps(propType) { return _vueTypes2['default'].oneOfType([propType, _vueTypes2['default'].arrayOf(propType)]); } /** * Origin code check `multiple` is true when `treeCheckStrictly` & `labelInValue`. * But in process logic is already cover to array. * Check array is not necessary. Let's simplify this check logic. */ function valueProp() { for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } var props = args[0], propName = args[1], Component = args[2]; if ((0, _util.isLabelInValue)(props)) { var _err = genArrProps(_vueTypes2['default'].shape({ label: _vueTypes2['default'].node, value: internalValProp }).loose).apply(undefined, args); if (_err) { return new Error('Invalid prop `' + propName + '` supplied to `' + Component + '`. ' + 'You should use { label: string, value: string | number } or [{ label: string, value: string | number }] instead.'); } return null; } var err = genArrProps(internalValProp).apply(undefined, args); if (err) { return new Error('Invalid prop `' + propName + '` supplied to `' + Component + '`. ' + 'You should use string or [string] instead.'); } return null; }