@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
150 lines • 22.3 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { ChangeDetectorRef, Component, ElementRef, Inject, Input, NgZone, PLATFORM_ID, ViewChild, } from '@angular/core';
import { HeatMapComponent, LegendPosition } from '@swimlane/ngx-charts';
import { MonitoringAppGenComponent } from '../../metadata/decorators';
import { ChartDataModel, } from '../ChartDataModel';
import { dataWithSeriesToCsv } from '../ExportDataFormat';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "@swimlane/ngx-charts";
import * as i3 from "../../ui-directive/export-data.directive";
import * as i4 from "@ionic/angular";
let TapVariableHeatMapChartComponent = class TapVariableHeatMapChartComponent extends HeatMapComponent {
set label(indexOrArray) {
this.chartModel.initLabel(indexOrArray);
}
set variable(variableOrArray) {
this.inputStream = this.chartModel.initVariable(variableOrArray);
}
set inputStream(inputs) {
this.subscription = this.chartModel
.defineInputStreamMulti(inputs, this.history, this.valueCountLimit)
.subscribe((result) => {
result.map((e) => {
e.series.map((v) => {
if (typeof v.value === 'number' && v.value > this.maxValue) {
this.maxValue = v.value;
}
});
});
this.heatChart.max = this.maxValue;
this.chartHeight = result[0].series.length * 50;
if (this.chartHeight <= 100) {
this.chartHeight = 100;
}
this.results = result;
});
}
constructor(myChartElement, zone, platformId, cd) {
super(myChartElement, zone, cd, platformId);
this.colorScheme = {
domain: [
'#e0f7fa',
'#b2ebf2',
'#80deea',
'#4dd0e1',
'#26c6da',
'#00bcd4',
'#00acc1',
'#0097a7',
'#00838f',
'#006064',
],
};
this.showExportButton = false;
this.yAxis = true;
this.showYAxisLabel = true;
this.xAxis = true;
this.showXAxisLabel = false;
this.legend = true;
this.legendPosition = LegendPosition.Below;
this.valueCountLimit = 15;
this.history = false;
this.xAxisTickFormatting = this.defaultDateTickFormatting.bind(this);
this.chartHeight = 100;
this.maxValue = 1;
this.results = [
{
name: '---',
series: [
{
name: '---',
value: 0,
extra: 0,
},
],
},
];
this.chartModel = new ChartDataModel();
}
createExportedData() {
return dataWithSeriesToCsv(this.results);
}
ngAfterContentChecked() {
this.cd.detectChanges();
}
defaultDateTickFormatting(val) {
if (val instanceof Date) {
return val.toLocaleTimeString();
}
return val;
}
ngOnDestroy() {
this.subscription?.unsubscribe();
this.chartModel.destroyCurrentSub();
}
onSelect(event) {
/* Not implemented
this.chartModel.showDetail(event, this.modalController, TapVariableDataPopupComponent);
*/
}
};
/** @nocollapse */ TapVariableHeatMapChartComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TapVariableHeatMapChartComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: PLATFORM_ID }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ TapVariableHeatMapChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TapVariableHeatMapChartComponent, selector: "tap-variable-heat-map-chart", inputs: { colorScheme: "colorScheme", showExportButton: "showExportButton", exportedFileName: "exportedFileName", yAxis: "yAxis", showYAxisLabel: "showYAxisLabel", xAxis: "xAxis", showXAxisLabel: "showXAxisLabel", legend: "legend", legendPosition: "legendPosition", valueCountLimit: "valueCountLimit", history: "history", label: "label", xAxisTickFormatting: "xAxisTickFormatting", variable: "variable", inputStream: "inputStream" }, viewQueries: [{ propertyName: "heatChart", first: true, predicate: HeatMapComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n style=\"position: relative\"\n #containerRef\n [style.height.px]=\"chartHeight\"\n [ngClass]=\"legendPosition === 'below' ? 'belowLegend' : 'rightLegend'\"\n>\n <ngx-charts-heat-map\n [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n [scheme]=\"colorScheme\"\n [animations]=\"false\"\n [legend]=\"legend\"\n [legendPosition]=\"legendPosition\"\n [xAxis]=\"xAxis\"\n [yAxis]=\"yAxis\"\n [showXAxisLabel]=\"false\"\n [showYAxisLabel]=\"false\"\n [innerPadding]=\"[1.5, 1, 1, 1]\"\n [results]=\"results\"\n [xAxisTickFormatting]=\"xAxisTickFormatting\"\n (select)=\"onSelect($event)\"\n >\n </ngx-charts-heat-map>\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: ["::ng-deep .scale-legend{padding:20px!important}::ng-deep .horizontal-legend{overflow:auto!important}.belowLegend{width:100%;margin-bottom:100px}.rightLegend{width:100%}#exportFabButton{position:absolute;top:10px;right:10px}@media (prefers-color-scheme: dark){::ng-deep span.legend-label-text{color:#ccc!important}::ng-deep span.legend-label-text:hover{color:#fff!important}::ng-deep .ngx-charts text{fill:#fff!important}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.HeatMapComponent, selector: "ngx-charts-heat-map", inputs: ["legend", "legendTitle", "legendPosition", "xAxis", "yAxis", "showXAxisLabel", "showYAxisLabel", "xAxisLabel", "yAxisLabel", "gradient", "innerPadding", "trimXAxisTicks", "trimYAxisTicks", "rotateXAxisTicks", "maxXAxisTickLength", "maxYAxisTickLength", "xAxisTickFormatting", "yAxisTickFormatting", "xAxisTicks", "yAxisTicks", "tooltipDisabled", "tooltipText", "min", "max", "activeEntries", "wrapTicks"], outputs: ["activate", "deactivate"] }, { kind: "directive", type: i3.ExportDataDirective, selector: "[tapExportData]", inputs: ["exportedFileName", "dataToExport", "format"], outputs: ["exportDataError"] }, { kind: "component", type: i4.IonFabButton, selector: "ion-fab-button", inputs: ["activated", "closeIcon", "color", "disabled", "download", "href", "mode", "rel", "routerAnimation", "routerDirection", "show", "size", "target", "translucent", "type"] }, { kind: "component", type: i4.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }] });
TapVariableHeatMapChartComponent = __decorate([
MonitoringAppGenComponent({}),
__metadata("design:paramtypes", [ElementRef,
NgZone, String, ChangeDetectorRef])
], TapVariableHeatMapChartComponent);
export { TapVariableHeatMapChartComponent };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TapVariableHeatMapChartComponent, decorators: [{
type: Component,
args: [{ selector: 'tap-variable-heat-map-chart', template: "<div\n style=\"position: relative\"\n #containerRef\n [style.height.px]=\"chartHeight\"\n [ngClass]=\"legendPosition === 'below' ? 'belowLegend' : 'rightLegend'\"\n>\n <ngx-charts-heat-map\n [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n [scheme]=\"colorScheme\"\n [animations]=\"false\"\n [legend]=\"legend\"\n [legendPosition]=\"legendPosition\"\n [xAxis]=\"xAxis\"\n [yAxis]=\"yAxis\"\n [showXAxisLabel]=\"false\"\n [showYAxisLabel]=\"false\"\n [innerPadding]=\"[1.5, 1, 1, 1]\"\n [results]=\"results\"\n [xAxisTickFormatting]=\"xAxisTickFormatting\"\n (select)=\"onSelect($event)\"\n >\n </ngx-charts-heat-map>\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: ["::ng-deep .scale-legend{padding:20px!important}::ng-deep .horizontal-legend{overflow:auto!important}.belowLegend{width:100%;margin-bottom:100px}.rightLegend{width:100%}#exportFabButton{position:absolute;top:10px;right:10px}@media (prefers-color-scheme: dark){::ng-deep span.legend-label-text{color:#ccc!important}::ng-deep span.legend-label-text:hover{color:#fff!important}::ng-deep .ngx-charts text{fill:#fff!important}}\n"] }]
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: undefined, decorators: [{
type: Inject,
args: [PLATFORM_ID]
}] }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { heatChart: [{
type: ViewChild,
args: [HeatMapComponent]
}], colorScheme: [{
type: Input
}], showExportButton: [{
type: Input
}], exportedFileName: [{
type: Input
}], yAxis: [{
type: Input
}], showYAxisLabel: [{
type: Input
}], xAxis: [{
type: Input
}], showXAxisLabel: [{
type: Input
}], legend: [{
type: Input
}], legendPosition: [{
type: Input
}], valueCountLimit: [{
type: Input
}], history: [{
type: Input
}], label: [{
type: Input
}], xAxisTickFormatting: [{
type: Input
}], variable: [{
type: Input
}], inputStream: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tap-variable-heat-map-chart.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-heat-map-chart/tap-variable-heat-map-chart.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-heat-map-chart/tap-variable-heat-map-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentChecked,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  PLATFORM_ID,\n  ViewChild,\n} from '@angular/core';\nimport { AbstractVariable } from '@iotize/tap/data';\nimport { HeatMapComponent, LegendPosition } from '@swimlane/ngx-charts';\nimport { Subscription } from 'rxjs';\nimport { MonitoringAppGenComponent } from '../../metadata/decorators';\nimport {\n  ChartDataModel,\n  ChartInputMutli,\n  ChartInputStreamVar,\n} from '../ChartDataModel';\nimport { dataWithSeriesToCsv } from '../ExportDataFormat';\nimport { OnChartSelectEvent } from '../shared-types';\n\n@MonitoringAppGenComponent({})\n@Component({\n  selector: 'tap-variable-heat-map-chart',\n  templateUrl: './tap-variable-heat-map-chart.component.html',\n  styleUrls: ['./tap-variable-heat-map-chart.component.scss'],\n})\nexport class TapVariableHeatMapChartComponent\n  extends HeatMapComponent\n  implements AfterContentChecked, OnDestroy\n{\n  @ViewChild(HeatMapComponent) heatChart!: HeatMapComponent;\n\n  @Input()\n  colorScheme = {\n    domain: [\n      '#e0f7fa',\n      '#b2ebf2',\n      '#80deea',\n      '#4dd0e1',\n      '#26c6da',\n      '#00bcd4',\n      '#00acc1',\n      '#0097a7',\n      '#00838f',\n      '#006064',\n    ],\n  };\n\n  @Input()\n  showExportButton: boolean = false;\n\n  @Input()\n  exportedFileName?: string;\n\n  @Input()\n  yAxis: boolean = true;\n\n  @Input()\n  showYAxisLabel = true;\n\n  @Input()\n  xAxis: boolean = true;\n\n  @Input()\n  showXAxisLabel = false;\n\n  @Input()\n  legend = true;\n\n  @Input()\n  legendPosition: LegendPosition = LegendPosition.Below;\n\n  @Input()\n  valueCountLimit = 15;\n\n  @Input()\n  history: boolean = false;\n\n  @Input()\n  set label(indexOrArray: string | string[] | undefined | Function) {\n    this.chartModel.initLabel(indexOrArray);\n  }\n\n  @Input() xAxisTickFormatting: (input: any) => string =\n    this.defaultDateTickFormatting.bind(this);\n\n  isArray?: boolean;\n  chartHeight = 100;\n  maxValue = 1;\n\n  @Input()\n  set variable(\n    variableOrArray:\n      | AbstractVariable<number | number[]>\n      | AbstractVariable<number | number[]>[]\n      | undefined\n  ) {\n    this.inputStream = this.chartModel.initVariable(variableOrArray);\n  }\n\n  @Input()\n  set inputStream(inputs: ChartInputStreamVar[]) {\n    this.subscription = this.chartModel\n      .defineInputStreamMulti(inputs, this.history, this.valueCountLimit)\n      .subscribe((result) => {\n        result.map((e) => {\n          e.series.map((v) => {\n            if (typeof v.value === 'number' && v.value > this.maxValue) {\n              this.maxValue = v.value;\n            }\n          });\n        });\n        this.heatChart.max = this.maxValue;\n        this.chartHeight = result[0].series.length * 50;\n        if (this.chartHeight <= 100) {\n          this.chartHeight = 100;\n        }\n        this.results = result;\n      });\n  }\n\n  results: ChartInputMutli[] = [\n    {\n      name: '---',\n      series: [\n        {\n          name: '---',\n          value: 0,\n          extra: 0,\n        },\n      ],\n    },\n  ];\n\n  private chartModel = new ChartDataModel();\n\n  private subscription?: Subscription;\n\n  constructor(\n    myChartElement: ElementRef<any>,\n    zone: NgZone,\n    @Inject(PLATFORM_ID) platformId: string,\n    cd: ChangeDetectorRef\n  ) {\n    super(myChartElement, zone, cd, platformId);\n  }\n\n  createExportedData() {\n    return dataWithSeriesToCsv(this.results);\n  }\n\n  ngAfterContentChecked() {\n    this.cd.detectChanges();\n  }\n\n  defaultDateTickFormatting(val: any): string {\n    if (val instanceof Date) {\n      return val.toLocaleTimeString();\n    }\n    return val;\n  }\n\n  ngOnDestroy() {\n    this.subscription?.unsubscribe();\n    this.chartModel.destroyCurrentSub();\n  }\n\n  onSelect(event: OnChartSelectEvent) {\n    /* Not implemented\n    this.chartModel.showDetail(event, this.modalController, TapVariableDataPopupComponent);\n    */\n  }\n}\n","<div\n  style=\"position: relative\"\n  #containerRef\n  [style.height.px]=\"chartHeight\"\n  [ngClass]=\"legendPosition === 'below' ? 'belowLegend' : 'rightLegend'\"\n>\n  <ngx-charts-heat-map\n    [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n    [scheme]=\"colorScheme\"\n    [animations]=\"false\"\n    [legend]=\"legend\"\n    [legendPosition]=\"legendPosition\"\n    [xAxis]=\"xAxis\"\n    [yAxis]=\"yAxis\"\n    [showXAxisLabel]=\"false\"\n    [showYAxisLabel]=\"false\"\n    [innerPadding]=\"[1.5, 1, 1, 1]\"\n    [results]=\"results\"\n    [xAxisTickFormatting]=\"xAxisTickFormatting\"\n    (select)=\"onSelect($event)\"\n  >\n  </ngx-charts-heat-map>\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"]}