avancées

This commit is contained in:
Sana EL HIRI 2022-03-06 18:30:50 +01:00
parent 4a4c511fcd
commit b7e4e1ad18
4 changed files with 39 additions and 6 deletions

View File

@ -15,12 +15,14 @@ export class PageAccountComponent implements OnInit {
public listMembres: any[]; public listMembres: any[];
currentUser: any; currentUser: any;
currentTeam: any; currentTeam: any;
parent: boolean;
constructor(private membreService: MembreService, constructor(private membreService: MembreService,
private teamService: TeamService, private teamService: TeamService,
private tokenService: TokenService, private tokenService: TokenService,
private router: Router) { private router: Router) {
this.listMembres = []; this.listMembres = [];
this.parent = false;
} }
ngOnInit(): void { ngOnInit(): void {
@ -36,5 +38,24 @@ export class PageAccountComponent implements OnInit {
this.membreService.getMembresByTeamId()?.subscribe((membres: any[]) => { this.membreService.getMembresByTeamId()?.subscribe((membres: any[]) => {
this.listMembres = membres; this.listMembres = membres;
}); });
/***Gestion des limatations en fonction du role (parent ou enfant) */
const roleUser = this.tokenService.getRole();
if(roleUser == "ROLE_PARENT"){
this.parent = true;
}
}
/** Méthode qui au click va supprimer un contact en faisant appel au service dédié dans Membre Service **/
onClickDelete(membreId: number){
this.membreService.deleteMembre(membreId).subscribe((resp) => {
if(membreId) {
this.listMembres.forEach(membreId => console.log(membreId))
}else{
window.alert("Le profil ne peut pas être supprimé!")
}
this.router.navigate(['compte/']);
});
window.location.reload();
} }
} }

View File

@ -22,8 +22,7 @@
id = "bouton-ajout" id = "bouton-ajout"
type="button" type="button"
class="btn btn-primary btn-lg bouton-oui" class="btn btn-primary btn-lg bouton-oui"
(clickDelete)="onClickDelete($event)"
>Oui, je souhaite supprimer ce compte >Oui, je souhaite supprimer ce compte
</button> </button>
</div> </div>

View File

@ -1,4 +1,6 @@
import { Component, EventEmitter, OnInit, Output } from '@angular/core'; import { Component, EventEmitter, OnInit, Output } from '@angular/core';
import { Router } from '@angular/router';
import { Membre } from 'src/app/models/membre';
import { MembreService } from 'src/app/services/membre.service'; import { MembreService } from 'src/app/services/membre.service';
import { TokenService } from 'src/app/services/token.service'; import { TokenService } from 'src/app/services/token.service';
@ -11,12 +13,23 @@ export class PageDeleteMemberComponent implements OnInit {
@Output() clickDelete = new EventEmitter(); @Output() clickDelete = new EventEmitter();
parent: boolean; parent: boolean;
constructor(private tokenService: TokenService, private membreService: MembreService) { constructor(private membreService: MembreService, private tokenService: TokenService) {
this.parent = false; this.parent = false;
} }
ngOnInit(): void { ngOnInit(): void {
const roleUser = this.tokenService.getRole();
if(roleUser == "ROLE_PARENT"){
this.parent = true;
} }
}
onClickDelete(membreId: any){
window.alert("Le profil à bien été supprimé!")
this.clickDelete.emit(membreId);
}
} }

View File

@ -45,8 +45,8 @@ export class MembreService {
} }
} }
deleteMembre(membre: Membre): Observable<any>{ deleteMembre(membreId: number): Observable<any>{
return this.http.delete(`${this.apiUrl}/membres/delete/${membre.id}`); return this.http.delete(`${this.apiUrl}/membres/delete/${membreId}`);
} }
updateMembre(membre: Membre): Observable<any> | void { updateMembre(membre: Membre): Observable<any> | void {