@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
91 lines • 20.8 kB
JavaScript
import { ChangeDetectorRef, Component, EventEmitter, Input, Output, } from '@angular/core';
import { bufferToHexString } from '@iotize/common/byte-converter';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "@ionic/angular";
export class TapDatalogTableComponent {
changeRefDetector;
_packets;
dataColumns = [];
date = true;
sync = true;
onSyncEvent = new EventEmitter();
constructor(changeRefDetector) {
this.changeRefDetector = changeRefDetector;
}
set dataLogger(dataLogger) {
if (dataLogger) {
dataLogger.stream.subscribe((p) => {
if (this.dataColumns.length === 0) {
this.initColumnsFromPacket(p);
}
if (!this._packets) {
this._packets = [];
}
this._packets.push(p);
this.changeRefDetector.detectChanges();
});
}
}
set packets(packets) {
this._packets = packets;
if (packets && this.dataColumns.length === 0 && packets.length > 0) {
this.initColumnsFromPacket(packets[0]);
}
}
onRetrySync = new EventEmitter();
get packets() {
return this._packets;
}
packetVariableValue(packet, key) {
let value = packet.decodedData[key];
if (value instanceof Uint8Array) {
value = `0x${bufferToHexString(value)}`;
}
return value;
}
packetId(packet) {
return packet.meta.packetId;
}
packetDate(packet) {
return packet.meta.logTime;
}
isPacketSync(packetInfo) {
if (!('syncInfo' in packetInfo)) {
return false;
}
return packetInfo.syncInfo && packetInfo.syncInfo.isSync;
}
syncPacket(packetInfo) {
this.onRetrySync.emit(packetInfo);
}
initColumnsFromPacket(p) {
this.dataColumns = Object.keys(p.decodedData).map((key) => {
return {
key: key,
title: key,
};
});
}
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TapDatalogTableComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: TapDatalogTableComponent, selector: "tap-datalog-table", inputs: { dataColumns: "dataColumns", date: "date", sync: "sync", dataLogger: "dataLogger", packets: "packets" }, outputs: { onSyncEvent: "onSyncEvent", onRetrySync: "onRetrySync" }, ngImport: i0, template: "<table *ngIf=\"dataColumns\" class=\"table\" mat-table>\n <thead>\n <th *ngIf=\"date\"><ion-icon name=\"time\"></ion-icon> Date</th>\n <th><ion-icon name=\"document\"></ion-icon> ID</th>\n <th *ngFor=\"let dataColumn of dataColumns\">\n <ion-icon name=\"analytics\"></ion-icon> {{ dataColumn.title }}\n </th>\n <th *ngIf=\"sync\"><ion-icon name=\"cloud\"></ion-icon> Cloud sync</th>\n </thead>\n <tbody>\n <tr *ngFor=\"let packet of packets\">\n <td *ngIf=\"date\">\n {{ packetDate(packet) | date: 'short' }}\n </td>\n <td>\n {{ packetId(packet) }}\n </td>\n <td *ngFor=\"let info of dataColumns\">\n {{ packetVariableValue(packet, info.key) }}\n </td>\n <td *ngIf=\"sync\">\n <ion-text *ngIf=\"isPacketSync(packet)\" color=\"success\">\n <ion-icon [name]=\"'checkmark'\"></ion-icon> Sync\n </ion-text>\n <ion-text *ngIf=\"!isPacketSync(packet)\" color=\"danger\">\n <ion-icon [name]=\"'alert'\"></ion-icon> Not sync \n <a (click)=\"syncPacket(packet)\"> retry </a>\n </ion-text>\n <!-- <ion-buttons slot=\"end\">\n <ion-button (click)=\"syncPacket(packet)\" [color]=\"isPacketSync(packet) ? 'success': ''\" [disabled]=\"isPacketSync(packet)\">\n <ion-icon [name]=\"isPacketSync(packet) ? 'checkmark' : 'sync'\"></ion-icon>\n Sync\n </ion-button>\n <ion-button (click)=\"decodePacket(syncInfo)\">\n <ion-icon name=\"sync\"></ion-icon>\n Decode\n </ion-button> \n <ion-button (click)=\"detail(syncInfo)\">\n <ion-icon name=\"more\"></ion-icon>\n Detail\n </ion-button> \n </ion-buttons>-->\n </td>\n </tr>\n </tbody>\n</table>\n", styles: ["table{width:100%;border-collapse:collapse}tr:nth-of-type(odd){background:#eee}th{background:#333;color:#fff;font-weight:700}td,th{padding:10px;text-align:left}@media only screen and (max-width: 760px),(min-device-width: 768px) and (max-device-width: 1024px){table,thead,tbody,th,td,tr{display:block}thead tr{position:absolute;top:-9999px;left:-9999px}tr{border:1px solid #ccc}td{border:none;border-bottom:1px solid #eee;position:relative;padding-left:50%}td:before{position:relative;top:0;left:6px;width:45%;padding-right:10px;white-space:nowrap}}@media only screen and (min-device-width: 320px) and (max-device-width: 480px){body{padding:0;margin:0;width:320px}}@media only screen and (min-device-width: 768px) and (max-device-width: 1024px){body{width:495px}}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i2.IonText, selector: "ion-text", inputs: ["color", "mode"] }, { kind: "pipe", type: i1.DatePipe, name: "date" }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TapDatalogTableComponent, decorators: [{
type: Component,
args: [{ selector: 'tap-datalog-table', template: "<table *ngIf=\"dataColumns\" class=\"table\" mat-table>\n <thead>\n <th *ngIf=\"date\"><ion-icon name=\"time\"></ion-icon> Date</th>\n <th><ion-icon name=\"document\"></ion-icon> ID</th>\n <th *ngFor=\"let dataColumn of dataColumns\">\n <ion-icon name=\"analytics\"></ion-icon> {{ dataColumn.title }}\n </th>\n <th *ngIf=\"sync\"><ion-icon name=\"cloud\"></ion-icon> Cloud sync</th>\n </thead>\n <tbody>\n <tr *ngFor=\"let packet of packets\">\n <td *ngIf=\"date\">\n {{ packetDate(packet) | date: 'short' }}\n </td>\n <td>\n {{ packetId(packet) }}\n </td>\n <td *ngFor=\"let info of dataColumns\">\n {{ packetVariableValue(packet, info.key) }}\n </td>\n <td *ngIf=\"sync\">\n <ion-text *ngIf=\"isPacketSync(packet)\" color=\"success\">\n <ion-icon [name]=\"'checkmark'\"></ion-icon> Sync\n </ion-text>\n <ion-text *ngIf=\"!isPacketSync(packet)\" color=\"danger\">\n <ion-icon [name]=\"'alert'\"></ion-icon> Not sync \n <a (click)=\"syncPacket(packet)\"> retry </a>\n </ion-text>\n <!-- <ion-buttons slot=\"end\">\n <ion-button (click)=\"syncPacket(packet)\" [color]=\"isPacketSync(packet) ? 'success': ''\" [disabled]=\"isPacketSync(packet)\">\n <ion-icon [name]=\"isPacketSync(packet) ? 'checkmark' : 'sync'\"></ion-icon>\n Sync\n </ion-button>\n <ion-button (click)=\"decodePacket(syncInfo)\">\n <ion-icon name=\"sync\"></ion-icon>\n Decode\n </ion-button> \n <ion-button (click)=\"detail(syncInfo)\">\n <ion-icon name=\"more\"></ion-icon>\n Detail\n </ion-button> \n </ion-buttons>-->\n </td>\n </tr>\n </tbody>\n</table>\n", styles: ["table{width:100%;border-collapse:collapse}tr:nth-of-type(odd){background:#eee}th{background:#333;color:#fff;font-weight:700}td,th{padding:10px;text-align:left}@media only screen and (max-width: 760px),(min-device-width: 768px) and (max-device-width: 1024px){table,thead,tbody,th,td,tr{display:block}thead tr{position:absolute;top:-9999px;left:-9999px}tr{border:1px solid #ccc}td{border:none;border-bottom:1px solid #eee;position:relative;padding-left:50%}td:before{position:relative;top:0;left:6px;width:45%;padding-right:10px;white-space:nowrap}}@media only screen and (min-device-width: 320px) and (max-device-width: 480px){body{padding:0;margin:0;width:320px}}@media only screen and (min-device-width: 768px) and (max-device-width: 1024px){body{width:495px}}\n"] }]
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { dataColumns: [{
type: Input
}], date: [{
type: Input
}], sync: [{
type: Input
}], onSyncEvent: [{
type: Output
}], dataLogger: [{
type: Input
}], packets: [{
type: Input
}], onRetrySync: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tap-datalog-table.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-datalog-table/tap-datalog-table.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-datalog-table/tap-datalog-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core';\nimport { bufferToHexString } from '@iotize/common/byte-converter';\nimport { IonicDataLogger, SyncableDatalogPacket } from '@iotize/ionic';\n\n@Component({\n  selector: 'tap-datalog-table',\n  templateUrl: './tap-datalog-table.component.html',\n  styleUrls: ['./tap-datalog-table.component.scss'],\n})\nexport class TapDatalogTableComponent {\n  _packets?: IonicDataLogger.PacketInfo[];\n\n  @Input() dataColumns: { key: string; title: string }[] = [];\n\n  @Input() date = true;\n\n  @Input() sync = true;\n\n  @Output() onSyncEvent = new EventEmitter<SyncableDatalogPacket>();\n\n  constructor(protected changeRefDetector: ChangeDetectorRef) {}\n\n  @Input() set dataLogger(dataLogger: IonicDataLogger | undefined) {\n    if (dataLogger) {\n      dataLogger.stream.subscribe(\n        (p: IonicDataLogger.PacketInfo<Record<string, any>>) => {\n          if (this.dataColumns.length === 0) {\n            this.initColumnsFromPacket(p);\n          }\n          if (!this._packets) {\n            this._packets = [];\n          }\n          this._packets.push(p);\n          this.changeRefDetector.detectChanges();\n        }\n      );\n    }\n  }\n\n  @Input() set packets(packets: IonicDataLogger.PacketInfo[] | undefined) {\n    this._packets = packets;\n    if (packets && this.dataColumns.length === 0 && packets.length > 0) {\n      this.initColumnsFromPacket(packets[0]);\n    }\n  }\n\n  @Output() onRetrySync = new EventEmitter<SyncableDatalogPacket>();\n\n  get packets() {\n    return this._packets;\n  }\n\n  packetVariableValue(packet: IonicDataLogger.PacketInfo, key: string): string {\n    let value = packet.decodedData[key];\n    if (value instanceof Uint8Array) {\n      value = `0x${bufferToHexString(value)}`;\n    }\n    return value;\n  }\n\n  packetId(packet: IonicDataLogger.PacketInfo): number {\n    return packet.meta.packetId;\n  }\n\n  packetDate(packet: IonicDataLogger.PacketInfo): Date {\n    return packet.meta.logTime;\n  }\n\n  isPacketSync(packetInfo: SyncableDatalogPacket | IonicDataLogger.PacketInfo) {\n    if (!('syncInfo' in packetInfo)) {\n      return false;\n    }\n    return packetInfo.syncInfo && packetInfo.syncInfo.isSync;\n  }\n\n  syncPacket(packetInfo: SyncableDatalogPacket) {\n    this.onRetrySync.emit(packetInfo);\n  }\n\n  private initColumnsFromPacket(\n    p: IonicDataLogger.PacketInfo<Record<string, any>>\n  ) {\n    this.dataColumns = Object.keys(p.decodedData).map((key) => {\n      return {\n        key: key,\n        title: key,\n      };\n    });\n  }\n}\n","<table *ngIf=\"dataColumns\" class=\"table\" mat-table>\n  <thead>\n    <th *ngIf=\"date\"><ion-icon name=\"time\"></ion-icon> Date</th>\n    <th><ion-icon name=\"document\"></ion-icon> ID</th>\n    <th *ngFor=\"let dataColumn of dataColumns\">\n      <ion-icon name=\"analytics\"></ion-icon> {{ dataColumn.title }}\n    </th>\n    <th *ngIf=\"sync\"><ion-icon name=\"cloud\"></ion-icon> Cloud sync</th>\n  </thead>\n  <tbody>\n    <tr *ngFor=\"let packet of packets\">\n      <td *ngIf=\"date\">\n        {{ packetDate(packet) | date: 'short' }}\n      </td>\n      <td>\n        {{ packetId(packet) }}\n      </td>\n      <td *ngFor=\"let info of dataColumns\">\n        {{ packetVariableValue(packet, info.key) }}\n      </td>\n      <td *ngIf=\"sync\">\n        <ion-text *ngIf=\"isPacketSync(packet)\" color=\"success\">\n          <ion-icon [name]=\"'checkmark'\"></ion-icon> &nbsp; Sync\n        </ion-text>\n        <ion-text *ngIf=\"!isPacketSync(packet)\" color=\"danger\">\n          <ion-icon [name]=\"'alert'\"></ion-icon> &nbsp; Not sync &nbsp;\n          <a (click)=\"syncPacket(packet)\"> retry </a>\n        </ion-text>\n        <!--  <ion-buttons slot=\"end\">\n                                    <ion-button (click)=\"syncPacket(packet)\" [color]=\"isPacketSync(packet) ? 'success': ''\" [disabled]=\"isPacketSync(packet)\">\n                                        <ion-icon [name]=\"isPacketSync(packet) ? 'checkmark' : 'sync'\"></ion-icon>\n                                        Sync\n                                    </ion-button>\n                                    <ion-button (click)=\"decodePacket(syncInfo)\">\n                        <ion-icon name=\"sync\"></ion-icon>\n                        Decode\n                    </ion-button> \n                                    <ion-button (click)=\"detail(syncInfo)\">\n                                                                                                                                                    <ion-icon name=\"more\"></ion-icon>\n                                                                                                                                                    Detail\n                                                                                                                                              </ion-button> \n                                </ion-buttons>-->\n      </td>\n    </tr>\n  </tbody>\n</table>\n"]}