UNPKG

@iotize/ionic

Version:

Iotize specific building blocks on top of @ionic/angular.

162 lines 21.7 kB
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"]}