@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
159 lines • 21.1 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostListener, Inject, Input, NgZone, PLATFORM_ID, } from '@angular/core';
import { ModalController } from '@ionic/angular';
import { NumberCardComponent } from '@swimlane/ngx-charts';
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";
/**
* @deprecated it will probably be removed as it's not very usefull
*/
let TapVariableNumberChartComponent = class TapVariableNumberChartComponent extends NumberCardComponent {
modalController;
showDetails = false;
cardColor = '#232837';
showExportButton = false;
exportedFileName;
set label(indexOrArray) {
this.chartModel.initLabel(indexOrArray);
}
colorScheme = {
domain: [
'#5AA454',
'#E44D25',
'#CFC0BB',
'#7aa3e5',
'#a8385d',
'#aae3f5',
'#5DADE2',
'#9B59B6',
'#F39C12',
'#5AA454',
'#A10A28',
'#C7B42C',
'#AAAAAA',
],
};
set variable(variableOrArray) {
this.input = this.chartModel.initVariable(variableOrArray);
}
set input(inputs) {
this.subscription = this.chartModel
.defineInputStreamSingle(inputs, false, 0)
.subscribe((result) => {
let index = 0;
for (const item of result) {
if (!this.results[index]) {
if (item.value !== this.results[index].value) {
this.results = result;
}
}
else {
this.results = result;
}
index++;
}
this.resizeComponent();
this.loaded = true;
});
}
results = [
{
name: '---',
value: 0,
extra: 0,
},
];
subscription;
innerWidth;
innerHeight;
loaded = false;
chartModel = new ChartDataModel();
constructor(myChartElement, zone, cd, platformId, modalController) {
super(myChartElement, zone, cd, platformId);
this.modalController = modalController;
}
onSelect(event) {
if (typeof event === 'object') {
if (this.showDetails) {
this.chartModel
.showDetail(event, this.modalController, TapVariableDataPopupComponent)
.catch((err) => {
console.warn('Failed to show value detail', err);
});
}
}
}
ngAfterViewInit() {
this.innerWidth = window.innerWidth;
this.resizeComponent();
}
resizeComponent() {
if (this.innerWidth <= 400) {
this.innerWidth = 400;
}
this.innerHeight = (150 * this.results.length) / (this.innerWidth / 300);
if (this.results.length === 1) {
this.innerHeight = 150;
}
else {
if (this.innerHeight <= 210) {
this.innerHeight = 210;
}
}
this.cd.detectChanges();
}
onResize(event) {
this.innerWidth = window.innerWidth;
this.resizeComponent();
}
ngOnDestroy() {
this.subscription?.unsubscribe();
this.chartModel.destroyCurrentSub();
}
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TapVariableNumberChartComponent, 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: TapVariableNumberChartComponent, selector: "tap-variable-number-chart", inputs: { showDetails: "showDetails", cardColor: "cardColor", showExportButton: "showExportButton", exportedFileName: "exportedFileName", label: "label", colorScheme: "colorScheme", variable: "variable", input: "input" }, host: { listeners: { "window:resize": "onResize($event)" } }, usesInheritance: true, ngImport: i0, template: "<div #containerRef style=\"width: 100%; overflow: auto; position: relative\">\n <ngx-charts-number-card\n #charts\n [view]=\"[containerRef.offsetWidth, innerHeight]\"\n [scheme]=\"colorScheme\"\n [results]=\"results\"\n [cardColor]=\"cardColor\"\n (select)=\"onSelect($event)\"\n >\n </ngx-charts-number-card>\n <ion-fab-button\n id=\"exportFabButton\"\n size=\"small\"\n tapExportData\n *ngIf=\"showExportButton\"\n [exportedFileName]=\"exportedFileName\"\n [dataToExport]=\"results\"\n >\n <ion-icon name=\"download\"></ion-icon>\n </ion-fab-button>\n</div>\n", styles: [":host ::ng-deep rect.card{min-height:250!important;min-width:250!important;margin:500px!important}@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}}#exportFabButton{position:absolute;top:10px;right:10px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.NumberCardComponent, selector: "ngx-charts-number-card", inputs: ["cardColor", "bandColor", "emptyColor", "innerPadding", "textColor", "valueFormatting", "labelFormatting", "designatedTotal"] }, { kind: "directive", type: i4.ExportDataDirective, selector: "[tapExportData]", inputs: ["exportedFileName", "dataToExport", "format"], outputs: ["exportDataError"] }, { 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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
};
TapVariableNumberChartComponent = __decorate([
MonitoringAppGenComponent({
constraints: {
isNumber: 'YES',
},
}),
__metadata("design:paramtypes", [ElementRef,
NgZone,
ChangeDetectorRef, String, ModalController])
], TapVariableNumberChartComponent);
export { TapVariableNumberChartComponent };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TapVariableNumberChartComponent, decorators: [{
type: Component,
args: [{ selector: 'tap-variable-number-chart', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #containerRef style=\"width: 100%; overflow: auto; position: relative\">\n <ngx-charts-number-card\n #charts\n [view]=\"[containerRef.offsetWidth, innerHeight]\"\n [scheme]=\"colorScheme\"\n [results]=\"results\"\n [cardColor]=\"cardColor\"\n (select)=\"onSelect($event)\"\n >\n </ngx-charts-number-card>\n <ion-fab-button\n id=\"exportFabButton\"\n size=\"small\"\n tapExportData\n *ngIf=\"showExportButton\"\n [exportedFileName]=\"exportedFileName\"\n [dataToExport]=\"results\"\n >\n <ion-icon name=\"download\"></ion-icon>\n </ion-fab-button>\n</div>\n", styles: [":host ::ng-deep rect.card{min-height:250!important;min-width:250!important;margin:500px!important}@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}}#exportFabButton{position:absolute;top:10px;right:10px}\n"] }]
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
type: Inject,
args: [PLATFORM_ID]
}] }, { type: i1.ModalController }], propDecorators: { showDetails: [{
type: Input
}], cardColor: [{
type: Input
}], showExportButton: [{
type: Input
}], exportedFileName: [{
type: Input
}], label: [{
type: Input
}], colorScheme: [{
type: Input
}], variable: [{
type: Input
}], input: [{
type: Input
}], onResize: [{
type: HostListener,
args: ['window:resize', ['$event']]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tap-variable-number-chart.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-number-chart/tap-variable-number-chart.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-number-chart/tap-variable-number-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostListener,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  PLATFORM_ID,\n} from '@angular/core';\nimport { ModalController } from '@ionic/angular';\nimport { AbstractVariable } from '@iotize/tap/data';\nimport { NumberCardComponent } from '@swimlane/ngx-charts';\nimport { Subscription } from 'rxjs';\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/**\n * @deprecated it will probably be removed as it's not very usefull\n */\n@MonitoringAppGenComponent({\n  constraints: {\n    isNumber: 'YES',\n  },\n})\n@Component({\n  selector: 'tap-variable-number-chart',\n  templateUrl: './tap-variable-number-chart.component.html',\n  styleUrls: ['./tap-variable-number-chart.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TapVariableNumberChartComponent\n  extends NumberCardComponent\n  implements AfterViewInit, OnDestroy\n{\n  @Input()\n  showDetails = false;\n\n  @Input()\n  cardColor = '#232837';\n\n  @Input()\n  showExportButton: boolean = false;\n\n  @Input()\n  exportedFileName?: string;\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      '#5AA454',\n      '#E44D25',\n      '#CFC0BB',\n      '#7aa3e5',\n      '#a8385d',\n      '#aae3f5',\n      '#5DADE2',\n      '#9B59B6',\n      '#F39C12',\n      '#5AA454',\n      '#A10A28',\n      '#C7B42C',\n      '#AAAAAA',\n    ],\n  };\n\n  @Input()\n  set variable(\n    variableOrArray: AbstractVariable<number | number[]> | undefined\n  ) {\n    this.input = this.chartModel.initVariable(variableOrArray);\n  }\n\n  @Input()\n  set input(inputs: ChartInputStreamVar[]) {\n    this.subscription = this.chartModel\n      .defineInputStreamSingle(inputs, false, 0)\n      .subscribe((result: ChartInputSingle[]) => {\n        let index = 0;\n        for (const item of result as ChartInputSingle[]) {\n          if (!this.results[index]) {\n            if (item.value !== this.results[index].value) {\n              this.results = result as ChartInputSingle[];\n            }\n          } else {\n            this.results = result as ChartInputSingle[];\n          }\n          index++;\n        }\n        this.resizeComponent();\n        this.loaded = true;\n      });\n  }\n\n  results: ChartInputSingle[] = [\n    {\n      name: '---',\n      value: 0,\n      extra: 0,\n    },\n  ];\n\n  private subscription?: Subscription;\n\n  innerWidth!: number;\n  innerHeight?: number;\n  loaded = false;\n\n  private chartModel: ChartDataModel = new ChartDataModel();\n\n  constructor(\n    myChartElement: ElementRef<any>,\n    zone: NgZone,\n    cd: ChangeDetectorRef,\n    @Inject(PLATFORM_ID) platformId: string,\n    private modalController: ModalController\n  ) {\n    super(myChartElement, zone, cd, platformId);\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.warn('Failed to show value detail', err);\n          });\n      }\n    }\n  }\n\n  ngAfterViewInit() {\n    this.innerWidth = window.innerWidth;\n    this.resizeComponent();\n  }\n\n  resizeComponent() {\n    if (this.innerWidth <= 400) {\n      this.innerWidth = 400;\n    }\n    this.innerHeight = (150 * this.results.length) / (this.innerWidth / 300);\n    if (this.results.length === 1) {\n      this.innerHeight = 150;\n    } else {\n      if (this.innerHeight <= 210) {\n        this.innerHeight = 210;\n      }\n    }\n    this.cd.detectChanges();\n  }\n\n  @HostListener('window:resize', ['$event'])\n  onResize(event: any) {\n    this.innerWidth = window.innerWidth;\n    this.resizeComponent();\n  }\n\n  ngOnDestroy() {\n    this.subscription?.unsubscribe();\n    this.chartModel.destroyCurrentSub();\n  }\n}\n","<div #containerRef style=\"width: 100%; overflow: auto; position: relative\">\n  <ngx-charts-number-card\n    #charts\n    [view]=\"[containerRef.offsetWidth, innerHeight]\"\n    [scheme]=\"colorScheme\"\n    [results]=\"results\"\n    [cardColor]=\"cardColor\"\n    (select)=\"onSelect($event)\"\n  >\n  </ngx-charts-number-card>\n  <ion-fab-button\n    id=\"exportFabButton\"\n    size=\"small\"\n    tapExportData\n    *ngIf=\"showExportButton\"\n    [exportedFileName]=\"exportedFileName\"\n    [dataToExport]=\"results\"\n  >\n    <ion-icon name=\"download\"></ion-icon>\n  </ion-fab-button>\n</div>\n"]}