UNPKG

@iotize/ionic

Version:

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

233 lines 30.9 kB
import { Component, EventEmitter, inject, Input, Output, ViewChild, } from '@angular/core'; import { FormBuilder, FormControl, Validators } from '@angular/forms'; import { AbstractVariable } from '@iotize/tap/data'; import { CurrentDeviceService, LibError, PendingCallManager, } from '@iotize/ionic'; import { Subject } from 'rxjs'; import * as i0 from "@angular/core"; import * as i1 from "@iotize/ionic"; import * as i2 from "@angular/common"; import * as i3 from "@angular/forms"; import * as i4 from "@ionic/angular"; /** * @deprecated */ export class MonitoringEditTextComponent { loading = false; validationMessages = { required: 'Input is required', minlength: 'Input is too short', maxlength: 'Input is too long', pattern: 'Input does not match pattern', }; subscription; _variable; inputref; pendingCallManager; set inputStream(stream) { this.setStream(stream); } set variable(variable) { this._variable = variable; } label = undefined; input = 'string'; type = 'string'; actions; clearInput = false; clearOnEdit = false; color = 'primary'; disabled = false; inputMode = 'text'; max = undefined; min = undefined; maxLength = undefined; minLength = undefined; name = undefined; pattern = undefined; placeholder = undefined; readonly = false; required = false; set value(v) { this.myControl.setValue(v); } outEvent = new EventEmitter(); myControl = new FormControl('', Validators.compose([ Validators.required, // Validators.maxLength(this.minLength), // Validators.minLength(this.maxLength), // Validators.pattern(this.pattern), ])); formBuilder = inject(FormBuilder); myGroup = this.formBuilder.group({ myControl: this.myControl, }); errorToString(item) { if (item.key in this.validationMessages) { return this.validationMessages[item.key]; } return item.value; } submit() { const newValue = this.myControl.value; if (this.actions) { this.actions.next(newValue); } if (!this._variable) { throw LibError.componentArgumentRequired(this.constructor.name, 'variable'); } this.pendingCallManager .exec(async () => { if (this._variable) { await this.startAction(this._variable.write(newValue).then(() => { this.myControl.setErrors(null); this.outEvent.emit({ type: 'WRITE_SUCCESS', payload: { newValue: newValue, }, }); })); } }) .catch((err) => { this.addFormError.bind(err); throw err; }); } onKeydown(event) { if (event.key === 'Enter') { this.submit(); } else if (event.key === 'Escape') { this.close(); } } ngAfterViewInit() { setTimeout(() => { // if (!this.inputref.nativeElement) { // console.warn('no this.inputref'); // return; // } this.inputref.setFocus(); }, 200); } close() { this.outEvent.emit({ type: 'CLOSE', }); } addFormError(err) { console.warn('Form error', err); this.myControl.setErrors({ write: err.message, }); this.outEvent.emit({ type: 'WRITE_ERROR', payload: { error: err, }, }); } refresh() { if (!this._variable) { throw LibError.componentArgumentRequired(this.constructor.name, 'variable'); } this.startAction(this._variable .read() .then((v) => { this.value = v; }) .catch(this.addFormError.bind(this))).catch((err) => { console.log(err); }); } startAction(actions) { this.setLoading(true); return actions.finally(() => this.setLoading(false)); } setLoading(value) { this.loading = value; if (this.loading) { this.myControl.disable(); } else { this.myControl.enable(); } } setStream(stream) { this.subscription?.unsubscribe(); if (stream) { this.subscription = stream.subscribe({ next: (value) => { this.value = value; }, error: (err) => { this.myControl.setErrors({ refresh: err.message, }); }, }); } } constructor(tapService) { this.pendingCallManager = PendingCallManager.create(tapService); this.loading = false; } ngOnInit() { this.refresh(); } /** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MonitoringEditTextComponent, deps: [{ token: i1.CurrentDeviceService }], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: MonitoringEditTextComponent, selector: "monitoring-edit-text", inputs: { inputStream: "inputStream", variable: "variable", label: "label", input: "input", type: "type", actions: "actions", clearInput: "clearInput", clearOnEdit: "clearOnEdit", color: "color", disabled: "disabled", inputMode: "inputMode", max: "max", min: "min", maxLength: "maxLength", minLength: "minLength", name: "name", pattern: "pattern", placeholder: "placeholder", readonly: "readonly", required: "required", value: "value" }, outputs: { outEvent: "outEvent" }, viewQueries: [{ propertyName: "inputref", first: true, predicate: ["inputref"], descendants: true }], ngImport: i0, template: "<ion-item [formGroup]=\"myGroup\">\n <ion-input\n auto-focus\n (keydown)=\"onKeydown($event)\"\n #inputref\n formControlName=\"myControl\"\n [max]=\"max\"\n [maxlength]=\"maxLength\"\n [min]=\"min\"\n [minlength]=\"minLength\"\n [placeholder]=\"placeholder\"\n [required]=\"required\"\n [type]=\"type\"\n label=\"label\"\n labelPlacement=\"start\"\n >\n </ion-input>\n <ion-buttons>\n <ion-button [disabled]=\"loading\" (click)=\"submit()\">\n <ion-icon name=\"send\" slot=\"start\"></ion-icon>\n <!-- Write -->\n </ion-button>\n <ion-button [disabled]=\"loading\" (click)=\"refresh()\">\n <ion-icon name=\"refresh\" slot=\"start\"></ion-icon>\n <!-- Refresh -->\n </ion-button>\n <ion-button [disabled]=\"loading\" (click)=\"close()\">\n <ion-icon name=\"close\" slot=\"start\"></ion-icon>\n </ion-button>\n </ion-buttons>\n <ion-spinner [style.opacity]=\"loading ? 1 : 0\" name=\"lines\"></ion-spinner>\n</ion-item>\n<ion-item\n class=\"validation-errors\"\n *ngIf=\"\n myControl.dirty &&\n myControl.errors &&\n (myControl.errors | keyvalue).length > 0\n \"\n>\n <!-- {{ myControl.errors | json}} -->\n <ng-container *ngFor=\"let item of myControl.errors | keyvalue\">\n <ion-text color=\"danger error-message \">{{ errorToString(item) }}</ion-text>\n </ng-container>\n</ion-item>\n", styles: [".error-message{font-weight:700}ion-item{background:#ccc}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: ["minlength"] }, { kind: "directive", type: i3.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "component", type: i4.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i4.IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { kind: "component", type: i4.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i4.IonInput, selector: "ion-input", inputs: ["autocapitalize", "autocomplete", "autocorrect", "autofocus", "clearInput", "clearInputIcon", "clearOnEdit", "color", "counter", "counterFormatter", "debounce", "disabled", "enterkeyhint", "errorText", "fill", "helperText", "inputmode", "label", "labelPlacement", "max", "maxlength", "min", "minlength", "mode", "multiple", "name", "pattern", "placeholder", "readonly", "required", "shape", "spellcheck", "step", "type", "value"] }, { kind: "component", type: i4.IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: i4.IonSpinner, selector: "ion-spinner", inputs: ["color", "duration", "name", "paused"] }, { kind: "component", type: i4.IonText, selector: "ion-text", inputs: ["color", "mode"] }, { kind: "directive", type: i4.TextValueAccessor, selector: "ion-input:not([type=number]),ion-input-otp[type=text],ion-textarea,ion-searchbar" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "pipe", type: i2.KeyValuePipe, name: "keyvalue" }] }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MonitoringEditTextComponent, decorators: [{ type: Component, args: [{ selector: 'monitoring-edit-text', template: "<ion-item [formGroup]=\"myGroup\">\n <ion-input\n auto-focus\n (keydown)=\"onKeydown($event)\"\n #inputref\n formControlName=\"myControl\"\n [max]=\"max\"\n [maxlength]=\"maxLength\"\n [min]=\"min\"\n [minlength]=\"minLength\"\n [placeholder]=\"placeholder\"\n [required]=\"required\"\n [type]=\"type\"\n label=\"label\"\n labelPlacement=\"start\"\n >\n </ion-input>\n <ion-buttons>\n <ion-button [disabled]=\"loading\" (click)=\"submit()\">\n <ion-icon name=\"send\" slot=\"start\"></ion-icon>\n <!-- Write -->\n </ion-button>\n <ion-button [disabled]=\"loading\" (click)=\"refresh()\">\n <ion-icon name=\"refresh\" slot=\"start\"></ion-icon>\n <!-- Refresh -->\n </ion-button>\n <ion-button [disabled]=\"loading\" (click)=\"close()\">\n <ion-icon name=\"close\" slot=\"start\"></ion-icon>\n </ion-button>\n </ion-buttons>\n <ion-spinner [style.opacity]=\"loading ? 1 : 0\" name=\"lines\"></ion-spinner>\n</ion-item>\n<ion-item\n class=\"validation-errors\"\n *ngIf=\"\n myControl.dirty &&\n myControl.errors &&\n (myControl.errors | keyvalue).length > 0\n \"\n>\n <!-- {{ myControl.errors | json}} -->\n <ng-container *ngFor=\"let item of myControl.errors | keyvalue\">\n <ion-text color=\"danger error-message \">{{ errorToString(item) }}</ion-text>\n </ng-container>\n</ion-item>\n", styles: [".error-message{font-weight:700}ion-item{background:#ccc}\n"] }] }], ctorParameters: () => [{ type: i1.CurrentDeviceService }], propDecorators: { inputref: [{ type: ViewChild, args: ['inputref', { static: false }] }], inputStream: [{ type: Input }], variable: [{ type: Input }], label: [{ type: Input }], input: [{ type: Input }], type: [{ type: Input }], actions: [{ type: Input }], clearInput: [{ type: Input }], clearOnEdit: [{ type: Input }], color: [{ type: Input }], disabled: [{ type: Input }], inputMode: [{ type: Input }], max: [{ type: Input }], min: [{ type: Input }], maxLength: [{ type: Input }], minLength: [{ type: Input }], name: [{ type: Input }], pattern: [{ type: Input }], placeholder: [{ type: Input }], readonly: [{ type: Input }], required: [{ type: Input }], value: [{ type: Input }], outEvent: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monitoring-edit-text.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/monitoring-edit-text/monitoring-edit-text.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/monitoring-edit-text/monitoring-edit-text.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  EventEmitter,\n  inject,\n  Input,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { FormBuilder, FormControl, Validators } from '@angular/forms';\nimport { AbstractVariable } from '@iotize/tap/data';\nimport {\n  CurrentDeviceService,\n  LibError,\n  PendingCallManager,\n} from '@iotize/ionic';\nimport { Observable, Subject, Subscription } from 'rxjs';\n\nexport interface MonitoringEditTextEvent {\n  type: 'CLOSE' | 'WRITE_SUCCESS' | 'WRITE_ERROR';\n  payload?: any;\n}\n\n/**\n * @deprecated\n */\n@Component({\n  selector: 'monitoring-edit-text',\n  templateUrl: './monitoring-edit-text.component.html',\n  styleUrls: ['./monitoring-edit-text.component.scss'],\n})\nexport class MonitoringEditTextComponent implements OnInit, AfterViewInit {\n  loading = false;\n\n  validationMessages = {\n    required: 'Input is required',\n    minlength: 'Input is too short',\n    maxlength: 'Input is too long',\n    pattern: 'Input does not match pattern',\n  };\n\n  private subscription?: Subscription;\n\n  _variable?: AbstractVariable<any>;\n\n  @ViewChild('inputref', { static: false }) inputref: any;\n  pendingCallManager: PendingCallManager;\n\n  @Input()\n  set inputStream(stream: Observable<any> | undefined) {\n    this.setStream(stream);\n  }\n\n  @Input() set variable(variable: AbstractVariable<any>) {\n    this._variable = variable;\n  }\n\n  @Input() label?: string = undefined;\n  @Input() input = 'string';\n  @Input() type = 'string';\n  @Input() actions?: Subject<any>;\n\n  @Input() clearInput = false;\n  @Input() clearOnEdit = false;\n  @Input() color = 'primary';\n  @Input() disabled = false;\n  @Input() inputMode = 'text';\n  @Input() max?: number = undefined;\n  @Input() min?: number = undefined;\n  @Input() maxLength?: number = undefined;\n  @Input() minLength?: number = undefined;\n  @Input() name? = undefined;\n  @Input() pattern? = undefined;\n  @Input() placeholder? = undefined;\n  @Input() readonly = false;\n  @Input() required = false;\n\n  @Input() set value(v: any) {\n    this.myControl.setValue(v);\n  }\n\n  @Output() outEvent = new EventEmitter<MonitoringEditTextEvent>();\n\n  public myControl: FormControl = new FormControl(\n    '',\n    Validators.compose([\n      Validators.required,\n      // Validators.maxLength(this.minLength),\n      // Validators.minLength(this.maxLength),\n      // Validators.pattern(this.pattern),\n    ])\n  );\n\n  protected formBuilder = inject(FormBuilder);\n\n  myGroup = this.formBuilder.group({\n    myControl: this.myControl,\n  });\n\n  errorToString(item: { key: string; value: any }) {\n    if (item.key in this.validationMessages) {\n      return (this.validationMessages as any)[item.key];\n    }\n    return item.value;\n  }\n\n  submit() {\n    const newValue = this.myControl.value;\n    if (this.actions) {\n      this.actions.next(newValue);\n    }\n    if (!this._variable) {\n      throw LibError.componentArgumentRequired(\n        this.constructor.name,\n        'variable'\n      );\n    }\n\n    this.pendingCallManager\n      .exec(async () => {\n        if (this._variable) {\n          await this.startAction(\n            this._variable.write(newValue).then(() => {\n              this.myControl.setErrors(null);\n              this.outEvent.emit({\n                type: 'WRITE_SUCCESS',\n                payload: {\n                  newValue: newValue,\n                },\n              });\n            })\n          );\n        }\n      })\n      .catch((err) => {\n        this.addFormError.bind(err);\n        throw err;\n      });\n  }\n\n  onKeydown(event: KeyboardEvent) {\n    if (event.key === 'Enter') {\n      this.submit();\n    } else if (event.key === 'Escape') {\n      this.close();\n    }\n  }\n\n  ngAfterViewInit() {\n    setTimeout(() => {\n      // if (!this.inputref.nativeElement) {\n      //   console.warn('no this.inputref');\n      //   return;\n      // }\n      this.inputref.setFocus();\n    }, 200);\n  }\n\n  close() {\n    this.outEvent.emit({\n      type: 'CLOSE',\n    });\n  }\n\n  private addFormError(err: Error) {\n    console.warn('Form error', err);\n    this.myControl.setErrors({\n      write: err.message,\n    });\n    this.outEvent.emit({\n      type: 'WRITE_ERROR',\n      payload: {\n        error: err,\n      },\n    });\n  }\n\n  refresh() {\n    if (!this._variable) {\n      throw LibError.componentArgumentRequired(\n        this.constructor.name,\n        'variable'\n      );\n    }\n    this.startAction(\n      this._variable\n        .read()\n        .then((v) => {\n          this.value = v;\n        })\n        .catch(this.addFormError.bind(this))\n    ).catch((err) => {\n      console.log(err);\n    });\n  }\n\n  private startAction(actions: Promise<any>): Promise<any> {\n    this.setLoading(true);\n    return actions.finally(() => this.setLoading(false));\n  }\n\n  setLoading(value: boolean): void {\n    this.loading = value;\n    if (this.loading) {\n      this.myControl.disable();\n    } else {\n      this.myControl.enable();\n    }\n  }\n\n  private setStream(stream: Observable<any> | undefined) {\n    this.subscription?.unsubscribe();\n    if (stream) {\n      this.subscription = stream.subscribe({\n        next: (value) => {\n          this.value = value;\n        },\n        error: (err) => {\n          this.myControl.setErrors({\n            refresh: err.message,\n          });\n        },\n      });\n    }\n  }\n\n  constructor(tapService: CurrentDeviceService) {\n    this.pendingCallManager = PendingCallManager.create(tapService);\n    this.loading = false;\n  }\n\n  ngOnInit() {\n    this.refresh();\n  }\n}\n","<ion-item [formGroup]=\"myGroup\">\n  <ion-input\n    auto-focus\n    (keydown)=\"onKeydown($event)\"\n    #inputref\n    formControlName=\"myControl\"\n    [max]=\"max\"\n    [maxlength]=\"maxLength\"\n    [min]=\"min\"\n    [minlength]=\"minLength\"\n    [placeholder]=\"placeholder\"\n    [required]=\"required\"\n    [type]=\"type\"\n    label=\"label\"\n    labelPlacement=\"start\"\n  >\n  </ion-input>\n  <ion-buttons>\n    <ion-button [disabled]=\"loading\" (click)=\"submit()\">\n      <ion-icon name=\"send\" slot=\"start\"></ion-icon>\n      <!-- Write -->\n    </ion-button>\n    <ion-button [disabled]=\"loading\" (click)=\"refresh()\">\n      <ion-icon name=\"refresh\" slot=\"start\"></ion-icon>\n      <!-- Refresh -->\n    </ion-button>\n    <ion-button [disabled]=\"loading\" (click)=\"close()\">\n      <ion-icon name=\"close\" slot=\"start\"></ion-icon>\n    </ion-button>\n  </ion-buttons>\n  <ion-spinner [style.opacity]=\"loading ? 1 : 0\" name=\"lines\"></ion-spinner>\n</ion-item>\n<ion-item\n  class=\"validation-errors\"\n  *ngIf=\"\n    myControl.dirty &&\n    myControl.errors &&\n    (myControl.errors | keyvalue).length > 0\n  \"\n>\n  <!-- {{ myControl.errors | json}} -->\n  <ng-container *ngFor=\"let item of myControl.errors | keyvalue\">\n    <ion-text color=\"danger error-message \">{{ errorToString(item) }}</ion-text>\n  </ng-container>\n</ion-item>\n"]}