Simplified validate function. Removed validateAll function, merged into validate function. Cleaned up code.
This commit is contained in:
parent
368f713dba
commit
bf7bd34567
@ -157,16 +157,6 @@ function notify(target, type, msg, duration) {
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
//Setup a constructor to create a validate function on the created element.
|
||||
this._constructors.push(() => this.element.validate = () => {
|
||||
for (var i = 0; i < this._validators.length; i++) {
|
||||
if (!this._validators[i]()) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
});
|
||||
}
|
||||
|
||||
//Register a new validator
|
||||
@ -206,7 +196,9 @@ function notify(target, type, msg, duration) {
|
||||
*/
|
||||
IgniteTemplate.prototype.validateEmail = function (msg) {
|
||||
return this.validate((value, error) => {
|
||||
if (!value || value.trim().length < 5) {
|
||||
if (!value || value.length == 0) {
|
||||
return error(msg ? msg : `Please enter an email address.`);
|
||||
} else if (value.trim().length < 5) {
|
||||
return error(msg ? msg : `Email address too short.`);
|
||||
} else if (!value.includes('@')) {
|
||||
return error(msg ? msg : 'Email address missing @ symbol.');
|
||||
@ -316,15 +308,33 @@ function notify(target, type, msg, duration) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Validates all the children of an element and returns if they are valid or not.
|
||||
* @returns {Boolean} Whether or not all the children of this element are valid.
|
||||
* Validates this element and all the children within the element.
|
||||
* @returns {Boolean} Whether or not this element and all children in this element are valid.
|
||||
*/
|
||||
HTMLElement.prototype.validateAll = function() {
|
||||
var elements = this.getElementsByTagName("*");
|
||||
for (var i = 0; i < elements.length; i++) {
|
||||
if (elements[i].validate != undefined && !elements[i].validate()) {
|
||||
HTMLElement.prototype.validate = function () {
|
||||
//If this element has a template with validators run them.
|
||||
if (this.template && this.template._validators) {
|
||||
for (var i = 0; i < this.template._validators.length; i++) {
|
||||
if (!this.template._validators[i]()) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
//Look for elements that we can try to validate.
|
||||
var elements = this.getElementsByTagName("*");
|
||||
for (var i = 0; i < elements.length; i++) {
|
||||
var element = elements[i];
|
||||
|
||||
//If this element has a template, and has validators, run them, if any are false, return false.
|
||||
if (element.template && element.template._validators) {
|
||||
for (var v = 0; v < element.template._validators.length; v++) {
|
||||
if (!element.template._validators[v]()) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user