@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
88 lines • 15.7 kB
JavaScript
import { ChangeDetectorRef, Component, Input } from '@angular/core';
import { CurrentDeviceService, PendingCallManager } from '@iotize/ionic';
import { Observable } from 'rxjs';
import * as i0 from "@angular/core";
import * as i1 from "@iotize/ionic";
import * as i2 from "@angular/common";
import * as i3 from "@ionic/angular";
export class TapVariableSwitchPictureComponent {
set fieldError(err) {
this.error = err;
}
get pending() {
return this.pendingCallManager.pendingCall !== undefined;
}
set variable(variable) {
this._variable = variable;
if (variable) {
this.inputStream = variable.values;
}
}
set inputStream(inputs) {
this.subscription = inputs.subscribe((value) => {
this.state = value;
this.pictures.filter((picture) => {
if (picture.index === this.state) {
this.currentSrc = picture.src;
this.loaded = true;
}
});
});
}
constructor(changeDetectorRef, tapService) {
this.changeDetectorRef = changeDetectorRef;
this.state = 0;
this.loaded = false;
this.stateText = 'State';
this.pendingCallManager = PendingCallManager.create(tapService);
}
ngOnDestroy() {
this.subscription?.unsubscribe();
this.pendingCallManager.destroy();
}
switchPicture() {
if (this.editable) {
this.state++;
if (this.state === this.pictures.length + 1) {
this.state = 1;
}
this.pictures.filter((value) => {
if (value.index === this.state) {
this.pendingCallManager
.exec(async () => this._variable?.write(value.src).then(() => {
this.changeDetectorRef.detectChanges();
}))
.catch((err) => {
if (!this.pending) {
this.fieldError = err;
}
else {
this.pendingSubmitValue = value.src;
}
this.changeDetectorRef.detectChanges();
});
this.currentSrc = value.src;
}
});
}
}
}
/** @nocollapse */ TapVariableSwitchPictureComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TapVariableSwitchPictureComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.CurrentDeviceService }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ TapVariableSwitchPictureComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TapVariableSwitchPictureComponent, selector: "tap-variable-switch-picture", inputs: { fieldError: "fieldError", pictures: "pictures", stateText: "stateText", editable: "editable", variable: "variable", inputStream: "inputStream" }, ngImport: i0, template: "<ion-item-sliding [disabled]=\"!error\">\n <ion-item>\n <ion-thumbnail slot=\"start\">\n <img *ngIf=\"loaded\" (click)=\"switchPicture()\" [src]=\"currentSrc\" />\n <ion-spinner\n style=\"height: 100%; width: 100%\"\n *ngIf=\"!loaded\"\n name=\"crescent\"\n color=\"primary\"\n ></ion-spinner>\n </ion-thumbnail>\n <ion-label>{{ stateText }} : {{ state }}</ion-label>\n <ion-icon\n slot=\"end\"\n *ngIf=\"error\"\n name=\"alert-outline\"\n color=\"danger\"\n ></ion-icon>\n </ion-item>\n\n <ion-item-options side=\"end\" style=\"max-width: 85%\">\n <ion-item-option color=\"danger\">\n <ion-text *ngIf=\"error\" color=\"light\" style=\"max-width: 100%\">\n <span style=\"text-transform: none !important\">{{ error.message }}</span>\n </ion-text>\n </ion-item-option>\n </ion-item-options>\n</ion-item-sliding>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i3.IonItem, selector: "ion-item", inputs: ["button", "color", "counter", "counterFormatter", "detail", "detailIcon", "disabled", "download", "fill", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "shape", "target", "type"] }, { kind: "component", type: i3.IonItemOption, selector: "ion-item-option", inputs: ["color", "disabled", "download", "expandable", "href", "mode", "rel", "target", "type"] }, { kind: "component", type: i3.IonItemOptions, selector: "ion-item-options", inputs: ["side"] }, { kind: "component", type: i3.IonItemSliding, selector: "ion-item-sliding", inputs: ["disabled"] }, { kind: "component", type: i3.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: i3.IonSpinner, selector: "ion-spinner", inputs: ["color", "duration", "name", "paused"] }, { kind: "component", type: i3.IonText, selector: "ion-text", inputs: ["color", "mode"] }, { kind: "component", type: i3.IonThumbnail, selector: "ion-thumbnail" }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TapVariableSwitchPictureComponent, decorators: [{
type: Component,
args: [{ selector: 'tap-variable-switch-picture', template: "<ion-item-sliding [disabled]=\"!error\">\n <ion-item>\n <ion-thumbnail slot=\"start\">\n <img *ngIf=\"loaded\" (click)=\"switchPicture()\" [src]=\"currentSrc\" />\n <ion-spinner\n style=\"height: 100%; width: 100%\"\n *ngIf=\"!loaded\"\n name=\"crescent\"\n color=\"primary\"\n ></ion-spinner>\n </ion-thumbnail>\n <ion-label>{{ stateText }} : {{ state }}</ion-label>\n <ion-icon\n slot=\"end\"\n *ngIf=\"error\"\n name=\"alert-outline\"\n color=\"danger\"\n ></ion-icon>\n </ion-item>\n\n <ion-item-options side=\"end\" style=\"max-width: 85%\">\n <ion-item-option color=\"danger\">\n <ion-text *ngIf=\"error\" color=\"light\" style=\"max-width: 100%\">\n <span style=\"text-transform: none !important\">{{ error.message }}</span>\n </ion-text>\n </ion-item-option>\n </ion-item-options>\n</ion-item-sliding>\n" }]
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.CurrentDeviceService }]; }, propDecorators: { fieldError: [{
type: Input
}], pictures: [{
type: Input
}], stateText: [{
type: Input
}], editable: [{
type: Input
}], variable: [{
type: Input
}], inputStream: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tap-variable-switch-picture.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-switch-picture/tap-variable-switch-picture.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-switch-picture/tap-variable-switch-picture.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Input, OnDestroy } from '@angular/core';\nimport { CurrentDeviceService, PendingCallManager } from '@iotize/ionic';\nimport { AbstractVariable } from '@iotize/tap/data';\nimport { Observable, Subscription } from 'rxjs';\nimport { AppGenField } from '../../metadata/decorators';\nimport { TAP_VARIABLE_SCHEMA } from '../shared-schema';\n\nexport interface PictureData {\n  index: number;\n  src: string;\n}\n\n@Component({\n  selector: 'tap-variable-switch-picture',\n  templateUrl: './tap-variable-switch-picture.component.html',\n  styleUrls: ['./tap-variable-switch-picture.component.scss'],\n})\nexport class TapVariableSwitchPictureComponent implements OnDestroy {\n  state = 0;\n  currentSrc?: string;\n\n  subscription?: Subscription;\n  pendingCallManager: PendingCallManager;\n  pendingSubmitValue: any;\n\n  public error?: Error;\n\n  loaded = false;\n\n  _variable?: AbstractVariable<any>;\n\n  @Input() set fieldError(err: Error) {\n    this.error = err;\n  }\n\n  get pending(): boolean {\n    return this.pendingCallManager.pendingCall !== undefined;\n  }\n\n  @Input() pictures!: PictureData[];\n\n  @Input() stateText = 'State';\n\n  @Input()\n  editable?: boolean;\n\n  @Input()\n  set variable(variable: AbstractVariable<any | any[]> | undefined) {\n    this._variable = variable;\n    if (variable) {\n      this.inputStream = variable.values;\n    }\n  }\n\n  @Input()\n  set inputStream(inputs: Observable<any>) {\n    this.subscription = inputs.subscribe((value) => {\n      this.state = value;\n      this.pictures.filter((picture) => {\n        if (picture.index === this.state) {\n          this.currentSrc = picture.src;\n          this.loaded = true;\n        }\n      });\n    });\n  }\n\n  constructor(\n    private changeDetectorRef: ChangeDetectorRef,\n    tapService: CurrentDeviceService\n  ) {\n    this.pendingCallManager = PendingCallManager.create(tapService);\n  }\n  ngOnDestroy(): void {\n    this.subscription?.unsubscribe();\n    this.pendingCallManager.destroy();\n  }\n\n  switchPicture() {\n    if (this.editable) {\n      this.state++;\n      if (this.state === this.pictures.length + 1) {\n        this.state = 1;\n      }\n      this.pictures.filter((value) => {\n        if (value.index === this.state) {\n          this.pendingCallManager\n            .exec(async () =>\n              this._variable?.write(value.src).then(() => {\n                this.changeDetectorRef.detectChanges();\n              })\n            )\n            .catch((err) => {\n              if (!this.pending) {\n                this.fieldError = err;\n              } else {\n                this.pendingSubmitValue = value.src;\n              }\n              this.changeDetectorRef.detectChanges();\n            });\n          this.currentSrc = value.src;\n        }\n      });\n    }\n  }\n}\n","<ion-item-sliding [disabled]=\"!error\">\n  <ion-item>\n    <ion-thumbnail slot=\"start\">\n      <img *ngIf=\"loaded\" (click)=\"switchPicture()\" [src]=\"currentSrc\" />\n      <ion-spinner\n        style=\"height: 100%; width: 100%\"\n        *ngIf=\"!loaded\"\n        name=\"crescent\"\n        color=\"primary\"\n      ></ion-spinner>\n    </ion-thumbnail>\n    <ion-label>{{ stateText }} : {{ state }}</ion-label>\n    <ion-icon\n      slot=\"end\"\n      *ngIf=\"error\"\n      name=\"alert-outline\"\n      color=\"danger\"\n    ></ion-icon>\n  </ion-item>\n\n  <ion-item-options side=\"end\" style=\"max-width: 85%\">\n    <ion-item-option color=\"danger\">\n      <ion-text *ngIf=\"error\" color=\"light\" style=\"max-width: 100%\">\n        <span style=\"text-transform: none !important\">{{ error.message }}</span>\n      </ion-text>\n    </ion-item-option>\n  </ion-item-options>\n</ion-item-sliding>\n"]}