import {Component, OnInit, ViewChild} from '@angular/core'; import {MatPaginator, MatSort} from '@angular/material'; import {UserListDataSource} from './user-list-datasource'; import {User} from '../user'; import {ActivatedRoute} from '@angular/router'; @Component({ selector: 'app-user-list', templateUrl: './user-list.component.html', styleUrls: ['./user-list.component.css'] }) export class UserListComponent implements OnInit { @ViewChild(MatPaginator) paginator: MatPaginator; @ViewChild(MatSort) 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); } }