Simplified validate function. Removed validateAll function, merged into validate function. Cleaned up code.

This commit is contained in:
MattMo 2021-12-28 22:34:36 -08:00
parent 368f713dba
commit bf7bd34567

View File

@ -99,7 +99,7 @@ function notify(target, type, msg, duration) {
* @param {Number} duration The number of miliseconds to show the error. Default is 4000. -1 is infinite. * @param {Number} duration The number of miliseconds to show the error. Default is 4000. -1 is infinite.
* @returns {HTMLElement} The created notification HTMLElement. * @returns {HTMLElement} The created notification HTMLElement.
*/ */
HTMLElement.prototype.error = function(msg, duration = 4000) { HTMLElement.prototype.error = function (msg, duration = 4000) {
return notify(this, "error", msg, duration); return notify(this, "error", msg, duration);
} }
@ -109,7 +109,7 @@ function notify(target, type, msg, duration) {
* @param {Number} duration The number of miliseconds to show the warning. Default is 4000. -1 is infinite. * @param {Number} duration The number of miliseconds to show the warning. Default is 4000. -1 is infinite.
* @returns {HTMLElement} The created notification HTMLElement. * @returns {HTMLElement} The created notification HTMLElement.
*/ */
HTMLElement.prototype.warning = function(msg, duration = 4000) { HTMLElement.prototype.warning = function (msg, duration = 4000) {
return notify(this, "warning", msg, duration); return notify(this, "warning", msg, duration);
} }
@ -119,7 +119,7 @@ function notify(target, type, msg, duration) {
* @param {Number} duration The number of miliseconds to show the notification. Default is 4000. -1 is infinite. * @param {Number} duration The number of miliseconds to show the notification. Default is 4000. -1 is infinite.
* @returns {HTMLElement} The created notification HTMLElement. * @returns {HTMLElement} The created notification HTMLElement.
*/ */
HTMLElement.prototype.success = function(msg, duration = 4000) { HTMLElement.prototype.success = function (msg, duration = 4000) {
return notify(this, "success", msg, duration); return notify(this, "success", msg, duration);
} }
@ -129,7 +129,7 @@ function notify(target, type, msg, duration) {
* @param {Number} duration The number of miliseconds to show the notification. Default is 4000. -1 is infinite. * @param {Number} duration The number of miliseconds to show the notification. Default is 4000. -1 is infinite.
* @returns {HTMLElement} The created notification HTMLElement. * @returns {HTMLElement} The created notification HTMLElement.
*/ */
HTMLElement.prototype.info = function(msg, duration = 4000) { HTMLElement.prototype.info = function (msg, duration = 4000) {
notify(this, "info", msg, duration); notify(this, "info", msg, duration);
} }
@ -144,7 +144,7 @@ function notify(target, type, msg, duration) {
* }) * })
* @returns {IgniteTemplate} This ignite template. * @returns {IgniteTemplate} This ignite template.
*/ */
IgniteTemplate.prototype.validate = function(callback) { IgniteTemplate.prototype.validate = function (callback) {
//Setup the validators array if it doesn't exist. //Setup the validators array if it doesn't exist.
if (!this._validators) { if (!this._validators) {
this._validators = []; this._validators = [];
@ -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 //Register a new validator
@ -204,9 +194,11 @@ function notify(target, type, msg, duration) {
* @param {string|Function|IgniteProperty} msg The message to display when the email is incorrect. If null a default one will show. * @param {string|Function|IgniteProperty} msg The message to display when the email is incorrect. If null a default one will show.
* @returns {IgniteTemplate} This ignite template. * @returns {IgniteTemplate} This ignite template.
*/ */
IgniteTemplate.prototype.validateEmail = function(msg) { IgniteTemplate.prototype.validateEmail = function (msg) {
return this.validate((value, error) => { 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.`); return error(msg ? msg : `Email address too short.`);
} else if (!value.includes('@')) { } else if (!value.includes('@')) {
return error(msg ? msg : 'Email address missing @ symbol.'); return error(msg ? msg : 'Email address missing @ symbol.');
@ -225,7 +217,7 @@ function notify(target, type, msg, duration) {
* @param {string|Function|IgniteProperty} msg The message to display when the email is incorrect. If null a default one will show. * @param {string|Function|IgniteProperty} msg The message to display when the email is incorrect. If null a default one will show.
* @returns {IgniteTemplate} This ignite template. * @returns {IgniteTemplate} This ignite template.
*/ */
IgniteTemplate.prototype.validatePassword = function(msg) { IgniteTemplate.prototype.validatePassword = function (msg) {
return this.validate((value, error) => { return this.validate((value, error) => {
if (!value || value.trim().length < 5) { if (!value || value.trim().length < 5) {
return error(msg ? msg : `Password is must be at least 5 characters.`); return error(msg ? msg : `Password is must be at least 5 characters.`);
@ -243,7 +235,7 @@ function notify(target, type, msg, duration) {
* @param {string|Function|IgniteProperty} msg The message to display when the input length is too short. If null a default one will show. * @param {string|Function|IgniteProperty} msg The message to display when the input length is too short. If null a default one will show.
* @returns {IgniteTemplate} This ignite template. * @returns {IgniteTemplate} This ignite template.
*/ */
IgniteTemplate.prototype.validateMin = function(min, msg) { IgniteTemplate.prototype.validateMin = function (min, msg) {
return this.validate((value, error) => { return this.validate((value, error) => {
if (!value || value.toString().trim().length < min) { if (!value || value.toString().trim().length < min) {
return error(msg ? msg : `Input must contain at least ${min} character(s).`); return error(msg ? msg : `Input must contain at least ${min} character(s).`);
@ -257,7 +249,7 @@ function notify(target, type, msg, duration) {
* @param {string|Function|IgniteProperty} msg The message to display when the input length is too long. If null a default one will show. * @param {string|Function|IgniteProperty} msg The message to display when the input length is too long. If null a default one will show.
* @returns {IgniteTemplate} This ignite template. * @returns {IgniteTemplate} This ignite template.
*/ */
IgniteTemplate.prototype.validateMax = function(max, msg) { IgniteTemplate.prototype.validateMax = function (max, msg) {
return this.validate((value, error) => { return this.validate((value, error) => {
if (!value || value.toString().trim().length > max) { if (!value || value.toString().trim().length > max) {
return error(msg ? msg : `Input must contain less than ${max} character(s).`); return error(msg ? msg : `Input must contain less than ${max} character(s).`);
@ -271,7 +263,7 @@ function notify(target, type, msg, duration) {
* @param {string|Function|IgniteProperty} msg The message to display when the input length is too long. If null a default one will show. * @param {string|Function|IgniteProperty} msg The message to display when the input length is too long. If null a default one will show.
* @returns {IgniteTemplate} This ignite template. * @returns {IgniteTemplate} This ignite template.
*/ */
IgniteTemplate.prototype.validateNot = function(expected, msg) { IgniteTemplate.prototype.validateNot = function (expected, msg) {
return this.validate((value, error) => { return this.validate((value, error) => {
if (!value || value == expected) { if (!value || value == expected) {
return error(msg ? msg : `Input cannot be ${expected}.`); return error(msg ? msg : `Input cannot be ${expected}.`);
@ -285,7 +277,7 @@ function notify(target, type, msg, duration) {
* @param {string|Function|IgniteProperty} msg The message to display when the input doesn't contain the string. If null a default one will show. * @param {string|Function|IgniteProperty} msg The message to display when the input doesn't contain the string. If null a default one will show.
* @returns {IgniteTemplate} This ignite template. * @returns {IgniteTemplate} This ignite template.
*/ */
IgniteTemplate.prototype.validateIncludes = function(str, msg) { IgniteTemplate.prototype.validateIncludes = function (str, msg) {
return this.validate((value, error) => { return this.validate((value, error) => {
if (!value || !value.toString().includes(str)) { if (!value || !value.toString().includes(str)) {
return error(msg ? msg : `Input must contain ${str}.`); return error(msg ? msg : `Input must contain ${str}.`);
@ -299,7 +291,7 @@ function notify(target, type, msg, duration) {
* @param {string|Function|IgniteProperty} msg The message to display when the input doesn't match. If null a default one will show. * @param {string|Function|IgniteProperty} msg The message to display when the input doesn't match. If null a default one will show.
* @returns {IgniteTemplate} This ignite template. * @returns {IgniteTemplate} This ignite template.
*/ */
IgniteTemplate.prototype.validateMatches = function(compare, msg) { IgniteTemplate.prototype.validateMatches = function (compare, msg) {
return this.validate((value, error) => { return this.validate((value, error) => {
if (compare instanceof Function) { if (compare instanceof Function) {
if (compare() != value) { if (compare() != value) {
@ -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. * Validates this element and all the children within the element.
* @returns {Boolean} Whether or not all the children of this element are valid. * @returns {Boolean} Whether or not this element and all children in this element are valid.
*/ */
HTMLElement.prototype.validateAll = function() { HTMLElement.prototype.validate = function () {
var elements = this.getElementsByTagName("*"); //If this element has a template with validators run them.
for (var i = 0; i < elements.length; i++) { if (this.template && this.template._validators) {
if (elements[i].validate != undefined && !elements[i].validate()) { for (var i = 0; i < this.template._validators.length; i++) {
if (!this.template._validators[i]()) {
return false; 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; return true;
} }