@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
162 lines • 26.1 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, } from '@angular/core';
import { ModalController } from '@ionic/angular';
import { ColumnMode } from '@swimlane/ngx-datatable';
import { BehaviorSubject, Subject, combineLatest } from 'rxjs';
import { switchMap, takeUntil } from 'rxjs/operators';
import { MonitoringAppGenComponent } from '../../metadata/decorators';
import { ChartDataModel, } from '../ChartDataModel';
import { TapVariableDataPopupComponent } from '../tap-variable-data-popup/tap-variable-data-popup.component';
import * as i0 from "@angular/core";
import * as i1 from "@ionic/angular";
import * as i2 from "@angular/common";
import * as i3 from "@swimlane/ngx-datatable";
import * as i4 from "../../ui-directive/export-data.directive";
const TABLE_LIMIT = 10;
let TapVariableTableComponent = class TapVariableTableComponent {
set history(enable) {
this._history.next(enable);
}
set valueCountLimit(limit) {
if (limit === undefined) {
limit = 30;
}
this._valueCountLimit.next(limit);
}
set label(indexOrArray) {
this.chartModel.initLabel(indexOrArray);
}
set variable(variableOrArray) {
this.multiple = !!Array.isArray(variableOrArray);
this.input = this.chartModel.initVariable(variableOrArray);
}
set input(inputs) {
this._input.next(inputs);
}
columnsPushForEachKey(key) {
console.log('DEBUG columnsPushForEachKey', key, this.columns);
if (this.history && key === 'name') {
this.columns.push({
prop: key,
name: !this.nameLabel
? this.history
? 'Time'
: 'Name'
: this.nameLabel,
sortable: true,
});
}
else if (key === 'value') {
this.columns.push({ prop: key, name: this.valueLabel, sortable: true });
}
else if (key !== 'extra') {
this.columns.push({ prop: key, name: key, sortable: true });
}
}
constructor(modalController, cdr) {
this.modalController = modalController;
this.cdr = cdr;
this.rows = [];
this.chartModel = new ChartDataModel();
this.loadingIndicator = true;
this.reorderable = false;
this.columnMode = ColumnMode.force;
this.limit = TABLE_LIMIT;
this.valueLabel = 'Value';
this.showExportButton = false;
this._history = new BehaviorSubject(true);
this._valueCountLimit = new BehaviorSubject(30);
this.destroyed = new Subject();
this._input = new BehaviorSubject([]);
this.multiple = false;
}
createExportedData() {
return this.rows;
}
ngAfterViewInit() {
this.darkModeStatus =
window.matchMedia &&
window.matchMedia('(prefers-color-scheme: dark)').matches;
combineLatest([this._valueCountLimit, this._input, this._history])
.pipe(takeUntil(this.destroyed), switchMap(([valueCountLimit, input, history]) => {
this.chartModel.destroyCurrentSub();
if (this.multiple) {
return this.chartModel.defineMultiInputStream(input);
}
else {
return this.chartModel.defineInputStreamSingle(input, history, valueCountLimit, true);
}
}))
.subscribe((result) => {
this.resultToTableData(result);
});
}
resultToTableData(result) {
this.rows = result;
this.columns = [];
const jsonData = JSON.parse(JSON.stringify(this.rows[0]));
for (const key of Object.keys(jsonData)) {
if (key === 'series') {
jsonData['series'].forEach((k) => this.columnsPushForEachKey(k.name));
}
else {
this.columnsPushForEachKey(key);
}
}
this.loadingIndicator = false;
this.cdr.detectChanges();
}
onSelect(event) {
if (typeof event === 'object') {
this.chartModel
.showDetail(event, this.modalController, TapVariableDataPopupComponent)
.catch((err) => {
console.warn(err);
});
}
}
ngOnDestroy() {
this.chartModel.destroyCurrentSub();
this.destroyed.next();
this.destroyed.complete();
}
};
/** @nocollapse */ TapVariableTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TapVariableTableComponent, deps: [{ token: i1.ModalController }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ TapVariableTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TapVariableTableComponent, selector: "tap-variable-table", inputs: { loadingIndicator: "loadingIndicator", reorderable: "reorderable", columnMode: "columnMode", limit: "limit", valueLabel: "valueLabel", nameLabel: "nameLabel", history: "history", valueCountLimit: "valueCountLimit", showExportButton: "showExportButton", exportedFileName: "exportedFileName", label: "label", variable: "variable", input: "input" }, ngImport: i0, template: "<div style=\"position: relative\">\n <ngx-datatable\n [ngClass]=\"darkModeStatus ? 'dark' : 'material'\"\n [rows]=\"rows\"\n [loadingIndicator]=\"loadingIndicator\"\n [columns]=\"columns\"\n [columnMode]=\"columnMode\"\n [headerHeight]=\"50\"\n [footerHeight]=\"50\"\n [rowHeight]=\"50\"\n [reorderable]=\"reorderable\"\n [scrollbarH]=\"true\"\n [limit]=\"limit\"\n >\n </ngx-datatable>\n <!--\n [targetMarkerTemplate]=\"targetMarkerTemplate\"\n <ng-template #targetMarkerTemplate let-class=\"class\">\n <div [ngClass]=\"class\">\n <div class=\"icon datatable-icon-down\"></div>\n <div class=\"icon datatable-icon-up\"></div>\n </div>\n </ng-template>\n -->\n\n <ion-fab-button\n id=\"exportFabButton\"\n size=\"small\"\n tapExportData\n [dataToExport]=\"createExportedData.bind(this)\"\n [exportedFileName]=\"exportedFileName\"\n *ngIf=\"showExportButton\"\n >\n <ion-icon name=\"download\"></ion-icon>\n </ion-fab-button>\n</div>\n", styles: [":host ::ng-deep .datatable-scroll{width:100%!important}:host ::ng-deep datatable-pager{width:85%!important}#exportFabButton{position:absolute;top:0;right:2px}:host ::ng-deep .page-count{white-space:nowrap!important}:host ::ng-deep .datatable-pager{max-width:85%!important}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.DatatableComponent, selector: "ngx-datatable", inputs: ["targetMarkerTemplate", "rows", "groupRowsBy", "groupedRows", "columns", "selected", "scrollbarV", "scrollbarH", "rowHeight", "columnMode", "headerHeight", "footerHeight", "externalPaging", "externalSorting", "limit", "count", "offset", "loadingIndicator", "selectionType", "reorderable", "swapColumns", "sortType", "sorts", "cssClasses", "messages", "rowClass", "selectCheck", "displayCheck", "groupExpansionDefault", "trackByProp", "selectAllRowsOnPage", "virtualization", "treeFromRelation", "treeToRelation", "summaryRow", "summaryHeight", "summaryPosition", "rowIdentity"], outputs: ["scroll", "activate", "select", "sort", "page", "reorder", "resize", "tableContextmenu", "treeAction"] }, { kind: "component", type: i1.IonFabButton, selector: "ion-fab-button", inputs: ["activated", "closeIcon", "color", "disabled", "download", "href", "mode", "rel", "routerAnimation", "routerDirection", "show", "size", "target", "translucent", "type"] }, { kind: "component", type: i1.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "directive", type: i4.ExportDataDirective, selector: "[tapExportData]", inputs: ["exportedFileName", "dataToExport", "format"], outputs: ["exportDataError"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
TapVariableTableComponent = __decorate([
MonitoringAppGenComponent({}),
__metadata("design:paramtypes", [ModalController,
ChangeDetectorRef])
], TapVariableTableComponent);
export { TapVariableTableComponent };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TapVariableTableComponent, decorators: [{
type: Component,
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'tap-variable-table', template: "<div style=\"position: relative\">\n <ngx-datatable\n [ngClass]=\"darkModeStatus ? 'dark' : 'material'\"\n [rows]=\"rows\"\n [loadingIndicator]=\"loadingIndicator\"\n [columns]=\"columns\"\n [columnMode]=\"columnMode\"\n [headerHeight]=\"50\"\n [footerHeight]=\"50\"\n [rowHeight]=\"50\"\n [reorderable]=\"reorderable\"\n [scrollbarH]=\"true\"\n [limit]=\"limit\"\n >\n </ngx-datatable>\n <!--\n [targetMarkerTemplate]=\"targetMarkerTemplate\"\n <ng-template #targetMarkerTemplate let-class=\"class\">\n <div [ngClass]=\"class\">\n <div class=\"icon datatable-icon-down\"></div>\n <div class=\"icon datatable-icon-up\"></div>\n </div>\n </ng-template>\n -->\n\n <ion-fab-button\n id=\"exportFabButton\"\n size=\"small\"\n tapExportData\n [dataToExport]=\"createExportedData.bind(this)\"\n [exportedFileName]=\"exportedFileName\"\n *ngIf=\"showExportButton\"\n >\n <ion-icon name=\"download\"></ion-icon>\n </ion-fab-button>\n</div>\n", styles: [":host ::ng-deep .datatable-scroll{width:100%!important}:host ::ng-deep datatable-pager{width:85%!important}#exportFabButton{position:absolute;top:0;right:2px}:host ::ng-deep .page-count{white-space:nowrap!important}:host ::ng-deep .datatable-pager{max-width:85%!important}\n"] }]
}], ctorParameters: function () { return [{ type: i1.ModalController }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { loadingIndicator: [{
type: Input
}], reorderable: [{
type: Input
}], columnMode: [{
type: Input
}], limit: [{
type: Input
}], valueLabel: [{
type: Input
}], nameLabel: [{
type: Input
}], history: [{
type: Input
}], valueCountLimit: [{
type: Input
}], showExportButton: [{
type: Input
}], exportedFileName: [{
type: Input
}], label: [{
type: Input
}], variable: [{
type: Input
}], input: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tap-variable-table.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-table/tap-variable-table.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-table/tap-variable-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnDestroy,\n} from '@angular/core';\nimport { ModalController } from '@ionic/angular';\nimport { AbstractVariable } from '@iotize/tap/data';\nimport { ColumnMode } from '@swimlane/ngx-datatable';\nimport { BehaviorSubject, Subject, combineLatest } from 'rxjs';\nimport { switchMap, takeUntil } from 'rxjs/operators';\nimport { MonitoringAppGenComponent } from '../../metadata/decorators';\nimport {\n  ChartDataModel,\n  ChartInputSingle,\n  ChartInputStreamVar,\n  ChartInputTable,\n} from '../ChartDataModel';\nimport { OnChartSelectEvent } from '../shared-types';\nimport { TapVariableDataPopupComponent } from '../tap-variable-data-popup/tap-variable-data-popup.component';\n\nconst TABLE_LIMIT = 10;\n\n@MonitoringAppGenComponent({})\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  selector: 'tap-variable-table',\n  templateUrl: './tap-variable-table.component.html',\n  styleUrls: ['./tap-variable-table.component.scss'],\n})\nexport class TapVariableTableComponent implements AfterViewInit, OnDestroy {\n  rows: ChartInputSingle[] | ChartInputTable[] = [];\n\n  columns!: any[];\n  darkModeStatus?: boolean;\n\n  private chartModel: ChartDataModel = new ChartDataModel();\n\n  @Input()\n  loadingIndicator = true;\n\n  @Input()\n  reorderable = false;\n\n  @Input()\n  columnMode = ColumnMode.force;\n\n  @Input()\n  limit: number = TABLE_LIMIT;\n\n  @Input()\n  valueLabel = 'Value';\n\n  @Input()\n  nameLabel?: string;\n\n  @Input()\n  set history(enable: boolean) {\n    this._history.next(enable);\n  }\n\n  @Input()\n  set valueCountLimit(limit: number | undefined) {\n    if (limit === undefined) {\n      limit = 30;\n    }\n    this._valueCountLimit.next(limit);\n  }\n\n  @Input()\n  showExportButton: boolean = false;\n\n  @Input()\n  exportedFileName?: string;\n\n  @Input()\n  set label(indexOrArray: string | string[] | undefined | Function) {\n    this.chartModel.initLabel(indexOrArray);\n  }\n\n  private _history = new BehaviorSubject<boolean>(true);\n\n  private _valueCountLimit = new BehaviorSubject<number>(30);\n\n  private destroyed = new Subject<void>();\n\n  private _input = new BehaviorSubject<ChartInputStreamVar[]>([]);\n\n  private multiple: boolean = false;\n\n  @Input()\n  set variable(\n    variableOrArray:\n      | AbstractVariable<number | number[]>\n      | AbstractVariable<number | number[]>[]\n      | undefined\n  ) {\n    this.multiple = !!Array.isArray(variableOrArray);\n    this.input = this.chartModel.initVariable(variableOrArray);\n  }\n\n  @Input()\n  set input(inputs: ChartInputStreamVar[]) {\n    this._input.next(inputs);\n  }\n\n  columnsPushForEachKey(key: string) {\n    console.log('DEBUG columnsPushForEachKey', key, this.columns);\n    if (this.history && key === 'name') {\n      this.columns.push({\n        prop: key,\n        name: !this.nameLabel\n          ? this.history\n            ? 'Time'\n            : 'Name'\n          : this.nameLabel,\n        sortable: true,\n      });\n    } else if (key === 'value') {\n      this.columns.push({ prop: key, name: this.valueLabel, sortable: true });\n    } else if (key !== 'extra') {\n      this.columns.push({ prop: key, name: key, sortable: true });\n    }\n  }\n\n  constructor(\n    public modalController: ModalController,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  createExportedData() {\n    return this.rows;\n  }\n\n  ngAfterViewInit(): void {\n    this.darkModeStatus =\n      window.matchMedia &&\n      window.matchMedia('(prefers-color-scheme: dark)').matches;\n    combineLatest([this._valueCountLimit, this._input, this._history])\n      .pipe(\n        takeUntil(this.destroyed),\n        switchMap(([valueCountLimit, input, history]) => {\n          this.chartModel.destroyCurrentSub();\n          if (this.multiple) {\n            return this.chartModel.defineMultiInputStream(input);\n          } else {\n            return this.chartModel.defineInputStreamSingle(\n              input,\n              history,\n              valueCountLimit,\n              true\n            );\n          }\n        })\n      )\n      .subscribe((result) => {\n        this.resultToTableData(result);\n      });\n  }\n\n  resultToTableData(result: any) {\n    this.rows = result;\n    this.columns = [];\n    const jsonData = JSON.parse(JSON.stringify(this.rows[0]));\n    for (const key of Object.keys(jsonData)) {\n      if (key === 'series') {\n        jsonData['series'].forEach((k: { name: string }) =>\n          this.columnsPushForEachKey(k.name)\n        );\n      } else {\n        this.columnsPushForEachKey(key);\n      }\n    }\n    this.loadingIndicator = false;\n    this.cdr.detectChanges();\n  }\n\n  onSelect(event: OnChartSelectEvent) {\n    if (typeof event === 'object') {\n      this.chartModel\n        .showDetail(event, this.modalController, TapVariableDataPopupComponent)\n        .catch((err) => {\n          console.warn(err);\n        });\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.chartModel.destroyCurrentSub();\n    this.destroyed.next();\n    this.destroyed.complete();\n  }\n}\n","<div style=\"position: relative\">\n  <ngx-datatable\n    [ngClass]=\"darkModeStatus ? 'dark' : 'material'\"\n    [rows]=\"rows\"\n    [loadingIndicator]=\"loadingIndicator\"\n    [columns]=\"columns\"\n    [columnMode]=\"columnMode\"\n    [headerHeight]=\"50\"\n    [footerHeight]=\"50\"\n    [rowHeight]=\"50\"\n    [reorderable]=\"reorderable\"\n    [scrollbarH]=\"true\"\n    [limit]=\"limit\"\n  >\n  </ngx-datatable>\n  <!--\n        [targetMarkerTemplate]=\"targetMarkerTemplate\"\n        <ng-template #targetMarkerTemplate let-class=\"class\">\n    <div [ngClass]=\"class\">\n      <div class=\"icon datatable-icon-down\"></div>\n      <div class=\"icon datatable-icon-up\"></div>\n    </div>\n    </ng-template>\n  -->\n\n  <ion-fab-button\n    id=\"exportFabButton\"\n    size=\"small\"\n    tapExportData\n    [dataToExport]=\"createExportedData.bind(this)\"\n    [exportedFileName]=\"exportedFileName\"\n    *ngIf=\"showExportButton\"\n  >\n    <ion-icon name=\"download\"></ion-icon>\n  </ion-fab-button>\n</div>\n"]}