| function _extends() { | 
|     _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; | 
|     }; | 
|   | 
|     return _extends.apply(this, arguments); | 
| } | 
|   | 
| /* eslint no-console:0 */ | 
| var formatRegExp = /%[sdj%]/g; | 
| var warning = function warning() {}; // don't print warning message when in production env or node runtime | 
|   | 
| if (typeof process !== 'undefined' && process.env && process.env.NODE_ENV !== 'production' && typeof window !== | 
|     'undefined' && typeof document !== 'undefined') { | 
|     warning = function warning(type, errors) { | 
|         if (typeof console !== 'undefined' && console.warn) { | 
|             if (errors.every(function(e) { | 
|                     return typeof e === 'string'; | 
|                 })) { | 
|                 console.warn(type, errors); | 
|             } | 
|         } | 
|     }; | 
| } | 
|   | 
| function convertFieldsError(errors) { | 
|     if (!errors || !errors.length) return null; | 
|     var fields = {}; | 
|     errors.forEach(function(error) { | 
|         var field = error.field; | 
|         fields[field] = fields[field] || []; | 
|         fields[field].push(error); | 
|     }); | 
|     return fields; | 
| } | 
|   | 
| function format() { | 
|     for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { | 
|         args[_key] = arguments[_key]; | 
|     } | 
|   | 
|     var i = 1; | 
|     var f = args[0]; | 
|     var len = args.length; | 
|   | 
|     if (typeof f === 'function') { | 
|         return f.apply(null, args.slice(1)); | 
|     } | 
|   | 
|     if (typeof f === 'string') { | 
|         var str = String(f).replace(formatRegExp, function(x) { | 
|             if (x === '%%') { | 
|                 return '%'; | 
|             } | 
|   | 
|             if (i >= len) { | 
|                 return x; | 
|             } | 
|   | 
|             switch (x) { | 
|                 case '%s': | 
|                     return String(args[i++]); | 
|   | 
|                 case '%d': | 
|                     return Number(args[i++]); | 
|   | 
|                 case '%j': | 
|                     try { | 
|                         return JSON.stringify(args[i++]); | 
|                     } catch (_) { | 
|                         return '[Circular]'; | 
|                     } | 
|   | 
|                     break; | 
|   | 
|                 default: | 
|                     return x; | 
|             } | 
|         }); | 
|   | 
|         for (var arg = args[i]; i < len; arg = args[++i]) { | 
|             str += " " + arg; | 
|         } | 
|   | 
|         return str; | 
|     } | 
|   | 
|     return f; | 
| } | 
|   | 
| function isNativeStringType(type) { | 
|     return type === 'string' || type === 'url' || type === 'hex' || type === 'email' || type === 'pattern'; | 
| } | 
|   | 
| function isEmptyValue(value, type) { | 
|     if (value === undefined || value === null) { | 
|         return true; | 
|     } | 
|   | 
|     if (type === 'array' && Array.isArray(value) && !value.length) { | 
|         return true; | 
|     } | 
|   | 
|     if (isNativeStringType(type) && typeof value === 'string' && !value) { | 
|         return true; | 
|     } | 
|   | 
|     return false; | 
| } | 
|   | 
| function asyncParallelArray(arr, func, callback) { | 
|     var results = []; | 
|     var total = 0; | 
|     var arrLength = arr.length; | 
|   | 
|     function count(errors) { | 
|         results.push.apply(results, errors); | 
|         total++; | 
|   | 
|         if (total === arrLength) { | 
|             callback(results); | 
|         } | 
|     } | 
|   | 
|     arr.forEach(function(a) { | 
|         func(a, count); | 
|     }); | 
| } | 
|   | 
| function asyncSerialArray(arr, func, callback) { | 
|     var index = 0; | 
|     var arrLength = arr.length; | 
|   | 
|     function next(errors) { | 
|         if (errors && errors.length) { | 
|             callback(errors); | 
|             return; | 
|         } | 
|   | 
|         var original = index; | 
|         index = index + 1; | 
|   | 
|         if (original < arrLength) { | 
|             func(arr[original], next); | 
|         } else { | 
|             callback([]); | 
|         } | 
|     } | 
|   | 
|     next([]); | 
| } | 
|   | 
| function flattenObjArr(objArr) { | 
|     var ret = []; | 
|     Object.keys(objArr).forEach(function(k) { | 
|         ret.push.apply(ret, objArr[k]); | 
|     }); | 
|     return ret; | 
| } | 
|   | 
| function asyncMap(objArr, option, func, callback) { | 
|     if (option.first) { | 
|         var _pending = new Promise(function(resolve, reject) { | 
|             var next = function next(errors) { | 
|                 callback(errors); | 
|                 return errors.length ? reject({ | 
|                     errors: errors, | 
|                     fields: convertFieldsError(errors) | 
|                 }) : resolve(); | 
|             }; | 
|   | 
|             var flattenArr = flattenObjArr(objArr); | 
|             asyncSerialArray(flattenArr, func, next); | 
|         }); | 
|   | 
|         _pending["catch"](function(e) { | 
|             return e; | 
|         }); | 
|   | 
|         return _pending; | 
|     } | 
|   | 
|     var firstFields = option.firstFields || []; | 
|   | 
|     if (firstFields === true) { | 
|         firstFields = Object.keys(objArr); | 
|     } | 
|   | 
|     var objArrKeys = Object.keys(objArr); | 
|     var objArrLength = objArrKeys.length; | 
|     var total = 0; | 
|     var results = []; | 
|     var pending = new Promise(function(resolve, reject) { | 
|         var next = function next(errors) { | 
|             results.push.apply(results, errors); | 
|             total++; | 
|   | 
|             if (total === objArrLength) { | 
|                 callback(results); | 
|                 return results.length ? reject({ | 
|                     errors: results, | 
|                     fields: convertFieldsError(results) | 
|                 }) : resolve(); | 
|             } | 
|         }; | 
|   | 
|         if (!objArrKeys.length) { | 
|             callback(results); | 
|             resolve(); | 
|         } | 
|   | 
|         objArrKeys.forEach(function(key) { | 
|             var arr = objArr[key]; | 
|   | 
|             if (firstFields.indexOf(key) !== -1) { | 
|                 asyncSerialArray(arr, func, next); | 
|             } else { | 
|                 asyncParallelArray(arr, func, next); | 
|             } | 
|         }); | 
|     }); | 
|     pending["catch"](function(e) { | 
|         return e; | 
|     }); | 
|     return pending; | 
| } | 
|   | 
| function complementError(rule) { | 
|     return function(oe) { | 
|         if (oe && oe.message) { | 
|             oe.field = oe.field || rule.fullField; | 
|             return oe; | 
|         } | 
|   | 
|         return { | 
|             message: typeof oe === 'function' ? oe() : oe, | 
|             field: oe.field || rule.fullField | 
|         }; | 
|     }; | 
| } | 
|   | 
| function deepMerge(target, source) { | 
|     if (source) { | 
|         for (var s in source) { | 
|             if (source.hasOwnProperty(s)) { | 
|                 var value = source[s]; | 
|   | 
|                 if (typeof value === 'object' && typeof target[s] === 'object') { | 
|                     target[s] = _extends({}, target[s], {}, value); | 
|                 } else { | 
|                     target[s] = value; | 
|                 } | 
|             } | 
|         } | 
|     } | 
|   | 
|     return target; | 
| } | 
|   | 
| /** | 
|  *  Rule for validating required fields. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param source The source object being validated. | 
|  *  @param errors An array of errors that this rule may add | 
|  *  validation errors to. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function required(rule, value, source, errors, options, type) { | 
|     if (rule.required && (!source.hasOwnProperty(rule.field) || isEmptyValue(value, type || rule.type))) { | 
|         errors.push(format(options.messages.required, rule.fullField)); | 
|     } | 
| } | 
|   | 
| /** | 
|  *  Rule for validating whitespace. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param source The source object being validated. | 
|  *  @param errors An array of errors that this rule may add | 
|  *  validation errors to. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function whitespace(rule, value, source, errors, options) { | 
|     if (/^\s+$/.test(value) || value === '') { | 
|         errors.push(format(options.messages.whitespace, rule.fullField)); | 
|     } | 
| } | 
|   | 
| /* eslint max-len:0 */ | 
|   | 
| var pattern = { | 
|     // http://emailregex.com/ | 
|     email: /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/, | 
|     url: new RegExp( | 
|         "^(?!mailto:)(?:(?:http|https|ftp)://|//)(?:\\S+(?::\\S*)?@)?(?:(?:(?:[1-9]\\d?|1\\d\\d|2[01]\\d|22[0-3])(?:\\.(?:1?\\d{1,2}|2[0-4]\\d|25[0-5])){2}(?:\\.(?:[0-9]\\d?|1\\d\\d|2[0-4]\\d|25[0-4]))|(?:(?:[a-z\\u00a1-\\uffff0-9]+-*)*[a-z\\u00a1-\\uffff0-9]+)(?:\\.(?:[a-z\\u00a1-\\uffff0-9]+-*)*[a-z\\u00a1-\\uffff0-9]+)*(?:\\.(?:[a-z\\u00a1-\\uffff]{2,})))|localhost)(?::\\d{2,5})?(?:(/|\\?|#)[^\\s]*)?$", | 
|         'i'), | 
|     hex: /^#?([a-f0-9]{6}|[a-f0-9]{3})$/i | 
| }; | 
| var types = { | 
|     integer: function integer(value) { | 
|         return types.number(value) && parseInt(value, 10) === value; | 
|     }, | 
|     "float": function float(value) { | 
|         return types.number(value) && !types.integer(value); | 
|     }, | 
|     array: function array(value) { | 
|         return Array.isArray(value); | 
|     }, | 
|     regexp: function regexp(value) { | 
|         if (value instanceof RegExp) { | 
|             return true; | 
|         } | 
|   | 
|         try { | 
|             return !!new RegExp(value); | 
|         } catch (e) { | 
|             return false; | 
|         } | 
|     }, | 
|     date: function date(value) { | 
|         return typeof value.getTime === 'function' && typeof value.getMonth === 'function' && typeof value.getYear === | 
|             'function'; | 
|     }, | 
|     number: function number(value) { | 
|         if (isNaN(value)) { | 
|             return false; | 
|         } | 
|   | 
|         // 修改源码,将字符串数值先转为数值 | 
|         return typeof +value === 'number'; | 
|     }, | 
|     object: function object(value) { | 
|         return typeof value === 'object' && !types.array(value); | 
|     }, | 
|     method: function method(value) { | 
|         return typeof value === 'function'; | 
|     }, | 
|     email: function email(value) { | 
|         return typeof value === 'string' && !!value.match(pattern.email) && value.length < 255; | 
|     }, | 
|     url: function url(value) { | 
|         return typeof value === 'string' && !!value.match(pattern.url); | 
|     }, | 
|     hex: function hex(value) { | 
|         return typeof value === 'string' && !!value.match(pattern.hex); | 
|     } | 
| }; | 
| /** | 
|  *  Rule for validating the type of a value. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param source The source object being validated. | 
|  *  @param errors An array of errors that this rule may add | 
|  *  validation errors to. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function type(rule, value, source, errors, options) { | 
|     if (rule.required && value === undefined) { | 
|         required(rule, value, source, errors, options); | 
|         return; | 
|     } | 
|   | 
|     var custom = ['integer', 'float', 'array', 'regexp', 'object', 'method', 'email', 'number', 'date', 'url', 'hex']; | 
|     var ruleType = rule.type; | 
|   | 
|     if (custom.indexOf(ruleType) > -1) { | 
|         if (!types[ruleType](value)) { | 
|             errors.push(format(options.messages.types[ruleType], rule.fullField, rule.type)); | 
|         } // straight typeof check | 
|   | 
|     } else if (ruleType && typeof value !== rule.type) { | 
|         errors.push(format(options.messages.types[ruleType], rule.fullField, rule.type)); | 
|     } | 
| } | 
|   | 
| /** | 
|  *  Rule for validating minimum and maximum allowed values. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param source The source object being validated. | 
|  *  @param errors An array of errors that this rule may add | 
|  *  validation errors to. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function range(rule, value, source, errors, options) { | 
|     var len = typeof rule.len === 'number'; | 
|     var min = typeof rule.min === 'number'; | 
|     var max = typeof rule.max === 'number'; // 正则匹配码点范围从U+010000一直到U+10FFFF的文字(补充平面Supplementary Plane) | 
|   | 
|     var spRegexp = /[\uD800-\uDBFF][\uDC00-\uDFFF]/g; | 
|     var val = value; | 
|     var key = null; | 
|     var num = typeof value === 'number'; | 
|     var str = typeof value === 'string'; | 
|     var arr = Array.isArray(value); | 
|   | 
|     if (num) { | 
|         key = 'number'; | 
|     } else if (str) { | 
|         key = 'string'; | 
|     } else if (arr) { | 
|         key = 'array'; | 
|     } // if the value is not of a supported type for range validation | 
|     // the validation rule rule should use the | 
|     // type property to also test for a particular type | 
|   | 
|   | 
|     if (!key) { | 
|         return false; | 
|     } | 
|   | 
|     if (arr) { | 
|         val = value.length; | 
|     } | 
|   | 
|     if (str) { | 
|         // 处理码点大于U+010000的文字length属性不准确的bug,如"𠮷𠮷𠮷".lenght !== 3 | 
|         val = value.replace(spRegexp, '_').length; | 
|     } | 
|   | 
|     if (len) { | 
|         if (val !== rule.len) { | 
|             errors.push(format(options.messages[key].len, rule.fullField, rule.len)); | 
|         } | 
|     } else if (min && !max && val < rule.min) { | 
|         errors.push(format(options.messages[key].min, rule.fullField, rule.min)); | 
|     } else if (max && !min && val > rule.max) { | 
|         errors.push(format(options.messages[key].max, rule.fullField, rule.max)); | 
|     } else if (min && max && (val < rule.min || val > rule.max)) { | 
|         errors.push(format(options.messages[key].range, rule.fullField, rule.min, rule.max)); | 
|     } | 
| } | 
|   | 
| var ENUM = 'enum'; | 
| /** | 
|  *  Rule for validating a value exists in an enumerable list. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param source The source object being validated. | 
|  *  @param errors An array of errors that this rule may add | 
|  *  validation errors to. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function enumerable(rule, value, source, errors, options) { | 
|     rule[ENUM] = Array.isArray(rule[ENUM]) ? rule[ENUM] : []; | 
|   | 
|     if (rule[ENUM].indexOf(value) === -1) { | 
|         errors.push(format(options.messages[ENUM], rule.fullField, rule[ENUM].join(', '))); | 
|     } | 
| } | 
|   | 
| /** | 
|  *  Rule for validating a regular expression pattern. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param source The source object being validated. | 
|  *  @param errors An array of errors that this rule may add | 
|  *  validation errors to. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function pattern$1(rule, value, source, errors, options) { | 
|     if (rule.pattern) { | 
|         if (rule.pattern instanceof RegExp) { | 
|             // if a RegExp instance is passed, reset `lastIndex` in case its `global` | 
|             // flag is accidentally set to `true`, which in a validation scenario | 
|             // is not necessary and the result might be misleading | 
|             rule.pattern.lastIndex = 0; | 
|   | 
|             if (!rule.pattern.test(value)) { | 
|                 errors.push(format(options.messages.pattern.mismatch, rule.fullField, value, rule.pattern)); | 
|             } | 
|         } else if (typeof rule.pattern === 'string') { | 
|             var _pattern = new RegExp(rule.pattern); | 
|   | 
|             if (!_pattern.test(value)) { | 
|                 errors.push(format(options.messages.pattern.mismatch, rule.fullField, value, rule.pattern)); | 
|             } | 
|         } | 
|     } | 
| } | 
|   | 
| var rules = { | 
|     required: required, | 
|     whitespace: whitespace, | 
|     type: type, | 
|     range: range, | 
|     "enum": enumerable, | 
|     pattern: pattern$1 | 
| }; | 
|   | 
| /** | 
|  *  Performs validation for string types. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param callback The callback function. | 
|  *  @param source The source object being validated. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function string(rule, value, callback, source, options) { | 
|     var errors = []; | 
|     var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field); | 
|   | 
|     if (validate) { | 
|         if (isEmptyValue(value, 'string') && !rule.required) { | 
|             return callback(); | 
|         } | 
|   | 
|         rules.required(rule, value, source, errors, options, 'string'); | 
|   | 
|         if (!isEmptyValue(value, 'string')) { | 
|             rules.type(rule, value, source, errors, options); | 
|             rules.range(rule, value, source, errors, options); | 
|             rules.pattern(rule, value, source, errors, options); | 
|   | 
|             if (rule.whitespace === true) { | 
|                 rules.whitespace(rule, value, source, errors, options); | 
|             } | 
|         } | 
|     } | 
|   | 
|     callback(errors); | 
| } | 
|   | 
| /** | 
|  *  Validates a function. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param callback The callback function. | 
|  *  @param source The source object being validated. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function method(rule, value, callback, source, options) { | 
|     var errors = []; | 
|     var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field); | 
|   | 
|     if (validate) { | 
|         if (isEmptyValue(value) && !rule.required) { | 
|             return callback(); | 
|         } | 
|   | 
|         rules.required(rule, value, source, errors, options); | 
|   | 
|         if (value !== undefined) { | 
|             rules.type(rule, value, source, errors, options); | 
|         } | 
|     } | 
|   | 
|     callback(errors); | 
| } | 
|   | 
| /** | 
|  *  Validates a number. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param callback The callback function. | 
|  *  @param source The source object being validated. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function number(rule, value, callback, source, options) { | 
|     var errors = []; | 
|     var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field); | 
|   | 
|     if (validate) { | 
|         if (value === '') { | 
|             value = undefined; | 
|         } | 
|   | 
|         if (isEmptyValue(value) && !rule.required) { | 
|             return callback(); | 
|         } | 
|   | 
|         rules.required(rule, value, source, errors, options); | 
|   | 
|         if (value !== undefined) { | 
|             rules.type(rule, value, source, errors, options); | 
|             rules.range(rule, value, source, errors, options); | 
|         } | 
|     } | 
|   | 
|     callback(errors); | 
| } | 
|   | 
| /** | 
|  *  Validates a boolean. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param callback The callback function. | 
|  *  @param source The source object being validated. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function _boolean(rule, value, callback, source, options) { | 
|     var errors = []; | 
|     var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field); | 
|   | 
|     if (validate) { | 
|         if (isEmptyValue(value) && !rule.required) { | 
|             return callback(); | 
|         } | 
|   | 
|         rules.required(rule, value, source, errors, options); | 
|   | 
|         if (value !== undefined) { | 
|             rules.type(rule, value, source, errors, options); | 
|         } | 
|     } | 
|   | 
|     callback(errors); | 
| } | 
|   | 
| /** | 
|  *  Validates the regular expression type. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param callback The callback function. | 
|  *  @param source The source object being validated. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function regexp(rule, value, callback, source, options) { | 
|     var errors = []; | 
|     var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field); | 
|   | 
|     if (validate) { | 
|         if (isEmptyValue(value) && !rule.required) { | 
|             return callback(); | 
|         } | 
|   | 
|         rules.required(rule, value, source, errors, options); | 
|   | 
|         if (!isEmptyValue(value)) { | 
|             rules.type(rule, value, source, errors, options); | 
|         } | 
|     } | 
|   | 
|     callback(errors); | 
| } | 
|   | 
| /** | 
|  *  Validates a number is an integer. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param callback The callback function. | 
|  *  @param source The source object being validated. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function integer(rule, value, callback, source, options) { | 
|     var errors = []; | 
|     var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field); | 
|   | 
|     if (validate) { | 
|         if (isEmptyValue(value) && !rule.required) { | 
|             return callback(); | 
|         } | 
|   | 
|         rules.required(rule, value, source, errors, options); | 
|   | 
|         if (value !== undefined) { | 
|             rules.type(rule, value, source, errors, options); | 
|             rules.range(rule, value, source, errors, options); | 
|         } | 
|     } | 
|   | 
|     callback(errors); | 
| } | 
|   | 
| /** | 
|  *  Validates a number is a floating point number. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param callback The callback function. | 
|  *  @param source The source object being validated. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function floatFn(rule, value, callback, source, options) { | 
|     var errors = []; | 
|     var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field); | 
|   | 
|     if (validate) { | 
|         if (isEmptyValue(value) && !rule.required) { | 
|             return callback(); | 
|         } | 
|   | 
|         rules.required(rule, value, source, errors, options); | 
|   | 
|         if (value !== undefined) { | 
|             rules.type(rule, value, source, errors, options); | 
|             rules.range(rule, value, source, errors, options); | 
|         } | 
|     } | 
|   | 
|     callback(errors); | 
| } | 
|   | 
| /** | 
|  *  Validates an array. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param callback The callback function. | 
|  *  @param source The source object being validated. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function array(rule, value, callback, source, options) { | 
|     var errors = []; | 
|     var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field); | 
|   | 
|     if (validate) { | 
|         if (isEmptyValue(value, 'array') && !rule.required) { | 
|             return callback(); | 
|         } | 
|   | 
|         rules.required(rule, value, source, errors, options, 'array'); | 
|   | 
|         if (!isEmptyValue(value, 'array')) { | 
|             rules.type(rule, value, source, errors, options); | 
|             rules.range(rule, value, source, errors, options); | 
|         } | 
|     } | 
|   | 
|     callback(errors); | 
| } | 
|   | 
| /** | 
|  *  Validates an object. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param callback The callback function. | 
|  *  @param source The source object being validated. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function object(rule, value, callback, source, options) { | 
|     var errors = []; | 
|     var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field); | 
|   | 
|     if (validate) { | 
|         if (isEmptyValue(value) && !rule.required) { | 
|             return callback(); | 
|         } | 
|   | 
|         rules.required(rule, value, source, errors, options); | 
|   | 
|         if (value !== undefined) { | 
|             rules.type(rule, value, source, errors, options); | 
|         } | 
|     } | 
|   | 
|     callback(errors); | 
| } | 
|   | 
| var ENUM$1 = 'enum'; | 
| /** | 
|  *  Validates an enumerable list. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param callback The callback function. | 
|  *  @param source The source object being validated. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function enumerable$1(rule, value, callback, source, options) { | 
|     var errors = []; | 
|     var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field); | 
|   | 
|     if (validate) { | 
|         if (isEmptyValue(value) && !rule.required) { | 
|             return callback(); | 
|         } | 
|   | 
|         rules.required(rule, value, source, errors, options); | 
|   | 
|         if (value !== undefined) { | 
|             rules[ENUM$1](rule, value, source, errors, options); | 
|         } | 
|     } | 
|   | 
|     callback(errors); | 
| } | 
|   | 
| /** | 
|  *  Validates a regular expression pattern. | 
|  * | 
|  *  Performs validation when a rule only contains | 
|  *  a pattern property but is not declared as a string type. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param callback The callback function. | 
|  *  @param source The source object being validated. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function pattern$2(rule, value, callback, source, options) { | 
|     var errors = []; | 
|     var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field); | 
|   | 
|     if (validate) { | 
|         if (isEmptyValue(value, 'string') && !rule.required) { | 
|             return callback(); | 
|         } | 
|   | 
|         rules.required(rule, value, source, errors, options); | 
|   | 
|         if (!isEmptyValue(value, 'string')) { | 
|             rules.pattern(rule, value, source, errors, options); | 
|         } | 
|     } | 
|   | 
|     callback(errors); | 
| } | 
|   | 
| function date(rule, value, callback, source, options) { | 
|     var errors = []; | 
|     var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field);  | 
|   | 
|     if (validate) { | 
|         if (isEmptyValue(value) && !rule.required) { | 
|             return callback(); | 
|         } | 
|   | 
|         rules.required(rule, value, source, errors, options); | 
|   | 
|         if (!isEmptyValue(value)) { | 
|             var dateObject; | 
|   | 
|             if (typeof value === 'number') { | 
|                 dateObject = new Date(value); | 
|             } else { | 
|                 dateObject = value; | 
|             } | 
|   | 
|             rules.type(rule, dateObject, source, errors, options); | 
|   | 
|             if (dateObject) { | 
|                 rules.range(rule, dateObject.getTime(), source, errors, options); | 
|             } | 
|         } | 
|     } | 
|   | 
|     callback(errors); | 
| } | 
|   | 
| function required$1(rule, value, callback, source, options) { | 
|     var errors = []; | 
|     var type = Array.isArray(value) ? 'array' : typeof value; | 
|     rules.required(rule, value, source, errors, options, type); | 
|     callback(errors); | 
| } | 
|   | 
| function type$1(rule, value, callback, source, options) { | 
|     var ruleType = rule.type; | 
|     var errors = []; | 
|     var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field); | 
|   | 
|     if (validate) { | 
|         if (isEmptyValue(value, ruleType) && !rule.required) { | 
|             return callback(); | 
|         } | 
|   | 
|         rules.required(rule, value, source, errors, options, ruleType); | 
|   | 
|         if (!isEmptyValue(value, ruleType)) { | 
|             rules.type(rule, value, source, errors, options); | 
|         } | 
|     } | 
|   | 
|     callback(errors); | 
| } | 
|   | 
| /** | 
|  *  Performs validation for any type. | 
|  * | 
|  *  @param rule The validation rule. | 
|  *  @param value The value of the field on the source object. | 
|  *  @param callback The callback function. | 
|  *  @param source The source object being validated. | 
|  *  @param options The validation options. | 
|  *  @param options.messages The validation messages. | 
|  */ | 
|   | 
| function any(rule, value, callback, source, options) { | 
|     var errors = []; | 
|     var validate = rule.required || !rule.required && source.hasOwnProperty(rule.field); | 
|   | 
|     if (validate) { | 
|         if (isEmptyValue(value) && !rule.required) { | 
|             return callback(); | 
|         } | 
|   | 
|         rules.required(rule, value, source, errors, options); | 
|     } | 
|   | 
|     callback(errors); | 
| } | 
|   | 
| var validators = { | 
|     string: string, | 
|     method: method, | 
|     number: number, | 
|     "boolean": _boolean, | 
|     regexp: regexp, | 
|     integer: integer, | 
|     "float": floatFn, | 
|     array: array, | 
|     object: object, | 
|     "enum": enumerable$1, | 
|     pattern: pattern$2, | 
|     date: date, | 
|     url: type$1, | 
|     hex: type$1, | 
|     email: type$1, | 
|     required: required$1, | 
|     any: any | 
| }; | 
|   | 
| function newMessages() { | 
|     return { | 
|         "default": 'Validation error on field %s', | 
|         required: '%s is required', | 
|         "enum": '%s must be one of %s', | 
|         whitespace: '%s cannot be empty', | 
|         date: { | 
|             format: '%s date %s is invalid for format %s', | 
|             parse: '%s date could not be parsed, %s is invalid ', | 
|             invalid: '%s date %s is invalid' | 
|         }, | 
|         types: { | 
|             string: '%s is not a %s', | 
|             method: '%s is not a %s (function)', | 
|             array: '%s is not an %s', | 
|             object: '%s is not an %s', | 
|             number: '%s is not a %s', | 
|             date: '%s is not a %s', | 
|             "boolean": '%s is not a %s', | 
|             integer: '%s is not an %s', | 
|             "float": '%s is not a %s', | 
|             regexp: '%s is not a valid %s', | 
|             email: '%s is not a valid %s', | 
|             url: '%s is not a valid %s', | 
|             hex: '%s is not a valid %s' | 
|         }, | 
|         string: { | 
|             len: '%s must be exactly %s characters', | 
|             min: '%s must be at least %s characters', | 
|             max: '%s cannot be longer than %s characters', | 
|             range: '%s must be between %s and %s characters' | 
|         }, | 
|         number: { | 
|             len: '%s must equal %s', | 
|             min: '%s cannot be less than %s', | 
|             max: '%s cannot be greater than %s', | 
|             range: '%s must be between %s and %s' | 
|         }, | 
|         array: { | 
|             len: '%s must be exactly %s in length', | 
|             min: '%s cannot be less than %s in length', | 
|             max: '%s cannot be greater than %s in length', | 
|             range: '%s must be between %s and %s in length' | 
|         }, | 
|         pattern: { | 
|             mismatch: '%s value %s does not match pattern %s' | 
|         }, | 
|         clone: function clone() { | 
|             var cloned = JSON.parse(JSON.stringify(this)); | 
|             cloned.clone = this.clone; | 
|             return cloned; | 
|         } | 
|     }; | 
| } | 
| var messages = newMessages(); | 
|   | 
| /** | 
|  *  Encapsulates a validation schema. | 
|  * | 
|  *  @param descriptor An object declaring validation rules | 
|  *  for this schema. | 
|  */ | 
|   | 
| function Schema(descriptor) { | 
|     this.rules = null; | 
|     this._messages = messages; | 
|     this.define(descriptor); | 
| } | 
|   | 
| Schema.prototype = { | 
|     messages: function messages(_messages) { | 
|         if (_messages) { | 
|             this._messages = deepMerge(newMessages(), _messages); | 
|         } | 
|   | 
|         return this._messages; | 
|     }, | 
|     define: function define(rules) { | 
|         if (!rules) { | 
|             throw new Error('Cannot configure a schema with no rules'); | 
|         } | 
|   | 
|         if (typeof rules !== 'object' || Array.isArray(rules)) { | 
|             throw new Error('Rules must be an object'); | 
|         } | 
|   | 
|         this.rules = {}; | 
|         var z; | 
|         var item; | 
|   | 
|         for (z in rules) { | 
|             if (rules.hasOwnProperty(z)) { | 
|                 item = rules[z]; | 
|                 this.rules[z] = Array.isArray(item) ? item : [item]; | 
|             } | 
|         } | 
|     }, | 
|     validate: function validate(source_, o, oc) { | 
|         var _this = this; | 
|   | 
|         if (o === void 0) { | 
|             o = {}; | 
|         } | 
|   | 
|         if (oc === void 0) { | 
|             oc = function oc() {}; | 
|         } | 
|   | 
|         var source = source_; | 
|         var options = o; | 
|         var callback = oc; | 
|   | 
|         if (typeof options === 'function') { | 
|             callback = options; | 
|             options = {}; | 
|         } | 
|   | 
|         if (!this.rules || Object.keys(this.rules).length === 0) { | 
|             if (callback) { | 
|                 callback(); | 
|             } | 
|   | 
|             return Promise.resolve(); | 
|         } | 
|   | 
|         function complete(results) { | 
|             var i; | 
|             var errors = []; | 
|             var fields = {}; | 
|   | 
|             function add(e) { | 
|                 if (Array.isArray(e)) { | 
|                     var _errors; | 
|   | 
|                     errors = (_errors = errors).concat.apply(_errors, e); | 
|                 } else { | 
|                     errors.push(e); | 
|                 } | 
|             } | 
|   | 
|             for (i = 0; i < results.length; i++) { | 
|                 add(results[i]); | 
|             } | 
|   | 
|             if (!errors.length) { | 
|                 errors = null; | 
|                 fields = null; | 
|             } else { | 
|                 fields = convertFieldsError(errors); | 
|             } | 
|   | 
|             callback(errors, fields); | 
|         } | 
|   | 
|         if (options.messages) { | 
|             var messages$1 = this.messages(); | 
|   | 
|             if (messages$1 === messages) { | 
|                 messages$1 = newMessages(); | 
|             } | 
|   | 
|             deepMerge(messages$1, options.messages); | 
|             options.messages = messages$1; | 
|         } else { | 
|             options.messages = this.messages(); | 
|         } | 
|   | 
|         var arr; | 
|         var value; | 
|         var series = {}; | 
|         var keys = options.keys || Object.keys(this.rules); | 
|         keys.forEach(function(z) { | 
|             arr = _this.rules[z]; | 
|             value = source[z]; | 
|             arr.forEach(function(r) { | 
|                 var rule = r; | 
|   | 
|                 if (typeof rule.transform === 'function') { | 
|                     if (source === source_) { | 
|                         source = _extends({}, source); | 
|                     } | 
|   | 
|                     value = source[z] = rule.transform(value); | 
|                 } | 
|   | 
|                 if (typeof rule === 'function') { | 
|                     rule = { | 
|                         validator: rule | 
|                     }; | 
|                 } else { | 
|                     rule = _extends({}, rule); | 
|                 } | 
|   | 
|                 rule.validator = _this.getValidationMethod(rule); | 
|                 rule.field = z; | 
|                 rule.fullField = rule.fullField || z; | 
|                 rule.type = _this.getType(rule); | 
|   | 
|                 if (!rule.validator) { | 
|                     return; | 
|                 } | 
|   | 
|                 series[z] = series[z] || []; | 
|                 series[z].push({ | 
|                     rule: rule, | 
|                     value: value, | 
|                     source: source, | 
|                     field: z | 
|                 }); | 
|             }); | 
|         }); | 
|         var errorFields = {}; | 
|         return asyncMap(series, options, function(data, doIt) { | 
|             var rule = data.rule; | 
|             var deep = (rule.type === 'object' || rule.type === 'array') && (typeof rule.fields === 'object' || typeof rule.defaultField === | 
|                 'object'); | 
|             deep = deep && (rule.required || !rule.required && data.value); | 
|             rule.field = data.field; | 
|   | 
|             function addFullfield(key, schema) { | 
|                 return _extends({}, schema, { | 
|                     fullField: rule.fullField + "." + key | 
|                 }); | 
|             } | 
|   | 
|             function cb(e) { | 
|                 if (e === void 0) { | 
|                     e = []; | 
|                 } | 
|   | 
|                 var errors = e; | 
|   | 
|                 if (!Array.isArray(errors)) { | 
|                     errors = [errors]; | 
|                 } | 
|   | 
|                 if (!options.suppressWarning && errors.length) { | 
|                     Schema.warning('async-validator:', errors); | 
|                 } | 
|   | 
|                 if (errors.length && rule.message) { | 
|                     errors = [].concat(rule.message); | 
|                 } | 
|   | 
|                 errors = errors.map(complementError(rule)); | 
|   | 
|                 if (options.first && errors.length) { | 
|                     errorFields[rule.field] = 1; | 
|                     return doIt(errors); | 
|                 } | 
|   | 
|                 if (!deep) { | 
|                     doIt(errors); | 
|                 } else { | 
|                     // if rule is required but the target object | 
|                     // does not exist fail at the rule level and don't | 
|                     // go deeper | 
|                     if (rule.required && !data.value) { | 
|                         if (rule.message) { | 
|                             errors = [].concat(rule.message).map(complementError(rule)); | 
|                         } else if (options.error) { | 
|                             errors = [options.error(rule, format(options.messages.required, rule.field))]; | 
|                         } else { | 
|                             errors = []; | 
|                         } | 
|   | 
|                         return doIt(errors); | 
|                     } | 
|   | 
|                     var fieldsSchema = {}; | 
|   | 
|                     if (rule.defaultField) { | 
|                         for (var k in data.value) { | 
|                             if (data.value.hasOwnProperty(k)) { | 
|                                 fieldsSchema[k] = rule.defaultField; | 
|                             } | 
|                         } | 
|                     } | 
|   | 
|                     fieldsSchema = _extends({}, fieldsSchema, {}, data.rule.fields); | 
|   | 
|                     for (var f in fieldsSchema) { | 
|                         if (fieldsSchema.hasOwnProperty(f)) { | 
|                             var fieldSchema = Array.isArray(fieldsSchema[f]) ? fieldsSchema[f] : [fieldsSchema[f]]; | 
|                             fieldsSchema[f] = fieldSchema.map(addFullfield.bind(null, f)); | 
|                         } | 
|                     } | 
|   | 
|                     var schema = new Schema(fieldsSchema); | 
|                     schema.messages(options.messages); | 
|   | 
|                     if (data.rule.options) { | 
|                         data.rule.options.messages = options.messages; | 
|                         data.rule.options.error = options.error; | 
|                     } | 
|   | 
|                     schema.validate(data.value, data.rule.options || options, function(errs) { | 
|                         var finalErrors = []; | 
|   | 
|                         if (errors && errors.length) { | 
|                             finalErrors.push.apply(finalErrors, errors); | 
|                         } | 
|   | 
|                         if (errs && errs.length) { | 
|                             finalErrors.push.apply(finalErrors, errs); | 
|                         } | 
|   | 
|                         doIt(finalErrors.length ? finalErrors : null); | 
|                     }); | 
|                 } | 
|             } | 
|   | 
|             var res; | 
|   | 
|             if (rule.asyncValidator) { | 
|                 res = rule.asyncValidator(rule, data.value, cb, data.source, options); | 
|             } else if (rule.validator) { | 
|                 res = rule.validator(rule, data.value, cb, data.source, options); | 
|   | 
|                 if (res === true) { | 
|                     cb(); | 
|                 } else if (res === false) { | 
|                     cb(rule.message || rule.field + " fails"); | 
|                 } else if (res instanceof Array) { | 
|                     cb(res); | 
|                 } else if (res instanceof Error) { | 
|                     cb(res.message); | 
|                 } | 
|             } | 
|   | 
|             if (res && res.then) { | 
|                 res.then(function() { | 
|                     return cb(); | 
|                 }, function(e) { | 
|                     return cb(e); | 
|                 }); | 
|             } | 
|         }, function(results) { | 
|             complete(results); | 
|         }); | 
|     }, | 
|     getType: function getType(rule) { | 
|         if (rule.type === undefined && rule.pattern instanceof RegExp) { | 
|             rule.type = 'pattern'; | 
|         } | 
|   | 
|         if (typeof rule.validator !== 'function' && rule.type && !validators.hasOwnProperty(rule.type)) { | 
|             throw new Error(format('Unknown rule type %s', rule.type)); | 
|         } | 
|   | 
|         return rule.type || 'string'; | 
|     }, | 
|     getValidationMethod: function getValidationMethod(rule) { | 
|         if (typeof rule.validator === 'function') { | 
|             return rule.validator; | 
|         } | 
|   | 
|         var keys = Object.keys(rule); | 
|         var messageIndex = keys.indexOf('message'); | 
|   | 
|         if (messageIndex !== -1) { | 
|             keys.splice(messageIndex, 1); | 
|         } | 
|   | 
|         if (keys.length === 1 && keys[0] === 'required') { | 
|             return validators.required; | 
|         } | 
|   | 
|         return validators[this.getType(rule)] || false; | 
|     } | 
| }; | 
|   | 
| Schema.register = function register(type, validator) { | 
|     if (typeof validator !== 'function') { | 
|         throw new Error('Cannot register a validator by type, validator is not a function'); | 
|     } | 
|   | 
|     validators[type] = validator; | 
| }; | 
|   | 
| Schema.warning = warning; | 
| Schema.messages = messages; | 
|   | 
| export default Schema; | 
| //# sourceMappingURL=index.js.map |