1.0.6 • Published 7 years ago
angular-alternative-validation v1.0.6
angular-alternative-validation
Angular Alternative Validation - The smoothest way to implement validation hints/warnings for your forms
Demo
Quick code example:
// app.component.ts
...
import { IAlternativeValidationConfig } from 'angular-alternative-validation/struct/alternative-validation-config';
@Component({
selector: 'app-basic-usage',
template: `<input type="text"
formControlName="name"
[alternativeValidation]="{validator: ['required']}"
#aV="alternativeValidation">
{{fg.get('name').valid}} vs {{aV.valid}}`
})
export class BasicUsageComponent {
...
}
Basic Usage:
Implement Library
$ npm install angular-alternative-validation --save
// app.module.ts
...
// IMPORT YOUR LIBRARY
import { AlternativeValidationModule } from 'angular-alternative-validation';
@NgModule({
imports: [
...
AlternativeValidationModule.forRoot();
]
...
})
export class AppModule { }
Create alternative validation config object
// app.component.ts
...
import { IAlternativeValidationConfig } from 'angular-alternative-validation/struct/alternative-validation-config';
@Component({
selector: 'app-basic-usage',
template: `
<form [formGroup]="formGroup">
<input type="text" formControlName="name" [alternativeValidation]="aVConfig">
Value: {{formGroup.get('name').value}} , Valid: {{formGroup.get('name').valid}}
</form>
`
})
export class BasicUsageComponent {
aVConfig: IAlternativeValidationConfig = {
validator: [
{name: 'required'},
{name: 'minLength', params: [3] }
]
}
formGroup: FormGroup;
constructor(private fb: FormBuilder) {
this.basicFormGroup = this.fb.group({ name: [] });
}
}
Template reference to the directive
// app.component.html
...
<input type="text" formControlName="name" [alternativeValidation]="aVConfig" #aV="alternativeValidation">
{{aV.errors | json}} {{aV.valid}}
A Reference to the directive in the class
// app.component.ts
...
@ViewChild(AlternativeValidationDirective)
alternativeValidationRef
...
ngAfterViewInit() {
console.log('Directive referenc: ', this.alternativeValidationRef);
}
...
Use custom validations
Create custom function
// app.module.ts
export function myValidation(param1, param2): ValidatorFn {
}
...
@NgModule({
...
providers: [
{ provide: NG_VALIDATION, useValue: myValidation, multi: true }
]
...
})
export class AppModule {
}
Use custom transform function in config object
// app.component.ts
...
export class BasicUsageComponent {
fPConfig: IAlternativeValidationConfig = {
alternativeValidation:[
{ name: 'myValidation', params: [param1, param2] }
]
}
}
What it is
There are many ways to build a alternative validation state.
Many of them can't reuse existing validators and all of them do not provide a separate state of validation.
What this library do is it provides an alternative state of the host control.
You can use it like the normal form control validation
but it is not effecting the actual validation of the form.
It's a mix of FormControlName
, AbstractControlDirective
, ControlValueAccessor
, NG_VALIDATORS
and a little bit of magic-glue$
.
In this way you can:
- reuse default validators and async validators
- treat the alternative control stated independent from the real one that effects formGroup and formControl states
- display user hints/information separated from the error messages
- use other libraries working with formControl logic
License
MIT © Michael Hladky
Copyright 2017 Michael Hladky. All Rights Reserved. Use of this source code is governed by an MIT-style license that can be found in the LICENSE file at angular-alternative-validation