UNPKG

@iotize/ionic

Version:

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

161 lines 29.7 kB
import { Component, Input } from '@angular/core'; import { Router } from '@angular/router'; import { getAbstractVariableOrError, LibError } from '@iotize/ionic'; import { AbstractVariable, TapVariable } from '@iotize/tap/data'; import * as i0 from "@angular/core"; import * as i1 from "@angular/router"; import * as i2 from "@angular/common"; import * as i3 from "@ionic/angular"; import * as i4 from "../monitoring-variable-value/monitoring-variable-value.component"; import * as i5 from "../tap-variable-range/tap-variable-range.component"; import * as i6 from "../tap-variable-buttons/tap-variable-buttons.component"; import * as i7 from "../tap-variable-toggle/tap-variable-toggle.component"; import * as i8 from "../tap-variable-select/tap-variable-select.component"; export class VariableCardComponent { router; waitForSubmit = false; cardType = 'text'; cardTypes = [ // 'chart', 'gauge', 'switch', 'text', 'buttons', 'range', 'select', ]; editMode = false; monitor = true; showStartStopMonitoring = false; unit = ''; bundleName = '...'; error; value = 'Unknown'; refreshValues = false; monitoringButtons = [0, 1, 2, 3, 4, 5].map((v) => { return { label: `${v}`, value: v, }; }); selectOptions = [0, 1, 2, 3, 4, 5].map((v) => { return { key: v, text: `Value ${v}`, }; }); _variable; _subscription; // private _switchButtonSubscription?: Subscription; set variable(variable) { // console.log('VariableCardComponent', 'SET VARIABLE', variable); this._variable = variable; if (this._subscription) { this._subscription.unsubscribe(); } this._subscription = variable.values.subscribe({ next: (value) => { if (this.refreshValues) { this.value = value; } }, error: (error) => { // console.warn(`Monitoring error: `, error); this.error = error; }, complete: () => { // console.warn('VariableCardComponent', 'values observable is complete') }, }); } get variable() { return getAbstractVariableOrError(this._variable); } constructor(router) { this.router = router; } get variableConfig() { if (this._variable instanceof TapVariable) { return this._variable.context.config; } return undefined; } // editConfig() { // this.router.navigate(['/device/monitoring/add']); // } async switchButtonToggleAction(checked) { if (!this._variable) { throw LibError.componentArgumentRequired('VariableCardComponent', 'variable'); } const value = checked ? 1 : 0; await this._variable.write(value); // .catch((error) => { // console.warn(`Cannot write ${this._variable.identifier()}: ${error}`) // this.error = error; // }) } // onEditEvent(event: MonitoringEditTextEvent) { // console.log('EDIT EVENT => ', event); // switch (event.type) { // case 'CLOSE': // this.editMode = false; // break; // case 'WRITE_SUCCESS': // this.editMode = false; // break; // } // } ngOnDestroy() { if (this._subscription) { this._subscription.unsubscribe(); } // if (this._switchButtonSubscription) { // this._switchButtonSubscription.unsubscribe(); // } } onCardTypeChange($event) { // console.log('onCardTypeChange', $event); // this.cardType = $event.detail.value; } toggleMonitoring() { // if (this.monitor) { // if (!this._variable) { // throw LibError.componentArgumentRequired('VariableCardComponent', 'variable'); // } this.refreshValues = !this.refreshValues; // if (this.refreshValues) { // // console.log('Start monitoring with period: ', this.monitoringPeriod); // this._variable.monitor().start({ // forceChange: false, // period: this.monitoringPeriod // }); // } else { // // console.log('Pause monitoring'); // this._variable.monitor().pause(); // } // } } /** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: VariableCardComponent, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: VariableCardComponent, selector: "app-variable-card", inputs: { cardType: "cardType", cardTypes: "cardTypes", editMode: "editMode", monitor: "monitor", showStartStopMonitoring: "showStartStopMonitoring", unit: "unit", bundleName: "bundleName", variable: "variable" }, ngImport: i0, template: "<ion-card *ngIf=\"_variable\">\n <ion-item lines=\"none\">\n <ion-label slot=\"start\">{{ bundleName }}</ion-label>\n <ion-label slot=\"end\">#{{ _variable.id }}</ion-label>\n </ion-item>\n <!-- <ion-item>\n <ion-icon *ngIf=\"icon\" name=\"{{icon}}\" slot=\"start\"></ion-icon>\n <ion-label>{{variable.identifier() || variableConfig.id }}</ion-label>\n </ion-item> -->\n <ion-card-content *ngIf=\"monitor\">\n <ng-container [ngSwitch]=\"cardType\">\n <ion-item *ngSwitchCase=\"'text'\" lines=\"none\" class=\"ion-no-padding\">\n <monitoring-variable-value\n style=\"margin: auto\"\n [lines]=\"'none'\"\n [variable]=\"variable\"\n [editable]=\"editMode\"\n ></monitoring-variable-value>\n <span slot=\"end\" *ngIf=\"unit\" class=\"unit\">{{ unit }}</span>\n </ion-item>\n <ion-item *ngSwitchCase=\"'select'\" lines=\"none\" class=\"ion-no-padding\">\n <tap-variable-select\n style=\"margin: auto\"\n [lines]=\"'none'\"\n [variable]=\"variable\"\n [options]=\"selectOptions\"\n [editable]=\"editMode\"\n ></tap-variable-select>\n <span slot=\"end\" *ngIf=\"unit\" class=\"unit\">{{ unit }}</span>\n </ion-item>\n <tap-variable-toggle\n *ngSwitchCase=\"'switch'\"\n [variable]=\"_variable\"\n ></tap-variable-toggle>\n <tap-variable-buttons\n *ngSwitchCase=\"'buttons'\"\n [variable]=\"variable\"\n [buttons]=\"monitoringButtons\"\n ></tap-variable-buttons>\n <tap-variable-range\n *ngSwitchCase=\"'range'\"\n [variable]=\"_variable\"\n [pin]=\"true\"\n [snaps]=\"true\"\n [ticks]=\"true\"\n [min]=\"0\"\n [max]=\"100\"\n ></tap-variable-range>\n <ion-text color=\"danger\" *ngSwitchDefault>\n <ion-icon name=\"alert\"></ion-icon> Unknown card type {{ cardType }}\n </ion-text>\n </ng-container>\n </ion-card-content>\n <ion-card-content *ngIf=\"error\">\n <ion-text color=\"danger\">{{ error }}</ion-text>\n </ion-card-content>\n <!--\n <ion-item>\n <ion-select\n [(ngModel)]=\"cardType\"\n okText=\"Select\"\n cancelText=\"Dismiss\"\n (ionChange)=\"onCardTypeChange($event)\"\n >\n <ion-select-option\n *ngFor=\"let cardType of cardTypes\"\n value=\"{{ cardType }}\"\n >{{ cardType }}</ion-select-option\n >\n </ion-select>\n <ion-buttons slot=\"end\">\n <ion-button (click)=\"toggleMonitoring()\" *ngIf=\"showStartStopMonitoring\">\n <ion-icon *ngIf=\"!playMonitoring\" name=\"play\"></ion-icon>\n <ion-icon *ngIf=\"playMonitoring\" name=\"pause\"></ion-icon>\n </ion-button>\n <ion-button (click)=\"editMode = !editMode\">\n <ion-icon *ngIf=\"!editMode\" name=\"create\"></ion-icon> <span *ngIf=\"!editMode\"></span>\n <ion-icon *ngIf=\"editMode\" name=\"close\"></ion-icon> \n </ion-button>\n <ion-button (click)=\"editConfig()\">\n \n <ion-icon name=\"cog\"></ion-icon> \n </ion-button>\n </ion-buttons>\n </ion-item>\n -->\n</ion-card>\n", styles: [".variable-value{font-size:1.4em;font-weight:700}ion-card-content{text-align:center}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i2.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i3.IonCard, selector: "ion-card", inputs: ["button", "color", "disabled", "download", "href", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: i3.IonCardContent, selector: "ion-card-content", inputs: ["mode"] }, { 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", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: i3.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: i3.IonText, selector: "ion-text", inputs: ["color", "mode"] }, { kind: "component", type: i4.MonitoringVariableValueComponent, selector: "monitoring-variable-value", inputs: ["lines", "unitValue", "error", "variable", "config", "inputOptions", "editable", "modalEdition", "valueStyle", "digitsInfo", "refreshable", "valueFormatting"] }, { kind: "component", type: i5.TapVariableRangeComponent, selector: "tap-variable-range", inputs: ["variable", "editable", "writeValueForEveryChange", "min", "max", "step", "color", "pin", "snaps", "ticks", "debounce", "leftIcon", "leftIconColor", "rightIcon", "rightIconColor", "value"], outputs: ["valueChange"] }, { kind: "component", type: i6.TapVariableButtonsComponent, selector: "tap-variable-buttons", inputs: ["variable", "editable", "color", "segment", "buttons"] }, { kind: "component", type: i7.TapVariableToggleComponent, selector: "tap-variable-toggle", inputs: ["textOnLeft", "textOnRight", "lines", "toggleColor", "variable", "editable", "valueOn", "valueOff", "chip"] }, { kind: "component", type: i8.TapVariableSelectComponent, selector: "tap-variable-select", inputs: ["variable", "value", "editable", "refreshable", "multiple", "lines", "options"], outputs: ["valueChange"] }] }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: VariableCardComponent, decorators: [{ type: Component, args: [{ selector: 'app-variable-card', template: "<ion-card *ngIf=\"_variable\">\n <ion-item lines=\"none\">\n <ion-label slot=\"start\">{{ bundleName }}</ion-label>\n <ion-label slot=\"end\">#{{ _variable.id }}</ion-label>\n </ion-item>\n <!-- <ion-item>\n <ion-icon *ngIf=\"icon\" name=\"{{icon}}\" slot=\"start\"></ion-icon>\n <ion-label>{{variable.identifier() || variableConfig.id }}</ion-label>\n </ion-item> -->\n <ion-card-content *ngIf=\"monitor\">\n <ng-container [ngSwitch]=\"cardType\">\n <ion-item *ngSwitchCase=\"'text'\" lines=\"none\" class=\"ion-no-padding\">\n <monitoring-variable-value\n style=\"margin: auto\"\n [lines]=\"'none'\"\n [variable]=\"variable\"\n [editable]=\"editMode\"\n ></monitoring-variable-value>\n <span slot=\"end\" *ngIf=\"unit\" class=\"unit\">{{ unit }}</span>\n </ion-item>\n <ion-item *ngSwitchCase=\"'select'\" lines=\"none\" class=\"ion-no-padding\">\n <tap-variable-select\n style=\"margin: auto\"\n [lines]=\"'none'\"\n [variable]=\"variable\"\n [options]=\"selectOptions\"\n [editable]=\"editMode\"\n ></tap-variable-select>\n <span slot=\"end\" *ngIf=\"unit\" class=\"unit\">{{ unit }}</span>\n </ion-item>\n <tap-variable-toggle\n *ngSwitchCase=\"'switch'\"\n [variable]=\"_variable\"\n ></tap-variable-toggle>\n <tap-variable-buttons\n *ngSwitchCase=\"'buttons'\"\n [variable]=\"variable\"\n [buttons]=\"monitoringButtons\"\n ></tap-variable-buttons>\n <tap-variable-range\n *ngSwitchCase=\"'range'\"\n [variable]=\"_variable\"\n [pin]=\"true\"\n [snaps]=\"true\"\n [ticks]=\"true\"\n [min]=\"0\"\n [max]=\"100\"\n ></tap-variable-range>\n <ion-text color=\"danger\" *ngSwitchDefault>\n <ion-icon name=\"alert\"></ion-icon> Unknown card type {{ cardType }}\n </ion-text>\n </ng-container>\n </ion-card-content>\n <ion-card-content *ngIf=\"error\">\n <ion-text color=\"danger\">{{ error }}</ion-text>\n </ion-card-content>\n <!--\n <ion-item>\n <ion-select\n [(ngModel)]=\"cardType\"\n okText=\"Select\"\n cancelText=\"Dismiss\"\n (ionChange)=\"onCardTypeChange($event)\"\n >\n <ion-select-option\n *ngFor=\"let cardType of cardTypes\"\n value=\"{{ cardType }}\"\n >{{ cardType }}</ion-select-option\n >\n </ion-select>\n <ion-buttons slot=\"end\">\n <ion-button (click)=\"toggleMonitoring()\" *ngIf=\"showStartStopMonitoring\">\n <ion-icon *ngIf=\"!playMonitoring\" name=\"play\"></ion-icon>\n <ion-icon *ngIf=\"playMonitoring\" name=\"pause\"></ion-icon>\n </ion-button>\n <ion-button (click)=\"editMode = !editMode\">\n <ion-icon *ngIf=\"!editMode\" name=\"create\"></ion-icon> <span *ngIf=\"!editMode\"></span>\n <ion-icon *ngIf=\"editMode\" name=\"close\"></ion-icon> \n </ion-button>\n <ion-button (click)=\"editConfig()\">\n \n <ion-icon name=\"cog\"></ion-icon> \n </ion-button>\n </ion-buttons>\n </ion-item>\n -->\n</ion-card>\n", styles: [".variable-value{font-size:1.4em;font-weight:700}ion-card-content{text-align:center}\n"] }] }], ctorParameters: () => [{ type: i1.Router }], propDecorators: { cardType: [{ type: Input }], cardTypes: [{ type: Input }], editMode: [{ type: Input }], monitor: [{ type: Input }], showStartStopMonitoring: [{ type: Input }], unit: [{ type: Input }], bundleName: [{ type: Input }], variable: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"variable-card.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/variable-card/variable-card.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/variable-card/variable-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { getAbstractVariableOrError, LibError } from '@iotize/ionic';\nimport { AbstractVariable, TapVariable } from '@iotize/tap/data';\nimport { Subscription } from 'rxjs';\nimport { TapVariableButton } from '../tap-variable-buttons/tap-variable-buttons.component';\n\ntype CardType =\n  | 'gauge'\n  | 'text'\n  | 'chart'\n  | 'switch'\n  | 'buttons'\n  | 'range'\n  | 'select';\n\n@Component({\n  selector: 'app-variable-card',\n  templateUrl: './variable-card.component.html',\n  styleUrls: ['./variable-card.component.scss'],\n})\nexport class VariableCardComponent implements OnDestroy {\n  waitForSubmit = false;\n\n  @Input() cardType: CardType = 'text';\n\n  @Input() cardTypes: CardType[] = [\n    // 'chart',\n    'gauge',\n    'switch',\n    'text',\n    'buttons',\n    'range',\n    'select',\n  ];\n\n  @Input() editMode = false;\n\n  @Input() monitor = true;\n\n  @Input() showStartStopMonitoring = false;\n\n  @Input() unit = '';\n\n  @Input() bundleName = '...';\n\n  error?: Error;\n  value: any = 'Unknown';\n  refreshValues = false;\n\n  monitoringButtons: TapVariableButton[] = [0, 1, 2, 3, 4, 5].map((v) => {\n    return {\n      label: `${v}`,\n      value: v,\n    };\n  });\n\n  selectOptions = [0, 1, 2, 3, 4, 5].map((v) => {\n    return {\n      key: v,\n      text: `Value ${v}`,\n    };\n  });\n\n  public _variable?: AbstractVariable<any>;\n  private _subscription?: Subscription;\n  // private _switchButtonSubscription?: Subscription;\n\n  @Input() set variable(variable: AbstractVariable<any>) {\n    // console.log('VariableCardComponent', 'SET VARIABLE', variable);\n    this._variable = variable;\n    if (this._subscription) {\n      this._subscription.unsubscribe();\n    }\n    this._subscription = variable.values.subscribe({\n      next: (value) => {\n        if (this.refreshValues) {\n          this.value = value;\n        }\n      },\n      error: (error) => {\n        // console.warn(`Monitoring error: `, error);\n        this.error = error;\n      },\n      complete: () => {\n        // console.warn('VariableCardComponent', 'values observable is complete')\n      },\n    });\n  }\n\n  get variable(): AbstractVariable<any> {\n    return getAbstractVariableOrError(this._variable);\n  }\n\n  constructor(public router: Router) {}\n\n  get variableConfig(): TapVariable.Config | undefined {\n    if (this._variable instanceof TapVariable) {\n      return this._variable.context.config;\n    }\n    return undefined;\n  }\n\n  // editConfig() {\n  //   this.router.navigate(['/device/monitoring/add']);\n  // }\n\n  async switchButtonToggleAction(checked: boolean) {\n    if (!this._variable) {\n      throw LibError.componentArgumentRequired(\n        'VariableCardComponent',\n        'variable'\n      );\n    }\n    const value = checked ? 1 : 0;\n    await this._variable.write(value);\n    // .catch((error) => {\n    //   console.warn(`Cannot write ${this._variable.identifier()}: ${error}`)\n    //   this.error = error;\n    // })\n  }\n\n  // onEditEvent(event: MonitoringEditTextEvent) {\n  //   console.log('EDIT EVENT => ', event);\n  //   switch (event.type) {\n  //     case 'CLOSE':\n  //       this.editMode = false;\n  //       break;\n  //     case 'WRITE_SUCCESS':\n  //       this.editMode = false;\n  //       break;\n  //   }\n  // }\n\n  ngOnDestroy() {\n    if (this._subscription) {\n      this._subscription.unsubscribe();\n    }\n    // if (this._switchButtonSubscription) {\n    //   this._switchButtonSubscription.unsubscribe();\n    // }\n  }\n\n  onCardTypeChange($event: CustomEvent<{ value: CardType }>) {\n    // console.log('onCardTypeChange', $event);\n    // this.cardType = $event.detail.value;\n  }\n\n  toggleMonitoring() {\n    // if (this.monitor) {\n    // if (!this._variable) {\n    //   throw LibError.componentArgumentRequired('VariableCardComponent', 'variable');\n    // }\n    this.refreshValues = !this.refreshValues;\n    // if (this.refreshValues) {\n    //   // console.log('Start monitoring with period: ', this.monitoringPeriod);\n    //   this._variable.monitor().start({\n    //     forceChange: false,\n    //     period: this.monitoringPeriod\n    //   });\n    // } else {\n    //   // console.log('Pause monitoring');\n    //   this._variable.monitor().pause();\n    // }\n    // }\n  }\n}\n","<ion-card *ngIf=\"_variable\">\n  <ion-item lines=\"none\">\n    <ion-label slot=\"start\">{{ bundleName }}</ion-label>\n    <ion-label slot=\"end\">#{{ _variable.id }}</ion-label>\n  </ion-item>\n  <!-- <ion-item>\n    <ion-icon *ngIf=\"icon\" name=\"{{icon}}\" slot=\"start\"></ion-icon>\n    <ion-label>{{variable.identifier() || variableConfig.id }}</ion-label>\n  </ion-item> -->\n  <ion-card-content *ngIf=\"monitor\">\n    <ng-container [ngSwitch]=\"cardType\">\n      <ion-item *ngSwitchCase=\"'text'\" lines=\"none\" class=\"ion-no-padding\">\n        <monitoring-variable-value\n          style=\"margin: auto\"\n          [lines]=\"'none'\"\n          [variable]=\"variable\"\n          [editable]=\"editMode\"\n        ></monitoring-variable-value>\n        <span slot=\"end\" *ngIf=\"unit\" class=\"unit\">{{ unit }}</span>\n      </ion-item>\n      <ion-item *ngSwitchCase=\"'select'\" lines=\"none\" class=\"ion-no-padding\">\n        <tap-variable-select\n          style=\"margin: auto\"\n          [lines]=\"'none'\"\n          [variable]=\"variable\"\n          [options]=\"selectOptions\"\n          [editable]=\"editMode\"\n        ></tap-variable-select>\n        <span slot=\"end\" *ngIf=\"unit\" class=\"unit\">{{ unit }}</span>\n      </ion-item>\n      <tap-variable-toggle\n        *ngSwitchCase=\"'switch'\"\n        [variable]=\"_variable\"\n      ></tap-variable-toggle>\n      <tap-variable-buttons\n        *ngSwitchCase=\"'buttons'\"\n        [variable]=\"variable\"\n        [buttons]=\"monitoringButtons\"\n      ></tap-variable-buttons>\n      <tap-variable-range\n        *ngSwitchCase=\"'range'\"\n        [variable]=\"_variable\"\n        [pin]=\"true\"\n        [snaps]=\"true\"\n        [ticks]=\"true\"\n        [min]=\"0\"\n        [max]=\"100\"\n      ></tap-variable-range>\n      <ion-text color=\"danger\" *ngSwitchDefault>\n        <ion-icon name=\"alert\"></ion-icon> Unknown card type {{ cardType }}\n      </ion-text>\n    </ng-container>\n  </ion-card-content>\n  <ion-card-content *ngIf=\"error\">\n    <ion-text color=\"danger\">{{ error }}</ion-text>\n  </ion-card-content>\n  <!--\n  <ion-item>\n    <ion-select\n      [(ngModel)]=\"cardType\"\n      okText=\"Select\"\n      cancelText=\"Dismiss\"\n      (ionChange)=\"onCardTypeChange($event)\"\n    >\n      <ion-select-option\n        *ngFor=\"let cardType of cardTypes\"\n        value=\"{{ cardType }}\"\n        >{{ cardType }}</ion-select-option\n      >\n    </ion-select>\n    <ion-buttons slot=\"end\">\n      <ion-button (click)=\"toggleMonitoring()\" *ngIf=\"showStartStopMonitoring\">\n        <ion-icon *ngIf=\"!playMonitoring\" name=\"play\"></ion-icon>\n        <ion-icon *ngIf=\"playMonitoring\" name=\"pause\"></ion-icon>\n      </ion-button>\n      <ion-button (click)=\"editMode = !editMode\">\n        <ion-icon *ngIf=\"!editMode\" name=\"create\"></ion-icon> <span *ngIf=\"!editMode\"></span>\n        <ion-icon *ngIf=\"editMode\" name=\"close\"></ion-icon> \n      </ion-button>\n      <ion-button (click)=\"editConfig()\">\n        \n        <ion-icon name=\"cog\"></ion-icon> \n      </ion-button>\n    </ion-buttons>\n  </ion-item>\n  -->\n</ion-card>\n"]}