Fix des champs non modifies non reconnus pour les Agences

pull/12/head
Clement FERRERE 3 years ago
parent b2339e34cd
commit a787c890f2
  1. 5
      src/app/components/agence/agence-edit/agence-edit.component.html
  2. 44
      src/app/components/agence/agence-edit/agence-edit.component.ts

@ -4,7 +4,10 @@
<h2>{{agence.name | uppercase}} </h2> <h2>{{agence.name | uppercase}} </h2>
<div><span>id : </span>{{agence.id}}</div> <div><span>id : </span>{{agence.id}}</div>
<form [formGroup]="registerForm" (ngSubmit)="onSubmit()" > <form
*ngIf="agenceObservable | async;"
[formGroup]="registerForm"
(ngSubmit)="onSubmit()" >
<div class="form-group col-12 col-sm-6 col-md-4 col-lg-3 mb-2"> <div class="form-group col-12 col-sm-6 col-md-4 col-lg-3 mb-2">
<label class="form-label">Nom</label> <label class="form-label">Nom</label>

@ -6,6 +6,8 @@ import {Location} from "@angular/common";
import {FormBuilder, FormGroup, Validators} from '@angular/forms'; import {FormBuilder, FormGroup, Validators} from '@angular/forms';
import {Businessunit} from "../../../interfaces/businessunit"; import {Businessunit} from "../../../interfaces/businessunit";
import {BusinessunitService} from "../../../services/businessunit.service"; import {BusinessunitService} from "../../../services/businessunit.service";
import {Observable} from "rxjs";
import {take, tap} from "rxjs/operators";
@Component({ @Component({
selector: 'app-agence-edit', selector: 'app-agence-edit',
@ -14,9 +16,12 @@ import {BusinessunitService} from "../../../services/businessunit.service";
}) })
export class AgenceEditComponent implements OnInit { export class AgenceEditComponent implements OnInit {
agence = {} as Agence; agence = {} as Agence;
agenceObservable!:Observable<Agence>;
businessUnits : Businessunit[] = []; businessUnits : Businessunit[] = [];
businessUnit = {} as Businessunit ; businessUnit = {} as Businessunit ;
id: number;
registerForm!: FormGroup; registerForm!: FormGroup;
submitted = false; submitted = false;
@ -26,43 +31,40 @@ export class AgenceEditComponent implements OnInit {
private businessUnitService: BusinessunitService, private businessUnitService: BusinessunitService,
private location: Location, private location: Location,
private formBuilder: FormBuilder private formBuilder: FormBuilder
) { } ) {
this.id = Number(this.route.snapshot.paramMap.get('id'))
}
ngOnInit(): void { async ngOnInit(): Promise<void> {
this.getBusinessUnits() this.getBusinessUnits()
this.getAgence()
this.registerForm = this.formBuilder.group({ this.registerForm = this.formBuilder.group({
name: ['', Validators.required], name: ['', Validators.required],
businessUnitId:['',Validators.required] businessUnitId:['',Validators.required]
}); });
this.agenceObservable = this.agenceService.getAgence(this.id).pipe(tap(agence => this.registerForm.patchValue(agence)))
this.agence = await this.agenceObservable.pipe(take(1)).toPromise()
} }
getAgence(): void { getBusinessUnits() {
const id = Number(this.route.snapshot.paramMap.get('id')) this.businessUnitService.getBusinessunits()
this.agenceService.getAgence(id) .subscribe(businessunits => this.businessUnits = businessunits);
.subscribe(agence => this.agence = agence);
} }
goBack(): void { goBack(): void {
this.location.back(); this.location.back();
} }
save():void{ onSubmit():void{
if (this.agence){ this.submitted = true
this.agenceService.updateAgence(this.agence)
.subscribe(()=>this.goBack());
}
}
onSubmit() {
this.submitted = true;
if (this.registerForm.invalid) { if (this.registerForm.invalid) {
return; return;
} }
if (this.agence){
this.agence.name = this.registerForm.value.name this.agence.name = this.registerForm.value.name
this.save() this.agence.businessUnitId = this.registerForm.value.businessUnitId
this.agenceService.updateAgence(this.agence)
.subscribe(()=>this.goBack());
}
} }
get f() { return this.registerForm.controls; } get f() { return this.registerForm.controls; }
@ -71,9 +73,5 @@ export class AgenceEditComponent implements OnInit {
this.submitted = false; this.submitted = false;
this.registerForm.reset(); this.registerForm.reset();
} }
getBusinessUnits():void {
this.businessUnitService.getBusinessunits()
.subscribe(businessunits => this.businessUnits = businessunits);
}
} }

Loading…
Cancel
Save