@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
162 lines • 21.7 kB
JavaScript
import { Component, Input } from '@angular/core';
import { DataSource } from '@angular/cdk/table';
import { Observable, Subject, combineLatest } from 'rxjs';
import { debug } from '../../debug';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "@angular/material/table";
import * as i3 from "@angular/cdk/table";
export class MonitoringTableComponent {
set columnsMap(mapping) {
if (mapping) {
if (!this.columns) {
this.setupColumns();
}
for (const key in mapping) {
if (!this.columns?.find((info) => info.columnDef === key)) {
debug('Column ', key, 'is not in columns', this.columns);
this.addColumn(key, mapping[key]);
}
}
// Removing old columns
const toRemove = [];
this.columns?.forEach((column, index) => {
if (!(column.columnDef in mapping)) {
debug('Deleting column: ', column);
toRemove.push(index);
}
});
toRemove.reverse().forEach((index) => this.columns?.splice(index, 1));
// debug(`COLUMNS:`, this.columns)
this.displayedColumns = this.columns?.map((x) => x.columnDef);
// refresh data
this.dataSource.refresh();
}
}
set variables(variables) {
combineLatest(variables.map((variable) => variable.values)).subscribe((values) => {
if (this.columns) {
const item = {};
this.columns.forEach((column, index) => {
if (column.columnDef === '__date') {
item[column.columnDef] = new Date().toLocaleTimeString();
}
else {
item[column.columnDef] = values[index - (this.date ? 1 : 0)];
}
});
this.dataSource.add(item);
}
});
}
set data$(stream) {
if (stream) {
stream.subscribe((value) => {
if (this.columns) {
this.dataSource.add(value);
}
});
}
}
set data(data) {
debug('Setting table data: ', data);
this.dataSource.data = data;
}
constructor() {
/** Table columns */
this.columns = undefined;
this.dataSource = new MonitoringTableComponentDataSource();
/** Column definitions in order */
this.displayedColumns = [];
this.date = true;
}
setupColumns() {
debug('setupColumns');
if (this.columns) {
this.columns.splice(0, this.columns.length);
}
else {
this.columns = [];
}
if (this.date) {
this.addColumn('__date', 'Date');
}
}
addColumn(id, header) {
if (!this.columns) {
this.columns = [];
}
const columnInfo = {
header: header,
columnDef: id,
cell: (row) => `${row[id]}`,
};
this.columns.push(columnInfo);
}
}
/** @nocollapse */ MonitoringTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MonitoringTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ MonitoringTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: MonitoringTableComponent, selector: "tap-app-monitoring-table", inputs: { columns: "columns", dataSource: "dataSource", columnsMap: "columnsMap", displayedColumns: "displayedColumns", variables: "variables", data$: "data$", data: "data", date: "date" }, ngImport: i0, template: "<mat-table\n *ngIf=\"columns && columns.length > 0\"\n [dataSource]=\"dataSource\"\n #table\n>\n <ng-container\n *ngFor=\"let column of columns\"\n [cdkColumnDef]=\"column.columnDef\"\n >\n <mat-header-cell *cdkHeaderCellDef>{{ column.header }}</mat-header-cell>\n <mat-cell *cdkCellDef=\"let row\">{{ column.cell(row) }}</mat-cell>\n </ng-container>\n\n <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n</mat-table>\n", styles: [""], 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.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i2.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i2.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i2.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i2.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i2.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i2.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: i3.CdkCellDef, selector: "[cdkCellDef]" }, { kind: "directive", type: i3.CdkHeaderCellDef, selector: "[cdkHeaderCellDef]" }, { kind: "directive", type: i3.CdkColumnDef, selector: "[cdkColumnDef]", inputs: ["sticky", "cdkColumnDef", "stickyEnd"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MonitoringTableComponent, decorators: [{
type: Component,
args: [{ selector: 'tap-app-monitoring-table', template: "<mat-table\n *ngIf=\"columns && columns.length > 0\"\n [dataSource]=\"dataSource\"\n #table\n>\n <ng-container\n *ngFor=\"let column of columns\"\n [cdkColumnDef]=\"column.columnDef\"\n >\n <mat-header-cell *cdkHeaderCellDef>{{ column.header }}</mat-header-cell>\n <mat-cell *cdkCellDef=\"let row\">{{ column.cell(row) }}</mat-cell>\n </ng-container>\n\n <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n</mat-table>\n" }]
}], ctorParameters: function () { return []; }, propDecorators: { columns: [{
type: Input
}], dataSource: [{
type: Input
}], columnsMap: [{
type: Input
}], displayedColumns: [{
type: Input
}], variables: [{
type: Input
}], data$: [{
type: Input
}], data: [{
type: Input
}], date: [{
type: Input
}] } });
export class MonitoringTableComponentDataSource extends DataSource {
constructor(options = {
max: -1,
newItemOnTop: true,
}) {
super();
this.options = options;
this._data = [];
this._subject = new Subject();
}
add(item) {
if (this.options.newItemOnTop) {
this._data.unshift(item);
if (this.options.max >= 0 && this._data.length > this.options.max) {
this._data.pop();
}
}
else {
this._data.push(item);
if (this.options.max >= 0 && this._data.length > this.options.max) {
this._data.shift();
}
}
this._subject.next(this._data);
// debug(`Adding values: `, item)
}
set data(d) {
this._data = d;
this._subject.next(this._data);
}
connect() {
return this._subject;
}
refresh() {
this._data = [...this._data];
this._subject.next(this._data);
}
disconnect() { }
clear() {
this._data = [];
this._subject.next(this._data);
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monitoring-table.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/monitoring-table/monitoring-table.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/monitoring-table/monitoring-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\nimport { DataSource } from '@angular/cdk/table';\nimport { Observable, Subject, combineLatest } from 'rxjs';\nimport { AbstractVariable } from '@iotize/tap/data';\nimport { debug } from '../../debug';\n\nexport interface TableDataEntry {\n  __date?: number;\n  [key: string]: any;\n}\n\nexport interface TableColumnType {\n  header: string;\n  columnDef: string;\n  cell: (row: any) => string;\n}\n\n@Component({\n  selector: 'tap-app-monitoring-table',\n  templateUrl: './monitoring-table.component.html',\n  styleUrls: ['./monitoring-table.component.scss'],\n})\nexport class MonitoringTableComponent {\n  /** Table columns */\n  @Input() columns?: TableColumnType[] = undefined;\n\n  @Input() dataSource = new MonitoringTableComponentDataSource();\n\n  @Input() set columnsMap(mapping: { [key: string]: string }) {\n    if (mapping) {\n      if (!this.columns) {\n        this.setupColumns();\n      }\n      for (const key in mapping) {\n        if (!this.columns?.find((info) => info.columnDef === key)) {\n          debug('Column ', key, 'is not in columns', this.columns);\n          this.addColumn(key, mapping[key]);\n        }\n      }\n      // Removing old columns\n      const toRemove: number[] = [];\n      this.columns?.forEach((column, index) => {\n        if (!(column.columnDef in mapping)) {\n          debug('Deleting column: ', column);\n          toRemove.push(index);\n        }\n      });\n      toRemove.reverse().forEach((index) => this.columns?.splice(index, 1));\n      // debug(`COLUMNS:`, this.columns)\n      this.displayedColumns = this.columns?.map((x) => x.columnDef);\n\n      // refresh data\n      this.dataSource.refresh();\n    }\n  }\n\n  /** Column definitions in order */\n  @Input() displayedColumns: string[] | undefined = [];\n\n  @Input() set variables(variables: AbstractVariable<any>[]) {\n    combineLatest(variables.map((variable) => variable.values)).subscribe(\n      (values) => {\n        if (this.columns) {\n          const item: Record<string, any> = {};\n          this.columns.forEach((column, index: number) => {\n            if (column.columnDef === '__date') {\n              item[column.columnDef] = new Date().toLocaleTimeString();\n            } else {\n              item[column.columnDef] = values[index - (this.date ? 1 : 0)];\n            }\n          });\n          this.dataSource.add(item as TableDataEntry);\n        }\n      }\n    );\n  }\n\n  @Input() set data$(stream: Observable<any>) {\n    if (stream) {\n      stream.subscribe((value) => {\n        if (this.columns) {\n          this.dataSource.add(value);\n        }\n      });\n    }\n  }\n\n  @Input() set data(data: TableDataEntry[]) {\n    debug('Setting table data: ', data);\n    this.dataSource.data = data;\n  }\n\n  @Input() date = true;\n\n  constructor() {}\n\n  private setupColumns() {\n    debug('setupColumns');\n    if (this.columns) {\n      this.columns.splice(0, this.columns.length);\n    } else {\n      this.columns = [];\n    }\n    if (this.date) {\n      this.addColumn('__date', 'Date');\n    }\n  }\n\n  private addColumn(id: string, header: string): any {\n    if (!this.columns) {\n      this.columns = [];\n    }\n    const columnInfo = {\n      header: header,\n      columnDef: id,\n      cell: (row: any) => `${row[id]}`,\n    };\n    this.columns.push(columnInfo);\n  }\n}\n\nexport class MonitoringTableComponentDataSource extends DataSource<TableDataEntry> {\n  _data: TableDataEntry[] = [];\n\n  private _subject = new Subject<TableDataEntry[]>();\n\n  constructor(\n    public options: {\n      max: number;\n      newItemOnTop: boolean;\n    } = {\n      max: -1,\n      newItemOnTop: true,\n    }\n  ) {\n    super();\n  }\n\n  add(item: TableDataEntry) {\n    if (this.options.newItemOnTop) {\n      this._data.unshift(item);\n      if (this.options.max >= 0 && this._data.length > this.options.max) {\n        this._data.pop();\n      }\n    } else {\n      this._data.push(item);\n      if (this.options.max >= 0 && this._data.length > this.options.max) {\n        this._data.shift();\n      }\n    }\n    this._subject.next(this._data);\n    // debug(`Adding values: `, item)\n  }\n\n  set data(d: TableDataEntry[]) {\n    this._data = d;\n    this._subject.next(this._data);\n  }\n\n  connect(): Observable<TableDataEntry[]> {\n    return this._subject;\n  }\n\n  refresh() {\n    this._data = [...this._data];\n    this._subject.next(this._data);\n  }\n\n  disconnect() {}\n\n  clear() {\n    this._data = [];\n    this._subject.next(this._data);\n  }\n}\n","<mat-table\n  *ngIf=\"columns && columns.length > 0\"\n  [dataSource]=\"dataSource\"\n  #table\n>\n  <ng-container\n    *ngFor=\"let column of columns\"\n    [cdkColumnDef]=\"column.columnDef\"\n  >\n    <mat-header-cell *cdkHeaderCellDef>{{ column.header }}</mat-header-cell>\n    <mat-cell *cdkCellDef=\"let row\">{{ column.cell(row) }}</mat-cell>\n  </ng-container>\n\n  <mat-header-row *matHeaderRowDef=\"displayedColumns\"></mat-header-row>\n  <mat-row *matRowDef=\"let row; columns: displayedColumns\"></mat-row>\n</mat-table>\n"]}