cic-staff-client/src/app/pages/admin/admin.component.ts

87 lines
2.7 KiB
TypeScript
Raw Normal View History

2021-05-10 18:15:25 +02:00
import { ChangeDetectionStrategy, Component, OnInit, ViewChild } from '@angular/core';
import { MatTableDataSource } from '@angular/material/table';
import { MatPaginator } from '@angular/material/paginator';
import { MatSort } from '@angular/material/sort';
import { LoggingService, UserService } from '@app/_services';
import { animate, state, style, transition, trigger } from '@angular/animations';
import { first } from 'rxjs/operators';
import { exportCsv } from '@app/_helpers';
import { Action } from '@app/_models';
2020-11-25 08:58:14 +01:00
@Component({
selector: 'app-admin',
templateUrl: './admin.component.html',
styleUrls: ['./admin.component.scss'],
changeDetection: ChangeDetectionStrategy.OnPush,
animations: [
trigger('detailExpand', [
2021-05-10 18:15:25 +02:00
state('collapsed', style({ height: '0px', minHeight: 0, visibility: 'hidden' })),
state('expanded', style({ height: '*', visibility: 'visible' })),
transition('expanded <=> collapsed', animate('225ms cubic-bezier(0.4, 0.0, 0.2, 1)')),
2021-05-10 18:15:25 +02:00
]),
],
2020-11-25 08:58:14 +01:00
})
export class AdminComponent implements OnInit {
2020-11-25 08:58:14 +01:00
dataSource: MatTableDataSource<any>;
2021-04-30 14:50:16 +02:00
displayedColumns: Array<string> = ['expand', 'user', 'role', 'action', 'status', 'approve'];
action: Action;
actions: Array<Action>;
loading: boolean = true;
2020-11-25 08:58:14 +01:00
@ViewChild(MatPaginator) paginator: MatPaginator;
@ViewChild(MatSort) sort: MatSort;
2021-05-19 18:57:10 +02:00
constructor(private userService: UserService, private loggingService: LoggingService) {}
ngOnInit(): void {
this.userService.getActions();
2021-05-10 18:15:25 +02:00
this.userService.actionsSubject.subscribe((actions) => {
this.dataSource = new MatTableDataSource<any>(actions);
this.dataSource.paginator = this.paginator;
this.dataSource.sort = this.sort;
2021-03-24 14:26:51 +01:00
this.actions = actions;
if (actions.length > 0) {
this.loading = false;
}
});
2020-11-25 08:58:14 +01:00
}
doFilter(value: string): void {
this.dataSource.filter = value.trim().toLocaleLowerCase();
}
approvalStatus(status: boolean): string {
return status ? 'Approved' : 'Unapproved';
}
approveAction(action: any): void {
2021-05-10 18:15:25 +02:00
if (!confirm('Approve action?')) {
return;
}
this.userService
.approveAction(action.id)
.pipe(first())
.subscribe((res) => this.loggingService.sendInfoLevelMessage(res));
this.userService.getActions();
}
disapproveAction(action: any): void {
2021-05-10 18:15:25 +02:00
if (!confirm('Disapprove action?')) {
return;
}
this.userService
.revokeAction(action.id)
.pipe(first())
.subscribe((res) => this.loggingService.sendInfoLevelMessage(res));
this.userService.getActions();
}
expandCollapse(row): void {
row.isExpanded = !row.isExpanded;
2020-11-25 08:58:14 +01:00
}
2021-03-24 14:26:51 +01:00
downloadCsv(): void {
exportCsv(this.actions, 'actions');
}
2020-11-25 08:58:14 +01:00
}