I have a reactive form with three error messages, but when I type something on the textboxes no errors are appearing, I´ve searching for something missing or mistyped, but I can´t see anything. Any help will be appreciated. Angular version: 12.2.10
Ts file:
import { Component, OnInit } from '@angular/core';
import { FormBuilder, FormGroup, NgForm, Validators, FormControl} from '@angular/forms';
import { ServicioSettings } from '../data/servicio-settings';
import { DataService } from '../data/data.service';
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
@Component({
selector: 'app-verhoras',
templateUrl: './verhoras.component.html',
styleUrls: ['./verhoras.component.css']
})
export class VerhorasComponent implements OnInit {
servicioSettings: ServicioSettings = {
IdTecnico: null,
tecnico: null,
servicioRealizado: null,
fechaDeInicio: null,
horaDeInicio: null,
semanaDelAno: null,
fechaDeFinalizacion: null,
horaDeFinalizacion: null,
cantidadDeHoras: null,
tipoDeHora: null
};
myForm: FormGroup;
items: ServicioSettings;
submitted = false;
constructor(private formBuilder: FormBuilder, private dataService: DataService) { }
iniciarFormulario(){
this.myForm = new FormGroup({
IdTecnico: new FormControl(this.servicioSettings.IdTecnico, [Validators.required, Validators.minLength(4), Validators.maxLength(30)]),
semanaDelAno: new FormControl(this.servicioSettings.semanaDelAno,[Validators.required])
});
}
ngOnInit(): void {
this.iniciarFormulario();
}
onSubmit() {
this.submitted = true;
if (this.myForm.valid) {
console.log(this.myForm.value)
this.dataService.getServicioSettingsForm(this.myForm.value).subscribe(
//result => console.log('success ', result),
result => this.items = result,
error => console.log('error ', error)
);
}
}
}
Html file:
<form (ngSubmit)="onSubmit()" [formGroup]="myForm">
<div class="form-group">
<label for="IdTecnico">Id técnico (*)</label>
<input type="number" class="form-control" id="IdTecnico" name="IdTecnico" formControlName="IdTecnico"/>
<div class="alert-danger"
*ngIf="
myForm.get('IdTecnico').invalid &&
(myForm.get('IdTecnico').dirty || myForm.get('IdTecnico').touched)
"
>
<div *ngIf="myForm.get('IdTecnico').errors.required">
El IdTecnico es requerido
</div>
<div *ngIf="myForm.get('IdTecnico').errors.minlength">
El IdTecnico debe ser mínimo de 4 caracteres
</div>
<div *ngIf="myForm.get('IdTecnico').errors.maxlength">
El IdTecnico debe ser máximo de 30 caracteres
</div>
</div>
</div>
<div class="form-group">
<label for="semanaDelAno">Semana del año (*)</label>
<input
type="number"
class="form-control"
id="semanaDelAno"
formControlName="semanaDelAno"
/>
</div>
<button type="submit" class="btn btn-primary" [disabled]="myForm.invalid">Enviar</button>
</form>
The form is just a couple of textboxes and a button, the idea is that for example when typing only one character on the first one, an error of min length should appears.