Refonte agence et BU (inversion)

pull/11/head
Clement FERRERE 3 years ago
parent 86fa9acf14
commit 640b3f2f6d
  1. 4
      src/app/app.component.html
  2. 11
      src/app/components/agence/agence-edit/agence-edit.component.html
  3. 13
      src/app/components/agence/agence-edit/agence-edit.component.ts
  4. 11
      src/app/components/agence/agence.component.html
  5. 18
      src/app/components/agence/agence.component.ts
  6. 11
      src/app/components/businessunit/businessunit-edit/businessunit-edit.component.html
  7. 4
      src/app/components/businessunit/businessunit-edit/businessunit-edit.component.ts
  8. 11
      src/app/components/businessunit/businessunit.component.html
  9. 12
      src/app/components/businessunit/businessunit.component.ts
  10. 1
      src/app/interfaces/agence.ts
  11. 1
      src/app/interfaces/businessunit.ts
  12. 2
      src/app/services/agence.service.ts
  13. 2
      src/app/services/businessunit.service.ts
  14. 2
      src/app/services/collaborateur.service.ts

@ -61,13 +61,13 @@
<a class="toolbar-button" routerLink="/home">Home</a> <a class="toolbar-button" routerLink="/home">Home</a>
</nav> </nav>
<nav> <nav>
<a class="toolbar-button" routerLink="/collaborateurs">Collaborateurs</a> <a class="toolbar-button" routerLink="/businessunits">Business Units</a>
</nav> </nav>
<nav> <nav>
<a class="toolbar-button" routerLink="/agences">Agences</a> <a class="toolbar-button" routerLink="/agences">Agences</a>
</nav> </nav>
<nav> <nav>
<a class="toolbar-button" routerLink="/businessunits">Business Units</a> <a class="toolbar-button" routerLink="/collaborateurs">Collaborateurs</a>
</nav> </nav>
</div> </div>

@ -14,6 +14,17 @@
</div> </div>
</div> </div>
<div class="form-group col-12 col-md-6">
<label class="form-label">Business Unit</label>
<select class="form-select" formControlName="businessUnitId" id="businessUnit-select" [ngClass]="{ 'is-invalid': submitted && f.businessUnitId.errors }">
<option value="" disabled selected>Choisissez la business unit de cette agence</option>
<option *ngFor="let businessUnit of businessUnits" [ngValue]="businessUnit.id">{{businessUnit.name}}</option>
</select>
<div *ngIf="submitted && f.businessUnitId.errors" class="invalid-feedback">
<div *ngIf="f.businessUnitId.errors.required">Vous devez choisir la business unit à laquelle appartient l'agence </div>
</div>
</div>
<div> <div>
<button (click)="goBack()">Retour</button> <button (click)="goBack()">Retour</button>

@ -4,6 +4,8 @@ import {ActivatedRoute} from "@angular/router";
import {AgenceService} from "../../../services/agence.service"; import {AgenceService} from "../../../services/agence.service";
import {Location} from "@angular/common"; 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 {BusinessunitService} from "../../../services/businessunit.service";
@Component({ @Component({
selector: 'app-agence-edit', selector: 'app-agence-edit',
@ -12,6 +14,8 @@ import {FormBuilder, FormGroup, Validators} from '@angular/forms';
}) })
export class AgenceEditComponent implements OnInit { export class AgenceEditComponent implements OnInit {
agence = {} as Agence; agence = {} as Agence;
businessUnits : Businessunit[] = [];
businessUnit = {} as Businessunit ;
registerForm!: FormGroup; registerForm!: FormGroup;
submitted = false; submitted = false;
@ -19,14 +23,17 @@ export class AgenceEditComponent implements OnInit {
constructor( constructor(
private route: ActivatedRoute, private route: ActivatedRoute,
private agenceService: AgenceService, private agenceService: AgenceService,
private businessUnitService: BusinessunitService,
private location: Location, private location: Location,
private formBuilder: FormBuilder private formBuilder: FormBuilder
) { } ) { }
ngOnInit(): void { ngOnInit(): void {
this.getBusinessUnits()
this.getAgence() this.getAgence()
this.registerForm = this.formBuilder.group({ this.registerForm = this.formBuilder.group({
name: ['', Validators.required] name: ['', Validators.required],
businessUnitId:['',Validators.required]
}); });
} }
@ -64,5 +71,9 @@ 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);
}
} }

@ -12,6 +12,17 @@
</div> </div>
</div> </div>
<div class="form-group col-12 col-md-6">
<label class="form-label">Business Unit</label>
<select class="form-select" formControlName="businessUnitId" id="businessUnit-select" [ngClass]="{ 'is-invalid': submitted && f.businessUnitId.errors }">
<option value="" disabled selected>Choisissez la business unit de cette agence</option>
<option *ngFor="let businessUnit of businessUnits" [ngValue]="businessUnit.id">{{businessUnit.name}}</option>
</select>
<div *ngIf="submitted && f.businessUnitId.errors" class="invalid-feedback">
<div *ngIf="f.businessUnitId.errors.required">Vous devez choisir la business unit à laquelle appartient l'agence </div>
</div>
</div>
<div> <div>
<button type="submit">Créer l'agence</button> <button type="submit">Créer l'agence</button>

