Skip to content

Global model validation for TemplateDriven Form based on vest suite by Sanders

License

Notifications You must be signed in to change notification settings

dmorosinotto/validointi

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

All Contributors

Validointi

logo

We finsish the validation debate

@validointi/core

This is a library to help you validate your template driven forms.

Installation

To install this library, run:

$ npm install @validointi/core --save

Using it in your project.

You can use this library by importing the directives and services in the components you want to use them in.

First you register your validation function to the service like this:

#vr = inject(ValidatorRegistryService);

validate = this.#vr.registerValidator('sample-data', validateSampleData);

a validation function can look like this:

async function validateSampleData(data: SampleData, field?: string): Promise<ValidationErrors> {
  /**
   * In here we use Vest to validate the data.
   * However, you can validate the data however you want.
   */
  const errors = await suite(data, field).getErrors();
  return Object.entries(errors).reduce((acc, [key, err]) => {
    acc[key] = err;
    return acc;
  }, {} as ValidationErrors);
}

Pro Tip: When you use vest, you can use the createVestAdapter(suite) function to create a validation function that can be used with this library.

validate = this.#vr.registerValidator('sample-data', createVestAdapter(suite));

will make sure the vest results are formatted correctly for this library.

The only restriction is that the function must return a Promise<ValidationErrors>.

After that you can use the directive in your template like this:

<form validationId="sample-data" (ngSubmit)="mySubmitFunction($any(data))" #form="ngForm">
  <label for="name">
    <span>Name</span>
    <input type="text" name="name" placeholder="Your name" [(ngModel)]="data.name" />
  </label>
  <input type="submit" value="Submit" [disabled]="form.invalid" />
</form>

From this point the form will be validated on formControl.valueChanges and errors coming from the function will be set on the corresponding formControl.

Contributors

Jeffrey Bosch
Jeffrey Bosch

💻 📖 💡 🔧 🚧
Sander Elias
Sander Elias

💻 📖 💡 🚧

About

Global model validation for TemplateDriven Form based on vest suite by Sanders

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 83.3%
  • HTML 8.8%
  • CSS 4.5%
  • JavaScript 3.3%
  • Shell 0.1%