diff --git a/src/app/components/periode-essai/periode-essai.component.html b/src/app/components/periode-essai/periode-essai.component.html index 4e9f785..97e5388 100644 --- a/src/app/components/periode-essai/periode-essai.component.html +++ b/src/app/components/periode-essai/periode-essai.component.html @@ -1 +1,92 @@ -

periode-essai works!

+
+ +

Ajouter une Période d'Essai :

+ + + +
+ + +
+
Vous devez choisir le collaborateur concerné par cette période d'essai
+
+
+ +
+ + +
+
La date de début d'une période d'essai est obligatoire
+
+
+ +
+ + +
+
La date de fin prévue d'une période d'essai est obligatoire
+
+
+ +
+ + +
+
La date de fin réelle d'une période d'essai est obligatoire
+
+
+ +
+ + +
+
Le commentaire d'une période d'essai est obligatoire
+
+
+ +
+ + +
+
L'issue d'une période d'essai est obligatoire
+
+
+ + + + +
+ + +
+ + +

Périodes d'essai

+ +
+ + + + + + + + + + + + + + + + +
IDCollaborateur IDIssue
{{periodeEssai.id}} {{periodeEssai.collaborateurId}} Modifier
+
+ + + + +
diff --git a/src/app/components/periode-essai/periode-essai.component.ts b/src/app/components/periode-essai/periode-essai.component.ts index 20fab35..22ec458 100644 --- a/src/app/components/periode-essai/periode-essai.component.ts +++ b/src/app/components/periode-essai/periode-essai.component.ts @@ -1,4 +1,10 @@ import { Component, OnInit } from '@angular/core'; +import {HttpClient} from "@angular/common/http"; +import {FormBuilder, FormGroup, Validators} from '@angular/forms'; +import {PeriodeEssai} from "../../interfaces/periode-essai"; +import {Collaborateur} from "../../interfaces/collaborateur"; +import {CollaborateurService} from "../../services/collaborateur.service"; +import {PeriodeEssaiService} from "../../services/periode-essai.service"; @Component({ selector: 'app-periode-essai', @@ -7,9 +13,91 @@ import { Component, OnInit } from '@angular/core'; }) export class PeriodeEssaiComponent implements OnInit { - constructor() { } + collaborateurs : Collaborateur[] = []; + collaborateur = {} as Collaborateur; + + periodeEssais : PeriodeEssai[] = []; + periodeEssai = {} as PeriodeEssai; + + registerForm!: FormGroup; + submitted = false; + + startingDate : String = ""; + plannedEndingDate : String = ""; + realEndingDate : String = ""; + + constructor( + private http : HttpClient, + private collaborateurService: CollaborateurService, + private periodeEssaiService: PeriodeEssaiService, + private formBuilder: FormBuilder + ) { } ngOnInit(): void { + this.getCollaborateurs(); + this.registerForm = this.formBuilder.group({ + comment: ['', Validators.required], + collaborateurId: ['',Validators.required], + issue: ['',Validators.required], + plannedEndingDate: ['',Validators.required], + realEndingDate: ['',Validators.required], + startingDate: ['',Validators.required] + }); + if (this.periodeEssai.startingDate) { + this.startingDate = new Date(this.periodeEssai.startingDate).toISOString().split('T')[0]; + } + if (this.periodeEssai.plannedEndingDate) { + this.plannedEndingDate = new Date(this.periodeEssai.plannedEndingDate).toISOString().split('T')[0]; + } + if (this.periodeEssai.realEndingDate) { + this.realEndingDate = new Date(this.periodeEssai.realEndingDate).toISOString().split('T')[0]; + } + } + + getCollaborateurs():void { + this.collaborateurService.getCollaborateurs() + .subscribe(collaborateurs => this.collaborateurs = collaborateurs); + } + + add(periodeEssai: PeriodeEssai): void { + this.periodeEssaiService.addPeriodeEssai(periodeEssai) + .subscribe(periodeEssai => { + this.periodeEssais.push(periodeEssai); + }); + } + + onSubmit() { + this.submitted = true; + + if (this.registerForm.invalid) { + return; + } + this.periodeEssai.comment = this.registerForm.value.comment + this.periodeEssai.collaborateurId = this.registerForm.value.collaborateurId + this.periodeEssai.issue = this.registerForm.value.issue + this.periodeEssai.plannedEndingDate = this.registerForm.value.plannedEndingDate + this.periodeEssai.realEndingDate = this.registerForm.value.realEndingDate + this.periodeEssai.startingDate = this.registerForm.value.startingDate + this.add(this.periodeEssai) + } + + get f() { return this.registerForm.controls; } + + onReset() { + this.submitted = false; + this.registerForm.reset(); + } + + onStartingDateChange($event: any):void { + this.periodeEssai.startingDate = new Date($event.target.value); + } + + onPlannedEndingDateChange($event: any):void { + this.periodeEssai.plannedEndingDate = new Date($event.target.value); + } + + onRealEndingDateChange($event: any):void { + this.periodeEssai.realEndingDate = new Date($event.target.value); } } diff --git a/src/app/interfaces/periode-essai.ts b/src/app/interfaces/periode-essai.ts new file mode 100644 index 0000000..7ffc318 --- /dev/null +++ b/src/app/interfaces/periode-essai.ts @@ -0,0 +1,9 @@ +export interface PeriodeEssai { + id: number; + collaborateurId : number; + startingDate : Date; + plannedEndingDate : Date; + realEndingDate : Date; + comment : string; + issue : string; +} diff --git a/src/app/services/periode-essai.service.ts b/src/app/services/periode-essai.service.ts new file mode 100644 index 0000000..eb177e4 --- /dev/null +++ b/src/app/services/periode-essai.service.ts @@ -0,0 +1,37 @@ +import { Injectable } from '@angular/core'; +import {HttpClient, HttpHeaders} from "@angular/common/http"; +import {Observable} from "rxjs"; +import {periodeessaisUrl} from "../../ressources/routes/routesPreprod"; +import {PeriodeEssai} from "../interfaces/periode-essai"; + + +@Injectable({ + providedIn: 'root' +}) +export class PeriodeEssaiService{ + private periodeessaisUrl = periodeessaisUrl; + + httpOptions = { + headers: new HttpHeaders({ 'Content-Type': 'application/json' }) + }; + + constructor(private http: HttpClient) { } + + getPeriodeEssais():Observable { + return this.http.get(this.periodeessaisUrl); + } + + getPeriodeEssai(id : number):Observable{ + return this.http.get(this.periodeessaisUrl+"/"+id); + } + + updatePeriodeEssai(periodeEssai : PeriodeEssai):Observable{ + let body = JSON.stringify(periodeEssai); + return this.http.put(this.periodeessaisUrl + "/" + periodeEssai.id, body, this.httpOptions); + } + + addPeriodeEssai(periodeEssai: PeriodeEssai): Observable { + let body = JSON.stringify(periodeEssai); + return this.http.post(this.periodeessaisUrl, body, this.httpOptions); + } +} diff --git a/src/ressources/routes/routesPreprod.ts b/src/ressources/routes/routesPreprod.ts index 50dc52e..6eba4df 100644 --- a/src/ressources/routes/routesPreprod.ts +++ b/src/ressources/routes/routesPreprod.ts @@ -1,3 +1,4 @@ export const collaborateursUrl = 'https://collaborateur-epa.apsdigit.lan/api/collaborateurs'; export const agencesUrl = 'https://collaborateur-epa.apsdigit.lan/api/agences'; export const businessunitsUrl = 'https://collaborateur-epa.apsdigit.lan/api/businessunits'; +export const periodeessaisUrl = 'https://collaboratuer-epa.apsdigit.lan/api/periodeessais'; -- 2.36.3 From 911caff9f537b4b665577f4c5882327705d12d88 Mon Sep 17 00:00:00 2001 From: Clement FERRERE Date: Mon, 2 May 2022 15:57:02 +0200 Subject: [PATCH 08/11] =?UTF-8?q?gestion=20de=20la=20p=C3=A9riode=20d'essa?= =?UTF-8?q?i=20et=20des=20=C3=A9ditions?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../periode-essai-edit.component.html | 70 ++++++++++- .../periode-essai-edit.component.ts | 113 +++++++++++++++++- .../periode-essai.component.html | 2 +- .../periode-essai/periode-essai.component.ts | 6 +- src/app/services/periode-essai.service.ts | 4 + src/ressources/routes/routesPreprod.ts | 2 +- 6 files changed, 191 insertions(+), 6 deletions(-) diff --git a/src/app/components/periode-essai/periode-essai-edit/periode-essai-edit.component.html b/src/app/components/periode-essai/periode-essai-edit/periode-essai-edit.component.html index 59a58c9..22adbc5 100644 --- a/src/app/components/periode-essai/periode-essai-edit/periode-essai-edit.component.html +++ b/src/app/components/periode-essai/periode-essai-edit/periode-essai-edit.component.html @@ -1 +1,69 @@ -

