ngx-form-validator-super
Version:
A super flexible and time saving Validation logic handeling directive for Angular Reactive forms.
227 lines • 32.1 kB
JavaScript
import { Injectable } from '@angular/core';
import { FormControl, FormArray, FormGroup } from '@angular/forms';
import { PanelLogic } from './panel-logic';
import * as i0 from "@angular/core";
import * as i1 from "./panel-logic";
export class ValidatorLogic {
constructor(panelLogic) {
this.panelLogic = panelLogic;
this.ValidationLabels = {};
}
GetAllControls(controls) {
let extractedControls = [];
for (let ctrl in controls) {
if (controls[ctrl] instanceof FormControl) {
controls[ctrl].name = ctrl;
extractedControls.push(controls[ctrl]);
// Setting control status to valid for elements thata are nto visible on UI
if (!controls[ctrl].nativeElement) {
controls[ctrl].errors = null;
controls[ctrl].status = 'VALID';
}
else if ((!document.body.contains(controls[ctrl].nativeElement))) {
controls[ctrl].setValue(null);
controls[ctrl].errors = null;
controls[ctrl].status = 'VALID';
}
else {
controls[ctrl].updateValueAndValidity({ emitEvent: false });
}
}
if (controls[ctrl] instanceof FormArray) {
extractedControls = [...extractedControls, ...this.GetAllControls(controls[ctrl].controls)];
}
if (controls[ctrl] instanceof FormGroup) {
extractedControls = [...extractedControls, ...this.GetAllControls(controls[ctrl].controls)];
}
}
return extractedControls;
}
ValidateControls(changedControl) {
try {
let allControls = this.GetAllControls(this.formControl.form.controls);
let controls = [];
let selectedControlIndex = -1;
let hasError = false;
if (changedControl) {
selectedControlIndex = allControls.findIndex(x => (x.nativeElement && x.nativeElement.isSameNode(changedControl)));
controls = allControls.map((x, index) => {
if (index != selectedControlIndex) {
return index;
}
else
return -1;
}).filter((x) => x != -1);
}
this.errorControl = null;
allControls.forEach((formControl, index) => {
if (formControl.nativeElement)
if ((!controls.includes(index) && formControl.nativeElement.type == "checkbox") || (selectedControlIndex > -1 && (!controls.includes(index) || (index == selectedControlIndex))) || ((selectedControlIndex == -1) && formControl.nativeElement.type != "checkbox")) {
this.AddRemoveErrorMsg(false, "", formControl.nativeElement);
// Show validation msg only when forms submits not when control value changes
if (!changedControl || index == selectedControlIndex) {
for (let errorName in formControl.errors) {
let erroObj = {};
erroObj[errorName] = formControl.errors[errorName];
hasError = true;
// if(!changedControl)
this.setErrorControl(formControl.nativeElement);
this.AddRemoveErrorMsg(true, erroObj, formControl.nativeElement);
}
}
controls.push(index);
}
});
if (!hasError) {
this.formControl['form'].status = 'VALID';
}
this.panelLogic.updateControlStatus(this.formControl, allControls);
if (this.errorControl && !changedControl) {
// this.toatser.error("Please fill the required details.", "Error !")
this.scrollTo(this.errorControl.ele);
}
return hasError;
}
catch (ex) {
console.error(ex);
}
}
setErrorControl(element) {
let yAxis = element.getBoundingClientRect().y;
if (!this.errorControl) {
this.errorControl = { ele: element, y: yAxis };
return;
}
if (this.errorControl.y > yAxis) {
this.errorControl = { ele: element, y: yAxis };
}
}
scrollTo(element) {
if (element) {
element.scrollIntoView({ behavior: "smooth", block: "center", inline: "nearest" });
let t = null;
let func = () => {
t = setTimeout(() => {
element.focus();
window.onscroll = null;
}, 100);
};
func();
window.onscroll = () => {
if (t) {
clearTimeout(t);
t = null;
}
func();
};
}
}
GetValidationType(ele) {
if (!ele.attributes["validationHint"]) {
return 1;
}
let validationType = ele.attributes["validationHint"].value;
if (validationType = "borderOnly") {
return 2;
}
return 1;
}
GetValidationContainer(ele) {
if (!ele.attributes["validationContainerId"]) {
return null;
}
return document.getElementById(ele.attributes["validationContainerId"].value) || null;
}
AddRemoveErrorMsg(isAdd, error, ele) {
if (!ele || !ele.parentElement) {
return;
}
let validationContainer = this.GetValidationContainer(ele);
let validationType = this.GetValidationType(ele);
let childs = [];
let errorName = error ? Object.keys(error)[0] : null;
let errorObj = error ? error[errorName] : null;
ele.classList.remove('_BrdrError');
if (validationContainer) {
if (validationContainer.childNodes.length > 0) {
childs = validationContainer.childNodes;
}
}
else {
childs = ele.parentElement.childNodes;
}
if (validationType == 2) {
ele.classList.remove('_BrdrError');
if (validationContainer) {
validationContainer.classList.remove('_BrdrError');
}
}
for (let i = 0; i < childs.length; i++) {
if (childs[i].classList && childs[i].classList.contains('_ErX')) {
childs[i].remove();
}
}
if (isAdd) {
let div = document.createElement('div');
if (validationType == 2) {
if (validationContainer) {
validationContainer.classList.add('_BrdrError');
}
else {
ele.classList.add('_BrdrError');
}
return;
}
ele.classList.add('_BrdrError');
div.classList.add('_ErX');
this.GetErrorMsg(errorName, errorLabel => {
if (errorLabel && (errorObj.hasOwnProperty('requiredLength') || errorObj.hasOwnProperty('max'))) {
errorLabel = errorLabel.replace('_', errorObj.requiredLength || errorObj.max);
}
div.innerHTML = ' <small class="ngx-validation-label " >' + errorLabel + '</small>';
// Adding validation msg to given container element
if (validationContainer) {
//If container has childs
if (validationContainer.childNodes.lenght > 0) {
validationContainer.children[validationContainer.children.length - 1].insertAdjacentElement('beforeend', div);
}
else {
// if container has no child
validationContainer.appendChild(div);
}
}
else {
// adding validation on from control it self
ele.parentElement.insertAdjacentElement("beforeend", div);
}
});
}
}
GetErrorMsg(errorCode, cb) {
let eCode = {
required: "This field is required.",
email: "Invalid email.",
number: "Invalid number",
max: "Maxlength exceeds",
minlength: "Minimum length of this field must be _ .",
invalidOfficerTitle: "Select valid Officer Title.",
requiredExpiryDate: "Please enter card's expiry date.",
inavlidExpiryDate: "Past date is not allowed",
phoneLength: "Phone number must be _ digits long.",
zipLength: "Zip must be _ digits long.",
};
cb(this.ValidationLabels[errorCode]);
}
TogglePanel() {
this.panelLogic.IsConsoleShow = !this.panelLogic.IsConsoleShow;
this.panelLogic.updateControlStatus(this.formControl, this.GetAllControls(this.formControl.form.controls));
}
}
ValidatorLogic.ɵprov = i0.ɵɵdefineInjectable({ factory: function ValidatorLogic_Factory() { return new ValidatorLogic(i0.ɵɵinject(i1.PanelLogic)); }, token: ValidatorLogic, providedIn: "root" });
ValidatorLogic.decorators = [
{ type: Injectable, args: [{ providedIn: 'root' },] }
];
ValidatorLogic.ctorParameters = () => [
{ type: PanelLogic }
];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validator-logic.js","sourceRoot":"","sources":["../../../../../projects/ngx-form-validator/src/lib/Directive/validator-logic.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable } from '@angular/core';\r\nimport { FormControl, FormArray, FormGroup } from '@angular/forms';\r\nimport { PanelLogic } from './panel-logic';\r\n\r\n\r\n@Injectable({providedIn:'root'})\r\nexport class ValidatorLogic {\r\n\r\n  formControl: any;\r\n  ValidationLabels:any={}\r\n  errorControl:any;\r\n\r\n  constructor(private panelLogic:PanelLogic){}\r\n\r\n\r\n  private GetAllControls(controls) {\r\n\r\n    let extractedControls = []\r\n    for (let ctrl in controls) {\r\n\r\n      if (controls[ctrl] instanceof FormControl) {\r\n        controls[ctrl].name = ctrl;\r\n        extractedControls.push(controls[ctrl])\r\n\r\n\r\n\r\n          // Setting control status to valid for elements thata are nto visible on UI\r\n          if (!controls[ctrl].nativeElement ) {\r\n\r\n            controls[ctrl].errors = null;\r\n            controls[ctrl].status = 'VALID';\r\n          }\r\n          else if((!document.body.contains(controls[ctrl].nativeElement))){\r\n            controls[ctrl].setValue(null);\r\n            controls[ctrl].errors = null;\r\n            controls[ctrl].status = 'VALID';\r\n          }\r\n          else {\r\n            controls[ctrl].updateValueAndValidity({ emitEvent: false });\r\n          }\r\n\r\n\r\n\r\n\r\n      }\r\n\r\n      if (controls[ctrl] instanceof FormArray) {\r\n\r\n        extractedControls = [...extractedControls, ... this.GetAllControls(controls[ctrl].controls)]\r\n      }\r\n\r\n      if (controls[ctrl] instanceof FormGroup) {\r\n\r\n        extractedControls = [...extractedControls, ... this.GetAllControls(controls[ctrl].controls)]\r\n      }\r\n    }\r\n\r\n    return extractedControls;\r\n  }\r\n\r\n  public ValidateControls(changedControl) {\r\n\r\n    try {\r\n      let allControls = this.GetAllControls(this.formControl.form.controls);\r\n      let controls = []\r\n      let selectedControlIndex = -1;\r\n      let hasError =false;\r\n\r\n\r\n      if (changedControl) {\r\n        selectedControlIndex = allControls.findIndex(x => (x.nativeElement && x.nativeElement.isSameNode(changedControl)));\r\n\r\n        controls = allControls.map((x, index) => {\r\n          if (index != selectedControlIndex) { return index }\r\n          else\r\n            return -1;\r\n        }).filter((x) => x != -1)\r\n      }\r\n\r\n\r\n      this.errorControl=null\r\n      allControls.forEach((formControl, index) => {\r\n\r\n        if (formControl.nativeElement)\r\n          if ((!controls.includes(index) && formControl.nativeElement.type == \"checkbox\") || (selectedControlIndex > -1 && (!controls.includes(index) || (index == selectedControlIndex))) || ((selectedControlIndex == -1) && formControl.nativeElement.type != \"checkbox\")) {\r\n            this.AddRemoveErrorMsg(false, \"\", formControl.nativeElement);\r\n\r\n            // Show validation msg only when forms submits not when control value changes\r\n            if (!changedControl || index == selectedControlIndex) {\r\n              for (let errorName in formControl.errors) {\r\n\r\n                let erroObj = {};\r\n                erroObj[errorName] = formControl.errors[errorName];\r\n\r\n                hasError= true;\r\n\r\n                // if(!changedControl)\r\n                 this.setErrorControl(formControl.nativeElement);\r\n\r\n                this.AddRemoveErrorMsg(true, erroObj, formControl.nativeElement);\r\n              }\r\n            }\r\n            controls.push(index);\r\n          }\r\n      })\r\n\r\n      if(!hasError){\r\n        this.formControl['form'].status ='VALID';\r\n\r\n      }\r\n\r\n    this.panelLogic.updateControlStatus(this.formControl,allControls);\r\n\r\n\r\n      if (this.errorControl && !changedControl) {\r\n\r\n          // this.toatser.error(\"Please fill the required details.\", \"Error !\")\r\n          this.scrollTo(this.errorControl.ele);\r\n\r\n      }\r\n\r\n\r\n      return hasError;\r\n\r\n    }\r\n    catch (ex) {\r\n\r\n      console.error(ex)\r\n    }\r\n\r\n  }\r\n\r\n  private setErrorControl(element){\r\n\r\n    let yAxis= element.getBoundingClientRect().y\r\n\r\n    if(!this.errorControl){\r\n      this.errorControl ={  ele: element,y:yAxis};\r\n      return;\r\n    }\r\n\r\n    if(  this.errorControl.y>yAxis){\r\n      this.errorControl ={  ele: element,y:yAxis};\r\n    }\r\n\r\n  }\r\n\r\n  private  scrollTo(element){\r\n    if(element){\r\n      element.scrollIntoView({behavior: \"smooth\", block: \"center\", inline: \"nearest\"})\r\n      let t =null;\r\n\r\n      let func=()=>{\r\n        t = setTimeout(()=>{\r\n          element.focus();\r\n          window.onscroll=null;\r\n        },100)\r\n      }\r\n\r\n      func();\r\n      window.onscroll=()=>{\r\n        if(t){\r\n          clearTimeout(t);\r\n          t=null;\r\n        }\r\n        func();\r\n      }\r\n    }\r\n  }\r\n\r\n  private GetValidationType(ele) {\r\n\r\n    if (!ele.attributes[\"validationHint\"]) {\r\n\r\n      return 1;\r\n    }\r\n    let validationType = ele.attributes[\"validationHint\"].value;\r\n    if (validationType = \"borderOnly\") {\r\n      return 2;\r\n    }\r\n\r\n    return 1;\r\n  }\r\n\r\n  private GetValidationContainer(ele) {\r\n    if (!ele.attributes[\"validationContainerId\"]) {\r\n\r\n      return null;\r\n    }\r\n\r\n    return document.getElementById(ele.attributes[\"validationContainerId\"].value) || null\r\n  }\r\n\r\n  private AddRemoveErrorMsg(isAdd, error, ele) {\r\n\r\n    if (!ele || !ele.parentElement) { return; }\r\n\r\n\r\n    let validationContainer = this.GetValidationContainer(ele) as any;\r\n    let validationType = this.GetValidationType(ele);\r\n    let childs: any[] = [];\r\n    let errorName = error ? Object.keys(error)[0] : null;\r\n    let errorObj = error ? error[errorName] : null;\r\n\r\n    ele.classList.remove('_BrdrError');\r\n\r\n    if (validationContainer) {\r\n\r\n      if (validationContainer.childNodes.length > 0) {\r\n        childs = validationContainer.childNodes;\r\n      }\r\n\r\n    }\r\n    else {\r\n      childs = ele.parentElement.childNodes;\r\n    }\r\n\r\n    if (validationType == 2) {\r\n      ele.classList.remove('_BrdrError');\r\n\r\n      if (validationContainer) {\r\n        validationContainer.classList.remove('_BrdrError');\r\n      }\r\n\r\n    }\r\n\r\n    for (let i = 0; i < childs.length; i++) {\r\n\r\n      if (childs[i].classList && childs[i].classList.contains('_ErX')) {\r\n        childs[i].remove();\r\n      }\r\n    }\r\n\r\n    if (isAdd) {\r\n\r\n      let div = document.createElement('div');\r\n\r\n      if (validationType == 2) {\r\n\r\n\r\n        if (validationContainer) {\r\n          validationContainer.classList.add('_BrdrError');\r\n        }\r\n        else {\r\n          ele.classList.add('_BrdrError');\r\n        }\r\n        return;\r\n      }\r\n\r\n      ele.classList.add('_BrdrError');\r\n      div.classList.add('_ErX')\r\n\r\n      this.GetErrorMsg(errorName, errorLabel => {\r\n\r\n        if (errorLabel && (errorObj.hasOwnProperty('requiredLength') || errorObj.hasOwnProperty('max'))) {\r\n          errorLabel = errorLabel.replace('_', errorObj.requiredLength || errorObj.max)\r\n        }\r\n\r\n\r\n        div.innerHTML = ' <small  class=\"ngx-validation-label \" >' + errorLabel + '</small>';\r\n\r\n        // Adding validation msg to given container element\r\n        if (validationContainer) {\r\n\r\n          //If container has childs\r\n          if (validationContainer.childNodes.lenght > 0) {\r\n            validationContainer.children[validationContainer.children.length - 1].insertAdjacentElement('beforeend', div);\r\n\r\n          }\r\n          else {\r\n\r\n            // if container has no child\r\n            validationContainer.appendChild(div);\r\n\r\n          }\r\n\r\n        }\r\n        else {\r\n          // adding validation on from control it self\r\n          ele.parentElement.insertAdjacentElement(\"beforeend\", div);\r\n        }\r\n\r\n      })\r\n\r\n\r\n    }\r\n\r\n\r\n  }\r\n\r\n  private GetErrorMsg(errorCode,cb){\r\n    let eCode={\r\n        required:\"This field is required.\",\r\n        email:\"Invalid email.\",\r\n        number:\"Invalid number\",\r\n        max:\"Maxlength exceeds\",\r\n        minlength:\"Minimum length of this field must be _ .\",\r\n        invalidOfficerTitle:\"Select valid Officer Title.\",\r\n        requiredExpiryDate:\"Please enter card's expiry date.\",\r\n        inavlidExpiryDate:\"Past date is not allowed\",\r\n        phoneLength:\"Phone number must be _ digits long.\",\r\n        zipLength:\"Zip must be _ digits long.\",\r\n    }\r\n\r\n    cb(this.ValidationLabels[errorCode]);\r\n\r\n}\r\n\r\n  public TogglePanel(){\r\n    this.panelLogic.IsConsoleShow =!this.panelLogic.IsConsoleShow;\r\n    this.panelLogic.updateControlStatus(this.formControl,this.GetAllControls(this.formControl.form.controls));\r\n\r\n  }\r\n}\r\n"]}