@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
125 lines • 14.9 kB
JavaScript
import { __decorate } from "tslib";
import { Component, Input } from '@angular/core';
import { Observable, Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { MonitoringAppGenComponent, } from '../../metadata/decorators';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "@ionic/angular";
let TapVariableLinearGaugeComponent = class TapVariableLinearGaugeComponent {
dataValue = 0;
dataPercent = 0;
_variable;
destroyed = new Subject();
unit;
digitsInfo;
/**
* @deprecated use unit instead
*/
set units(v) {
this.unit = v;
}
min = 0;
max = 100;
color = 'primary';
textColor = 'dark';
reversed = false;
set value(v) {
if (v === undefined || v === null) {
v = 0;
}
if (typeof v === 'string') {
v = parseInt(v, 10);
if (isNaN(v)) {
v = 0;
}
}
if (typeof v !== 'number') {
console.warn(`TapVariableLinearGauge: Invalid value type: ${typeof v}`, v);
}
this.setValue(v);
}
/**
* @deprecated use [value]="..." instead
*/
set variable(variable) {
this._variable = variable;
if (variable) {
this.inputStream = variable.values;
}
}
/**
* @deprecated use [value]="..." instead
*/
set inputStream(inputs) {
inputs.pipe(takeUntil(this.destroyed)).subscribe((value) => {
this.setValue(value);
});
}
setValue(value) {
if (this.min === null) {
this.min = 0;
}
if (this.max == null) {
this.max = 100;
}
if (typeof value === 'string') {
value = parseInt(value);
}
if (typeof value !== 'number') {
value = this.min;
}
this.dataValue = value;
if (value <= this.min) {
this.min = value;
this.dataPercent = 0;
}
else if (value >= this.max) {
this.dataPercent = 1;
this.max = value;
}
else {
this.dataPercent = (value - this.min) / (this.max - this.min);
}
}
ngOnDestroy() {
this.destroyed.next();
}
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TapVariableLinearGaugeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: TapVariableLinearGaugeComponent, selector: "tap-variable-linear-gauge", inputs: { unit: "unit", digitsInfo: "digitsInfo", units: "units", min: "min", max: "max", color: "color", textColor: "textColor", reversed: "reversed", value: "value", variable: "variable", inputStream: "inputStream" }, ngImport: i0, template: "<div id=\"divBloc\">\n <ion-label id=\"labelValue\" [color]=\"textColor\"\n >{{ dataValue | number: digitsInfo }}\n <span *ngIf=\"unit\">{{ unit }}</span></ion-label\n >\n <ion-label id=\"labelMin\">\n {{ reversed ? max : min }}\n </ion-label>\n <ion-label id=\"labelMax\">\n {{ reversed ? min : max }}\n </ion-label>\n <ion-progress-bar\n id=\"progressBar\"\n [reversed]=\"reversed\"\n [color]=\"color\"\n [value]=\"dataPercent\"\n ></ion-progress-bar>\n</div>\n", styles: ["#divBloc{width:100%;position:relative;text-align:center;padding:10px 10px 20px}#labelValue{margin:5px;font-size:2em}#labelMin{left:10px;top:20px;position:absolute}#progressBar{box-shadow:#3c40434d 0 1px 2px,#3c404326 0 2px 6px 2px;border-radius:5px}#labelMax{position:absolute;top:20px;right:10px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: i2.IonProgressBar, selector: "ion-progress-bar", inputs: ["buffer", "color", "mode", "reversed", "type", "value"] }, { kind: "pipe", type: i1.DecimalPipe, name: "number" }] });
};
TapVariableLinearGaugeComponent = __decorate([
MonitoringAppGenComponent({
constraints: {
isNumber: 'YES',
},
})
], TapVariableLinearGaugeComponent);
export { TapVariableLinearGaugeComponent };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TapVariableLinearGaugeComponent, decorators: [{
type: Component,
args: [{ selector: 'tap-variable-linear-gauge', template: "<div id=\"divBloc\">\n <ion-label id=\"labelValue\" [color]=\"textColor\"\n >{{ dataValue | number: digitsInfo }}\n <span *ngIf=\"unit\">{{ unit }}</span></ion-label\n >\n <ion-label id=\"labelMin\">\n {{ reversed ? max : min }}\n </ion-label>\n <ion-label id=\"labelMax\">\n {{ reversed ? min : max }}\n </ion-label>\n <ion-progress-bar\n id=\"progressBar\"\n [reversed]=\"reversed\"\n [color]=\"color\"\n [value]=\"dataPercent\"\n ></ion-progress-bar>\n</div>\n", styles: ["#divBloc{width:100%;position:relative;text-align:center;padding:10px 10px 20px}#labelValue{margin:5px;font-size:2em}#labelMin{left:10px;top:20px;position:absolute}#progressBar{box-shadow:#3c40434d 0 1px 2px,#3c404326 0 2px 6px 2px;border-radius:5px}#labelMax{position:absolute;top:20px;right:10px}\n"] }]
}], propDecorators: { unit: [{
type: Input
}], digitsInfo: [{
type: Input
}], units: [{
type: Input
}], min: [{
type: Input
}], max: [{
type: Input
}], color: [{
type: Input
}], textColor: [{
type: Input
}], reversed: [{
type: Input
}], value: [{
type: Input
}], variable: [{
type: Input
}], inputStream: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tap-variable-linear-gauge.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-linear-gauge/tap-variable-linear-gauge.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-linear-gauge/tap-variable-linear-gauge.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy } from '@angular/core';\nimport { AbstractVariable } from '@iotize/tap/data';\nimport { Observable, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport {\n  AppGenField,\n  MonitoringAppGenComponent,\n} from '../../metadata/decorators';\nimport {\n  DIGITS_INFO_SCHEMA,\n  IONIC_COLOR_SCHEMA,\n  TAP_VARIABLE_SCHEMA,\n  VALUE_STREAM_FIELD,\n} from '../shared-schema';\n\n@MonitoringAppGenComponent({\n  constraints: {\n    isNumber: 'YES',\n  },\n})\n@Component({\n  selector: 'tap-variable-linear-gauge',\n  templateUrl: './tap-variable-linear-gauge.component.html',\n  styleUrls: ['./tap-variable-linear-gauge.component.scss'],\n})\nexport class TapVariableLinearGaugeComponent implements OnDestroy {\n  dataValue = 0;\n  dataPercent = 0;\n  _variable?: AbstractVariable<any>;\n\n  private destroyed = new Subject<void>();\n\n  @Input()\n  unit?: string;\n\n  @Input()\n  digitsInfo?: string;\n\n  /**\n   * @deprecated use unit instead\n   */\n  @Input() set units(v: string) {\n    this.unit = v;\n  }\n\n  @Input()\n  min?: number = 0;\n\n  @Input()\n  max?: number = 100;\n\n  @Input()\n  color = 'primary';\n\n  @Input()\n  textColor = 'dark';\n\n  @Input()\n  reversed = false;\n\n  @Input()\n  set value(v: number | string | undefined) {\n    if (v === undefined || v === null) {\n      v = 0;\n    }\n    if (typeof v === 'string') {\n      v = parseInt(v, 10);\n      if (isNaN(v)) {\n        v = 0;\n      }\n    }\n    if (typeof v !== 'number') {\n      console.warn(\n        `TapVariableLinearGauge: Invalid value type: ${typeof v}`,\n        v\n      );\n    }\n    this.setValue(v);\n  }\n\n  /**\n   * @deprecated use [value]=\"...\" instead\n   */\n  @Input()\n  set variable(variable: AbstractVariable<number | number[]> | undefined) {\n    this._variable = variable;\n    if (variable) {\n      this.inputStream = variable.values;\n    }\n  }\n\n  /**\n   * @deprecated use [value]=\"...\" instead\n   */\n  @Input()\n  set inputStream(inputs: Observable<any>) {\n    inputs.pipe(takeUntil(this.destroyed)).subscribe((value) => {\n      this.setValue(value);\n    });\n  }\n\n  setValue(value: number | string | undefined | null) {\n    if (this.min === null) {\n      this.min = 0;\n    }\n    if (this.max == null) {\n      this.max = 100;\n    }\n    if (typeof value === 'string') {\n      value = parseInt(value);\n    }\n    if (typeof value !== 'number') {\n      value = this.min!;\n    }\n    this.dataValue = value;\n    if (value <= this.min!) {\n      this.min = value;\n      this.dataPercent = 0;\n    } else if (value >= this.max) {\n      this.dataPercent = 1;\n      this.max = value;\n    } else {\n      this.dataPercent = (value - this.min!) / (this.max - this.min!);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroyed.next();\n  }\n}\n","<div id=\"divBloc\">\n  <ion-label id=\"labelValue\" [color]=\"textColor\"\n    >{{ dataValue | number: digitsInfo }}\n    <span *ngIf=\"unit\">{{ unit }}</span></ion-label\n  >\n  <ion-label id=\"labelMin\">\n    {{ reversed ? max : min }}\n  </ion-label>\n  <ion-label id=\"labelMax\">\n    {{ reversed ? min : max }}\n  </ion-label>\n  <ion-progress-bar\n    id=\"progressBar\"\n    [reversed]=\"reversed\"\n    [color]=\"color\"\n    [value]=\"dataPercent\"\n  ></ion-progress-bar>\n</div>\n"]}