@ -3,6 +3,8 @@ import {Agence} from "../../interfaces/agence";
import {HttpClient} from "@angular/common/http"; import {HttpClient} from "@angular/common/http";
import {AgenceService} from "../../services/agence.service"; import {AgenceService} from "../../services/agence.service";
import {FormBuilder, FormGroup, Validators} from '@angular/forms'; import {FormBuilder, FormGroup, Validators} from '@angular/forms';
import {Businessunit} from "../../interfaces/businessunit";
import {BusinessunitService} from "../../services/businessunit.service";
@Component({ @Component({
selector: 'app-agence', selector: 'app-agence',
@ -12,6 +14,8 @@ import {FormBuilder, FormGroup, Validators} from '@angular/forms';
export class AgenceComponent implements OnInit { export class AgenceComponent implements OnInit {
agences : Agence[] = []; agences : Agence[] = [];
agence = {} as Agence; agence = {} as Agence;
businessUnits : Businessunit[] = [];
businessUnit = {} as Businessunit ;
registerForm!: FormGroup; registerForm!: FormGroup;
submitted = false; submitted = false;
@ -19,13 +23,16 @@ export class AgenceComponent implements OnInit {
constructor( constructor(
private http : HttpClient, private http : HttpClient,
private agenceService: AgenceService, private agenceService: AgenceService,
private businessUnitService: BusinessunitService,
private formBuilder: FormBuilder private formBuilder: FormBuilder
) { } ) { }
ngOnInit(): void { ngOnInit(): void {
this.getAgences(); this.getAgences();
this.getBusinessUnits();
this.registerForm = this.formBuilder.group({ this.registerForm = this.formBuilder.group({
name: ['', Validators.required] name: ['', Validators.required],
businessUnitId: ['',Validators.required]
}); });
} }
@ -34,6 +41,11 @@ export class AgenceComponent implements OnInit {
.subscribe(agences => this.agences = agences); .subscribe(agences => this.agences = agences);
} }
getBusinessUnits() {
this.businessUnitService.getBusinessunits()
.subscribe(businessunits => this.businessUnits = businessunits);
}
add(agence: Agence): void { add(agence: Agence): void {
this.agenceService.addAgence(agence) this.agenceService.addAgence(agence)
.subscribe(agence => { .subscribe(agence => {
@ -47,7 +59,8 @@ export class AgenceComponent implements OnInit {
if (this.registerForm.invalid) { if (this.registerForm.invalid) {
return; return;
} }
this.agence = this.registerForm.value this.agence.name = this.registerForm.value.name
this.agence.businessUnitId = this.registerForm.value.businessUnitId
this.add(this.agence) this.add(this.agence)
} }
@ -58,4 +71,5 @@ export class AgenceComponent implements OnInit {
this.registerForm.reset(); this.registerForm.reset();
} }
} }

@ -14,17 +14,6 @@
</div> </div>
</div> </div>
<div class="form-group col-12 col-md-6">
<label class="form-label">Agence</label>
<select class="form-select" formControlName="agenceId" id="agence-select" [ngClass]="{ 'is-invalid': submitted && f.agenceId.errors }">
<option value="" disabled selected>Choisissez l'agence de cette business unit</option>
<option *ngFor="let agence of agences" [ngValue]="agence.id">{{agence.name}}</option>
</select>
<div *ngIf="submitted && f.agenceId.errors" class="invalid-feedback">
<div *ngIf="f.agenceId.errors.required">Vous devez choisir l'agence à laquelle appartient la business unit</div>
</div>
</div>
<div> <div>
<button (click)="goBack()">Retour</button> <button (click)="goBack()">Retour</button>
<button type="submit">Sauvegarder les changements</button> <button type="submit">Sauvegarder les changements</button>

@ -34,8 +34,7 @@ export class BusinessunitEditComponent implements OnInit {
this.getBusinessunit(); this.getBusinessunit();
this.getAgences(); this.getAgences();
this.registerForm = this.formBuilder.group({ this.registerForm = this.formBuilder.group({
name: ['', Validators.required], name: ['', Validators.required]
agenceId: ['',Validators.required]
}); });
} }
@ -75,7 +74,6 @@ export class BusinessunitEditComponent implements OnInit {
return; return;
} }
this.businessunit.name = this.registerForm.value.name this.businessunit.name = this.registerForm.value.name
this.businessunit.agenceId = this.registerForm.value.agenceId
this.save() this.save()
} }

@ -12,17 +12,6 @@
</div> </div>
</div> </div>
<div class="form-group col-12 col-md-6">
<label class="form-label">Agence</label>
<select class="form-select" formControlName="agenceId" id="agence-select" [ngClass]="{ 'is-invalid': submitted && f.agenceId.errors }">
<option value="" disabled selected>Choisissez l'agence de cette business unit</option>
<option *ngFor="let agence of agences" [ngValue]="agence.id">{{agence.name}}</option>
</select>
<div *ngIf="submitted && f.agenceId.errors" class="invalid-feedback">
<div *ngIf="f.agenceId.errors.required">Vous devez choisir l'agence à laquelle appartient la business unit</div>
</div>
</div>
<div> <div>
<button type="submit">Créer la business unit</button> <button type="submit">Créer la business unit</button>
<button type="reset" (click)="onReset()">Effacer</button> <button type="reset" (click)="onReset()">Effacer</button>

@ -2,8 +2,6 @@ import { Component, OnInit } from '@angular/core';
import {Businessunit} from "../../interfaces/businessunit"; import {Businessunit} from "../../interfaces/businessunit";
import {HttpClient} from "@angular/common/http"; import {HttpClient} from "@angular/common/http";
import {BusinessunitService} from "../../services/businessunit.service"; import {BusinessunitService} from "../../services/businessunit.service";
import {Agence} from "../../interfaces/agence";
import {AgenceService} from "../../services/agence.service";
import {FormBuilder, FormGroup, Validators} from "@angular/forms"; import {FormBuilder, FormGroup, Validators} from "@angular/forms";
@Component({ @Component({
@ -15,8 +13,6 @@ export class BusinessunitComponent implements OnInit {
businessunits : Businessunit[] = []; businessunits : Businessunit[] = [];
businessunit = {} as Businessunit ; businessunit = {} as Businessunit ;
agences : Agence[] = [];
agence = {} as Agence ;
registerForm!: FormGroup; registerForm!: FormGroup;
submitted = false; submitted = false;
@ -24,16 +20,13 @@ export class BusinessunitComponent implements OnInit {
constructor( constructor(
private http : HttpClient, private http : HttpClient,
private businessunitService: BusinessunitService, private businessunitService: BusinessunitService,
private agenceService: AgenceService,
private formBuilder: FormBuilder private formBuilder: FormBuilder
) { } ) { }
ngOnInit(): void { ngOnInit(): void {
this.getBusinessunits(); this.getBusinessunits();
this.getAgences();
this.registerForm = this.formBuilder.group({ this.registerForm = this.formBuilder.group({
name: ['', Validators.required], name: ['', Validators.required],
agenceId: ['',Validators.required]
}); });
} }
@ -42,11 +35,6 @@ export class BusinessunitComponent implements OnInit {
.subscribe(businessunits => this.businessunits = businessunits); .subscribe(businessunits => this.businessunits = businessunits);
} }
getAgences():void {
this.agenceService.getAgences()
.subscribe(agences => this.agences = agences);
}
add(businessunit: Businessunit): void { add(businessunit: Businessunit): void {
this.businessunitService.addBusinessunit(businessunit) this.businessunitService.addBusinessunit(businessunit)
.subscribe(businessunit => { .subscribe(businessunit => {

@ -1,4 +1,5 @@
export interface Agence { export interface Agence {
name: string; name: string;
id: number; id: number;
businessUnitId : number;
} }

@ -1,5 +1,4 @@
export interface Businessunit { export interface Businessunit {
name: string; name: string;
id: number; id: number;
agenceId : number;
} }

@ -2,7 +2,7 @@ import { Injectable } from '@angular/core';
import {HttpClient, HttpHeaders} from "@angular/common/http"; import {HttpClient, HttpHeaders} from "@angular/common/http";
import {Observable} from "rxjs"; import {Observable} from "rxjs";
import {Agence} from "../interfaces/agence"; import {Agence} from "../interfaces/agence";
import {agencesUrl} from "../../ressources/routes/routesPreprod"; import {agencesUrl} from "../../ressources/routes/routes";
@Injectable({ @Injectable({
providedIn: 'root' providedIn: 'root'

@ -2,7 +2,7 @@ import { Injectable } from '@angular/core';
import {HttpClient, HttpHeaders} from "@angular/common/http"; import {HttpClient, HttpHeaders} from "@angular/common/http";
import {Observable} from "rxjs"; import {Observable} from "rxjs";
import {Businessunit} from "../interfaces/businessunit"; import {Businessunit} from "../interfaces/businessunit";
import {businessunitsUrl} from "../../ressources/routes/routesPreprod"; import {businessunitsUrl} from "../../ressources/routes/routes";
@Injectable({ @Injectable({
providedIn: 'root' providedIn: 'root'

@ -2,7 +2,7 @@ import {Collaborateur} from "../interfaces/collaborateur";
import {Injectable} from '@angular/core'; import {Injectable} from '@angular/core';
import {Observable} from "rxjs"; import {Observable} from "rxjs";
import {HttpClient, HttpHeaders} from "@angular/common/http"; import {HttpClient, HttpHeaders} from "@angular/common/http";
import {collaborateursUrl} from "../../ressources/routes/routesPreprod"; import {collaborateursUrl} from "../../ressources/routes/routes";
@Injectable({providedIn: 'root'}) @Injectable({providedIn: 'root'})

Loading…
Cancel
Save