Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 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 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 | 5x 2791x 5582x 10x 5582x 12x 5x 2796x 5582x 5x 5x 5x 5x 2791x 2791x 5x 5x 5x 5x 2791x 2791x 5x 16953x 33929x 33906x 23x 33906x 2x 2145x 2x 58x 56x 2x 2x 112x 114x 2x 2x 2x 5x 2791x 5x 71x 2x 5x 2x 2145x 2x 107x 2x 2x 2x 2145x 2x 73x 2x 2x 2x 2145x 2x 66x 1x 30x 1x 2x 23x 10x 5582x 23x 5x 5x 5x 84x 15866x 84x 84x 15866x 84x 15782x 106746x 7425x 544x 46419x 544x 15782x 84x 5x 5582x 5x 5582x 78x 5x | <p-table showGridlines [value]="rows" [columns]="selectedColumns" [reorderableColumns]="true"
[tableStyle]="{ 'min-width': '60rem' }" (onRowReorder)="onRowReorder($event)" [loading]="isLoading">
<ng-template #caption>
<div class="toolbar">
<app-multi-select-signals [selectionLimit]="signalsSelectionLimit"
(finishedLoadingSignals)="handleSignalsLoaded()" />
<div class="toolbar-element">
<app-refresh-rate-selector [isResponseSlowerThanRefresh]="isResponseSlowerThanRefresh"
(selectionChanged)="handleRefreshRateChange($event)">
</app-refresh-rate-selector>
<p-multiselect display="chip" [options]="columns" [(ngModel)]="selectedColumns" optionLabel="label"
selectedItemsLabel="{0} columns selected" [style]="{ 'min-width': '200px' }"
placeholder="Choose Columns" />
</div>
</div>
</ng-template>
<ng-template #header let-columns>
<tr>
<th pSortableColumn="device_name">
<div class="table-header">
<div class="name-sort">
<div>Device</div>
<p-sortIcon field="device_name"></p-sortIcon>
</div>
<p-columnFilter field="device_name" display="menu" matchMode="contains" [showOperator]="false"
[showMatchModes]="false" [showAddButton]="false" />
</div>
</th>
<th pSortableColumn="ticker">
<div class="table-header">
<div class="name-sort">
<div>Ticker</div>
<p-sortIcon field="ticker"></p-sortIcon>
</div>
<p-columnFilter field="ticker" display="menu" matchMode="contains" [showOperator]="false"
[showMatchModes]="false" [showAddButton]="false" />
</div>
</th>
<th *ngFor="let col of selectedColumns" pReorderableColumn [pSortableColumn]="col.field">
<div class="table-header">
<div class="name-sort">
<div>{{col.label}}</div>
<p-sortIcon [field]="col.field" />
</div>
@if (col.field === "frequency") {
<p-columnFilter field="frequency" display="menu" matchMode="between" [showOperator]="false"
[showMatchModes]="false" [showAddButton]="false">
<ng-template #filter let-filter="filterCallback">
<p-slider [(ngModel)]="frequencyThresholds" [min]="getArrayMin(this.frequencies)"
[max]="getArrayMax(this.frequencies)" [range]="true" class="m-4"
(onSlideEnd)="filter($event.values)" />
<div class="flex items-center px-2">
<span *ngIf="!frequencyThresholds">0</span>
<span *ngIf="frequencyThresholds">{{ frequencyThresholds[0] }} - {{
frequencyThresholds[1] }}</span>
</div>
</ng-template>
</p-columnFilter>
}
@else if (col.field === "unit") {
<p-columnFilter field="unit" display="menu" matchMode="equals" [showOperator]="false"
[showMatchModes]="false" [showAddButton]="false">
<ng-template #filter let-filter="filterCallback">
<p-select [options]="units" (onChange)="filter($event.value)" placeholder="Select unit"
class="w-full"></p-select>
</ng-template>
</p-columnFilter>
}
@else if (col.field === "type") {
<p-columnFilter field="type" display="menu" matchMode="equals" [showOperator]="false"
[showMatchModes]="false" [showAddButton]="false">
<ng-template #filter let-filter="filterCallback">
<p-select [options]="types" (onChange)="filter($event.value)" placeholder="Select type"
class="w-full"></p-select>
</ng-template>
</p-columnFilter>
}
@else if (col.field === "precision_digits") {
<p-columnFilter field="precision_digits" display="menu" matchMode="equals" [showOperator]="false"
[showMatchModes]="false" [showAddButton]="false">
<ng-template #filter let-filter="filterCallback">
<p-select [options]="precisionDigits" (onChange)="filter($event.value)"
placeholder="Select precision" class="w-full"></p-select>
</ng-template>
</p-columnFilter>
}
@else if (col.field === "status") {
<p-columnFilter field="status.status" display="menu" matchMode="equals" [showOperator]="false"
[showMatchModes]="false" [showAddButton]="false">
<ng-template #filter let-filter="filterCallback">
<p-select [options]="statuses" (onChange)="filter($event.value)" placeholder="Select status"
class="w-full">
<ng-template let-status #item>
<p-badge [value]="status" [severity]="getSeverity(status)"></p-badge>
</ng-template>
</p-select>
</ng-template>
</p-columnFilter>
}
@else {
<p-columnFilter [field]="col.field" display="menu" matchMode="contains" [showOperator]="false"
[showMatchModes]="false" [showAddButton]="false" />
}
</div>
</th>
<th></th>
</tr>
</ng-template>
<ng-template #body let-row let-columns="columns">
<tr>
<td>
{{ row.device_name }}
</td>
<td>
{{ row.ticker }}
</td>
<td *ngFor="let column of columns">
@if (row[column.field] !== null && row.data_type === 'epoch' && (column.field === 'value' ||
column.field === 'forced_value')) {
{{ row[column.field] * 1000 | date:'yyyy/MM/dd - HH:mm:ss' }}
}
@else if (column.field === 'status') {
<p-badge [value]="row['status'].status" [severity]="getSeverity(row['status'].status)" />
}
@else {
{{ row[column.field] }}
}
</td>
<td>
<i class="pi pi-eye open-icon" aria-hidden="true" (click)="showSignal(row)" [id]="row.signal_id"></i>
</td>
</tr>
</ng-template>
</p-table>
<p-dialog class="signal-card-dialog" header="Signal details" [modal]="true" [(visible)]="signalDialogVisible"
(onHide)="hideSignal()">
<div class="card-container"><app-signal-card *ngIf="selectedSignal"
[signalId]="selectedSignal.signal_id"></app-signal-card></div>
</p-dialog>
|