@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
261 lines • 42.4 kB
JavaScript
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 { BarHorizontalComponent, BarVerticalComponent, BaseChartComponent, LegendPosition, } from '@swimlane/ngx-charts';
import { BehaviorSubject, Subject, combineLatest } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { MonitoringAppGenComponent } from '../../metadata/decorators';
import { ChartDataModel, } from '../ChartDataModel';
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 TapVariableBarChartComponent = class TapVariableBarChartComponent extends BaseChartComponent {
/**
* @deprecated use xAxis
*/
set showXAxis(v) {
this.xAxis = v;
}
/**
* @deprecated use yAxis
*/
set showYAxis(v) {
this.yAxis = v;
}
set variable(variableOrArray) {
this.input = this.chartModel.initVariable(variableOrArray);
}
set history(enable) {
this._history.next(enable);
}
set valueCountLimit(limit) {
if (limit === undefined) {
limit = 30;
}
this._valueCountLimit.next(limit);
}
set input(inputs) {
this._input.next(inputs);
}
set data(results) {
this.results = results;
}
set label(indexOrArray) {
this.chartModel.initLabel(indexOrArray);
}
constructor(myChartElement, zone, cd, platformId, modalController) {
super(myChartElement, zone, cd, platformId);
this.cd = cd;
this.modalController = modalController;
this.results = [];
this.orientation = 'vertical';
this.legend = false;
this.legendPosition = LegendPosition.Below;
this.showGridLines = false;
this.showDetails = false;
this.xAxis = true;
this.showXAxisLabel = false;
this.xAxisLabel = '';
this.yAxis = true;
this.showYAxisLabel = false;
this.yAxisLabel = '';
this.animations = true;
this.roundEdges = true;
this.noBarWhenZero = false;
this.showExportButton = false;
this.xAxisTickFormatting = this.defaultDateTickFormatting.bind(this);
this.scrollableChart = false;
this.colorScheme = {
domain: [
'#5DADE2',
'#9B59B6',
'#f69b05',
'#5AA454',
'#A10A28',
'#C7B42C',
'#AAAAAA',
],
};
this._history = new BehaviorSubject(true);
this._valueCountLimit = new BehaviorSubject(30);
this._input = new BehaviorSubject([]);
this.destroyed = new Subject();
this.chartModel = new ChartDataModel();
}
ngOnInit() {
combineLatest([this._valueCountLimit, this._input, this._history])
.pipe(takeUntil(this.destroyed))
.subscribe(([valueCountLimit, input, history]) => {
this.chartModel.destroyCurrentSub();
if (history) {
this.oldColorScheme = this.colorScheme;
this.colorScheme = { domain: [this.colorScheme.domain[0]] };
}
else {
if (this.oldColorScheme !== undefined) {
this.colorScheme = this.oldColorScheme;
}
}
this.subscription = this.chartModel
.defineInputStreamSingle(input, history, valueCountLimit)
.subscribe((result) => {
if (this.scrollableChart) {
this.resizeToScroll(result.length);
}
this.results = result;
});
this.cd.detectChanges();
});
}
ngAfterContentChecked() {
this.cd.detectChanges();
if (!this.scrollableChart) {
this.widthChart = this.divContainer.nativeElement.offsetWidth;
this.heightChart = this.divContainer.nativeElement.offsetHeight;
}
}
resizeToScroll(size) {
if (this.orientation === 'vertical') {
if (this.divContainer.nativeElement.offsetWidth <= size * 100) {
this.barChartVer.view = [
size * 100,
this.divContainer.nativeElement.offsetHeight,
];
}
}
else if (this.orientation === 'horizontal') {
if (this.divContainer.nativeElement.offsetHeight <= size * 100) {
this.barChartHor.view = [
this.divContainer.nativeElement.offsetWidth,
size * 100,
];
}
}
}
onSelect(event) {
if (typeof event === 'object') {
if (this.showDetails) {
this.chartModel
.showDetail(event, this.modalController, TapVariableDataPopupComponent)
.catch((err) => {
console.log(err);
});
}
}
}
defaultDateTickFormatting(val) {
if (val.time) {
return new Date(val.time).toLocaleDateString();
}
return val;
}
ngOnDestroy() {
this.subscription?.unsubscribe();
this.chartModel.destroyCurrentSub();
}
};
/** @nocollapse */ TapVariableBarChartComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TapVariableBarChartComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }, { token: PLATFORM_ID }, { token: i1.ModalController }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ TapVariableBarChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TapVariableBarChartComponent, selector: "tap-variable-bar-chart", inputs: { orientation: "orientation", legend: "legend", legendTitle: "legendTitle", legendPosition: "legendPosition", showGridLines: "showGridLines", showDetails: "showDetails", showXAxis: "showXAxis", xAxis: "xAxis", showXAxisLabel: "showXAxisLabel", xAxisLabel: "xAxisLabel", showYAxis: "showYAxis", yAxis: "yAxis", showYAxisLabel: "showYAxisLabel", yAxisLabel: "yAxisLabel", trimXAxisTicks: "trimXAxisTicks", maxXAxisTickLength: "maxXAxisTickLength", trimYAxisTicks: "trimYAxisTicks", maxYAxisTickLength: "maxYAxisTickLength", animations: "animations", roundDomains: "roundDomains", roundEdges: "roundEdges", barPadding: "barPadding", noBarWhenZero: "noBarWhenZero", showExportButton: "showExportButton", exportedFileName: "exportedFileName", variable: "variable", xAxisTickFormatting: "xAxisTickFormatting", history: "history", valueCountLimit: "valueCountLimit", input: "input", data: "data", scrollableChart: "scrollableChart", scaleMax: "scaleMax", scaleMin: "scaleMin", label: "label", colorScheme: "colorScheme" }, viewQueries: [{ propertyName: "divContainer", first: true, predicate: ["containerRef"], descendants: true }, { propertyName: "barChartHor", first: true, predicate: ["chartsHor"], descendants: true }, { propertyName: "barChartVer", first: true, predicate: ["chartsVer"], 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\n *ngSwitchCase=\"'horizontal'\"\n #chartsHor\n [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n [scheme]=\"colorScheme\"\n [results]=\"results\"\n [roundEdges]=\"roundEdges\"\n [showXAxisLabel]=\"showXAxisLabel\"\n [showYAxisLabel]=\"showYAxisLabel\"\n [xAxis]=\"xAxis\"\n [yAxisLabel]=\"yAxisLabel\"\n [yAxis]=\"yAxis\"\n [xAxisLabel]=\"xAxisLabel\"\n [legend]=\"legend\"\n [legendTitle]=\"legendTitle\"\n [legendPosition]=\"legendPosition\"\n [noBarWhenZero]=\"noBarWhenZero\"\n [xAxisTickFormatting]=\"xAxisTickFormatting\"\n [xScaleMax]=\"scaleMax\"\n [xScaleMin]=\"scaleMin\"\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 (select)=\"onSelect($event)\"\n >\n </ngx-charts-bar-horizontal>\n <ngx-charts-bar-vertical\n *ngSwitchCase=\"'vertical'\"\n #chartsVer\n [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n [noBarWhenZero]=\"noBarWhenZero\"\n [scheme]=\"colorScheme\"\n [results]=\"results\"\n [showXAxisLabel]=\"showXAxisLabel\"\n [showYAxisLabel]=\"showYAxisLabel\"\n [yAxisLabel]=\"yAxisLabel\"\n [xAxisLabel]=\"xAxisLabel\"\n [legend]=\"legend\"\n [legendTitle]=\"legendTitle\"\n [legendPosition]=\"legendPosition\"\n [xAxis]=\"xAxis\"\n [yAxis]=\"yAxis\"\n [yAxisTickFormatting]=\"xAxisTickFormatting\"\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 [yScaleMin]=\"scaleMin\"\n (select)=\"onSelect($event)\"\n >\n </ngx-charts-bar-vertical>\n <ion-fab-button\n id=\"exportFabButton\"\n size=\"small\"\n tapExportData\n [dataToExport]=\"results\"\n *ngIf=\"showExportButton\"\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;min-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.BarHorizontalComponent, selector: "ngx-charts-bar-horizontal", inputs: ["legend", "legendTitle", "legendPosition", "xAxis", "yAxis", "showXAxisLabel", "showYAxisLabel", "xAxisLabel", "yAxisLabel", "tooltipDisabled", "gradient", "showGridLines", "activeEntries", "schemeType", "trimXAxisTicks", "trimYAxisTicks", "rotateXAxisTicks", "maxXAxisTickLength", "maxYAxisTickLength", "xAxisTickFormatting", "yAxisTickFormatting", "xAxisTicks", "yAxisTicks", "barPadding", "roundDomains", "roundEdges", "xScaleMax", "xScaleMin", "showDataLabel", "dataLabelFormatting", "noBarWhenZero", "wrapTicks"], outputs: ["activate", "deactivate"] }, { kind: "component", type: i3.BarVerticalComponent, selector: "ngx-charts-bar-vertical", inputs: ["legend", "legendTitle", "legendPosition", "xAxis", "yAxis", "showXAxisLabel", "showYAxisLabel", "xAxisLabel", "yAxisLabel", "tooltipDisabled", "gradient", "showGridLines", "activeEntries", "schemeType", "trimXAxisTicks", "trimYAxisTicks", "rotateXAxisTicks", "maxXAxisTickLength", "maxYAxisTickLength", "xAxisTickFormatting", "yAxisTickFormatting", "xAxisTicks", "yAxisTicks", "barPadding", "roundDomains", "roundEdges", "yScaleMax", "yScaleMin", "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 });
TapVariableBarChartComponent = __decorate([
MonitoringAppGenComponent({
constraints: {
isNumber: 'YES',
},
}),
__metadata("design:paramtypes", [ElementRef,
NgZone,
ChangeDetectorRef, String, ModalController])
], TapVariableBarChartComponent);
export { TapVariableBarChartComponent };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TapVariableBarChartComponent, decorators: [{
type: Component,
args: [{ selector: 'tap-variable-bar-chart', 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\n *ngSwitchCase=\"'horizontal'\"\n #chartsHor\n [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n [scheme]=\"colorScheme\"\n [results]=\"results\"\n [roundEdges]=\"roundEdges\"\n [showXAxisLabel]=\"showXAxisLabel\"\n [showYAxisLabel]=\"showYAxisLabel\"\n [xAxis]=\"xAxis\"\n [yAxisLabel]=\"yAxisLabel\"\n [yAxis]=\"yAxis\"\n [xAxisLabel]=\"xAxisLabel\"\n [legend]=\"legend\"\n [legendTitle]=\"legendTitle\"\n [legendPosition]=\"legendPosition\"\n [noBarWhenZero]=\"noBarWhenZero\"\n [xAxisTickFormatting]=\"xAxisTickFormatting\"\n [xScaleMax]=\"scaleMax\"\n [xScaleMin]=\"scaleMin\"\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 (select)=\"onSelect($event)\"\n >\n </ngx-charts-bar-horizontal>\n <ngx-charts-bar-vertical\n *ngSwitchCase=\"'vertical'\"\n #chartsVer\n [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n [noBarWhenZero]=\"noBarWhenZero\"\n [scheme]=\"colorScheme\"\n [results]=\"results\"\n [showXAxisLabel]=\"showXAxisLabel\"\n [showYAxisLabel]=\"showYAxisLabel\"\n [yAxisLabel]=\"yAxisLabel\"\n [xAxisLabel]=\"xAxisLabel\"\n [legend]=\"legend\"\n [legendTitle]=\"legendTitle\"\n [legendPosition]=\"legendPosition\"\n [xAxis]=\"xAxis\"\n [yAxis]=\"yAxis\"\n [yAxisTickFormatting]=\"xAxisTickFormatting\"\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 [yScaleMin]=\"scaleMin\"\n (select)=\"onSelect($event)\"\n >\n </ngx-charts-bar-vertical>\n <ion-fab-button\n id=\"exportFabButton\"\n size=\"small\"\n tapExportData\n [dataToExport]=\"results\"\n *ngIf=\"showExportButton\"\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;min-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: function () { return [{ 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: ['chartsHor']
}], barChartVer: [{
type: ViewChild,
args: ['chartsVer']
}], orientation: [{
type: Input
}], legend: [{
type: Input
}], legendTitle: [{
type: Input
}], legendPosition: [{
type: Input
}], showGridLines: [{
type: Input
}], showDetails: [{
type: Input
}], showXAxis: [{
type: Input
}], xAxis: [{
type: Input
}], showXAxisLabel: [{
type: Input
}], xAxisLabel: [{
type: Input
}], showYAxis: [{
type: Input
}], yAxis: [{
type: Input
}], showYAxisLabel: [{
type: Input
}], yAxisLabel: [{
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
}], noBarWhenZero: [{
type: Input
}], showExportButton: [{
type: Input
}], exportedFileName: [{
type: Input
}], variable: [{
type: Input
}], xAxisTickFormatting: [{
type: Input
}], history: [{
type: Input
}], valueCountLimit: [{
type: Input
}], input: [{
type: Input
}], data: [{
type: Input
}], scrollableChart: [{
type: Input
}], scaleMax: [{
type: Input
}], scaleMin: [{
type: Input
}], label: [{
type: Input
}], colorScheme: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tap-variable-bar-chart.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-bar-chart/tap-variable-bar-chart.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-bar-chart/tap-variable-bar-chart.component.html"],"names":[],"mappings":";AAAA,OAAO,EAEL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,MAAM,EACN,KAAK,EACL,MAAM,EAGN,WAAW,EACX,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAEjD,OAAO,EACL,sBAAsB,EACtB,oBAAoB,EACpB,kBAAkB,EAClB,cAAc,GACf,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,eAAe,EAAE,OAAO,EAAgB,aAAa,EAAE,MAAM,MAAM,CAAC;AAC7E,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,yBAAyB,EAAE,MAAM,2BAA2B,CAAC;AACtE,OAAO,EACL,cAAc,GAGf,MAAM,mBAAmB,CAAC;AAE3B,OAAO,EAAE,6BAA6B,EAAE,MAAM,8DAA8D,CAAC;;;;;;AAatG,IAAM,4BAA4B,GAAlC,MAAM,4BACX,SAAQ,kBAAkB;IA2B1B;;OAEG;IACH,IACI,SAAS,CAAC,CAAU;QACtB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;IACjB,CAAC;IAWD;;OAEG;IACH,IACI,SAAS,CAAC,CAAU;QACtB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;IACjB,CAAC;IAoCD,IACI,QAAQ,CACV,eAAgE;QAEhE,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,eAAe,CAAC,CAAC;IAC7D,CAAC;IAKD,IACI,OAAO,CAAC,MAAe;QACzB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC7B,CAAC;IAED,IACI,eAAe,CAAC,KAAyB;QAC3C,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,KAAK,GAAG,EAAE,CAAC;SACZ;QACD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAED,IACI,KAAK,CAAC,MAA6B;QACrC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC3B,CAAC;IAED,IAAa,IAAI,CAAC,OAA2B;QAC3C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAUD,IACI,KAAK,CAAC,YAAsD;QAC9D,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;IAC1C,CAAC;IAgCD,YACE,cAA0B,EAC1B,IAAY,EACL,EAAqB,EACP,UAAkB,EAC/B,eAAgC;QAExC,KAAK,CAAC,cAAc,EAAE,IAAI,EAAE,EAAE,EAAE,UAAU,CAAC,CAAC;QAJrC,OAAE,GAAF,EAAE,CAAmB;QAEpB,oBAAe,GAAf,eAAe,CAAiB;QA/J1C,YAAO,GAAuB,EAAE,CAAC;QAGjC,gBAAW,GAAG,UAAU,CAAC;QAGzB,WAAM,GAAY,KAAK,CAAC;QAMxB,mBAAc,GAAmB,cAAc,CAAC,KAAK,CAAC;QAGtD,kBAAa,GAAG,KAAK,CAAC;QAGtB,gBAAW,GAAG,KAAK,CAAC;QAWpB,UAAK,GAAY,IAAI,CAAC;QAGtB,mBAAc,GAAY,KAAK,CAAC;QAGhC,eAAU,GAAG,EAAE,CAAC;QAWhB,UAAK,GAAY,IAAI,CAAC;QAGtB,mBAAc,GAAY,KAAK,CAAC;QAGhC,eAAU,GAAG,EAAE,CAAC;QAUP,eAAU,GAAY,IAAI,CAAC;QAI3B,eAAU,GAAG,IAAI,CAAC;QAK3B,kBAAa,GAAG,KAAK,CAAC;QAGtB,qBAAgB,GAAY,KAAK,CAAC;QAYzB,wBAAmB,GAC1B,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAwBnC,oBAAe,GAAG,KAAK,CAAC;QAcjC,gBAAW,GAAG;YACZ,MAAM,EAAE;gBACN,SAAS;gBACT,SAAS;gBACT,SAAS;gBACT,SAAS;gBACT,SAAS;gBACT,SAAS;gBACT,SAAS;aACV;SACF,CAAC;QAEM,aAAQ,GAAG,IAAI,eAAe,CAAU,IAAI,CAAC,CAAC;QAE9C,qBAAgB,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;QAEnD,WAAM,GAAG,IAAI,eAAe,CAAwB,EAAE,CAAC,CAAC;QAIxD,cAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;QAMhC,eAAU,GAAmB,IAAI,cAAc,EAAE,CAAC;IAW1D,CAAC;IAED,QAAQ;QACN,aAAa,CAAC,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC/D,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,CAAC,CAAC,eAAe,EAAE,KAAK,EAAE,OAAO,CAAC,EAAE,EAAE;YAC/C,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE,CAAC;YACpC,IAAI,OAAO,EAAE;gBACX,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC;gBACvC,IAAI,CAAC,WAAW,GAAG,EAAE,MAAM,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;aAC7D;iBAAM;gBACL,IAAI,IAAI,CAAC,cAAc,KAAK,SAAS,EAAE;oBACrC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC;iBACxC;aACF;YACD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU;iBAChC,uBAAuB,CAAC,KAAK,EAAE,OAAO,EAAE,eAAe,CAAC;iBACxD,SAAS,CAAC,CAAC,MAA0B,EAAE,EAAE;gBACxC,IAAI,IAAI,CAAC,eAAe,EAAE;oBACxB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;iBACpC;gBACD,IAAI,CAAC,OAAO,GAAG,MAA4B,CAAC;YAC9C,CAAC,CAAC,CAAC;YACL,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,qBAAqB;QACnB,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YACzB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,WAAW,CAAC;YAC9D,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,YAAY,CAAC;SACjE;IACH,CAAC;IAED,cAAc,CAAC,IAAY;QACzB,IAAI,IAAI,CAAC,WAAW,KAAK,UAAU,EAAE;YACnC,IAAI,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,WAAW,IAAI,IAAI,GAAG,GAAG,EAAE;gBAC7D,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG;oBACtB,IAAI,GAAG,GAAG;oBACV,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,YAAY;iBAC7C,CAAC;aACH;SACF;aAAM,IAAI,IAAI,CAAC,WAAW,KAAK,YAAY,EAAE;YAC5C,IAAI,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,YAAY,IAAI,IAAI,GAAG,GAAG,EAAE;gBAC9D,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG;oBACtB,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,WAAW;oBAC3C,IAAI,GAAG,GAAG;iBACX,CAAC;aACH;SACF;IACH,CAAC;IAED,QAAQ,CAAC,KAAyB;QAChC,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC7B,IAAI,IAAI,CAAC,WAAW,EAAE;gBACpB,IAAI,CAAC,UAAU;qBACZ,UAAU,CACT,KAAK,EACL,IAAI,CAAC,eAAe,EACpB,6BAA6B,CAC9B;qBACA,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;oBACb,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;gBACnB,CAAC,CAAC,CAAC;aACN;SACF;IACH,CAAC;IAED,yBAAyB,CAAC,GAAQ;QAChC,IAAI,GAAG,CAAC,IAAI,EAAE;YACZ,OAAO,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,kBAAkB,EAAE,CAAC;SAChD;QACD,OAAO,GAAG,CAAC;IACb,CAAC;IAED,WAAW;QACT,IAAI,CAAC,YAAY,EAAE,WAAW,EAAE,CAAC;QACjC,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE,CAAC;IACtC,CAAC;;6IAzPU,4BAA4B,mGAsK7B,WAAW;iIAtKV,4BAA4B,y3CC5CzC,w6FA4FA;ADhDa,4BAA4B;IAXxC,yBAAyB,CAAC;QACzB,WAAW,EAAE;YACX,QAAQ,EAAE,KAAK;SAChB;KACF,CAAC;qCA0KkB,UAAU;QACpB,MAAM;QACD,iBAAiB,UAEH,eAAe;GAvK/B,4BAA4B,CA0PxC;SA1PY,4BAA4B;4FAA5B,4BAA4B;kBANxC,SAAS;+BACE,wBAAwB,mBAGjB,uBAAuB,CAAC,MAAM;;0BAwK5C,MAAM;2BAAC,WAAW;0EAlKM,YAAY;sBAAtC,SAAS;uBAAC,cAAc;gBACD,WAAW;sBAAlC,SAAS;uBAAC,WAAW;gBACE,WAAW;sBAAlC,SAAS;uBAAC,WAAW;gBAKtB,WAAW;sBADV,KAAK;gBAIN,MAAM;sBADL,KAAK;gBAIN,WAAW;sBADV,KAAK;gBAIN,cAAc;sBADb,KAAK;gBAIN,aAAa;sBADZ,KAAK;gBAIN,WAAW;sBADV,KAAK;gBAOF,SAAS;sBADZ,KAAK;gBAMN,KAAK;sBADJ,KAAK;gBAIN,cAAc;sBADb,KAAK;gBAIN,UAAU;sBADT,KAAK;gBAOF,SAAS;sBADZ,KAAK;gBAMN,KAAK;sBADJ,KAAK;gBAIN,cAAc;sBADb,KAAK;gBAIN,UAAU;sBADT,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAEG,kBAAkB;sBAA1B,KAAK;gBAEG,cAAc;sBAAtB,KAAK;gBAEG,kBAAkB;sBAA1B,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAGN,aAAa;sBADZ,KAAK;gBAIN,gBAAgB;sBADf,KAAK;gBAIN,gBAAgB;sBADf,KAAK;gBAIF,QAAQ;sBADX,KAAK;gBAOG,mBAAmB;sBAA3B,KAAK;gBAIF,OAAO;sBADV,KAAK;gBAMF,eAAe;sBADlB,KAAK;gBASF,KAAK;sBADR,KAAK;gBAKO,IAAI;sBAAhB,KAAK;gBAIG,eAAe;sBAAvB,KAAK;gBAGC,QAAQ;sBADd,KAAK;gBAIC,QAAQ;sBADd,KAAK;gBAIF,KAAK;sBADR,KAAK;gBAMN,WAAW;sBADV,KAAK","sourcesContent":["import {\n  AfterContentChecked,\n  ChangeDetectionStrategy,\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 { ModalController } from '@ionic/angular';\nimport { AbstractVariable } from '@iotize/tap/data';\nimport {\n  BarHorizontalComponent,\n  BarVerticalComponent,\n  BaseChartComponent,\n  LegendPosition,\n} from '@swimlane/ngx-charts';\nimport { BehaviorSubject, Subject, Subscription, combineLatest } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { MonitoringAppGenComponent } from '../../metadata/decorators';\nimport {\n  ChartDataModel,\n  ChartInputSingle,\n  ChartInputStreamVar,\n} from '../ChartDataModel';\nimport { OnChartSelectEvent } from '../shared-types';\nimport { TapVariableDataPopupComponent } from '../tap-variable-data-popup/tap-variable-data-popup.component';\n\n@MonitoringAppGenComponent({\n  constraints: {\n    isNumber: 'YES',\n  },\n})\n@Component({\n  selector: 'tap-variable-bar-chart',\n  templateUrl: './tap-variable-bar-chart.component.html',\n  styleUrls: ['./tap-variable-bar-chart.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TapVariableBarChartComponent\n  extends BaseChartComponent\n  implements AfterContentChecked, OnDestroy, OnInit\n{\n  @ViewChild('containerRef') divContainer!: ElementRef;\n  @ViewChild('chartsHor') barChartHor!: BarHorizontalComponent;\n  @ViewChild('chartsVer') barChartVer!: BarVerticalComponent;\n\n  results: ChartInputSingle[] = [];\n\n  @Input()\n  orientation = 'vertical';\n\n  @Input()\n  legend: boolean = false;\n\n  @Input()\n  legendTitle?: string;\n\n  @Input()\n  legendPosition: LegendPosition = LegendPosition.Below;\n\n  @Input()\n  showGridLines = false;\n\n  @Input()\n  showDetails = false;\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  @Input()\n  showXAxisLabel: boolean = false;\n\n  @Input()\n  xAxisLabel = '';\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  showYAxisLabel: boolean = false;\n\n  @Input()\n  yAxisLabel = '';\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()\n  noBarWhenZero = false;\n\n  @Input()\n  showExportButton: boolean = false;\n\n  @Input()\n  exportedFileName?: string;\n\n  @Input()\n  set variable(\n    variableOrArray: AbstractVariable<number | number[]> | undefined\n  ) {\n    this.input = this.chartModel.initVariable(variableOrArray);\n  }\n\n  @Input() xAxisTickFormatting: (input: any) => string =\n    this.defaultDateTickFormatting.bind(this);\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 = 30;\n    }\n    this._valueCountLimit.next(limit);\n  }\n\n  @Input()\n  set input(inputs: ChartInputStreamVar[]) {\n    this._input.next(inputs);\n  }\n\n  @Input() set data(results: ChartInputSingle[]) {\n    this.results = results;\n  }\n\n  @Input() scrollableChart = false;\n\n  @Input()\n  public scaleMax?: number;\n\n  @Input()\n  public scaleMin?: number;\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      '#f69b05',\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  private _input = new BehaviorSubject<ChartInputStreamVar[]>([]);\n\n  private oldColorScheme: any;\n\n  private destroyed = new Subject<void>();\n\n  widthChart?: number;\n\n  heightChart?: number;\n\n  private chartModel: ChartDataModel = new ChartDataModel();\n  private subscription?: Subscription;\n\n  constructor(\n    myChartElement: ElementRef,\n    zone: NgZone,\n    public cd: ChangeDetectorRef,\n    @Inject(PLATFORM_ID) platformId: string,\n    private modalController: ModalController\n  ) {\n    super(myChartElement, zone, cd, platformId);\n  }\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 (history) {\n          this.oldColorScheme = this.colorScheme;\n          this.colorScheme = { domain: [this.colorScheme.domain[0]] };\n        } else {\n          if (this.oldColorScheme !== undefined) {\n            this.colorScheme = this.oldColorScheme;\n          }\n        }\n        this.subscription = this.chartModel\n          .defineInputStreamSingle(input, history, valueCountLimit)\n          .subscribe((result: ChartInputSingle[]) => {\n            if (this.scrollableChart) {\n              this.resizeToScroll(result.length);\n            }\n            this.results = result as ChartInputSingle[];\n          });\n        this.cd.detectChanges();\n      });\n  }\n\n  ngAfterContentChecked() {\n    this.cd.detectChanges();\n    if (!this.scrollableChart) {\n      this.widthChart = this.divContainer.nativeElement.offsetWidth;\n      this.heightChart = this.divContainer.nativeElement.offsetHeight;\n    }\n  }\n\n  resizeToScroll(size: number) {\n    if (this.orientation === 'vertical') {\n      if (this.divContainer.nativeElement.offsetWidth <= size * 100) {\n        this.barChartVer.view = [\n          size * 100,\n          this.divContainer.nativeElement.offsetHeight,\n        ];\n      }\n    } else if (this.orientation === 'horizontal') {\n      if (this.divContainer.nativeElement.offsetHeight <= size * 100) {\n        this.barChartHor.view = [\n          this.divContainer.nativeElement.offsetWidth,\n          size * 100,\n        ];\n      }\n    }\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  defaultDateTickFormatting(val: any): string {\n    if (val.time) {\n      return new Date(val.time).toLocaleDateString();\n    }\n    return val;\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\n      *ngSwitchCase=\"'horizontal'\"\n      #chartsHor\n      [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n      [scheme]=\"colorScheme\"\n      [results]=\"results\"\n      [roundEdges]=\"roundEdges\"\n      [showXAxisLabel]=\"showXAxisLabel\"\n      [showYAxisLabel]=\"showYAxisLabel\"\n      [xAxis]=\"xAxis\"\n      [yAxisLabel]=\"yAxisLabel\"\n      [yAxis]=\"yAxis\"\n      [xAxisLabel]=\"xAxisLabel\"\n      [legend]=\"legend\"\n      [legendTitle]=\"legendTitle\"\n      [legendPosition]=\"legendPosition\"\n      [noBarWhenZero]=\"noBarWhenZero\"\n      [xAxisTickFormatting]=\"xAxisTickFormatting\"\n      [xScaleMax]=\"scaleMax\"\n      [xScaleMin]=\"scaleMin\"\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      (select)=\"onSelect($event)\"\n    >\n    </ngx-charts-bar-horizontal>\n    <ngx-charts-bar-vertical\n      *ngSwitchCase=\"'vertical'\"\n      #chartsVer\n      [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n      [noBarWhenZero]=\"noBarWhenZero\"\n      [scheme]=\"colorScheme\"\n      [results]=\"results\"\n      [showXAxisLabel]=\"showXAxisLabel\"\n      [showYAxisLabel]=\"showYAxisLabel\"\n      [yAxisLabel]=\"yAxisLabel\"\n      [xAxisLabel]=\"xAxisLabel\"\n      [legend]=\"legend\"\n      [legendTitle]=\"legendTitle\"\n      [legendPosition]=\"legendPosition\"\n      [xAxis]=\"xAxis\"\n      [yAxis]=\"yAxis\"\n      [yAxisTickFormatting]=\"xAxisTickFormatting\"\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      [yScaleMin]=\"scaleMin\"\n      (select)=\"onSelect($event)\"\n    >\n    </ngx-charts-bar-vertical>\n    <ion-fab-button\n      id=\"exportFabButton\"\n      size=\"small\"\n      tapExportData\n      [dataToExport]=\"results\"\n      *ngIf=\"showExportButton\"\n      [exportedFileName]=\"exportedFileName\"\n    >\n      <ion-icon name=\"download\"></ion-icon>\n    </ion-fab-button>\n  </div>\n</div>\n"]}