|
|
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
|