From 28c1c528a72e41e8b6d6fc8e720ed4abb62bc4d5 Mon Sep 17 00:00:00 2001 From: clean-coder Date: Mon, 29 Jul 2024 09:38:30 +0200 Subject: [PATCH] #931: cleanup + calculate isUserMemberOfTeams on-the-fly (no longer cached) --- .../delete-user/delete-user.component.ts | 25 ++++++++----------- 1 file changed, 10 insertions(+), 15 deletions(-) diff --git a/frontend/src/app/team-management/delete-user/delete-user.component.ts b/frontend/src/app/team-management/delete-user/delete-user.component.ts index e27a618e76..76122b2481 100644 --- a/frontend/src/app/team-management/delete-user/delete-user.component.ts +++ b/frontend/src/app/team-management/delete-user/delete-user.component.ts @@ -16,8 +16,7 @@ import { AlertDialogComponent, AlertDialogData } from '../../shared/dialog/alert export class DeleteUserComponent implements OnInit { @Input({ required: true }) user!: User; - private isUserMemberOfTeams: boolean = false; - private isUserOwnerOfKeyResults: boolean = false; + private userHasKeyResults: boolean = false; constructor( private readonly userService: UserService, @@ -26,29 +25,25 @@ export class DeleteUserComponent implements OnInit { ) {} ngOnInit() { - this.memberOfTeams(this.user.id); - this.ownerOfKeyResults(this.user.id); + this.userService.isUserOwnerOfKeyResults(this.user).subscribe((booleanAsObject) => { + this.userHasKeyResults = !!booleanAsObject; + }); } - memberOfTeams(userId: number) { - this.isUserMemberOfTeams = this.user.userTeamList != null && this.user.userTeamList.length > 0; - console.log('### member_of_teams', userId, this.isUserMemberOfTeams); + isUserMemberOfTeams(): boolean { + return this.user.userTeamList != null && this.user.userTeamList.length > 0; } - ownerOfKeyResults(userId: number) { - this.isUserMemberOfTeams = this.user.userTeamList.length > 0; - this.userService.isUserOwnerOfKeyResults(this.user).subscribe((booleanAsObject) => { - this.isUserOwnerOfKeyResults = !!booleanAsObject; - console.log('### key_result', userId, !!booleanAsObject); - }); + isUserOwnerOfKeyResults(): boolean { + return this.userHasKeyResults; } deleteUser() { - if (this.isUserMemberOfTeams) { + if (this.isUserMemberOfTeams()) { this.showUnableToDeleteDialog(`${this.userInfo()} ist in Team(s) und kann nicht gelöscht werden!`); return; } - if (this.isUserOwnerOfKeyResults) { + if (this.isUserOwnerOfKeyResults()) { this.showUnableToDeleteDialog(`${this.userInfo()} ist Owner von KeyResults und kann nicht gelöscht werden!`); return; }