@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
276 lines • 38.4 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { ChangeDetectorRef, Component, ElementRef, Inject, Input, NgZone, PLATFORM_ID, ViewChild, } from '@angular/core';
import { AlertController } from '@ionic/angular';
import { LegendPosition, LineChartComponent } from '@swimlane/ngx-charts';
import * as shape from 'd3-shape';
import { BehaviorSubject, Subject, combineLatest, } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { MonitoringAppGenComponent, } from '../../metadata/decorators';
import { ChartDataModel, } from '../ChartDataModel';
import { dataWithSeriesToCsv } from '../ExportDataFormat';
import * as i0 from "@angular/core";
import * as i1 from "@ionic/angular";
import * as i2 from "@angular/common";
import * as i3 from "@swimlane/ngx-charts";
import * as i4 from "../../ui-directive/export-data.directive";
const CURVES = {
Basis: shape.curveBasis,
BasisClosed: shape.curveBasisClosed,
Bundle: shape.curveBundle.beta(1),
Cardinal: shape.curveCardinal,
CardinalClosed: shape.curveCardinalClosed,
CatmullRom: shape.curveCatmullRom,
CatmullRomClosed: shape.curveCatmullRomClosed,
Linear: shape.curveLinear,
Linear_Closed: shape.curveLinearClosed,
MonotoneX: shape.curveMonotoneX,
MonotoneY: shape.curveMonotoneY,
Natural: shape.curveNatural,
Step: shape.curveStep,
Step_After: shape.curveStepAfter,
Step_Before: shape.curveStepBefore,
Default: shape.curveLinear,
};
const DEFAULT_VALUE_COUNT_LIMIT = 30;
let TapVariableLineChartComponent = class TapVariableLineChartComponent extends LineChartComponent {
alertController;
id;
lineChart;
/**
* @deprecated use
*/
set linearCurve(curve) {
this.predefinedCurve = curve;
}
set predefinedCurve(curveFctOrId) {
if (Object.keys(CURVES).includes(curveFctOrId)) {
this._curve = CURVES[curveFctOrId];
}
else {
this._curve = CURVES.Default;
}
}
_curve = CURVES.Default;
legendTitle = '';
/**
* @deprecated use showLegend instead
*/
legend = true;
/**
* CHARTS OPTIONS
*/
/**
* @deprecated use legend instead
*/
set showLegend(v) {
this.legend = v;
}
legendPosition = LegendPosition.Below;
xAxis = true;
showXAxisLabel = false;
xAxisLabel = '';
yAxis = true;
showYAxisLabel = false;
yAxisLabel = '';
yScaleMin = 0;
showExportButton = false;
exportedFileName;
set history(enable) {
this._history.next(enable);
}
set valueCountLimit(limit) {
if (limit === undefined) {
limit = DEFAULT_VALUE_COUNT_LIMIT;
}
this._valueCountLimit.next(limit);
}
xAxisTickFormatting = this.defaultDateTickFormatting.bind(this);
set label(indexOrArray) {
this.chartModel.initLabel(indexOrArray);
}
colorScheme = {
domain: [
'#5DADE2',
'#9B59B6',
'#F39C12',
'#5AA454',
'#A10A28',
'#C7B42C',
'#AAAAAA',
],
};
_history = new BehaviorSubject(true);
_valueCountLimit = new BehaviorSubject(30);
set variable(variableOrArray) {
this.multiple = !!Array.isArray(variableOrArray);
this.input = this.chartModel.initVariable(variableOrArray);
}
_input = new BehaviorSubject([]);
set input(inputs) {
this._input.next(inputs);
}
set data(results) {
// TODO | ChartInputSingle[]
if (typeof results === 'number' || typeof results === 'string') {
if (!this.results?.[0]) {
this.results = [
{
name: 'Value',
series: [],
},
];
}
this.results[0].series.push({
name: new Date(),
value: results,
extra: results,
});
}
else if (results) {
if (!Array.isArray(results)) {
const result = results;
const existingSerieIndex = this.results.findIndex((r) => result.name);
if (existingSerieIndex >= 0) {
this.results[existingSerieIndex] = result;
}
else {
this.results.push(result);
}
}
else {
this.results = results;
}
}
}
destroyed = new Subject();
ngOnInit() {
combineLatest([this._valueCountLimit, this._input, this._history])
.pipe(takeUntil(this.destroyed))
.subscribe(([valueCountLimit, input, history]) => {
this.chartModel.destroyCurrentSub();
if (this.multiple) {
this.subscription = this.chartModel
.defineMultiInputStream(input)
.subscribe((result) => {
this.results = result;
});
}
else if (history && !this.multiple) {
this.subscription = this.chartModel
.defineInputStreamHistoryMultiLegend(input, valueCountLimit)
.subscribe((result) => {
this.results = result;
});
}
else if (!this.multiple) {
this.subscription = this.chartModel
.defineInputStreamMulti(input, false, valueCountLimit)
.subscribe((result) => {
this.results = result;
});
}
});
}
results = [
{
name: 'Value',
series: [],
},
];
subscription;
multiple;
chartModel = new ChartDataModel();
constructor(myChartElement, zone, cd, platformId, alertController) {
super(myChartElement, zone, cd, platformId);
this.alertController = alertController;
}
createExportedData() {
return dataWithSeriesToCsv(this.results);
}
defaultDateTickFormatting(val) {
if (val instanceof Date) {
return val.toLocaleTimeString();
}
return val;
}
onSelect(event) {
/* Not implemented
this.chartModel.showDetail(event, this.modalController, TapVariableDataPopupComponent);
*/
}
ngOnDestroy() {
this.subscription?.unsubscribe();
this.chartModel.destroyCurrentSub();
this.destroyed.next();
}
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TapVariableLineChartComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }, { token: PLATFORM_ID }, { token: i1.AlertController }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: TapVariableLineChartComponent, selector: "tap-variable-line-chart", inputs: { linearCurve: "linearCurve", predefinedCurve: "predefinedCurve", legendTitle: "legendTitle", legend: "legend", showLegend: "showLegend", legendPosition: "legendPosition", xAxis: "xAxis", showXAxisLabel: "showXAxisLabel", xAxisLabel: "xAxisLabel", yAxis: "yAxis", showYAxisLabel: "showYAxisLabel", yAxisLabel: "yAxisLabel", yScaleMin: "yScaleMin", showExportButton: "showExportButton", exportedFileName: "exportedFileName", history: "history", valueCountLimit: "valueCountLimit", xAxisTickFormatting: "xAxisTickFormatting", label: "label", colorScheme: "colorScheme", variable: "variable", input: "input", data: "data" }, viewQueries: [{ propertyName: "lineChart", first: true, predicate: LineChartComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n style=\"position: relative\"\n #containerRef\n class=\"chart-container\"\n [ngClass]=\"\n legendPosition === 'below' && legend ? 'belowLegend' : 'rightLegend'\n \"\n>\n <ngx-charts-line-chart\n [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n [scheme]=\"colorScheme\"\n [results]=\"results\"\n [gradient]=\"gradient\"\n [legendPosition]=\"legendPosition\"\n [xAxis]=\"xAxis\"\n [yAxis]=\"yAxis\"\n [legendTitle]=\"legendTitle\"\n [legend]=\"legend\"\n [showXAxisLabel]=\"showXAxisLabel\"\n [showYAxisLabel]=\"showYAxisLabel\"\n [timeline]=\"timeline\"\n [yAxisLabel]=\"yAxisLabel\"\n [xAxisLabel]=\"xAxisLabel\"\n [xAxisTickFormatting]=\"xAxisTickFormatting\"\n [curve]=\"_curve\"\n [autoScale]=\"autoScale\"\n [xScaleMin]=\"xScaleMin\"\n [xScaleMax]=\"xScaleMax\"\n [yScaleMin]=\"yScaleMin\"\n [yScaleMax]=\"yScaleMax\"\n [showGridLines]=\"showGridLines\"\n [animations]=\"animations\"\n [trimXAxisTicks]=\"trimXAxisTicks\"\n [maxXAxisTickLength]=\"maxXAxisTickLength\"\n [trimYAxisTicks]=\"trimYAxisTicks\"\n [maxYAxisTickLength]=\"maxYAxisTickLength\"\n [rangeFillOpacity]=\"rangeFillOpacity\"\n [roundDomains]=\"roundDomains\"\n [showRefLines]=\"showRefLines\"\n [showRefLabels]=\"showRefLabels\"\n [referenceLines]=\"referenceLines\"\n (select)=\"onSelect($event)\"\n >\n </ngx-charts-line-chart>\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 .horizontal-legend{overflow:auto!important}.belowLegend{height:50vh;width:100%;margin-bottom:100px}.rightLegend{height:50vh;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}::ng-deep .ngx-charts .tooltip-anchor{fill:var(--ion-color-primary)!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.LineChartComponent, selector: "ngx-charts-line-chart", inputs: ["legend", "legendTitle", "legendPosition", "xAxis", "yAxis", "showXAxisLabel", "showYAxisLabel", "xAxisLabel", "yAxisLabel", "autoScale", "timeline", "gradient", "showGridLines", "curve", "activeEntries", "schemeType", "rangeFillOpacity", "trimXAxisTicks", "trimYAxisTicks", "rotateXAxisTicks", "maxXAxisTickLength", "maxYAxisTickLength", "xAxisTickFormatting", "yAxisTickFormatting", "xAxisTicks", "yAxisTicks", "roundDomains", "tooltipDisabled", "showRefLines", "referenceLines", "showRefLabels", "xScaleMin", "xScaleMax", "yScaleMin", "yScaleMax", "wrapTicks"], outputs: ["activate", "deactivate"] }, { 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"] }] });
};
TapVariableLineChartComponent = __decorate([
MonitoringAppGenComponent({
constraints: {
isNumber: 'YES',
},
}),
__metadata("design:paramtypes", [ElementRef,
NgZone,
ChangeDetectorRef, String, AlertController])
], TapVariableLineChartComponent);
export { TapVariableLineChartComponent };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TapVariableLineChartComponent, decorators: [{
type: Component,
args: [{ selector: 'tap-variable-line-chart', template: "<div\n style=\"position: relative\"\n #containerRef\n class=\"chart-container\"\n [ngClass]=\"\n legendPosition === 'below' && legend ? 'belowLegend' : 'rightLegend'\n \"\n>\n <ngx-charts-line-chart\n [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n [scheme]=\"colorScheme\"\n [results]=\"results\"\n [gradient]=\"gradient\"\n [legendPosition]=\"legendPosition\"\n [xAxis]=\"xAxis\"\n [yAxis]=\"yAxis\"\n [legendTitle]=\"legendTitle\"\n [legend]=\"legend\"\n [showXAxisLabel]=\"showXAxisLabel\"\n [showYAxisLabel]=\"showYAxisLabel\"\n [timeline]=\"timeline\"\n [yAxisLabel]=\"yAxisLabel\"\n [xAxisLabel]=\"xAxisLabel\"\n [xAxisTickFormatting]=\"xAxisTickFormatting\"\n [curve]=\"_curve\"\n [autoScale]=\"autoScale\"\n [xScaleMin]=\"xScaleMin\"\n [xScaleMax]=\"xScaleMax\"\n [yScaleMin]=\"yScaleMin\"\n [yScaleMax]=\"yScaleMax\"\n [showGridLines]=\"showGridLines\"\n [animations]=\"animations\"\n [trimXAxisTicks]=\"trimXAxisTicks\"\n [maxXAxisTickLength]=\"maxXAxisTickLength\"\n [trimYAxisTicks]=\"trimYAxisTicks\"\n [maxYAxisTickLength]=\"maxYAxisTickLength\"\n [rangeFillOpacity]=\"rangeFillOpacity\"\n [roundDomains]=\"roundDomains\"\n [showRefLines]=\"showRefLines\"\n [showRefLabels]=\"showRefLabels\"\n [referenceLines]=\"referenceLines\"\n (select)=\"onSelect($event)\"\n >\n </ngx-charts-line-chart>\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 .horizontal-legend{overflow:auto!important}.belowLegend{height:50vh;width:100%;margin-bottom:100px}.rightLegend{height:50vh;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}::ng-deep .ngx-charts .tooltip-anchor{fill:var(--ion-color-primary)!important}}\n"] }]
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
type: Inject,
args: [PLATFORM_ID]
}] }, { type: i1.AlertController }], propDecorators: { lineChart: [{
type: ViewChild,
args: [LineChartComponent]
}], linearCurve: [{
type: Input
}], predefinedCurve: [{
type: Input
}], legendTitle: [{
type: Input
}], legend: [{
type: Input
}], showLegend: [{
type: Input
}], legendPosition: [{
type: Input
}], xAxis: [{
type: Input
}], showXAxisLabel: [{
type: Input
}], xAxisLabel: [{
type: Input
}], yAxis: [{
type: Input
}], showYAxisLabel: [{
type: Input
}], yAxisLabel: [{
type: Input
}], yScaleMin: [{
type: Input
}], showExportButton: [{
type: Input
}], exportedFileName: [{
type: Input
}], history: [{
type: Input
}], valueCountLimit: [{
type: Input
}], xAxisTickFormatting: [{
type: Input
}], label: [{
type: Input
}], colorScheme: [{
type: Input
}], variable: [{
type: Input
}], input: [{
type: Input
}], data: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tap-variable-line-chart.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-line-chart/tap-variable-line-chart.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-line-chart/tap-variable-line-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  PLATFORM_ID,\n  ViewChild,\n} from '@angular/core';\nimport { AlertController } from '@ionic/angular';\nimport { AbstractVariable } from '@iotize/tap/data';\nimport { LegendPosition, LineChartComponent } from '@swimlane/ngx-charts';\nimport * as shape from 'd3-shape';\nimport {\n  BehaviorSubject,\n  Observable,\n  Subject,\n  Subscription,\n  combineLatest,\n} from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport {\n  AppGenField,\n  MonitoringAppGenComponent,\n} from '../../metadata/decorators';\nimport {\n  ChartDataModel,\n  ChartInputMutli,\n  ChartInputStreamVar,\n} from '../ChartDataModel';\nimport { dataWithSeriesToCsv } from '../ExportDataFormat';\nimport {\n  COLOR_SCHEME_SCHEMA,\n  EXPORT_DATA_FILE_NAME_SCHEMA,\n  LEGEND_POSITION_SCHEMA,\n  LEGEND_TITLE_SCHEMA,\n  SHOW_EXPORT_DATA_BUTTON_SCHEMA,\n  SHOW_LEGEND_SCHEMA,\n  SHOW_X_AXIS_LABEL_SCHEMA,\n  SHOW_X_AXIS_SCHEMA,\n  SHOW_Y_AXIS_LABEL_SCHEMA,\n  SHOW_Y_AXIS_SCHEMA,\n  TAP_VARIABLE_SCHEMA,\n  X_AXIS_LABEL_SCHEMA,\n  Y_AXIS_LABEL_SCHEMA,\n  Y_SCALE_MAX_SCHEMA,\n  Y_SCALE_MIN_SCHEMA,\n} from '../shared-schema';\nimport { OnChartSelectEvent } from '../shared-types';\n\nconst CURVES = {\n  Basis: shape.curveBasis,\n  BasisClosed: shape.curveBasisClosed,\n  Bundle: shape.curveBundle.beta(1),\n  Cardinal: shape.curveCardinal,\n  CardinalClosed: shape.curveCardinalClosed,\n  CatmullRom: shape.curveCatmullRom,\n  CatmullRomClosed: shape.curveCatmullRomClosed,\n  Linear: shape.curveLinear,\n  Linear_Closed: shape.curveLinearClosed,\n  MonotoneX: shape.curveMonotoneX,\n  MonotoneY: shape.curveMonotoneY,\n  Natural: shape.curveNatural,\n  Step: shape.curveStep,\n  Step_After: shape.curveStepAfter,\n  Step_Before: shape.curveStepBefore,\n  Default: shape.curveLinear,\n};\ninterface SerieItem {\n  name: string | Date;\n  value: number;\n}\n\nexport interface ChartInputData {\n  name: string;\n  series?: SerieItem[];\n}\n\nexport interface ChartInputStream {\n  stream: Observable<number>;\n  label: string;\n}\n\nconst DEFAULT_VALUE_COUNT_LIMIT = 30;\n\n@MonitoringAppGenComponent({\n  constraints: {\n    isNumber: 'YES',\n  },\n})\n@Component({\n  selector: 'tap-variable-line-chart',\n  templateUrl: './tap-variable-line-chart.component.html',\n  styleUrls: ['./tap-variable-line-chart.component.scss'],\n})\nexport class TapVariableLineChartComponent\n  extends LineChartComponent\n  implements OnDestroy, OnInit\n{\n  id?: KeyType;\n\n  @ViewChild(LineChartComponent) lineChart!: LineChartComponent;\n\n  /**\n   * @deprecated use\n   */\n  @Input()\n  set linearCurve(curve: string) {\n    this.predefinedCurve = curve;\n  }\n\n  @Input() set predefinedCurve(curveFctOrId: string) {\n    if (Object.keys(CURVES).includes(curveFctOrId)) {\n      this._curve = CURVES[curveFctOrId as keyof typeof CURVES];\n    } else {\n      this._curve = CURVES.Default;\n    }\n  }\n\n  _curve: shape.CurveFactory | shape.CurveBundleFactory = CURVES.Default;\n\n  @Input()\n  legendTitle: string = '';\n\n  /**\n   * @deprecated use showLegend instead\n   */\n  @Input()\n  legend: boolean = true;\n\n  /**\n   * CHARTS OPTIONS\n   */\n  /**\n   * @deprecated use legend instead\n   */\n  @Input()\n  set showLegend(v: boolean) {\n    this.legend = v;\n  }\n\n  @Input()\n  legendPosition: LegendPosition = LegendPosition.Below;\n\n  @Input()\n  xAxis: boolean = true;\n\n  @Input()\n  showXAxisLabel: boolean = false;\n\n  @Input()\n  xAxisLabel = '';\n\n  @Input()\n  yAxis: boolean = true;\n\n  @Input()\n  showYAxisLabel: boolean = false;\n\n  @Input()\n  yAxisLabel = '';\n\n  @Input()\n  yScaleMin: number = 0;\n\n  @Input()\n  showExportButton: boolean = false;\n\n  @Input()\n  exportedFileName?: 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 = DEFAULT_VALUE_COUNT_LIMIT;\n    }\n    this._valueCountLimit.next(limit);\n  }\n\n  @Input() xAxisTickFormatting: (input: any) => string =\n    this.defaultDateTickFormatting.bind(this);\n\n  @Input()\n  set label(indexOrArray: string | string[] | undefined | Function) {\n    this.chartModel.initLabel(indexOrArray);\n  }\n\n  @Input()\n  colorScheme = {\n    domain: [\n      '#5DADE2',\n      '#9B59B6',\n      '#F39C12',\n      '#5AA454',\n      '#A10A28',\n      '#C7B42C',\n      '#AAAAAA',\n    ],\n  };\n\n  private _history = new BehaviorSubject<boolean>(true);\n\n  private _valueCountLimit = new BehaviorSubject<number>(30);\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  private _input = new BehaviorSubject<ChartInputStreamVar[]>([]);\n\n  @Input()\n  set input(inputs: ChartInputStreamVar[]) {\n    this._input.next(inputs);\n  }\n\n  @Input() set data(results: ChartInputMutli[] | number | string) {\n    // TODO  | ChartInputSingle[]\n    if (typeof results === 'number' || typeof results === 'string') {\n      if (!this.results?.[0]) {\n        this.results = [\n          {\n            name: 'Value',\n            series: [],\n          },\n        ];\n      }\n      this.results[0].series.push({\n        name: new Date(),\n        value: results,\n        extra: results,\n      });\n    } else if (results) {\n      if (!Array.isArray(results)) {\n        const result = results as ChartInputMutli;\n        const existingSerieIndex = this.results.findIndex((r) => result.name);\n        if (existingSerieIndex >= 0) {\n          this.results[existingSerieIndex] = result;\n        } else {\n          this.results.push(result);\n        }\n      } else {\n        this.results = results;\n      }\n    }\n  }\n\n  private destroyed = new Subject<void>();\n\n  ngOnInit(): void {\n    combineLatest([this._valueCountLimit, this._input, this._history])\n      .pipe(takeUntil(this.destroyed))\n      .subscribe(([valueCountLimit, input, history]) => {\n        this.chartModel.destroyCurrentSub();\n        if (this.multiple) {\n          this.subscription = this.chartModel\n            .defineMultiInputStream(input)\n            .subscribe((result) => {\n              this.results = result;\n            });\n        } else if (history && !this.multiple) {\n          this.subscription = this.chartModel\n            .defineInputStreamHistoryMultiLegend(input, valueCountLimit!!)\n            .subscribe((result) => {\n              this.results = result;\n            });\n        } else if (!this.multiple) {\n          this.subscription = this.chartModel\n            .defineInputStreamMulti(input, false, valueCountLimit!!)\n            .subscribe((result) => {\n              this.results = result as ChartInputMutli[];\n            });\n        }\n      });\n  }\n\n  results: ChartInputMutli[] = [\n    {\n      name: 'Value',\n      series: [],\n    },\n  ];\n\n  private subscription?: Subscription;\n\n  private multiple?: boolean;\n\n  private chartModel: ChartDataModel = new ChartDataModel();\n\n  constructor(\n    myChartElement: ElementRef,\n    zone: NgZone,\n    cd: ChangeDetectorRef,\n    @Inject(PLATFORM_ID) platformId: string,\n    public alertController: AlertController\n  ) {\n    super(myChartElement, zone, cd, platformId);\n  }\n\n  createExportedData() {\n    return dataWithSeriesToCsv(this.results);\n  }\n\n  defaultDateTickFormatting(val: any): string {\n    if (val instanceof Date) {\n      return val.toLocaleTimeString();\n    }\n    return val;\n  }\n\n  onSelect(event: OnChartSelectEvent) {\n    /* Not implemented\n    this.chartModel.showDetail(event, this.modalController, TapVariableDataPopupComponent);\n    */\n  }\n\n  ngOnDestroy() {\n    this.subscription?.unsubscribe();\n    this.chartModel.destroyCurrentSub();\n    this.destroyed.next();\n  }\n}\n","<div\n  style=\"position: relative\"\n  #containerRef\n  class=\"chart-container\"\n  [ngClass]=\"\n    legendPosition === 'below' && legend ? 'belowLegend' : 'rightLegend'\n  \"\n>\n  <ngx-charts-line-chart\n    [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n    [scheme]=\"colorScheme\"\n    [results]=\"results\"\n    [gradient]=\"gradient\"\n    [legendPosition]=\"legendPosition\"\n    [xAxis]=\"xAxis\"\n    [yAxis]=\"yAxis\"\n    [legendTitle]=\"legendTitle\"\n    [legend]=\"legend\"\n    [showXAxisLabel]=\"showXAxisLabel\"\n    [showYAxisLabel]=\"showYAxisLabel\"\n    [timeline]=\"timeline\"\n    [yAxisLabel]=\"yAxisLabel\"\n    [xAxisLabel]=\"xAxisLabel\"\n    [xAxisTickFormatting]=\"xAxisTickFormatting\"\n    [curve]=\"_curve\"\n    [autoScale]=\"autoScale\"\n    [xScaleMin]=\"xScaleMin\"\n    [xScaleMax]=\"xScaleMax\"\n    [yScaleMin]=\"yScaleMin\"\n    [yScaleMax]=\"yScaleMax\"\n    [showGridLines]=\"showGridLines\"\n    [animations]=\"animations\"\n    [trimXAxisTicks]=\"trimXAxisTicks\"\n    [maxXAxisTickLength]=\"maxXAxisTickLength\"\n    [trimYAxisTicks]=\"trimYAxisTicks\"\n    [maxYAxisTickLength]=\"maxYAxisTickLength\"\n    [rangeFillOpacity]=\"rangeFillOpacity\"\n    [roundDomains]=\"roundDomains\"\n    [showRefLines]=\"showRefLines\"\n    [showRefLabels]=\"showRefLabels\"\n    [referenceLines]=\"referenceLines\"\n    (select)=\"onSelect($event)\"\n  >\n  </ngx-charts-line-chart>\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"]}