src/app/core/auth/role-list/role-list.component.ts
providers |
{ provide: URLBuilderService, useValue: new URLBuilderService(BASE_URL) }
|
selector | cd-role-list |
styleUrls | ./role-list.component.scss |
templateUrl | ./role-list.component.html |
Properties |
Methods |
constructor(roleService: RoleService, scopeService: ScopeService, emptyPipe: EmptyPipe, authStorageService: AuthStorageService, modalService: BsModalService, notificationService: NotificationService, i18n: I18n, urlBuilder: URLBuilderService, actionLabels: ActionLabelsI18n)
|
||||||||||||||||||||||||||||||
Parameters :
|
deleteRole | ||||||
deleteRole(role: string)
|
||||||
Parameters :
Returns :
void
|
deleteRoleModal |
deleteRoleModal()
|
Returns :
void
|
getRoles |
getRoles()
|
Returns :
void
|
ngOnInit |
ngOnInit()
|
Returns :
void
|
updateSelection | ||||||
updateSelection(selection: CdTableSelection)
|
||||||
Parameters :
Returns :
void
|
Public actionLabels |
Type : ActionLabelsI18n
|
columns |
Type : CdTableColumn[]
|
modalRef |
Type : BsModalRef
|
permission |
Type : Permission
|
roles |
Type : Array<any>
|
scopes |
Type : Array<string>
|
selection |
Default value : new CdTableSelection()
|
tableActions |
Type : CdTableAction[]
|
import { Component, OnInit } from '@angular/core';
import { I18n } from '@ngx-translate/i18n-polyfill';
import { BsModalRef, BsModalService } from 'ngx-bootstrap/modal';
import { forkJoin } from 'rxjs';
import { RoleService } from '../../../shared/api/role.service';
import { ScopeService } from '../../../shared/api/scope.service';
import { CriticalConfirmationModalComponent } from '../../../shared/components/critical-confirmation-modal/critical-confirmation-modal.component';
import { ActionLabelsI18n } from '../../../shared/constants/app.constants';
import { CellTemplate } from '../../../shared/enum/cell-template.enum';
import { NotificationType } from '../../../shared/enum/notification-type.enum';
import { CdTableAction } from '../../../shared/models/cd-table-action';
import { CdTableColumn } from '../../../shared/models/cd-table-column';
import { CdTableSelection } from '../../../shared/models/cd-table-selection';
import { Permission } from '../../../shared/models/permissions';
import { EmptyPipe } from '../../../shared/pipes/empty.pipe';
import { AuthStorageService } from '../../../shared/services/auth-storage.service';
import { NotificationService } from '../../../shared/services/notification.service';
import { URLBuilderService } from '../../../shared/services/url-builder.service';
const BASE_URL = 'user-management/roles';
@Component({
selector: 'cd-role-list',
templateUrl: './role-list.component.html',
styleUrls: ['./role-list.component.scss'],
providers: [{ provide: URLBuilderService, useValue: new URLBuilderService(BASE_URL) }]
})
export class RoleListComponent implements OnInit {
permission: Permission;
tableActions: CdTableAction[];
columns: CdTableColumn[];
roles: Array<any>;
scopes: Array<string>;
selection = new CdTableSelection();
modalRef: BsModalRef;
constructor(
private roleService: RoleService,
private scopeService: ScopeService,
private emptyPipe: EmptyPipe,
private authStorageService: AuthStorageService,
private modalService: BsModalService,
private notificationService: NotificationService,
private i18n: I18n,
private urlBuilder: URLBuilderService,
public actionLabels: ActionLabelsI18n
) {
this.permission = this.authStorageService.getPermissions().user;
const addAction: CdTableAction = {
permission: 'create',
icon: 'fa-plus',
routerLink: () => this.urlBuilder.getCreate(),
name: this.actionLabels.CREATE
};
const editAction: CdTableAction = {
permission: 'update',
icon: 'fa-pencil',
disable: () => !this.selection.hasSingleSelection || this.selection.first().system,
routerLink: () =>
this.selection.first() && this.urlBuilder.getEdit(this.selection.first().name),
name: this.actionLabels.EDIT
};
const deleteAction: CdTableAction = {
permission: 'delete',
icon: 'fa-times',
disable: () => !this.selection.hasSingleSelection || this.selection.first().system,
click: () => this.deleteRoleModal(),
name: this.actionLabels.DELETE
};
this.tableActions = [addAction, editAction, deleteAction];
}
ngOnInit() {
this.columns = [
{
name: this.i18n('Name'),
prop: 'name',
flexGrow: 3
},
{
name: this.i18n('Description'),
prop: 'description',
flexGrow: 5,
pipe: this.emptyPipe
},
{
name: this.i18n('System Role'),
prop: 'system',
cellClass: 'text-center',
flexGrow: 1,
cellTransformation: CellTemplate.checkIcon
}
];
}
getRoles() {
forkJoin([this.roleService.list(), this.scopeService.list()]).subscribe(
(data: [Array<any>, Array<string>]) => {
this.roles = data[0];
this.scopes = data[1];
}
);
}
updateSelection(selection: CdTableSelection) {
this.selection = selection;
}
deleteRole(role: string) {
this.roleService.delete(role).subscribe(
() => {
this.getRoles();
this.modalRef.hide();
this.notificationService.show(
NotificationType.success,
this.i18n(`Deleted role '{{role_name}}'`, { role_name: role })
);
},
() => {
this.modalRef.content.stopLoadingSpinner();
}
);
}
deleteRoleModal() {
const name = this.selection.first().name;
this.modalRef = this.modalService.show(CriticalConfirmationModalComponent, {
initialState: {
itemDescription: 'Role',
submitAction: () => this.deleteRole(name)
}
});
}
}
<cd-user-tabs></cd-user-tabs>
<cd-table [data]="roles"
columnMode="flex"
[columns]="columns"
identifier="name"
selectionType="single"
(fetchData)="getRoles()"
(updateSelection)="updateSelection($event)">
<cd-table-actions class="table-actions"
[permission]="permission"
[selection]="selection"
[tableActions]="tableActions">
</cd-table-actions>
<cd-role-details cdTableDetail
[selection]="selection"
[scopes]="scopes">
</cd-role-details>
</cd-table>
./role-list.component.scss