UNPKG

@iotize/ionic

Version:

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

137 lines 19.6 kB
import { __decorate, __metadata } from "tslib"; import { ChangeDetectorRef, Component, ElementRef, Inject, Input, NgZone, PLATFORM_ID, ViewEncapsulation, } from '@angular/core'; import { ModalController } from '@ionic/angular'; import { PieChartComponent } 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 TapVariablePieChartAdvancedComponent = class TapVariablePieChartAdvancedComponent extends PieChartComponent { modalController; showDetails = false; showExportButton = false; exportedFileName; 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 label(indexOrArray) { this.chartModel.initLabel(indexOrArray); } colorScheme = { domain: [ '#5DADE2', '#9B59B6', '#F39C12', '#5AA454', '#A10A28', '#C7B42C', '#AAAAAA', ], }; _history = new BehaviorSubject(true); _valueCountLimit = new BehaviorSubject(30); _input = new BehaviorSubject([]); set input(inputs) { this._input.next(inputs); } destroyed = new Subject(); ngOnInit() { combineLatest([this._valueCountLimit, this._input, this._history]) .pipe(takeUntil(this.destroyed)) .subscribe(([valueCountLimit, input, history]) => { this.chartModel.destroyCurrentSub(); this.subscription = this.chartModel .defineInputStreamSingle(input, history, valueCountLimit) .subscribe((result) => { this.results = result; }); this.cd.detectChanges(); }); } results = [ { name: '---', value: 0, extra: 0, }, ]; chartModel = new ChartDataModel(); subscription; constructor(myChartElement, zone, cd, platformId, modalController) { super(myChartElement, zone, cd, platformId); this.modalController = modalController; } ngAfterViewChecked() { this.cd.detectChanges(); } onSelect(event) { if (typeof event === 'object') { if (this.showDetails) { this.chartModel .showDetail(event, this.modalController, TapVariableDataPopupComponent) .catch((err) => { console.log(err); }); } } } ngOnDestroy() { this.subscription?.unsubscribe(); this.chartModel.destroyCurrentSub(); } /** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TapVariablePieChartAdvancedComponent, 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: TapVariablePieChartAdvancedComponent, selector: "tap-variable-pie-chart-advanced", inputs: { showDetails: "showDetails", showExportButton: "showExportButton", exportedFileName: "exportedFileName", variable: "variable", history: "history", valueCountLimit: "valueCountLimit", label: "label", colorScheme: "colorScheme", input: "input" }, usesInheritance: true, ngImport: i0, template: "<div #containerRef style=\"width: 100%; position: relative\">\n <ngx-charts-advanced-pie-chart\n #charts\n [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n [scheme]=\"colorScheme\"\n [results]=\"results\"\n (select)=\"onSelect($event)\"\n >\n </ngx-charts-advanced-pie-chart>\n <ion-fab-button\n id=\"exportFabButton\"\n size=\"small\"\n tapExportData\n [dataToExport]=\"results\"\n [exportedFileName]=\"exportedFileName\"\n *ngIf=\"showExportButton\"\n >\n <ion-icon name=\"download\"></ion-icon>\n </ion-fab-button>\n</div>\n", styles: [".legend-items{padding-top:10px!important;padding-bottom:10px!important}#exportFabButton{position:absolute;top:50px;right:10px}@media (prefers-color-scheme: dark){.legend-item{color:#ccc!important}.legend-item:hover{color:#fff!important}}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.AdvancedPieChartComponent, selector: "ngx-charts-advanced-pie-chart", inputs: ["gradient", "activeEntries", "tooltipDisabled", "tooltipText", "label", "valueFormatting", "nameFormatting", "percentageFormatting"], 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"] }], encapsulation: i0.ViewEncapsulation.None }); }; TapVariablePieChartAdvancedComponent = __decorate([ MonitoringAppGenComponent({ constraints: { isNumber: 'YES', isArray: 'YES', }, }), __metadata("design:paramtypes", [ElementRef, NgZone, ChangeDetectorRef, String, ModalController]) ], TapVariablePieChartAdvancedComponent); export { TapVariablePieChartAdvancedComponent }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TapVariablePieChartAdvancedComponent, decorators: [{ type: Component, args: [{ selector: 'tap-variable-pie-chart-advanced', encapsulation: ViewEncapsulation.None, template: "<div #containerRef style=\"width: 100%; position: relative\">\n <ngx-charts-advanced-pie-chart\n #charts\n [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n [scheme]=\"colorScheme\"\n [results]=\"results\"\n (select)=\"onSelect($event)\"\n >\n </ngx-charts-advanced-pie-chart>\n <ion-fab-button\n id=\"exportFabButton\"\n size=\"small\"\n tapExportData\n [dataToExport]=\"results\"\n [exportedFileName]=\"exportedFileName\"\n *ngIf=\"showExportButton\"\n >\n <ion-icon name=\"download\"></ion-icon>\n </ion-fab-button>\n</div>\n", styles: [".legend-items{padding-top:10px!important;padding-bottom:10px!important}#exportFabButton{position:absolute;top:50px;right:10px}@media (prefers-color-scheme: dark){.legend-item{color:#ccc!important}.legend-item:hover{color:#fff!important}}\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 }], showExportButton: [{ type: Input }], exportedFileName: [{ type: Input }], variable: [{ type: Input }], history: [{ type: Input }], valueCountLimit: [{ type: Input }], label: [{ type: Input }], colorScheme: [{ type: Input }], input: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tap-variable-pie-chart-advanced.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-pie-chart-advanced/tap-variable-pie-chart-advanced.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-pie-chart-advanced/tap-variable-pie-chart-advanced.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewChecked,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  PLATFORM_ID,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ModalController } from '@ionic/angular';\nimport { AbstractVariable } from '@iotize/tap/data';\nimport { PieChartComponent } 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    isArray: 'YES',\n  },\n})\n@Component({\n  selector: 'tap-variable-pie-chart-advanced',\n  templateUrl: './tap-variable-pie-chart-advanced.component.html',\n  styleUrls: ['./tap-variable-pie-chart-advanced.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class TapVariablePieChartAdvancedComponent\n  extends PieChartComponent\n  implements AfterViewChecked, OnDestroy, OnInit\n{\n  @Input()\n  showDetails: boolean = 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()\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 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  private _input = new BehaviorSubject<ChartInputStreamVar[]>([]);\n\n  @Input()\n  set input(inputs: ChartInputStreamVar[]) {\n    this._input.next(inputs);\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        this.subscription = this.chartModel\n          .defineInputStreamSingle(input, history, valueCountLimit)\n          .subscribe((result: ChartInputSingle[]) => {\n            this.results = result as ChartInputSingle[];\n          });\n        this.cd.detectChanges();\n      });\n  }\n\n  results: ChartInputSingle[] = [\n    {\n      name: '---',\n      value: 0,\n      extra: 0,\n    },\n  ];\n\n  private chartModel: ChartDataModel = new ChartDataModel();\n\n  private subscription?: Subscription;\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  ngAfterViewChecked() {\n    this.cd.detectChanges();\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  ngOnDestroy(): void {\n    this.subscription?.unsubscribe();\n    this.chartModel.destroyCurrentSub();\n  }\n}\n","<div #containerRef style=\"width: 100%; position: relative\">\n  <ngx-charts-advanced-pie-chart\n    #charts\n    [view]=\"[containerRef.offsetWidth, containerRef.offsetHeight]\"\n    [scheme]=\"colorScheme\"\n    [results]=\"results\"\n    (select)=\"onSelect($event)\"\n  >\n  </ngx-charts-advanced-pie-chart>\n  <ion-fab-button\n    id=\"exportFabButton\"\n    size=\"small\"\n    tapExportData\n    [dataToExport]=\"results\"\n    [exportedFileName]=\"exportedFileName\"\n    *ngIf=\"showExportButton\"\n  >\n    <ion-icon name=\"download\"></ion-icon>\n  </ion-fab-button>\n</div>\n"]}