I am currently working on a large project, and for this I need to work with Firebase and Angular 5, but I am blocking form validation a bit.
I would like to create my own validator to check if the email address already entered by the user is used.
To do this, I put the function in custom validators, an error appears when the email is already in use, but the problem is that we enter an unused address.
When I check the form with the address already in use, the form returns me the status "INVALID", which is quite normal, and this is what I am looking for, but when I check by email, which is not in Firestore, it returns an error telling me that the form is in the status "WAITING", that is, she is waiting ... But what to expect?
What am I doing
I create my formControl in my template
// inscription.component.html
<mat-step [stepControl]="form">
<form [formGroup]="form">
<mat-form-field>
<input matInput formControlName="email"
placeholder="Ton adresse email" required>
<mat-error *ngIf="email.invalid">
{{ getErrorMessage(email, 'adresse email', 3, 25) }}
</mat-error>
</mat-form-field>
</form>
</mat-step>
My getErrorMessage () function
getErrorMessage(selector: any, element: string, minCharacters: number, maxCharacters: number) {
return selector.hasError('required') ? 'Tu dois entrer ton ' + element :
selector.hasError('notunique') ? 'Cette ' + element + ' est déjà utilisée' :
'';
}
I initialize everything I need to create the form:
form: FormGroup;
email = new FormControl('', [
Validators.required,
Validators.email,
Validators.minLength(3),
Validators.maxLength(25)
], this.checkIfEmailExistsInDatabase.bind(this));
Then I initialize the email management form in my form
ngOnInit() {
this.form = new FormGroup({
email: this.email,
});
}
And finally ... where did the "error" come from:
checkIfEmailExistsInDatabase(control: AbstractControl) {
return new Promise(resolve => {
firebase.firestore().collection('items').where('email', '==', control.value).get()
.then(snapshot => {
snapshot.forEach(doc => {
if (!doc.exists) {
console.log('Email doesn\'t exists');
resolve(null);
} else {
console.log('Email exists already');
resolve({ 'notunique' : true });
})
});
});
}
I admit, I do not quite understand why I do not understand where I can get this error, if it is an error, and how to fix it ..:?
Sorry for my bad english, I'm French.
If you have an idea, feel free to answer, thanks in advance!