UNPKG

@iotize/ionic

Version:

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

157 lines 19.7 kB
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 { 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; } } } constructor(decimalPipe) { this.decimalPipe = decimalPipe; this.inputOptions = { type: 'text', }; this.editable = false; this.modalEdition = false; this.refreshable = false; this.forceValue = undefined; } 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 */ MonitoringVariableValueComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MonitoringVariableValueComponent, deps: [{ token: i1.DecimalPipe }], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ MonitoringVariableValueComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", 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: "15.2.10", 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: function () { return [{ 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"]}