UNPKG

@iotize/ionic

Version:

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

262 lines 39.8 kB
import { __decorate, __metadata } from "tslib"; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Inject, Input, NgZone, PLATFORM_ID, ViewChild, } from '@angular/core'; import { ModalController } from '@ionic/angular'; import { BarHorizontal2DComponent, BarVertical2DComponent, BaseChartComponent, LegendPosition, } from '@swimlane/ngx-charts'; import { MonitoringAppGenComponent } from '../../metadata/decorators'; import { ChartDataModel, } from '../ChartDataModel'; import { dataWithSeriesToCsv } from '../ExportDataFormat'; 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-charts"; import * as i4 from "../../ui-directive/export-data.directive"; let TapVariableBarChartGroupComponent = class TapVariableBarChartGroupComponent extends BaseChartComponent { modalController; divContainer; barChartHor; barChartVer; constructor(myChartElement, zone, cd, platformId, modalController) { super(myChartElement, zone, cd, platformId); this.modalController = modalController; } legendPosition = LegendPosition.Below; showExportButton = false; exportedFileName; legend = true; legendTitle; colorScheme = { domain: [ '#5DADE2', '#9B59B6', '#F39C12', '#5AA454', '#A10A28', '#C7B42C', '#AAAAAA', ], }; orientation = 'vertical'; showDetails = false; noBarWhenZero = false; trimXAxisTicks; maxXAxisTickLength; trimYAxisTicks; maxYAxisTickLength; animations = true; roundDomains; roundEdges = true; barPadding; showYAxisLabel; yAxisLabel; showXAxisLabel; xAxisLabel; showGridLines; scaleMax; /** * @deprecated use xAxis */ set showXAxis(v) { this.xAxis = v; } xAxis = true; /** * @deprecated use yAxis */ set showYAxis(v) { this.yAxis = v; } yAxis = true; history = false; valueCountLimit = 10; set label(indexOrArray) { this.chartModel.initLabel(indexOrArray); } set variable(variableOrArray) { this.mutlipleVar = variableOrArray.length > 1; this.input = this.chartModel.initVariable(variableOrArray); } set input(inputs) { if (this.mutlipleVar) { this.subscription = this.chartModel .defineMultiInputStream(inputs) .subscribe((result) => { if (this.scrollableChart) { this.resizeToScroll(result.length, result[0].series.length); } this.results = result; }); } else { this.subscription = this.chartModel .defineInputStreamMulti(inputs, this.history, this.valueCountLimit) .subscribe((result) => { if (this.scrollableChart) { this.resizeToScroll(result.length, result[0].series.length); } this.results = result; }); } this.cd.detectChanges(); } set data(results) { this.results = results; } results = [ { name: '---', series: [ { name: '---', value: 0, extra: 0, }, ], }, ]; scrollableChart = false; widthChart; heightChart; chartModel = new ChartDataModel(); subscription; mutlipleVar; createExportedData() { return dataWithSeriesToCsv(this.results); } onSelect(event) { if (typeof event === 'object') { if (this.showDetails) { this.chartModel .showDetail(event, this.modalController, TapVariableDataPopupComponent) .catch((err) => { console.log(err); }); } } } ngAfterViewChecked() { if (!this.scrollableChart) { this.widthChart = this.divContainer.nativeElement.offsetWidth; this.heightChart = this.divContainer.nativeElement.offsetHeight; } this.cd.detectChanges(); } resizeToScroll(size, seriesSize) { if (this.orientation === 'vertical') { if (this.divContainer.nativeElement.offsetWidth <= size * 50 * seriesSize) { this.barChartVer.view = [ size * 50 * seriesSize, this.divContainer.nativeElement.offsetHeight, ]; } } else if (this.orientation === 'horizontal') { if (this.divContainer.nativeElement.offsetHeight <= size * 50 * seriesSize) { this.barChartHor.view = [ this.divContainer.nativeElement.offsetWidth, size * 50 * seriesSize, ]; } } } ngOnDestroy() { this.subscription?.unsubscribe(); this.chartModel.destroyCurrentSub(); } /** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TapVariableBarChartGroupComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }, { token: PLATFORM_ID }, { token: i1.ModalController }], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: TapVariableBarChartGroupComponent, selector: "tap-variable-bar-chart-group", inputs: { legendPosition: "legendPosition", showExportButton: "showExportButton", exportedFileName: "exportedFileName", legend: "legend", legendTitle: "legendTitle", colorScheme: "colorScheme", orientation: "orientation", showDetails: "showDetails", noBarWhenZero: "noBarWhenZero", trimXAxisTicks: "trimXAxisTicks", maxXAxisTickLength: "maxXAxisTickLength", trimYAxisTicks: "trimYAxisTicks", maxYAxisTickLength: "maxYAxisTickLength", animations: "animations", roundDomains: "roundDomains", roundEdges: "roundEdges", barPadding: "barPadding", showYAxisLabel: "showYAxisLabel", yAxisLabel: "yAxisLabel", showXAxisLabel: "showXAxisLabel", xAxisLabel: "xAxisLabel", showGridLines: "showGridLines", scaleMax: "scaleMax", showXAxis: "showXAxis", xAxis: "xAxis", showYAxis: "showYAxis", yAxis: "yAxis", history: "history", valueCountLimit: "valueCountLimit", label: "label", variable: "variable", input: "input", data: "data", scrollableChart: "scrollableChart" }, viewQueries: [{ propertyName: "divContainer", first: true, predicate: ["containerRef"], descendants: true }, { propertyName: "barChartHor", first: true, predicate: ["barChartHor"], descendants: true }, { propertyName: "barChartVer", first: true, predicate: ["barChartVer"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n [ngClass]=\"\n scrollableChart\n ? orientation === 'vertical'\n ? 'verticalContainer'\n : 'horizontalContainer'\n : {}\n \"\n>\n <div\n #containerRef\n [ngClass]=\"\n legendPosition === 'below' && legend ? 'belowLegend' : 'rightLegend'\n \"\n [ngSwitch]=\"orientation\"\n style=\"position: relative\"\n >\n <ngx-charts-bar-horizontal-2d\n *ngSwitchCase=\"'horizontal'\"\n #barChartHor\n [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n [scheme]=\"colorScheme\"\n [results]=\"results\"\n [legend]=\"legend\"\n [legendTitle]=\"legendTitle\"\n [legendPosition]=\"legendPosition\"\n [noBarWhenZero]=\"noBarWhenZero\"\n [xAxis]=\"xAxis\"\n [showYAxisLabel]=\"showYAxisLabel\"\n [yAxisLabel]=\"yAxisLabel\"\n [yAxis]=\"yAxis\"\n [showXAxisLabel]=\"showXAxisLabel\"\n [xAxisLabel]=\"xAxisLabel\"\n [showGridLines]=\"showGridLines\"\n [trimXAxisTicks]=\"trimXAxisTicks\"\n [maxXAxisTickLength]=\"maxXAxisTickLength\"\n [trimYAxisTicks]=\"trimYAxisTicks\"\n [maxYAxisTickLength]=\"maxYAxisTickLength\"\n [animations]=\"animations\"\n [roundDomains]=\"roundDomains\"\n [roundEdges]=\"roundEdges\"\n [barPadding]=\"barPadding\"\n [xScaleMax]=\"scaleMax\"\n (select)=\"onSelect($event)\"\n >\n </ngx-charts-bar-horizontal-2d>\n <ngx-charts-bar-vertical-2d\n *ngSwitchCase=\"'vertical'\"\n #barChartVer\n [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n [scheme]=\"colorScheme\"\n [results]=\"results\"\n [roundEdges]=\"roundEdges\"\n [legend]=\"legend\"\n [legendTitle]=\"legendTitle\"\n [legendPosition]=\"legendPosition\"\n [noBarWhenZero]=\"noBarWhenZero\"\n [xAxis]=\"xAxis\"\n [showYAxisLabel]=\"showYAxisLabel\"\n [yAxisLabel]=\"yAxisLabel\"\n [yAxis]=\"yAxis\"\n [showXAxisLabel]=\"showXAxisLabel\"\n [xAxisLabel]=\"xAxisLabel\"\n [showGridLines]=\"showGridLines\"\n [trimXAxisTicks]=\"trimXAxisTicks\"\n [maxXAxisTickLength]=\"maxXAxisTickLength\"\n [trimYAxisTicks]=\"trimYAxisTicks\"\n [maxYAxisTickLength]=\"maxYAxisTickLength\"\n [animations]=\"animations\"\n [roundDomains]=\"roundDomains\"\n [roundEdges]=\"roundEdges\"\n [barPadding]=\"barPadding\"\n [yScaleMax]=\"scaleMax\"\n (select)=\"onSelect($event)\"\n >\n </ngx-charts-bar-vertical-2d>\n <ion-fab-button\n id=\"exportFabButton\"\n size=\"small\"\n tapExportData\n *ngIf=\"showExportButton\"\n [dataToExport]=\"createExportedData.bind(this)\"\n [exportedFileName]=\"exportedFileName\"\n >\n <ion-icon name=\"download\"></ion-icon>\n </ion-fab-button>\n </div>\n</div>\n", styles: ["::ng-deep .horizontal-legend{overflow:auto!important}.belowLegend{max-height:50vh;width:100%;min-width:100%;margin-bottom:60px}.rightLegend{max-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}}.verticalContainer{overflow-y:hidden;overflow-x:auto;max-height:60vh}.horizontalContainer{overflow-x:hidden;overflow-y:auto;max-height:60vh}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i3.BarHorizontal2DComponent, selector: "ngx-charts-bar-horizontal-2d", inputs: ["legend", "legendTitle", "legendPosition", "xAxis", "yAxis", "showXAxisLabel", "showYAxisLabel", "xAxisLabel", "yAxisLabel", "tooltipDisabled", "gradient", "showGridLines", "activeEntries", "schemeType", "trimXAxisTicks", "trimYAxisTicks", "rotateXAxisTicks", "maxXAxisTickLength", "maxYAxisTickLength", "xAxisTickFormatting", "yAxisTickFormatting", "xAxisTicks", "yAxisTicks", "groupPadding", "barPadding", "roundDomains", "roundEdges", "xScaleMax", "showDataLabel", "dataLabelFormatting", "noBarWhenZero", "wrapTicks"], outputs: ["activate", "deactivate"] }, { kind: "component", type: i3.BarVertical2DComponent, selector: "ngx-charts-bar-vertical-2d", inputs: ["legend", "legendTitle", "legendPosition", "xAxis", "yAxis", "showXAxisLabel", "showYAxisLabel", "xAxisLabel", "yAxisLabel", "tooltipDisabled", "scaleType", "gradient", "showGridLines", "activeEntries", "schemeType", "trimXAxisTicks", "trimYAxisTicks", "rotateXAxisTicks", "maxXAxisTickLength", "maxYAxisTickLength", "xAxisTickFormatting", "yAxisTickFormatting", "xAxisTicks", "yAxisTicks", "groupPadding", "barPadding", "roundDomains", "roundEdges", "yScaleMax", "showDataLabel", "dataLabelFormatting", "noBarWhenZero", "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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }; TapVariableBarChartGroupComponent = __decorate([ MonitoringAppGenComponent({}), __metadata("design:paramtypes", [ElementRef, NgZone, ChangeDetectorRef, String, ModalController]) ], TapVariableBarChartGroupComponent); export { TapVariableBarChartGroupComponent }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TapVariableBarChartGroupComponent, decorators: [{ type: Component, args: [{ selector: 'tap-variable-bar-chart-group', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n [ngClass]=\"\n scrollableChart\n ? orientation === 'vertical'\n ? 'verticalContainer'\n : 'horizontalContainer'\n : {}\n \"\n>\n <div\n #containerRef\n [ngClass]=\"\n legendPosition === 'below' && legend ? 'belowLegend' : 'rightLegend'\n \"\n [ngSwitch]=\"orientation\"\n style=\"position: relative\"\n >\n <ngx-charts-bar-horizontal-2d\n *ngSwitchCase=\"'horizontal'\"\n #barChartHor\n [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n [scheme]=\"colorScheme\"\n [results]=\"results\"\n [legend]=\"legend\"\n [legendTitle]=\"legendTitle\"\n [legendPosition]=\"legendPosition\"\n [noBarWhenZero]=\"noBarWhenZero\"\n [xAxis]=\"xAxis\"\n [showYAxisLabel]=\"showYAxisLabel\"\n [yAxisLabel]=\"yAxisLabel\"\n [yAxis]=\"yAxis\"\n [showXAxisLabel]=\"showXAxisLabel\"\n [xAxisLabel]=\"xAxisLabel\"\n [showGridLines]=\"showGridLines\"\n [trimXAxisTicks]=\"trimXAxisTicks\"\n [maxXAxisTickLength]=\"maxXAxisTickLength\"\n [trimYAxisTicks]=\"trimYAxisTicks\"\n [maxYAxisTickLength]=\"maxYAxisTickLength\"\n [animations]=\"animations\"\n [roundDomains]=\"roundDomains\"\n [roundEdges]=\"roundEdges\"\n [barPadding]=\"barPadding\"\n [xScaleMax]=\"scaleMax\"\n (select)=\"onSelect($event)\"\n >\n </ngx-charts-bar-horizontal-2d>\n <ngx-charts-bar-vertical-2d\n *ngSwitchCase=\"'vertical'\"\n #barChartVer\n [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n [scheme]=\"colorScheme\"\n [results]=\"results\"\n [roundEdges]=\"roundEdges\"\n [legend]=\"legend\"\n [legendTitle]=\"legendTitle\"\n [legendPosition]=\"legendPosition\"\n [noBarWhenZero]=\"noBarWhenZero\"\n [xAxis]=\"xAxis\"\n [showYAxisLabel]=\"showYAxisLabel\"\n [yAxisLabel]=\"yAxisLabel\"\n [yAxis]=\"yAxis\"\n [showXAxisLabel]=\"showXAxisLabel\"\n [xAxisLabel]=\"xAxisLabel\"\n [showGridLines]=\"showGridLines\"\n [trimXAxisTicks]=\"trimXAxisTicks\"\n [maxXAxisTickLength]=\"maxXAxisTickLength\"\n [trimYAxisTicks]=\"trimYAxisTicks\"\n [maxYAxisTickLength]=\"maxYAxisTickLength\"\n [animations]=\"animations\"\n [roundDomains]=\"roundDomains\"\n [roundEdges]=\"roundEdges\"\n [barPadding]=\"barPadding\"\n [yScaleMax]=\"scaleMax\"\n (select)=\"onSelect($event)\"\n >\n </ngx-charts-bar-vertical-2d>\n <ion-fab-button\n id=\"exportFabButton\"\n size=\"small\"\n tapExportData\n *ngIf=\"showExportButton\"\n [dataToExport]=\"createExportedData.bind(this)\"\n [exportedFileName]=\"exportedFileName\"\n >\n <ion-icon name=\"download\"></ion-icon>\n </ion-fab-button>\n </div>\n</div>\n", styles: ["::ng-deep .horizontal-legend{overflow:auto!important}.belowLegend{max-height:50vh;width:100%;min-width:100%;margin-bottom:60px}.rightLegend{max-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}}.verticalContainer{overflow-y:hidden;overflow-x:auto;max-height:60vh}.horizontalContainer{overflow-x:hidden;overflow-y:auto;max-height:60vh}\n"] }] }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{ type: Inject, args: [PLATFORM_ID] }] }, { type: i1.ModalController }], propDecorators: { divContainer: [{ type: ViewChild, args: ['containerRef'] }], barChartHor: [{ type: ViewChild, args: ['barChartHor'] }], barChartVer: [{ type: ViewChild, args: ['barChartVer'] }], legendPosition: [{ type: Input }], showExportButton: [{ type: Input }], exportedFileName: [{ type: Input }], legend: [{ type: Input }], legendTitle: [{ type: Input }], colorScheme: [{ type: Input }], orientation: [{ type: Input }], showDetails: [{ type: Input }], noBarWhenZero: [{ type: Input }], trimXAxisTicks: [{ type: Input }], maxXAxisTickLength: [{ type: Input }], trimYAxisTicks: [{ type: Input }], maxYAxisTickLength: [{ type: Input }], animations: [{ type: Input }], roundDomains: [{ type: Input }], roundEdges: [{ type: Input }], barPadding: [{ type: Input }], showYAxisLabel: [{ type: Input }], yAxisLabel: [{ type: Input }], showXAxisLabel: [{ type: Input }], xAxisLabel: [{ type: Input }], showGridLines: [{ type: Input }], scaleMax: [{ type: Input }], showXAxis: [{ type: Input }], xAxis: [{ type: Input }], showYAxis: [{ type: Input }], yAxis: [{ type: Input }], history: [{ type: Input }], valueCountLimit: [{ type: Input }], label: [{ type: Input }], variable: [{ type: Input }], input: [{ type: Input }], data: [{ type: Input }], scrollableChart: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tap-variable-bar-chart-group.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-bar-chart-group/tap-variable-bar-chart-group.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-bar-chart-group/tap-variable-bar-chart-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewChecked,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  PLATFORM_ID,\n  ViewChild,\n} from '@angular/core';\nimport { ModalController } from '@ionic/angular';\nimport { AbstractVariable } from '@iotize/tap/data';\nimport {\n  BarHorizontal2DComponent,\n  BarVertical2DComponent,\n  BaseChartComponent,\n  LegendPosition,\n} 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';\nimport { TapVariableDataPopupComponent } from '../tap-variable-data-popup/tap-variable-data-popup.component';\n\n@MonitoringAppGenComponent({})\n@Component({\n  selector: 'tap-variable-bar-chart-group',\n  templateUrl: './tap-variable-bar-chart-group.component.html',\n  styleUrls: ['./tap-variable-bar-chart-group.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TapVariableBarChartGroupComponent\n  extends BaseChartComponent\n  implements AfterViewChecked, OnDestroy\n{\n  @ViewChild('containerRef') divContainer!: ElementRef;\n  @ViewChild('barChartHor') barChartHor!: BarHorizontal2DComponent;\n  @ViewChild('barChartVer') barChartVer!: BarVertical2DComponent;\n\n  constructor(\n    myChartElement: ElementRef<any>,\n    zone: NgZone,\n    cd: ChangeDetectorRef,\n    @Inject(PLATFORM_ID) platformId: string,\n    public modalController: ModalController\n  ) {\n    super(myChartElement, zone, cd, platformId);\n  }\n\n  @Input()\n  legendPosition: LegendPosition = LegendPosition.Below;\n\n  @Input()\n  showExportButton: boolean = false;\n\n  @Input()\n  exportedFileName?: string;\n\n  @Input()\n  legend: boolean = true;\n\n  @Input()\n  legendTitle?: string;\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  @Input()\n  orientation: string = 'vertical';\n\n  @Input()\n  showDetails: boolean = false;\n\n  @Input() noBarWhenZero: boolean = false;\n\n  @Input() trimXAxisTicks?: boolean;\n\n  @Input() maxXAxisTickLength?: boolean;\n\n  @Input() trimYAxisTicks?: boolean;\n\n  @Input() maxYAxisTickLength?: boolean;\n\n  @Input() animations: boolean = true;\n\n  @Input() roundDomains?: boolean;\n\n  @Input() roundEdges = true;\n\n  @Input() barPadding?: number;\n\n  @Input() showYAxisLabel?: boolean;\n\n  @Input() yAxisLabel?: string;\n\n  @Input() showXAxisLabel?: boolean;\n\n  @Input() xAxisLabel?: string;\n\n  @Input() showGridLines?: boolean;\n\n  @Input() scaleMax?: number;\n\n  /**\n   * @deprecated use xAxis\n   */\n  @Input()\n  set showXAxis(v: boolean) {\n    this.xAxis = v;\n  }\n\n  @Input()\n  xAxis: boolean = true;\n\n  /**\n   * @deprecated use yAxis\n   */\n  @Input()\n  set showYAxis(v: boolean) {\n    this.yAxis = v;\n  }\n\n  @Input()\n  yAxis: boolean = true;\n\n  @Input()\n  history: boolean = false;\n\n  @Input()\n  valueCountLimit = 10;\n\n  @Input()\n  set label(indexOrArray: string | string[] | undefined | Function) {\n    this.chartModel.initLabel(indexOrArray);\n  }\n\n  @Input()\n  set variable(variableOrArray: AbstractVariable<number | number[]>[]) {\n    this.mutlipleVar = variableOrArray.length > 1;\n    this.input = this.chartModel.initVariable(variableOrArray);\n  }\n\n  @Input()\n  set input(inputs: ChartInputStreamVar[]) {\n    if (this.mutlipleVar) {\n      this.subscription = this.chartModel\n        .defineMultiInputStream(inputs)\n        .subscribe((result) => {\n          if (this.scrollableChart) {\n            this.resizeToScroll(result.length, result[0].series.length);\n          }\n          this.results = result;\n        });\n    } else {\n      this.subscription = this.chartModel\n        .defineInputStreamMulti(inputs, this.history, this.valueCountLimit)\n        .subscribe((result) => {\n          if (this.scrollableChart) {\n            this.resizeToScroll(result.length, result[0].series.length);\n          }\n          this.results = result;\n        });\n    }\n    this.cd.detectChanges();\n  }\n\n  @Input() set data(results: ChartInputMutli[]) {\n    this.results = results;\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  @Input() scrollableChart = false;\n\n  widthChart?: number;\n  heightChart?: number;\n\n  private chartModel: ChartDataModel = new ChartDataModel();\n\n  private subscription?: Subscription;\n\n  private mutlipleVar?: boolean;\n\n  createExportedData() {\n    return dataWithSeriesToCsv(this.results);\n  }\n\n  onSelect(event: OnChartSelectEvent) {\n    if (typeof event === 'object') {\n      if (this.showDetails) {\n        this.chartModel\n          .showDetail(\n            event,\n            this.modalController,\n            TapVariableDataPopupComponent\n          )\n          .catch((err) => {\n            console.log(err);\n          });\n      }\n    }\n  }\n\n  ngAfterViewChecked(): void {\n    if (!this.scrollableChart) {\n      this.widthChart = this.divContainer.nativeElement.offsetWidth;\n      this.heightChart = this.divContainer.nativeElement.offsetHeight;\n    }\n    this.cd.detectChanges();\n  }\n\n  resizeToScroll(size: number, seriesSize: number) {\n    if (this.orientation === 'vertical') {\n      if (\n        this.divContainer.nativeElement.offsetWidth <=\n        size * 50 * seriesSize\n      ) {\n        this.barChartVer.view = [\n          size * 50 * seriesSize,\n          this.divContainer.nativeElement.offsetHeight,\n        ];\n      }\n    } else if (this.orientation === 'horizontal') {\n      if (\n        this.divContainer.nativeElement.offsetHeight <=\n        size * 50 * seriesSize\n      ) {\n        this.barChartHor.view = [\n          this.divContainer.nativeElement.offsetWidth,\n          size * 50 * seriesSize,\n        ];\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subscription?.unsubscribe();\n    this.chartModel.destroyCurrentSub();\n  }\n}\n","<div\n  [ngClass]=\"\n    scrollableChart\n      ? orientation === 'vertical'\n        ? 'verticalContainer'\n        : 'horizontalContainer'\n      : {}\n  \"\n>\n  <div\n    #containerRef\n    [ngClass]=\"\n      legendPosition === 'below' && legend ? 'belowLegend' : 'rightLegend'\n    \"\n    [ngSwitch]=\"orientation\"\n    style=\"position: relative\"\n  >\n    <ngx-charts-bar-horizontal-2d\n      *ngSwitchCase=\"'horizontal'\"\n      #barChartHor\n      [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n      [scheme]=\"colorScheme\"\n      [results]=\"results\"\n      [legend]=\"legend\"\n      [legendTitle]=\"legendTitle\"\n      [legendPosition]=\"legendPosition\"\n      [noBarWhenZero]=\"noBarWhenZero\"\n      [xAxis]=\"xAxis\"\n      [showYAxisLabel]=\"showYAxisLabel\"\n      [yAxisLabel]=\"yAxisLabel\"\n      [yAxis]=\"yAxis\"\n      [showXAxisLabel]=\"showXAxisLabel\"\n      [xAxisLabel]=\"xAxisLabel\"\n      [showGridLines]=\"showGridLines\"\n      [trimXAxisTicks]=\"trimXAxisTicks\"\n      [maxXAxisTickLength]=\"maxXAxisTickLength\"\n      [trimYAxisTicks]=\"trimYAxisTicks\"\n      [maxYAxisTickLength]=\"maxYAxisTickLength\"\n      [animations]=\"animations\"\n      [roundDomains]=\"roundDomains\"\n      [roundEdges]=\"roundEdges\"\n      [barPadding]=\"barPadding\"\n      [xScaleMax]=\"scaleMax\"\n      (select)=\"onSelect($event)\"\n    >\n    </ngx-charts-bar-horizontal-2d>\n    <ngx-charts-bar-vertical-2d\n      *ngSwitchCase=\"'vertical'\"\n      #barChartVer\n      [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n      [scheme]=\"colorScheme\"\n      [results]=\"results\"\n      [roundEdges]=\"roundEdges\"\n      [legend]=\"legend\"\n      [legendTitle]=\"legendTitle\"\n      [legendPosition]=\"legendPosition\"\n      [noBarWhenZero]=\"noBarWhenZero\"\n      [xAxis]=\"xAxis\"\n      [showYAxisLabel]=\"showYAxisLabel\"\n      [yAxisLabel]=\"yAxisLabel\"\n      [yAxis]=\"yAxis\"\n      [showXAxisLabel]=\"showXAxisLabel\"\n      [xAxisLabel]=\"xAxisLabel\"\n      [showGridLines]=\"showGridLines\"\n      [trimXAxisTicks]=\"trimXAxisTicks\"\n      [maxXAxisTickLength]=\"maxXAxisTickLength\"\n      [trimYAxisTicks]=\"trimYAxisTicks\"\n      [maxYAxisTickLength]=\"maxYAxisTickLength\"\n      [animations]=\"animations\"\n      [roundDomains]=\"roundDomains\"\n      [roundEdges]=\"roundEdges\"\n      [barPadding]=\"barPadding\"\n      [yScaleMax]=\"scaleMax\"\n      (select)=\"onSelect($event)\"\n    >\n    </ngx-charts-bar-vertical-2d>\n    <ion-fab-button\n      id=\"exportFabButton\"\n      size=\"small\"\n      tapExportData\n      *ngIf=\"showExportButton\"\n      [dataToExport]=\"createExportedData.bind(this)\"\n      [exportedFileName]=\"exportedFileName\"\n    >\n      <ion-icon name=\"download\"></ion-icon>\n    </ion-fab-button>\n  </div>\n</div>\n"]}