sessions.component.html 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <nz-card [nzBordered]="false">
  2. <form nz-form [nzLayout]="'inline'" (ngSubmit)="onSearch()" class="search__form">
  3. <div nz-row [nzGutter]="{ xs: 8, sm: 8, md: 8, lg: 24, xl: 48, xxl: 48 }">
  4. <div nz-col nzMd="8" nzSm="24">
  5. <nz-form-item>
  6. <nz-form-label nzFor="startDatePicker">{{ 'mxk.text.startDate' | i18n }}</nz-form-label>
  7. <nz-form-control>
  8. <nz-date-picker
  9. nzShowTime
  10. nzFormat="yyyy-MM-dd HH:mm:ss"
  11. [(ngModel)]="query.params.startDatePicker"
  12. [ngModelOptions]="{ standalone: true }"
  13. name="startDatePicker"
  14. nzPlaceHolder="startDatePicker"
  15. >
  16. </nz-date-picker>
  17. </nz-form-control>
  18. </nz-form-item>
  19. </div>
  20. <div nz-col nzMd="8" nzSm="24">
  21. <nz-form-item>
  22. <nz-form-label nzFor="endDatePicker">{{ 'mxk.text.endDate' | i18n }}</nz-form-label>
  23. <nz-form-control>
  24. <nz-date-picker
  25. nzShowTime
  26. nzFormat="yyyy-MM-dd HH:mm:ss"
  27. [(ngModel)]="query.params.endDatePicker"
  28. [ngModelOptions]="{ standalone: true }"
  29. name="endDatePicker"
  30. nzPlaceHolder="endDatePicker"
  31. >
  32. </nz-date-picker>
  33. </nz-form-control>
  34. </nz-form-item>
  35. </div>
  36. <div nz-col [nzSpan]="query.expandForm ? 24 : 8" [class.text-right]="query.expandForm">
  37. <button nz-button type="submit" [nzType]="'primary'" [nzLoading]="query.submitLoading">{{ 'mxk.text.query' | i18n }}</button>
  38. <button nz-button type="reset" (click)="onReset()" class="mx-sm">{{ 'mxk.text.reset' | i18n }}</button>
  39. <button nz-button (click)="query.expandForm = !query.expandForm" class="mx-sm d-none">
  40. {{ query.expandForm ? ('mxk.text.collapse' | i18n) : ('mxk.text.expand' | i18n) }}</button
  41. >
  42. </div>
  43. </div>
  44. </form>
  45. </nz-card>
  46. <nz-card>
  47. <div nz-col [nzSpan]="24" class="table-list-toolbar">
  48. <button nz-button type="button" (click)="onTerminate($event)" [nzType]="'primary'" nzDanger class="mx-sm">{{
  49. 'mxk.text.terminate' | i18n
  50. }}</button>
  51. </div>
  52. <div nz-col [nzSpan]="24">
  53. <nz-table
  54. #dynamicTable
  55. nzTableLayout="auto"
  56. nzSize="small"
  57. nzShowSizeChanger
  58. [nzBordered]="true"
  59. [nzData]="query.results.rows"
  60. [nzFrontPagination]="false"
  61. [nzTotal]="query.results.records"
  62. [nzPageSizeOptions]="query.params.pageSizeOptions"
  63. [nzPageSize]="query.params.pageSize"
  64. [nzPageIndex]="query.params.pageNumber"
  65. [nzLoading]="this.query.tableLoading"
  66. (nzQueryParams)="onQueryParamsChange($event)"
  67. >
  68. <thead>
  69. <tr>
  70. <th [nzChecked]="query.checked" [nzIndeterminate]="query.indeterminate" (nzCheckedChange)="onTableAllChecked($event)"></th>
  71. <th nzAlign="center">{{ 'mxk.history.login.sessionId' | i18n }}</th>
  72. <th nzAlign="center">{{ 'mxk.history.login.username' | i18n }}</th>
  73. <th nzAlign="center">{{ 'mxk.history.login.displayName' | i18n }}</th>
  74. <th nzAlign="center">{{ 'mxk.history.login.sourceIp' | i18n }}</th>
  75. <th nzAlign="center">{{ 'mxk.history.login.location' | i18n }}</th>
  76. <th nzAlign="center">{{ 'mxk.history.login.browser' | i18n }}</th>
  77. <th nzAlign="center">{{ 'mxk.history.login.platform' | i18n }}</th>
  78. <th nzAlign="center">{{ 'mxk.history.login.loginTime' | i18n }}</th>
  79. </tr>
  80. </thead>
  81. <tbody>
  82. <tr *ngFor="let data of query.results.rows">
  83. <td
  84. [nzChecked]="query.tableCheckedId.has(data.sessionId)"
  85. [nzDisabled]="data.disabled"
  86. (nzCheckedChange)="onTableItemChecked(data.sessionId, $event)"
  87. ></td>
  88. <td nzAlign="left">
  89. <span>{{ data.sessionId }}</span>
  90. </td>
  91. <td nzAlign="left">{{ data.username }}</td>
  92. <td nzAlign="left">{{ data.displayName }}</td>
  93. <td nzAlign="left">{{ data.sourceIp }}</td>
  94. <td nzAlign="left">{{ data.location }}</td>
  95. <td nzAlign="left">{{ data.browser }}</td>
  96. <td nzAlign="left">{{ data.platform }}</td>
  97. <td nzAlign="left">{{ data.loginTime }}</td>
  98. </tr>
  99. </tbody>
  100. </nz-table>
  101. </div>
  102. </nz-card>