import { Component, OnInit } from '@angular/core'; import { MatAnchor } from '@angular/material/button'; import { MatCard, MatCardHeader, MatCardTitleGroup, MatCardTitle, MatCardContent } from '@angular/material/card'; import { MatIcon } from '@angular/material/icon'; import { MatTable, MatColumnDef, MatHeaderCellDef, MatHeaderCell, MatCellDef, MatCell, MatHeaderRowDef, MatHeaderRow, MatRowDef, MatRow, } from '@angular/material/table'; import { ActivatedRoute, RouterLink } from '@angular/router'; import { Role } from '../role'; import { RoleListDataSource } from './role-list-datasource'; @Component({ selector: 'app-role-list', templateUrl: './role-list.component.html', styleUrls: ['./role-list.component.css'], imports: [ MatCard, MatCardHeader, MatCardTitleGroup, MatCardTitle, MatAnchor, RouterLink, MatIcon, MatCardContent, MatTable, MatColumnDef, MatHeaderCellDef, MatHeaderCell, MatCellDef, MatCell, MatHeaderRowDef, MatHeaderRow, MatRowDef, MatRow, ], }) export class RoleListComponent implements OnInit { list: Role[] = []; dataSource: RoleListDataSource = new RoleListDataSource(this.list); /** Columns displayed in the table. Columns IDs can be added, removed, or reordered. */ displayedColumns = ['name', 'permissions']; constructor(private route: ActivatedRoute) {} ngOnInit() { this.route.data.subscribe((value) => { const data = value as { list: Role[] }; this.list = data.list; }); this.dataSource = new RoleListDataSource(this.list); } }