periode-essai-edit works!

+
+ +

Ajouter une Période d'Essai :

+ +
+ +
+ + +
+
Vous devez choisir le collaborateur concerné par cette période d'essai
+
+
+ +
+ + +
+
La date de début d'une période d'essai est obligatoire
+
+
+ +
+ + +
+
La date de fin prévue d'une période d'essai est obligatoire
+
+
+ +
+ + +
+
La date de fin réelle d'une période d'essai est obligatoire
+
+
+ +
+ + +
+
Le commentaire d'une période d'essai est obligatoire
+
+
+ +
+ + +
+
L'issue d'une période d'essai est obligatoire
+
+
+ +
+ + + + +
+ +
+ +
diff --git a/src/app/components/periode-essai/periode-essai-edit/periode-essai-edit.component.ts b/src/app/components/periode-essai/periode-essai-edit/periode-essai-edit.component.ts index ec7064a..39ec86a 100644 --- a/src/app/components/periode-essai/periode-essai-edit/periode-essai-edit.component.ts +++ b/src/app/components/periode-essai/periode-essai-edit/periode-essai-edit.component.ts @@ -1,4 +1,13 @@ import { Component, OnInit } from '@angular/core'; +import {FormBuilder, FormGroup, Validators} from '@angular/forms'; +import {PeriodeEssai} from "../../../interfaces/periode-essai"; +import {Collaborateur} from "../../../interfaces/collaborateur"; +import {CollaborateurService} from "../../../services/collaborateur.service"; +import {PeriodeEssaiService} from "../../../services/periode-essai.service"; +import {Observable} from "rxjs"; +import {ActivatedRoute} from "@angular/router"; +import {take, tap} from "rxjs/operators"; +import {Location} from "@angular/common"; @Component({ selector: 'app-periode-essai-edit', @@ -7,9 +16,109 @@ import { Component, OnInit } from '@angular/core'; }) export class PeriodeEssaiEditComponent implements OnInit { - constructor() { } + periodeEssaiObservable! : Observable; + id: number; - ngOnInit(): void { + collaborateurs : Collaborateur[] = []; + collaborateur = {} as Collaborateur; + + periodeEssais : PeriodeEssai[] = []; + periodeEssai = {} as PeriodeEssai; + + registerForm!: FormGroup; + submitted = false; + + startingDate : String = ""; + plannedEndingDate : String = ""; + realEndingDate : String = ""; + + constructor( + private route: ActivatedRoute, + private location: Location, + private collaborateurService: CollaborateurService, + private periodeEssaiService: PeriodeEssaiService, + private formBuilder: FormBuilder + ) { + this.id = Number(this.route.snapshot.paramMap.get('id')) + } + + async ngOnInit() { + this.getCollaborateurs(); + this.registerForm = this.formBuilder.group({ + comment: ['', Validators.required], + collaborateurId: ['',Validators.required], + issue: ['',Validators.required], + plannedEndingDate: ['',Validators.required], + realEndingDate: ['',Validators.required], + startingDate: ['',Validators.required] + }); + this.periodeEssaiObservable = this.periodeEssaiService.getPeriodeEssai(this.id).pipe(tap(periodeEssai => this.registerForm.patchValue(periodeEssai))) + this.periodeEssai = await this.periodeEssaiObservable.pipe(take(1)).toPromise() + if (this.periodeEssai.startingDate) { + this.startingDate = new Date(this.periodeEssai.startingDate).toISOString().split('T')[0]; + } + if (this.periodeEssai.plannedEndingDate) { + this.plannedEndingDate = new Date(this.periodeEssai.plannedEndingDate).toISOString().split('T')[0]; + } + if (this.periodeEssai.realEndingDate) { + this.realEndingDate = new Date(this.periodeEssai.realEndingDate).toISOString().split('T')[0]; + } + } + + getCollaborateurs():void { + this.collaborateurService.getCollaborateurs() + .subscribe(collaborateurs => this.collaborateurs = collaborateurs); + } + + goBack(): void { + this.location.back(); + } + + delete():void { + if (this.periodeEssai){ + this.periodeEssaiService.deletePeriodeEssai(this.periodeEssai) + .subscribe(()=>this.goBack()); + } + } + + onSubmit() { + this.submitted = true; + + if (this.registerForm.invalid) { + return; + } + this.periodeEssai.comment = this.registerForm.value.comment + this.periodeEssai.collaborateurId = this.registerForm.value.collaborateurId + this.periodeEssai.issue = this.registerForm.value.issue + this.periodeEssai.plannedEndingDate = this.registerForm.value.plannedEndingDate + this.periodeEssai.realEndingDate = this.registerForm.value.realEndingDate + this.periodeEssai.startingDate = this.registerForm.value.startingDate + + if (this.periodeEssai){ + this.periodeEssaiService.updatePeriodeEssai(this.periodeEssai) + .subscribe(()=>this.goBack()); + } + } + + get f() { return this.registerForm.controls; } + + onReset() { + this.submitted = false; + this.registerForm.reset(); + } + + onStartingDateChange($event: any):void { + this.periodeEssai.startingDate = new Date($event.target.value); + } + + onPlannedEndingDateChange($event: any):void { + this.periodeEssai.plannedEndingDate = new Date($event.target.value); + } + + onRealEndingDateChange($event: any):void { + this.periodeEssai.realEndingDate = new Date($event.target.value); } } + + diff --git a/src/app/components/periode-essai/periode-essai.component.html b/src/app/components/periode-essai/periode-essai.component.html index 97e5388..ab4f869 100644 --- a/src/app/components/periode-essai/periode-essai.component.html +++ b/src/app/components/periode-essai/periode-essai.component.html @@ -79,7 +79,7 @@ {{periodeEssai.id}} {{periodeEssai.collaborateurId}} - + {{periodeEssai.issue}} Modifier diff --git a/src/app/components/periode-essai/periode-essai.component.ts b/src/app/components/periode-essai/periode-essai.component.ts index 22ec458..7a84d53 100644 --- a/src/app/components/periode-essai/periode-essai.component.ts +++ b/src/app/components/periode-essai/periode-essai.component.ts @@ -35,6 +35,7 @@ export class PeriodeEssaiComponent implements OnInit { ngOnInit(): void { this.getCollaborateurs(); + this.getPeriodeEssais(); this.registerForm = this.formBuilder.group({ comment: ['', Validators.required], collaborateurId: ['',Validators.required], @@ -68,7 +69,6 @@ export class PeriodeEssaiComponent implements OnInit { onSubmit() { this.submitted = true; - if (this.registerForm.invalid) { return; } @@ -100,4 +100,8 @@ export class PeriodeEssaiComponent implements OnInit { this.periodeEssai.realEndingDate = new Date($event.target.value); } + getPeriodeEssais() { + this.periodeEssaiService.getPeriodeEssais() + .subscribe(periodeEssais => this.periodeEssais = periodeEssais); + } } diff --git a/src/app/services/periode-essai.service.ts b/src/app/services/periode-essai.service.ts index eb177e4..4bea51f 100644 --- a/src/app/services/periode-essai.service.ts +++ b/src/app/services/periode-essai.service.ts @@ -30,6 +30,10 @@ export class PeriodeEssaiService{ return this.http.put(this.periodeessaisUrl + "/" + periodeEssai.id, body, this.httpOptions); } + deletePeriodeEssai(periodeEssai: PeriodeEssai) { + return this.http.delete(this.periodeessaisUrl + "/" + periodeEssai.id); + } + addPeriodeEssai(periodeEssai: PeriodeEssai): Observable { let body = JSON.stringify(periodeEssai); return this.http.post(this.periodeessaisUrl, body, this.httpOptions); diff --git a/src/ressources/routes/routesPreprod.ts b/src/ressources/routes/routesPreprod.ts index 6eba4df..a611105 100644 --- a/src/ressources/routes/routesPreprod.ts +++ b/src/ressources/routes/routesPreprod.ts @@ -1,4 +1,4 @@ export const collaborateursUrl = 'https://collaborateur-epa.apsdigit.lan/api/collaborateurs'; export const agencesUrl = 'https://collaborateur-epa.apsdigit.lan/api/agences'; export const businessunitsUrl = 'https://collaborateur-epa.apsdigit.lan/api/businessunits'; -export const periodeessaisUrl = 'https://collaboratuer-epa.apsdigit.lan/api/periodeessais'; +export const periodeessaisUrl = 'https://collaborateur-epa.apsdigit.lan/api/periodeessais'; -- 2.36.3 From 7265a55e0beefd9111196be87ed28000d12cd188 Mon Sep 17 00:00:00 2001 From: Clement FERRERE Date: Wed, 4 May 2022 15:09:06 +0200 Subject: [PATCH 09/11] =?UTF-8?q?gestions=20des=20conflits=20sur=20l'unici?= =?UTF-8?q?t=C3=A9=20des=20mails=20Apside=20+=20appuyer=20sur=20entr=C3=A9?= =?UTF-8?q?e=20fonctionne?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../collaborateur-edit.component.html | 8 ++++++-- .../collaborateur-edit.component.ts | 19 ++++++++++++++----- src/app/services/collaborateur.service.ts | 12 +++++++++++- 3 files changed, 31 insertions(+), 8 deletions(-) diff --git a/src/app/components/collaborateur/collaborateur-edit/collaborateur-edit.component.html b/src/app/components/collaborateur/collaborateur-edit/collaborateur-edit.component.html index 4aa8ae7..f023ee9 100644 --- a/src/app/components/collaborateur/collaborateur-edit/collaborateur-edit.component.html +++ b/src/app/components/collaborateur/collaborateur-edit/collaborateur-edit.component.html @@ -104,11 +104,15 @@
- +
Le mail Apside d'un collaborateur est obligatoire
Le mail Apside d'un collaborateur doit être au format "exemple@apside-groupe.com" ou "exemple@apside.fr"
+
+
Le mail Apside que vous avez entré est déjà utilisé pour un autre collaborateur
+
+
@@ -148,10 +152,10 @@
- +
diff --git a/src/app/components/collaborateur/collaborateur-edit/collaborateur-edit.component.ts b/src/app/components/collaborateur/collaborateur-edit/collaborateur-edit.component.ts index e19ca82..a03d7f7 100644 --- a/src/app/components/collaborateur/collaborateur-edit/collaborateur-edit.component.ts +++ b/src/app/components/collaborateur/collaborateur-edit/collaborateur-edit.component.ts @@ -24,6 +24,7 @@ export class CollaborateurEditComponent implements OnInit { collaborateurs : Collaborateur[] = []; businessUnits : Businessunit[] = []; + errorValue : number = 0; rDate : String = ""; bDate : String = ""; @@ -52,8 +53,8 @@ export class CollaborateurEditComponent implements OnInit { childrenNumber: ['', Validators.required], address: ['', Validators.required], telephone: ['', Validators.required], - personalMail: ['',Validators.compose([Validators.required,Validators.pattern(".*@[a-z]*\.[a-z]*")])], - apsideMail: ['', Validators.compose([Validators.required,Validators.pattern(".*@apside-groupe\.com|.*@apside\.fr")])], + personalMail: ['',Validators.compose([Validators.required,Validators.pattern(".+@[a-z]*\.[a-z]*")])], + apsideMail: ['', Validators.compose([Validators.required,Validators.pattern(".+@apside-groupe\.com|.*@apside\.fr")])], resignationDate: ['', Validators.required], referrerId: ['', Validators.required], businessUnitId: ['', Validators.required], @@ -110,12 +111,20 @@ export class CollaborateurEditComponent implements OnInit { this.collaborateur.childrenNumber = this.registerForm.value.childrenNumber this.collaborateur.status = this.registerForm.value.status - if (this.collaborateur){ - this.collaborateurService.updateCollaborateur(this.collaborateur) - .subscribe(()=>this.goBack()); + if (this.collaborateur) { + this.collaborateurService.updateCollaborateur(this.collaborateur).subscribe({ + next: () => { + this.goBack(); + }, + error: () => { + this.errorValue = 1; + } + }) + } } + get f() { return this.registerForm.controls; } onReset() { diff --git a/src/app/services/collaborateur.service.ts b/src/app/services/collaborateur.service.ts index 2b58b98..41b2c21 100644 --- a/src/app/services/collaborateur.service.ts +++ b/src/app/services/collaborateur.service.ts @@ -28,6 +28,7 @@ export class CollaborateurService { updateCollaborateur(collaborateur : Collaborateur):Observable{ let body = JSON.stringify(collaborateur); return this.http.put(this.collaborateursUrl + "/" + collaborateur.id, body, this.httpOptions); + } deleteCollaborateur(collaborateur: Collaborateur) { @@ -36,6 +37,15 @@ export class CollaborateurService { addCollaborateur(collaborateur: Collaborateur): Observable { let body = JSON.stringify(collaborateur); - return this.http.post(this.collaborateursUrl, body, this.httpOptions); + let result = this.http.post(this.collaborateursUrl, body, this.httpOptions); + + result.subscribe({error:error => { + console.log("passage par l'erreur : "); + console.log(error); + + } + }) + + return result; } } -- 2.36.3 From efdd60291e33e38a7fafa0ac29575dba47ea0486 Mon Sep 17 00:00:00 2001 From: Clement FERRERE Date: Wed, 4 May 2022 15:10:33 +0200 Subject: [PATCH 10/11] =?UTF-8?q?appuyer=20sur=20entr=C3=A9e=20fonctionne?= =?UTF-8?q?=20pour=20les=20=C3=A9ditions?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../components/agence/agence-edit/agence-edit.component.html | 2 +- .../businessunit-edit/businessunit-edit.component.html | 2 +- .../periode-essai-edit/periode-essai-edit.component.html | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/app/components/agence/agence-edit/agence-edit.component.html b/src/app/components/agence/agence-edit/agence-edit.component.html index f5fd279..fb71e34 100644 --- a/src/app/components/agence/agence-edit/agence-edit.component.html +++ b/src/app/components/agence/agence-edit/agence-edit.component.html @@ -30,9 +30,9 @@
- +
diff --git a/src/app/components/businessunit/businessunit-edit/businessunit-edit.component.html b/src/app/components/businessunit/businessunit-edit/businessunit-edit.component.html index ec8a47a..c8bffb8 100644 --- a/src/app/components/businessunit/businessunit-edit/businessunit-edit.component.html +++ b/src/app/components/businessunit/businessunit-edit/businessunit-edit.component.html @@ -18,9 +18,9 @@