import { ChangeDetectorRef, Component, EventEmitter, Injector, OnInit, Output, ViewChild } from '@angular/core'; import { AddRoleModalComponent } from '@app/admin/organization-units/add-role-modal.component'; import { AppComponentBase } from '@shared/common/app-component-base'; import { OrganizationUnitServiceProxy, OrganizationUnitRoleListDto } from '@shared/service-proxies/service-proxies'; import { LazyLoadEvent } from 'primeng/components/common/lazyloadevent'; import { Paginator } from 'primeng/components/paginator/paginator'; import { Table } from 'primeng/components/table/table'; import { IBasicOrganizationUnitInfo } from './basic-organization-unit-info'; import { IRoleWithOrganizationUnit } from './role-with-organization-unit'; import { IRolesWithOrganizationUnit } from './roles-with-organization-unit'; import { finalize } from 'rxjs/operators'; @Component({ selector: 'organization-unit-roles', templateUrl: './organization-unit-roles.component.html' }) export class OrganizationUnitRolesComponent extends AppComponentBase implements OnInit { @Output() roleRemoved = new EventEmitter(); @Output() rolesAdded = new EventEmitter(); @ViewChild('addRoleModal', {static: true}) addRoleModal: AddRoleModalComponent; @ViewChild('dataTable', {static: true}) dataTable: Table; @ViewChild('paginator', {static: true}) paginator: Paginator; private _organizationUnit: IBasicOrganizationUnitInfo = null; constructor( injector: Injector, private _changeDetector: ChangeDetectorRef, private _organizationUnitService: OrganizationUnitServiceProxy ) { super(injector); } get organizationUnit(): IBasicOrganizationUnitInfo { return this._organizationUnit; } set organizationUnit(ou: IBasicOrganizationUnitInfo) { if (this._organizationUnit === ou) { return; } this._organizationUnit = ou; this.addRoleModal.organizationUnitId = ou.id; if (ou) { this.refreshRoles(); } } ngOnInit(): void { } getOrganizationUnitRoles(event?: LazyLoadEvent) { if (!this._organizationUnit) { return; } if (this.primengTableHelper.shouldResetPaging(event)) { this.paginator.changePage(0); return; } this.spinnerService.show(); this._organizationUnitService.getOrganizationUnitRoles( this._organizationUnit.id, this.primengTableHelper.getSorting(this.dataTable), this.primengTableHelper.getMaxResultCount(this.paginator, event), this.primengTableHelper.getSkipCount(this.paginator, event) ).pipe(finalize(() => this.spinnerService.hide())).subscribe(result => { this.primengTableHelper.totalRecordsCount = result.totalCount; this.primengTableHelper.records = result.items; this.spinnerService.hide(); }); } reloadPage(): void { this.paginator.changePage(this.paginator.getPage()); } refreshRoles(): void { this.reloadPage(); } openAddRoleModal(): void { this.addRoleModal.show(); } removeRole(role: OrganizationUnitRoleListDto): void { this.message.confirm( this.l('RemoveRoleFromOuWarningMessage', role.displayName, this.organizationUnit.displayName), this.l('AreYouSure'), isConfirmed => { if (isConfirmed) { this._organizationUnitService .removeRoleFromOrganizationUnit(role.id, this.organizationUnit.id) .subscribe(() => { this.notify.success(this.l('SuccessfullyRemoved')); this.roleRemoved.emit({ roleId: role.id, ouId: this.organizationUnit.id }); this.refreshRoles(); }); } } ); } addRoles(data: any): void { this.rolesAdded.emit({ roleIds: data.roleIds, ouId: data.ouId }); this.refreshRoles(); } }