students.component.html 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <h1 class="mat-display-1">Students</h1>
  2. <button mat-raised-button color="primary" (click)="openDialog()">Add</button>
  3. <button mat-raised-button color="primary" (click)="delete()">Remove</button>
  4. <br>
  5. <mat-form-field appearance="fill">
  6. <mat-label>Filter</mat-label>
  7. <input matInput (keyup)="applyFilter($event)" #filter>
  8. </mat-form-field>
  9. <table *ngIf="studentList" mat-table [dataSource]="studentList" matSort>
  10. <ng-container matColumnDef="select">
  11. <th mat-header-cell *matHeaderCellDef>
  12. <mat-checkbox (change)="$event ? masterToggle() : null"
  13. [checked]="selection.hasValue() && isAllSelected()"
  14. [indeterminate]="selection.hasValue() && !isAllSelected()"
  15. [aria-label]="checkboxLabel()">
  16. </mat-checkbox>
  17. </th>
  18. <td mat-cell *matCellDef="let row">
  19. <mat-checkbox (click)="$event.stopPropagation()"
  20. (change)="$event ? selection.toggle(row) : null"
  21. [checked]="selection.isSelected(row)"
  22. [aria-label]="checkboxLabel(row)">
  23. </mat-checkbox>
  24. </td>
  25. </ng-container>
  26. <ng-container matColumnDef="firstname">
  27. <th mat-header-cell *matHeaderCellDef mat-sort-header="firstname">Firstname</th>
  28. <td mat-cell *matCellDef="let student"> {{student.firstname}} </td>
  29. </ng-container>
  30. <ng-container matColumnDef="lastname">
  31. <th mat-header-cell *matHeaderCellDef mat-sort-header="lastname">Lastname</th>
  32. <td mat-cell *matCellDef="let student"> {{student.lastname}} </td>
  33. </ng-container>
  34. <ng-container matColumnDef="email">
  35. <th mat-header-cell *matHeaderCellDef mat-sort-header="email">Email</th>
  36. <td mat-cell *matCellDef="let student"> {{student.email}} </td>
  37. </ng-container>
  38. <ng-container matColumnDef="telephone">
  39. <th mat-header-cell *matHeaderCellDef mat-sort-header="telephone">Telephone</th>
  40. <td mat-cell *matCellDef="let student"> {{student.telephone}} </td>
  41. </ng-container>
  42. <tr mat-header-row *matHeaderRowDef="displayedColumns"></tr>
  43. <tr mat-row *matRowDef="let row; columns: displayedColumns;"></tr>
  44. <tr class="mat-row" *matNoDataRow>
  45. <td class="mat-cell" colspan="5">No data matching the filter "{{filter.value}}"</td>
  46. </tr>
  47. </table>
  48. <mat-paginator [pageSizeOptions]="[5, 10, 20]"
  49. showFirstLastButtons
  50. aria-label="Select page">
  51. </mat-paginator>