parent
4bb12a941c
commit
58e2f4b63f
@ -1 +1,58 @@ |
|||||||
|
:host { |
||||||
|
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"; |
||||||
|
font-size: 14px; |
||||||
|
color: #333; |
||||||
|
box-sizing: border-box; |
||||||
|
-webkit-font-smoothing: antialiased; |
||||||
|
-moz-osx-font-smoothing: grayscale; |
||||||
|
} |
||||||
|
|
||||||
|
h1, |
||||||
|
h2, |
||||||
|
h3, |
||||||
|
h4, |
||||||
|
h5, |
||||||
|
h6 { |
||||||
|
margin: 8px 0; |
||||||
|
} |
||||||
|
|
||||||
|
p { |
||||||
|
margin: 0; |
||||||
|
} |
||||||
|
|
||||||
|
.toolbar { |
||||||
|
top: 0; |
||||||
|
left: 0; |
||||||
|
right: 0; |
||||||
|
height: 60px; |
||||||
|
display: flex; |
||||||
|
align-items: center; |
||||||
|
background-color: #183650; |
||||||
|
color: white; |
||||||
|
font-weight: 600; |
||||||
|
} |
||||||
|
|
||||||
|
.terminal pre { |
||||||
|
font-family: SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace; |
||||||
|
color: white; |
||||||
|
padding: 0 1rem 1rem; |
||||||
|
margin: 0; |
||||||
|
} |
||||||
|
|
||||||
|
nav a { |
||||||
|
padding: 5px; |
||||||
|
text-decoration: none; |
||||||
|
margin: 5px; |
||||||
|
display: inline-block; |
||||||
|
background-color: #E77620; |
||||||
|
color: white; |
||||||
|
border-radius: 4px; |
||||||
|
} |
||||||
|
|
||||||
|
nav a:hover { |
||||||
|
background-color: #42545C; |
||||||
|
} |
||||||
|
|
||||||
|
.dropdown-menu{ |
||||||
|
min-width: fit-content; |
||||||
|
} |
||||||
|
@ -0,0 +1,168 @@ |
|||||||
|
<h3>Ajouter un collaborateur : </h3> |
||||||
|
|
||||||
|
<form [formGroup]="registerForm" (ngSubmit)="onSubmit()"> |
||||||
|
|
||||||
|
<div class="row mb-2"> |
||||||
|
|
||||||
|
<div class="form-group col-12 col-sm-6 col-md-4 col-lg-3"> |
||||||
|
<label class="form-label">Nom</label> |
||||||
|
<input class="form-control" formControlName="name" [ngClass]="{ 'is-invalid': submitted && f.name.errors }"> |
||||||
|
<div *ngIf="submitted && f.name.errors" class="invalid-feedback"> |
||||||
|
<div *ngIf="f.name.errors.required">Le nom d'un collaborateur est obligatoire</div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
<div class="form-group col-12 col-sm-6 col-md-4 col-lg-3"> |
||||||
|
<label class="form-label">Prénom</label> |
||||||
|
<input class="form-control" formControlName="firstName" |
||||||
|
[ngClass]="{ 'is-invalid': submitted && f.firstName.errors }"> |
||||||
|
<div *ngIf="submitted && f.firstName.errors" class="invalid-feedback"> |
||||||
|
<div *ngIf="f.firstName.errors.required">Le prénom d'un collaborateur est obligatoire</div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
<div class="form-group col-12 col-sm-6 col-md-4 col-lg-3"> |
||||||
|
<label class="form-label">Date de naissance</label> |
||||||
|
<input type="date" class="form-control" formControlName="birthDate" (change)="onBirthDateChange($event)" |
||||||
|
[ngClass]="{ 'is-invalid': submitted && f.birthDate.errors }"> |
||||||
|
<div *ngIf="submitted && f.birthDate.errors" class="invalid-feedback"> |
||||||
|
<div *ngIf="f.birthDate.errors.required">La date de naissance d'un collaborateur est obligatoire</div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
<div class="form-group col-12 col-sm-6 col-md-4 col-lg-3"> |
||||||
|
<label class="form-label">Genre</label> |
||||||
|
<select class="form-select" formControlName="gender" [ngClass]="{ 'is-invalid': submitted && f.gender.errors }"> |
||||||
|
<option value="" disabled selected>Genre</option> |
||||||
|
<option value="MASCULIN">Masculin</option> |
||||||
|
<option value="FEMININ">Féminin</option> |
||||||
|
<option value="AUTRE">Autre</option> |
||||||
|
</select> |
||||||
|
<div *ngIf="submitted && f.gender.errors" class="invalid-feedback"> |
||||||
|
<div *ngIf="f.gender.errors.required">Vous devez préciser le genre du collaborateur</div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
</div> |
||||||
|
|
||||||
|
<div class="row mb-2"> |
||||||
|
|
||||||
|
<div class="form-group col-12 col-sm-6 col-md-4 col-lg-3"> |
||||||
|
<label class="form-label">Statut</label> |
||||||
|
<select class="form-select" formControlName="status" [ngClass]="{ 'is-invalid': submitted && f.status.errors }"> |
||||||
|
<option value="" disabled selected>Statut</option> |
||||||
|
<option value="CADRE">Cadre</option> |
||||||
|
<option value="NON-CADRE">Non-cadre</option> |
||||||
|
<option value="ALTERNANT">Alternant</option> |
||||||
|
<option value="STAGIAIRE">Stagiaire</option> |
||||||
|
</select> |
||||||
|
<div *ngIf="submitted && f.status.errors" class="invalid-feedback"> |
||||||
|
<div *ngIf="f.status.errors.required">Vous devez préciser le statut du collaborateur</div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
<div class="form-group col-12 col-sm-6 col-md-4 col-lg-3"> |
||||||
|
<label class="form-label">Nombre d'enfants</label> |
||||||
|
<input class="form-control" formControlName="childrenNumber" |
||||||
|
[ngClass]="{ 'is-invalid': submitted && f.childrenNumber.errors }" type="number" min="0" |
||||||
|
onkeyup="if(this.value<0){this.value= this.value * -1}"> |
||||||
|
<div *ngIf="submitted && f.childrenNumber.errors" class="invalid-feedback"> |
||||||
|
<div *ngIf="f.childrenNumber.errors.required">Le nombre d'enfant d'un collaborateur est obligatoire</div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
<div class="form-group col-12 col-sm-6 col-md-4 col-lg-3"> |
||||||
|
<label class="form-label">Adresse</label> |
||||||
|
<input class="form-control" formControlName="address" [ngClass]="{ 'is-invalid': submitted && f.address.errors }"> |
||||||
|
<div *ngIf="submitted && f.address.errors" class="invalid-feedback"> |
||||||
|
<div *ngIf="f.address.errors.required">L'adresse d'un collaborateur est obligatoire</div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
<div class="form-group col-12 col-sm-6 col-md-4 col-lg-3"> |
||||||
|
<label class="form-label">Téléphone</label> |
||||||
|
<input class="form-control" formControlName="telephone" |
||||||
|
[ngClass]="{ 'is-invalid': submitted && f.telephone.errors }"> |
||||||
|
<div *ngIf="submitted && f.telephone.errors" class="invalid-feedback"> |
||||||
|
<div *ngIf="f.telephone.errors.required">Le numéro de téléphone d'un collaborateur est obligatoire</div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
<div class="row mb-2"> |
||||||
|
|
||||||
|
<div class="form-group col-12 col-sm-6 col-md-4 col-lg-3"> |
||||||
|
<label class="form-label">Mail personnel</label> |
||||||
|
<input type="email" class="form-control" formControlName="personalMail" |
||||||
|
[ngClass]="{ 'is-invalid': submitted && f.personalMail.errors }" placeholder="prenom.nom@example.com"> |
||||||
|
<div *ngIf="submitted && f.personalMail.errors" class="invalid-feedback"> |
||||||
|
<div *ngIf="f.personalMail.errors.required">Le mail personnel d'un collaborateur est obligatoire</div> |
||||||
|
<div *ngIf="f.personalMail.errors.pattern">Le mail personnel d'un collaborateur doit être au format |
||||||
|
"exemple@nom.de.domaine" |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
<div class="form-group col-12 col-sm-6 col-md-4 col-lg-3"> |
||||||
|
<label class="form-label">Mail Apside</label> |
||||||
|
<input type="email" class="form-control" formControlName="apsideMail" |
||||||
|
[ngClass]="{ 'is-invalid': (submitted && f.apsideMail.errors) || errorValue==1 }" |
||||||
|
placeholder="prenom.nom@apside-groupe.com" [value]="collaborateur.apsideMail"> |
||||||
|
<div *ngIf="submitted && f.apsideMail.errors" class="invalid-feedback"> |
||||||
|
<div *ngIf="f.apsideMail.errors.required">Le mail Apside d'un collaborateur est obligatoire</div> |
||||||
|
<div *ngIf="f.apsideMail.errors.pattern">Le mail Apside d'un collaborateur doit être au format |
||||||
|
"exemple@apside-groupe.com" ou "exemple@apside.fr" |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
<div *ngIf="submitted && errorValue==1" class="invalid-feedback"> |
||||||
|
<div *ngIf="errorValue==1">Le mail Apside que vous avez entré est déjà utilisé pour un autre collaborateur</div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
|
||||||
|
<div class="form-group col-12 col-sm-6 col-md-4 col-lg-3"> |
||||||
|
<label class="form-label">Date de départ</label> |
||||||
|
<input type="date" class="form-control" formControlName="resignationDate" |
||||||
|
(change)="onResignationDateChange($event)" |
||||||
|
[ngClass]="{ 'is-invalid': submitted && f.resignationDate.errors }"> |
||||||
|
<div *ngIf="submitted && f.resignationDate.errors" class="invalid-feedback"> |
||||||
|
<div *ngIf="f.resignationDate.errors.required">La date de départ d'un collaborateur est obligatoire</div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
</div> |
||||||
|
|
||||||
|
<div class="row mb-2"> |
||||||
|
|
||||||
|
<div class="form-group col-12 col-md-6"> |
||||||
|
<label class="form-label">Référent</label> |
||||||
|
<select class="form-select" formControlName="referrerId" |
||||||
|
[ngClass]="{ 'is-invalid': submitted && f.referrerId.errors }"> |
||||||
|
<option value="" disabled selected>Choisissez un référent pour le collaborateur</option> |
||||||
|
<option *ngFor="let collaborateur of collaborateurs" |
||||||
|
[ngValue]="collaborateur.id">{{collaborateur.name}} {{collaborateur.firstName}}</option> |
||||||
|
</select> |
||||||
|
<div *ngIf="submitted && f.referrerId.errors" class="invalid-feedback"> |
||||||
|
<div *ngIf="f.referrerId.errors.required">Vous devez préciser le référent du collaborateur</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" |
||||||
|
[ngClass]="{ 'is-invalid': submitted && f.businessUnitId.errors }"> |
||||||
|
<option value="" disabled selected>Choisissez une Business Unit pour le collaborateur</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 préciser la Business Unit du collaborateur</div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
</div> |
||||||
|
|
||||||
|
<div> |
||||||
|
<button type="submit">Ajouter le collaborateur</button> |
||||||
|
<button type="reset" (click)="onReset()">Effacer</button> |
||||||
|
</div> |
||||||
|
</form> |
@ -0,0 +1,105 @@ |
|||||||
|
import {Component, OnInit} from '@angular/core'; |
||||||
|
import {FormBuilder, FormGroup, Validators} from "@angular/forms"; |
||||||
|
import {Collaborateur} from "../../../interfaces/collaborateur"; |
||||||
|
import {Businessunit} from "../../../interfaces/businessunit"; |
||||||
|
import {HttpClient} from "@angular/common/http"; |
||||||
|
import {BusinessunitService} from "../../../services/businessunit.service"; |
||||||
|
import {CollaborateurService} from "../../../services/collaborateur.service"; |
||||||
|
|
||||||
|
@Component({ |
||||||
|
selector: 'app-collaborateur-add', |
||||||
|
templateUrl: './collaborateur-add.component.html', |
||||||
|
styleUrls: ['./collaborateur-add.component.scss'] |
||||||
|
}) |
||||||
|
export class CollaborateurAddComponent implements OnInit { |
||||||
|
|
||||||
|
collaborateurs: Collaborateur[] = []; |
||||||
|
collaborateur = {} as Collaborateur; |
||||||
|
businessUnits: Businessunit[] = []; |
||||||
|
businessUnit = {} as Businessunit; |
||||||
|
|
||||||
|
errorValue: number = 0; |
||||||
|
rDate: String = ""; |
||||||
|
bDate: String = ""; |
||||||
|
|
||||||
|
registerForm!: FormGroup; |
||||||
|
submitted = false; |
||||||
|
|
||||||
|
constructor(private http: HttpClient, |
||||||
|
private businessunitService: BusinessunitService, |
||||||
|
private collaborateurService: CollaborateurService, |
||||||
|
private formBuilder: FormBuilder) { |
||||||
|
} |
||||||
|
|
||||||
|
ngOnInit(): void { |
||||||
|
this.getCollaborateurs(); |
||||||
|
this.getBusinessunits(); |
||||||
|
this.registerForm = this.formBuilder.group({ |
||||||
|
name: ['', Validators.required], |
||||||
|
firstName: ['', Validators.required], |
||||||
|
birthDate: ['', Validators.required], |
||||||
|
gender: ['', Validators.required], |
||||||
|
status: ['', Validators.required], |
||||||
|
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")])], |
||||||
|
resignationDate: ['', Validators.required], |
||||||
|
referrerId: ['', Validators.required], |
||||||
|
businessUnitId: ['', Validators.required], |
||||||
|
}); |
||||||
|
if (this.collaborateur.resignationDate) { |
||||||
|
this.rDate = new Date(this.collaborateur.resignationDate).toISOString().split('T')[0]; |
||||||
|
} |
||||||
|
if (this.collaborateur.birthDate) { |
||||||
|
this.bDate = new Date(this.collaborateur.birthDate).toISOString().split('T')[0]; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
getCollaborateurs(): void { |
||||||
|
this.collaborateurService.getCollaborateurs() |
||||||
|
.subscribe(collaborateurs => this.collaborateurs = collaborateurs); |
||||||
|
} |
||||||
|
|
||||||
|
getBusinessunits(): void { |
||||||
|
this.businessunitService.getBusinessunits() |
||||||
|
.subscribe(businessunits => this.businessUnits = businessunits); |
||||||
|
} |
||||||
|
|
||||||
|
onSubmit() { |
||||||
|
this.submitted = true; |
||||||
|
if (this.registerForm.invalid) { |
||||||
|
return; |
||||||
|
} |
||||||
|
this.collaborateur = this.registerForm.value |
||||||
|
if (this.collaborateur) { |
||||||
|
this.collaborateurService.addCollaborateur(this.collaborateur).subscribe({ |
||||||
|
next: () => { |
||||||
|
}, |
||||||
|
error: () => { |
||||||
|
this.errorValue = 1; |
||||||
|
} |
||||||
|
}) |
||||||
|
|
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
get f() { |
||||||
|
return this.registerForm.controls; |
||||||
|
} |
||||||
|
|
||||||
|
onReset() { |
||||||
|
this.submitted = false; |
||||||
|
this.registerForm.reset(); |
||||||
|
} |
||||||
|
|
||||||
|
onResignationDateChange($event: any): void { |
||||||
|
this.collaborateur.resignationDate = new Date($event.target.value); |
||||||
|
} |
||||||
|
|
||||||
|
onBirthDateChange($event: any): void { |
||||||
|
this.collaborateur.birthDate = new Date($event.target.value); |
||||||
|
} |
||||||
|
|
||||||
|
} |
Loading…
Reference in new issue