@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
172 lines • 20.1 kB
JavaScript
import { DecimalPipe } from '@angular/common';
import { Component, Input, ViewChild, } from '@angular/core';
import { InlineEditorComponent, TapValueEditorContainerComponent, } from '@iotize/ionic';
import { AbstractVariable } from '@iotize/tap/data';
import { map, shareReplay } from 'rxjs/operators';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "@iotize/ionic";
export class MonitoringVariableValueComponent {
decimalPipe;
ctx;
lines;
unitValue;
set error(err) {
this.fieldError = err;
}
set variable(v) {
this._variable = v;
}
/**
* @deprecated
*/
set config(config) {
if (!this.inputOptions) {
switch (config.type) {
case 'FLOAT32':
this.inputOptions = {
type: 'number',
};
break;
case 'STRING':
this.inputOptions = {
type: 'text',
maxLength: config.length,
};
break;
case 'UINT32':
this.inputOptions = {
type: 'number',
min: 0,
max: 0xffffffff,
};
break;
case 'UINT16':
this.inputOptions = {
type: 'number',
min: 0,
max: 0xffff,
};
break;
case 'UINT8':
this.inputOptions = {
type: 'number',
min: 0,
max: 0xff,
};
break;
case 'INT32':
this.inputOptions = {
type: 'number',
min: -2147483648,
max: 2147483647,
};
break;
case 'INT16':
this.inputOptions = {
type: 'number',
min: -32768,
max: 32767,
};
break;
case 'INT8':
this.inputOptions = {
type: 'number',
min: -128,
max: 127,
};
break;
}
}
}
inputOptions = {
type: 'text',
};
editable = false;
modalEdition = false;
valueStyle;
/**
* See digitsInfo doc on @{link https://angular.io/api/common/DecimalPipe#parameters}
* Will be used only if value is a number
*/
digitsInfo;
refreshable = false;
valueFormatting;
_variable;
fieldError;
_value;
forceValue = undefined;
valueSub;
constructor(decimalPipe) {
this.decimalPipe = decimalPipe;
}
ngOnDestroy() {
this.valueSub?.unsubscribe();
}
ngAfterViewInit() {
this.valueSub = this.ctx?.valueToDisplay
?.pipe(map((value) => {
if (this.valueFormatting) {
value = this.valueFormatting(value);
}
if (this.digitsInfo && typeof value === 'number') {
value = this.decimalPipe.transform(value, this.digitsInfo);
}
return value;
}), shareReplay(1))
.subscribe((v) => {
this._value = v;
});
}
onSubmit(newValue) {
this.ctx?.notifyValueChange(newValue);
}
onSubmitValue() {
this.ctx?.submitValue();
}
onValueChange(event) {
this.ctx.valueToSubmit = event;
}
onEditModeChange(newValue) {
if (newValue) {
this.ctx?.enableEditMode();
}
else {
this.ctx?.cancelEdit();
}
}
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MonitoringVariableValueComponent, deps: [{ token: i1.DecimalPipe }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: MonitoringVariableValueComponent, selector: "monitoring-variable-value", inputs: { lines: "lines", unitValue: "unitValue", error: "error", variable: "variable", config: "config", inputOptions: "inputOptions", editable: "editable", modalEdition: "modalEdition", valueStyle: "valueStyle", digitsInfo: "digitsInfo", refreshable: "refreshable", valueFormatting: "valueFormatting" }, viewQueries: [{ propertyName: "ctx", first: true, predicate: ["ctx"], descendants: true }], ngImport: i0, template: "<tap-value-editor-container\n #ctx\n [variable]=\"_variable\"\n [showRefreshButton]=\"refreshable\"\n [showEditButton]=\"editable\"\n [showSubmitButton]=\"true\"\n [modalEdition]=\"modalEdition\"\n [inputOptions]=\"inputOptions\"\n [lines]=\"lines\"\n>\n <tap-inline-editor\n [forceValue]=\"forceValue\"\n [value]=\"\n ctx.pendingSubmitValue === undefined ? _value : ctx.pendingSubmitValue\n \"\n [editMode]=\"ctx.editModeChange | async\"\n (editModeChange)=\"onEditModeChange($event)\"\n [editable]=\"editable && ctx.pendingSubmitValue === undefined\"\n [fieldError]=\"fieldError\"\n [inputOptions]=\"inputOptions\"\n [unitValue]=\"unitValue\"\n [valueStyle]=\"valueStyle\"\n (valueChange)=\"onValueChange($event)\"\n (onSubmit)=\"onSubmit($event)\"\n >\n </tap-inline-editor>\n</tap-value-editor-container>\n", styles: [""], dependencies: [{ kind: "component", type: i2.TapValueEditorContainerComponent, selector: "tap-value-editor-container", inputs: ["button", "variable", "inputOptions", "showRefreshButton", "showSubmitButton", "showEditButton", "error", "lines", "modalEdition", "value"], outputs: ["submit", "refresh"] }, { kind: "component", type: i2.InlineEditorComponent, selector: "tap-inline-editor", inputs: ["editMode", "editable", "unitValue", "inputOptions", "valueStyle", "value", "forceValue", "showLoader", "fieldError"], outputs: ["onSubmit", "valueChange", "editModeChange"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MonitoringVariableValueComponent, decorators: [{
type: Component,
args: [{ selector: 'monitoring-variable-value', template: "<tap-value-editor-container\n #ctx\n [variable]=\"_variable\"\n [showRefreshButton]=\"refreshable\"\n [showEditButton]=\"editable\"\n [showSubmitButton]=\"true\"\n [modalEdition]=\"modalEdition\"\n [inputOptions]=\"inputOptions\"\n [lines]=\"lines\"\n>\n <tap-inline-editor\n [forceValue]=\"forceValue\"\n [value]=\"\n ctx.pendingSubmitValue === undefined ? _value : ctx.pendingSubmitValue\n \"\n [editMode]=\"ctx.editModeChange | async\"\n (editModeChange)=\"onEditModeChange($event)\"\n [editable]=\"editable && ctx.pendingSubmitValue === undefined\"\n [fieldError]=\"fieldError\"\n [inputOptions]=\"inputOptions\"\n [unitValue]=\"unitValue\"\n [valueStyle]=\"valueStyle\"\n (valueChange)=\"onValueChange($event)\"\n (onSubmit)=\"onSubmit($event)\"\n >\n </tap-inline-editor>\n</tap-value-editor-container>\n" }]
}], ctorParameters: () => [{ type: i1.DecimalPipe }], propDecorators: { ctx: [{
type: ViewChild,
args: ['ctx']
}], lines: [{
type: Input
}], unitValue: [{
type: Input
}], error: [{
type: Input
}], variable: [{
type: Input
}], config: [{
type: Input
}], inputOptions: [{
type: Input
}], editable: [{
type: Input
}], modalEdition: [{
type: Input
}], valueStyle: [{
type: Input
}], digitsInfo: [{
type: Input
}], refreshable: [{
type: Input
}], valueFormatting: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monitoring-variable-value.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/monitoring-variable-value/monitoring-variable-value.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/monitoring-variable-value/monitoring-variable-value.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DecimalPipe } from '@angular/common';\nimport {\n  AfterViewInit,\n  Component,\n  Input,\n  OnDestroy,\n  ViewChild,\n} from '@angular/core';\nimport {\n  InlineEditorComponent,\n  TapValueEditorContainerComponent,\n} from '@iotize/ionic';\nimport { VariableConfig } from '@iotize/tap/config/schema/v1';\nimport { AbstractVariable } from '@iotize/tap/data';\nimport { Subscription } from 'rxjs';\nimport { map, shareReplay } from 'rxjs/operators';\n\n@Component({\n  selector: 'monitoring-variable-value',\n  templateUrl: './monitoring-variable-value.component.html',\n  styleUrls: ['./monitoring-variable-value.component.scss'],\n})\nexport class MonitoringVariableValueComponent<ValueType = any>\n  implements AfterViewInit, OnDestroy\n{\n  @ViewChild('ctx') ctx?: TapValueEditorContainerComponent;\n\n  @Input() lines?: string;\n\n  @Input()\n  unitValue?: string;\n\n  @Input() set error(err: Error) {\n    this.fieldError = err;\n  }\n\n  @Input()\n  set variable(v: AbstractVariable<ValueType>) {\n    this._variable = v;\n  }\n\n  /**\n   * @deprecated\n   */\n  @Input() set config(config: VariableConfig) {\n    if (!this.inputOptions) {\n      switch (config.type) {\n        case 'FLOAT32':\n          this.inputOptions = {\n            type: 'number',\n          };\n          break;\n        case 'STRING':\n          this.inputOptions = {\n            type: 'text',\n            maxLength: config.length,\n          };\n          break;\n        case 'UINT32':\n          this.inputOptions = {\n            type: 'number',\n            min: 0,\n            max: 0xffffffff,\n          };\n          break;\n        case 'UINT16':\n          this.inputOptions = {\n            type: 'number',\n            min: 0,\n            max: 0xffff,\n          };\n          break;\n        case 'UINT8':\n          this.inputOptions = {\n            type: 'number',\n            min: 0,\n            max: 0xff,\n          };\n          break;\n        case 'INT32':\n          this.inputOptions = {\n            type: 'number',\n            min: -2147483648,\n            max: 2147483647,\n          };\n          break;\n        case 'INT16':\n          this.inputOptions = {\n            type: 'number',\n            min: -32768,\n            max: 32767,\n          };\n          break;\n        case 'INT8':\n          this.inputOptions = {\n            type: 'number',\n            min: -128,\n            max: 127,\n          };\n          break;\n      }\n    }\n  }\n\n  @Input() inputOptions: InlineEditorComponent.InputOptions = {\n    type: 'text',\n  };\n\n  @Input()\n  editable = false;\n\n  @Input()\n  modalEdition = false;\n\n  @Input()\n  valueStyle?: any;\n\n  /**\n   * See digitsInfo doc on @{link https://angular.io/api/common/DecimalPipe#parameters}\n   * Will be used only if value is a number\n   */\n  @Input()\n  digitsInfo?: string;\n\n  @Input()\n  refreshable = false;\n\n  @Input() valueFormatting?: (value: ValueType) => ValueType;\n\n  public _variable?: AbstractVariable<ValueType>;\n\n  public fieldError?: Error;\n\n  _value?: any;\n\n  forceValue: any = undefined;\n\n  valueSub?: Subscription;\n\n  constructor(private decimalPipe: DecimalPipe) {}\n\n  ngOnDestroy(): void {\n    this.valueSub?.unsubscribe();\n  }\n\n  ngAfterViewInit(): void {\n    this.valueSub = this.ctx?.valueToDisplay\n      ?.pipe(\n        map((value) => {\n          if (this.valueFormatting) {\n            value = this.valueFormatting(value);\n          }\n          if (this.digitsInfo && typeof value === 'number') {\n            value = this.decimalPipe.transform(value, this.digitsInfo);\n          }\n          return value;\n        }),\n        shareReplay(1)\n      )\n      .subscribe((v) => {\n        this._value = v;\n      });\n  }\n\n  onSubmit(newValue: any) {\n    this.ctx?.notifyValueChange(newValue);\n  }\n\n  onSubmitValue() {\n    this.ctx?.submitValue();\n  }\n\n  onValueChange(event: any) {\n    this.ctx!.valueToSubmit = event;\n  }\n\n  onEditModeChange(newValue: any) {\n    if (newValue) {\n      this.ctx?.enableEditMode();\n    } else {\n      this.ctx?.cancelEdit();\n    }\n  }\n}\n","<tap-value-editor-container\n  #ctx\n  [variable]=\"_variable\"\n  [showRefreshButton]=\"refreshable\"\n  [showEditButton]=\"editable\"\n  [showSubmitButton]=\"true\"\n  [modalEdition]=\"modalEdition\"\n  [inputOptions]=\"inputOptions\"\n  [lines]=\"lines\"\n>\n  <tap-inline-editor\n    [forceValue]=\"forceValue\"\n    [value]=\"\n      ctx.pendingSubmitValue === undefined ? _value : ctx.pendingSubmitValue\n    \"\n    [editMode]=\"ctx.editModeChange | async\"\n    (editModeChange)=\"onEditModeChange($event)\"\n    [editable]=\"editable && ctx.pendingSubmitValue === undefined\"\n    [fieldError]=\"fieldError\"\n    [inputOptions]=\"inputOptions\"\n    [unitValue]=\"unitValue\"\n    [valueStyle]=\"valueStyle\"\n    (valueChange)=\"onValueChange($event)\"\n    (onSubmit)=\"onSubmit($event)\"\n  >\n  </tap-inline-editor>\n</tap-value-editor-container>\n"]}