aboutsummaryrefslogtreecommitdiffhomepage
path: root/client/src/app/+admin/system/logs/logs.component.html
blob: 37f833020115c4594aa27b6f78c7fcefae49e35f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
<div class="header">
  <div class="peertube-select-container">
    <select [(ngModel)]="logType" (ngModelChange)="refresh()">
      <option *ngFor="let logTypeChoice of logTypeChoices" [value]="logTypeChoice.id">{{ logTypeChoice.label }}</option>
    </select>
  </div>

  <div class="peertube-select-container">
    <select [(ngModel)]="startDate" (ngModelChange)="refresh()">
      <option *ngFor="let timeChoice of timeChoices" [value]="timeChoice.id">{{ timeChoice.label }}</option>
    </select>
  </div>

  <div class="peertube-select-container" *ngIf="!isAuditLog()">
    <select [(ngModel)]="level" (ngModelChange)="refresh()">
      <option *ngFor="let levelChoice of levelChoices" [value]="levelChoice.id">{{ levelChoice.label }}</option>
    </select>
  </div>

  <my-button i18n-label label="Refresh" icon="refresh" (click)="refresh()"></my-button>
</div>

<div class="logs">
  <div *ngIf="loading" i18n>Loading...</div>

  <div #logsElement>
    <div *ngFor="let log of logs" class="log-row" [ngClass]="{ error: log.level === 'error', warn: log.level === 'warn' }">
      <span class="log-level">{{ log.level }}</span>

      <span class="log-date">[{{ log.localeDate }}]</span>

      <strong class="log-by" *ngIf="log.by" i18n>By {{ log.by }} -></strong>
      <strong class="log-domain-action" *ngIf="log.domain">{{ log.domain }} -> {{ log.action }}</strong>

      {{ log.message }}

      <pre>{{ log.meta }}</pre>
    </div>
  </div>
</div>