UNPKG

ngx-form-validator-super

Version:

A super flexible and time saving Validation logic handeling directive for Angular Reactive forms.

116 lines 13.2 kB
import { Directive, ElementRef, Optional, HostListener, Input } from '@angular/core'; import { NgControl, NgModel, ControlContainer } from '@angular/forms'; import { ValidatorLogic } from './validator-logic'; export class NGXFormValidator { constructor(controlContainer, ValidatorLogic, ele) { this.controlContainer = controlContainer; this.ValidatorLogic = ValidatorLogic; this.ele = ele; this.btnClickHandler = (event) => { event.preventDefault(); this.CallValidation(event.target); }; this.SetMutationOserver(); } ngOnInit() { } SetMutationOserver() { if (!this.ele) { return; } let observer = new MutationObserver((mutations) => { let buttons = this.GetSubmitButtons(); if (buttons && buttons.length > 0) { buttons.forEach(button => { this.OnSubmitBtnClick(button); }); } }); observer.observe(this.ele.nativeElement, { childList: true, subtree: true, attributes: true }); } GetSubmitButtons() { if (!this.ele) { return; } let submitButtons = this.ele.nativeElement.querySelectorAll("button[type=submit]"); return submitButtons; } OnSubmitBtnClick(btnRef) { btnRef.removeEventListener('click', this.btnClickHandler); btnRef.addEventListener('click', this.btnClickHandler); } CallValidation(target) { this.ValidatorLogic.formControl = this.controlContainer; if (!this.ValidatorLogic.ValidateControls(null)) { target.removeEventListener('click', this.btnClickHandler); target.click(); } } change(event) { this.ValidatorLogic.formControl = this.controlContainer; if (event.srcElement.attributes.formcontrolname) { this.ValidatorLogic.ValidateControls(event.srcElement); } } submit(e) { //e.currentTarget.stopPropagation(); //this.ValidatorLogic.formControl = this.controlContainer // this.ValidatorLogic.ValidateControls(null); // e.target.onSubmit=null; return false; } openPanel() { this.ValidatorLogic.formControl = this.controlContainer; this.ValidatorLogic.TogglePanel(); } } NGXFormValidator.decorators = [ { type: Directive, args: [{ selector: '[ngxValidator]' },] } ]; NGXFormValidator.ctorParameters = () => [ { type: ControlContainer }, { type: ValidatorLogic }, { type: ElementRef } ]; NGXFormValidator.propDecorators = { change: [{ type: HostListener, args: ["change", ["$event"],] }], submit: [{ type: HostListener, args: ["submit", ["$event"],] }], openPanel: [{ type: HostListener, args: ['document:keydown.shift.f8', ['$event'],] }] }; export class NativeElementInjectorDirective { constructor(el, control, model) { this.el = el; this.control = control; this.model = model; this.appendNativeElement(); } onChange(event) { this.appendNativeElement(); } ngAfterViewInit() { this.appendNativeElement(); } appendNativeElement() { if (!!this.model) this.model.control.nativeElement = this.el.nativeElement; else if (this.control.control) this.control.control.nativeElement = this.el.nativeElement; } } NativeElementInjectorDirective.decorators = [ { type: Directive, args: [{ selector: '[ngModel], [formControl], [formControlName]', },] } ]; NativeElementInjectorDirective.ctorParameters = () => [ { type: ElementRef }, { type: NgControl }, { type: NgModel, decorators: [{ type: Optional }] } ]; NativeElementInjectorDirective.propDecorators = { validationContainerId: [{ type: Input, args: ['validationContainerId',] }], onChange: [{ type: HostListener, args: ['change', ['$event'],] }] }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validator-directive.js","sourceRoot":"","sources":["../../../../../projects/ngx-form-validator/src/lib/Directive/validator-directive.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,YAAY,EAAoB,KAAK,EAAE,MAAM,eAAe,CAAC;AACvG,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAA;AACrE,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAKnD,MAAM,OAAO,gBAAgB;IAG3B,YAAoB,gBAAkC,EAAQ,cAA8B,EAAS,GAAc;QAA/F,qBAAgB,GAAhB,gBAAgB,CAAkB;QAAQ,mBAAc,GAAd,cAAc,CAAgB;QAAS,QAAG,GAAH,GAAG,CAAW;QA8C9G,oBAAe,GAAE,CAAC,KAAS,EAAC,EAAE;YAEnC,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;QACnC,CAAC,CAAA;QA/CC,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAE1B,CAAC;IACD,QAAQ;IAET,CAAC;IAIO,kBAAkB;QAEzB,IAAG,CAAC,IAAI,CAAC,GAAG,EAAC;YAAE,OAAO;SAAE;QACxB,IAAI,QAAQ,GAAG,IAAI,gBAAgB,CAAC,CAAC,SAAS,EAAC,EAAE;YAE7C,IAAI,OAAO,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACtC,IAAG,OAAO,IAAI,OAAO,CAAC,MAAM,GAAC,CAAC,EAAC;gBAC7B,OAAO,CAAC,OAAO,CAAC,MAAM,CAAA,EAAE;oBAEtB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;gBAChC,CAAC,CAAC,CAAA;aACH;QAEL,CAAC,CAAC,CAAC;QACH,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAC,EAAC,SAAS,EAAC,IAAI,EAAC,OAAO,EAAC,IAAI,EAAC,UAAU,EAAC,IAAI,EAAC,CAAC,CAAA;IACxF,CAAC;IAEO,gBAAgB;QAEtB,IAAG,CAAC,IAAI,CAAC,GAAG,EAAC;YAAE,OAAQ;SAAC;QAExB,IAAI,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,gBAAgB,CAAC,qBAAqB,CAAC,CAAC;QAEnF,OAAO,aAAa,CAAC;IACvB,CAAC;IAEO,gBAAgB,CAAC,MAAM;QAE5B,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAC,IAAI,CAAC,eAAe,CAAC,CAAA;QAExD,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAC,IAAI,CAAC,eAAe,CAAC,CAAA;IAExD,CAAC;IAQO,cAAc,CAAC,MAAM;QAE3B,IAAI,CAAC,cAAc,CAAC,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAA;QACvD,IAAG,CAAC,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAC;YAC7C,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAC,IAAI,CAAC,eAAe,CAAC,CAAA;YACxD,MAAM,CAAC,KAAK,EAAE,CAAC;SAChB;IAEH,CAAC;IASqC,MAAM,CAAC,KAAK;QAE9C,IAAI,CAAC,cAAc,CAAC,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC;QACxD,IAAI,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,eAAe,EAAE;YAC/C,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;SACxD;IACH,CAAC;IAEmC,MAAM,CAAC,CAAC;QAC1C,oCAAoC;QAEpC,yDAAyD;QAE1D,8CAA8C;QAC9C,0BAA0B;QACzB,OAAO,KAAK,CAAC;IACf,CAAC;IAEqD,SAAS;QAE7D,IAAI,CAAC,cAAc,CAAC,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAA;QACvD,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC;IAEpC,CAAC;;;YAlGF,SAAS,SAAC;gBACT,QAAQ,EAAE,gBAAgB;aAC3B;;;YAL4B,gBAAgB;YACpC,cAAc;YAFH,UAAU;;;qBA+E3B,YAAY,SAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC;qBAQjC,YAAY,SAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC;wBAUjC,YAAY,SAAC,2BAA2B,EAAC,CAAC,QAAQ,CAAC;;AAkBtD,MAAM,OAAO,8BAA8B;IACzC,YAAoB,EAAc,EAAU,OAAkB,EAAsB,KAAc;QAA9E,OAAE,GAAF,EAAE,CAAY;QAAU,YAAO,GAAP,OAAO,CAAW;QAAsB,UAAK,GAAL,KAAK,CAAS;QAChG,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAE7B,CAAC;IAKmC,QAAQ,CAAC,KAAK;QAChD,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAE7B,CAAC;IAED,eAAe;QAEb,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAEO,mBAAmB;QACzB,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK;YACR,IAAI,CAAC,KAAK,CAAC,OAAQ,CAAC,aAAa,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC;aAC7D,IAAG,IAAI,CAAC,OAAO,CAAC,OAAO;YACpB,IAAI,CAAC,OAAO,CAAC,OAAQ,CAAC,aAAa,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC;IAGtE,CAAC;;;YA7BF,SAAS,SAAC;gBACT,QAAQ,EAAE,6CAA6C;aACxD;;;YAlHmB,UAAU;YACrB,SAAS;YAAE,OAAO,uBAmHwC,QAAQ;;;oCAKxE,KAAK,SAAC,uBAAuB;uBAG7B,YAAY,SAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { stringify } from '@angular/compiler/src/util';\r\nimport { Directive, ElementRef, Optional, HostListener, ViewContainerRef, Input } from '@angular/core';\r\nimport { NgControl, NgModel, ControlContainer } from '@angular/forms'\r\nimport { ValidatorLogic } from './validator-logic';\r\n\r\n@Directive({\r\n  selector: '[ngxValidator]'\r\n})\r\nexport class NGXFormValidator {\r\n\r\n\r\n  constructor(private controlContainer: ControlContainer,public ValidatorLogic: ValidatorLogic,private ele:ElementRef) {\r\n\r\n\r\n  this.SetMutationOserver();\r\n\r\n  }\r\n  ngOnInit() {\r\n\r\n }\r\n\r\n\r\n\r\n private SetMutationOserver(){\r\n\r\n  if(!this.ele){ return; }\r\n  let observer = new MutationObserver((mutations)=>{\r\n\r\n      let buttons = this.GetSubmitButtons();\r\n      if(buttons && buttons.length>0){\r\n        buttons.forEach(button=>{\r\n\r\n          this.OnSubmitBtnClick(button);\r\n        })\r\n      }\r\n\r\n  });\r\n  observer.observe(this.ele.nativeElement,{childList:true,subtree:true,attributes:true})\r\n}\r\n\r\nprivate GetSubmitButtons():any[]{\r\n\r\n  if(!this.ele){ return ;}\r\n\r\n  let submitButtons = this.ele.nativeElement.querySelectorAll(\"button[type=submit]\");\r\n\r\n  return submitButtons;\r\n}\r\n\r\nprivate OnSubmitBtnClick(btnRef){\r\n\r\n   btnRef.removeEventListener('click',this.btnClickHandler)\r\n\r\n   btnRef.addEventListener('click',this.btnClickHandler)\r\n\r\n}\r\n\r\npublic btnClickHandler =(event:any)=>{\r\n\r\n  event.preventDefault();\r\n  this.CallValidation(event.target)\r\n}\r\n\r\nprivate CallValidation(target){\r\n\r\n  this.ValidatorLogic.formControl = this.controlContainer\r\n  if(!this.ValidatorLogic.ValidateControls(null)){\r\n    target.removeEventListener('click',this.btnClickHandler)\r\n    target.click();\r\n  }\r\n\r\n}\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  @HostListener(\"change\", [\"$event\"]) change(event) {\r\n\r\n    this.ValidatorLogic.formControl = this.controlContainer;\r\n    if (event.srcElement.attributes.formcontrolname) {\r\n      this.ValidatorLogic.ValidateControls(event.srcElement);\r\n    }\r\n  }\r\n\r\n  @HostListener(\"submit\", [\"$event\"]) submit(e) {\r\n    //e.currentTarget.stopPropagation();\r\n\r\n    //this.ValidatorLogic.formControl = this.controlContainer\r\n\r\n   // this.ValidatorLogic.ValidateControls(null);\r\n   // e.target.onSubmit=null;\r\n    return false;\r\n  }\r\n\r\n  @HostListener('document:keydown.shift.f8',['$event']) openPanel(){\r\n\r\n    this.ValidatorLogic.formControl = this.controlContainer\r\n    this.ValidatorLogic.TogglePanel();\r\n\r\n  }\r\n\r\n}\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n@Directive({\r\n  selector: '[ngModel], [formControl], [formControlName]', // or 'input, select, textarea' - but then your controls won't be handled and also checking for undefined would be necessary\r\n})\r\nexport class NativeElementInjectorDirective {\r\n  constructor(private el: ElementRef, private control: NgControl, @Optional() private model: NgModel) {\r\n    this.appendNativeElement();\r\n\r\n  }\r\n\r\n  @Input('validationContainerId') validationContainerId:string;\r\n\r\n\r\n  @HostListener('change', ['$event']) onChange(event) {\r\n    this.appendNativeElement();\r\n\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n\r\n    this.appendNativeElement();\r\n  }\r\n\r\n  private appendNativeElement() {\r\n    if (!!this.model)\r\n      (<any>this.model.control).nativeElement = this.el.nativeElement;\r\n    else if(this.control.control)\r\n      (<any>this.control.control).nativeElement = this.el.nativeElement;\r\n\r\n\r\n  }\r\n}\r\n"]}