import { Component, OnInit, ViewChild } from '@angular/core'; import { MatPaginator } from '@angular/material/paginator'; import { MatSort } from '@angular/material/sort'; import { ActivatedRoute } from '@angular/router'; import { User } from '../../core/user'; import { UserListDataSource } from './user-list-datasource'; @Component({ selector: 'app-user-list', templateUrl: './user-list.component.html', styleUrls: ['./user-list.component.css'], }) export class UserListComponent implements OnInit { @ViewChild(MatPaginator, { static: true }) paginator: MatPaginator; @ViewChild(MatSort, { static: true }) sort: MatSort; dataSource: UserListDataSource; list: User[]; /** Columns displayed in the table. Columns IDs can be added, removed, or reordered. */ displayedColumns = ['name', 'lockedOut', 'groups']; constructor(private route: ActivatedRoute) {} ngOnInit() { this.route.data.subscribe((data: { list: User[] }) => { this.list = data.list; }); this.dataSource = new UserListDataSource(this.paginator, this.sort, this.list); } }