react-form-validator-core
Version:
Core validator component for react forms.
97 lines (79 loc) • 3.85 kB
JavaScript
'use strict';
var isExisty = function isExisty(value) {
return value !== null && value !== undefined;
};
var _isEmpty = function _isEmpty(value) {
if (value instanceof Array) {
return value.length === 0;
}
return value === '' || !isExisty(value);
};
var isEmptyTrimed = function isEmptyTrimed(value) {
if (typeof value === 'string') {
return value.trim() === '';
}
return true;
};
var validations = {
matchRegexp: function matchRegexp(value, regexp) {
var validationRegexp = regexp instanceof RegExp ? regexp : new RegExp(regexp);
return _isEmpty(value) || validationRegexp.test(value);
},
// eslint-disable-next-line
isEmail: function isEmail(value) {
return validations.matchRegexp(value, /^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))$/i);
},
isEmpty: function isEmpty(value) {
return _isEmpty(value);
},
required: function required(value) {
return !_isEmpty(value);
},
trim: function trim(value) {
return !isEmptyTrimed(value);
},
isNumber: function isNumber(value) {
return validations.matchRegexp(value, /^-?[0-9]\d*(\d+)?$/i);
},
isFloat: function isFloat(value) {
return validations.matchRegexp(value, /^(?:-?[1-9]\d*|-?0)?(?:\.\d+)?$/i);
},
isPositive: function isPositive(value) {
if (isExisty(value)) {
return (validations.isNumber(value) || validations.isFloat(value)) && value >= 0;
}
return true;
},
maxNumber: function maxNumber(value, max) {
return _isEmpty(value) || parseInt(value, 10) <= parseInt(max, 10);
},
minNumber: function minNumber(value, min) {
return _isEmpty(value) || parseInt(value, 10) >= parseInt(min, 10);
},
maxFloat: function maxFloat(value, max) {
return _isEmpty(value) || parseFloat(value) <= parseFloat(max);
},
minFloat: function minFloat(value, min) {
return _isEmpty(value) || parseFloat(value) >= parseFloat(min);
},
isString: function isString(value) {
return _isEmpty(value) || typeof value === 'string' || value instanceof String;
},
minStringLength: function minStringLength(value, length) {
return validations.isString(value) && value.length >= length;
},
maxStringLength: function maxStringLength(value, length) {
return validations.isString(value) && value.length <= length;
},
// eslint-disable-next-line no-undef
isFile: function isFile(value) {
return _isEmpty(value) || value instanceof File;
},
maxFileSize: function maxFileSize(value, max) {
return _isEmpty(value) || validations.isFile(value) && value.size <= parseInt(max, 10);
},
allowedExtensions: function allowedExtensions(value, fileTypes) {
return _isEmpty(value) || validations.isFile(value) && fileTypes.split(',').indexOf(value.type) !== -1;
}
};
module.exports = validations;