fix role update infinte loop

This commit is contained in:
sylvain121 2023-11-06 16:03:17 +01:00
parent be6da1d2e1
commit ea6309c615
2 changed files with 35 additions and 25 deletions

View File

@ -12,27 +12,30 @@
</div> </div>
<div class="main"> <div class="main">
<div class="details"> <div class="details">
<div> <form [formGroup]="editRoleForm">
<mat-form-field> <div>
<mat-label>Role name:</mat-label> <mat-form-field>
<input matInput type="text" [ngModel]="($role | async)?.name"> <mat-label>Role name:</mat-label>
</mat-form-field> <input matInput type="text" formControlName="rolename">
</div> </mat-form-field>
<div> </div>
<mat-form-field> <div>
<mat-label>Description:</mat-label> <mat-form-field>
<input matInput type="text" [ngModel]="($role | async)?.description"> <mat-label>Description:</mat-label>
</mat-form-field> <input matInput type="text" formControlName="description">
</div> </mat-form-field>
</div>
</form>
<div>Creation date: {{($role | async)?.created_at}}</div> <div>Creation date: {{($role | async)?.created_at}}</div>
<div>Last update Date: {{($role | async )?.updated_at}}</div> <div>Last update Date: {{($role | async)?.updated_at}}</div>
<div>UUID: {{($role | async)?.role_id}}</div> <div>UUID: {{($role | async)?.role_id}}</div>
<div> <div>
<mat-checkbox [checked]="($role | async)?.is_builtin" disabled>Is built-in</mat-checkbox> <mat-checkbox [checked]="($role | async)?.is_builtin" disabled>Is built-in</mat-checkbox>
</div> </div>
<div mat-dialog-actions class="button-div"> <div mat-dialog-actions class="button-div">
<button mat-button (click)="onUpdate()" tabindex="2" mat-raised-button color="primary" <button mat-button (click)="onUpdate()" tabindex="2" mat-raised-button color="primary"
[disabled]="!editRoleForm.valid || ($role | async)?.is_builtin"> [disabled]="(!(editRoleForm.valueChanges | async) && editRoleForm.valid) || ($role | async)?.is_builtin">
Update Role Update Role
</button> </button>
</div> </div>
@ -41,8 +44,8 @@
<app-privilege <app-privilege
[disable]="($role | async)?.is_builtin" [disable]="($role | async)?.is_builtin"
[ownedPrivilege]="$ownedPrivilegesId | async" [ownedPrivilege]="$ownedPrivilegesId | async"
[privileges]="privileges | async" [privileges]="privileges | async"
(update)="onPrivilegesUpdate($event)"></app-privilege> (update)="onPrivilegesUpdate($event)"></app-privilege>
</div> </div>
</div> </div>
</div> </div>

View File

@ -15,14 +15,15 @@ import {RoleService} from "@services/role.service";
import {ActivatedRoute} from "@angular/router"; import {ActivatedRoute} from "@angular/router";
import {Controller} from "@models/controller"; import {Controller} from "@models/controller";
import {Role} from "@models/api/role"; import {Role} from "@models/api/role";
import {UntypedFormControl, UntypedFormGroup} from "@angular/forms"; import {FormBuilder, FormGroup} from "@angular/forms";
import {ToasterService} from "@services/toaster.service"; import {ToasterService} from "@services/toaster.service";
import {HttpErrorResponse} from "@angular/common/http"; import {HttpErrorResponse} from "@angular/common/http";
import {Privilege} from "@models/api/Privilege"; import {Privilege} from "@models/api/Privilege";
import {PrivilegeService} from "@services/privilege.service"; import {PrivilegeService} from "@services/privilege.service";
import {Observable, ReplaySubject} from "rxjs"; import {BehaviorSubject, Observable} from "rxjs";
import {IPrivilegesChange} from "@components/role-management/role-detail/privilege/IPrivilegesChange"; import {IPrivilegesChange} from "@components/role-management/role-detail/privilege/IPrivilegesChange";
import {map} from "rxjs/operators"; import {map} from "rxjs/operators";
import {string} from "yargs";
@Component({ @Component({
selector: 'app-role-detail', selector: 'app-role-detail',
@ -31,8 +32,8 @@ import {map} from "rxjs/operators";
}) })
export class RoleDetailComponent implements OnInit { export class RoleDetailComponent implements OnInit {
controller: Controller; controller: Controller;
$role: ReplaySubject<Role> = new ReplaySubject<Role>(1); $role: BehaviorSubject<Role> = new BehaviorSubject<Role>({role_id: "", description: "", updated_at: "", is_builtin: false, privileges: [], name: "", created_at:""});
editRoleForm: UntypedFormGroup; editRoleForm: FormGroup;
$ownedPrivilegesId: Observable<Privilege[]> = this.$role.pipe(map((role: Role) => { $ownedPrivilegesId: Observable<Privilege[]> = this.$role.pipe(map((role: Role) => {
return role.privileges return role.privileges
})); }));
@ -44,11 +45,16 @@ export class RoleDetailComponent implements OnInit {
private toastService: ToasterService, private toastService: ToasterService,
private route: ActivatedRoute, private route: ActivatedRoute,
private privilegeService: PrivilegeService, private privilegeService: PrivilegeService,
private fb : FormBuilder,
) { ) {
this.editRoleForm = new UntypedFormGroup({
rolename: new UntypedFormControl(),
description: new UntypedFormControl(), this.$role.subscribe((role) => {
this.editRoleForm = fb.group({
rolename: [role.name],
description: [role.description],
});
}); });
} }
@ -61,7 +67,9 @@ export class RoleDetailComponent implements OnInit {
}); });
} }
onUpdate() { onUpdate() {
this.$role.subscribe((role) => { const role = this.$role.value;
role.name = this.editRoleForm.get("rolename").value;
role.description = this.editRoleForm.get("description").value;
this.roleService.update(this.controller, role) this.roleService.update(this.controller, role)
.subscribe(() => { .subscribe(() => {
this.toastService.success(`role: ${role.name} was updated`); this.toastService.success(`role: ${role.name} was updated`);
@ -71,7 +79,6 @@ export class RoleDetailComponent implements OnInit {
this.toastService.error(`${error.message} this.toastService.error(`${error.message}
${error.error.message}`); ${error.error.message}`);
}); });
})
} }