Skip to content

jakub-hajduk/ngx-validators-manager

Repository files navigation

ngx-validators-manager

Validators manager for reactive forms in Angular.

What problem does it solve?

In Angular You don't have an option, where You can add or remove single validators from controls, groups or arrays. Everything You add is composed using composeValidators() function.

NgxValidatorsManager was written to solve this problem, and add more control over validators. It tracks what validators were added, and if we add or remove any of them, it recomposes and reapplies validators on the AbstractControl.

Install

$ npm install --save ngx-validators-manager

Adding module

Just import ngx-validators-manager to Your project

@NgModule({
  imports: [
    NgxValidatorsManagerModule
  ]
})
export class AppModule { }

Using it

It basically adds validatorManager property to Your controls. That's why You have to use custom interfaces.

  1. Import stuff
import { VMFormBuilder, VMFormGroup } from 'ngx-validators-manager';
  1. Use VmFormBuilder
export class FormComponent {
  form: VMFormGroup; // Use VMFormGroup interface

  constructor(private fb: VMFormBuilder) { // Use VMFormBuilder
    this.form = this.fb.group({ // Create form with FormBuilder as usual
      firstName: ''
    });
  }
}
  1. Add validators...
  addRequired() {
    this.form.get('firstName').validatorManager.addValidators({required: Validators.required}) // Add validators
  }
  1. ...and remove them.
  removeRequired() {
    this.form.get('firstName').validatorManager.removeValidators('required'); // Remove validators
  }

You can play with it at Stackblitz

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published