UNPKG

@iotize/ionic

Version:

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

195 lines 22.4 kB
import { __decorate, __metadata } from "tslib"; import { Component, HostListener, Input, ViewChild, } from '@angular/core'; import { ActionSheetController, Platform } from '@ionic/angular'; import { TapValueEditorContainerComponent } from '@iotize/ionic'; import { Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; import { MonitoringAppGenComponent } from '../../metadata/decorators'; import * as i0 from "@angular/core"; import * as i1 from "@ionic/angular"; import * as i2 from "@angular/common"; import * as i3 from "@iotize/ionic"; import * as i4 from "@iotize/app-common"; let TapVariablePushButtonComponent = class TapVariablePushButtonComponent { onTouchStart() { this._onTouchStartOrMouseDown(); } onMouseDown() { if (this.platform.is('desktop')) { this._onTouchStartOrMouseDown(); if (this._handleMouseUp) { document.removeEventListener('mouseup', this._handleMouseUp); } this._handleMouseUp = () => { if (this._handleMouseUp) { document.removeEventListener('mouseup', this._handleMouseUp); } this._onTouchEndOrMouseUp(); }; document.addEventListener('mouseup', this._handleMouseUp); } } onTouchEnd() { this._onTouchEndOrMouseUp(); } _onTouchStartOrMouseDown() { if (isConfiguredValue(this.mouseDownValue)) this.writeValue(this.mouseDownValue); } _onTouchEndOrMouseUp() { if (isConfiguredValue(this.mouseUpValue)) this.writeValue(this.mouseUpValue); } /** * @deprecated */ set defineValueOnClick(v) { this.value = v; } set fieldError(err) { this.error = err; } set variable(variable) { this._variable = variable; } constructor(actionSheetController, platform) { this.actionSheetController = actionSheetController; this.platform = platform; this.mouseDownValue = undefined; this.mouseUpValue = undefined; this.value = 1; this.buttonText = 'Write'; this.size = 'default'; this.color = 'primary'; this.iconPosition = 'start'; this.strong = false; this.confirm = false; this.confirmMessage = 'Are you sure ?'; this.editable = true; this.destroyed = new Subject(); this.loading = false; } ngAfterViewInit() { this.ctx?.valueToDisplay ?.pipe(takeUntil(this.destroyed)) .subscribe((newValue) => { }); } ngOnDestroy() { this.destroyed.next(); } async onClick() { if (!isConfiguredValue(this.value)) { return; } if (this.confirm) { const actionSheet = await this.actionSheetController.create({ header: this.confirmMessage, buttons: [ { text: 'Confirm', icon: 'checkmark', handler: () => { this.writeValue(this.value); }, }, { text: 'Cancel', icon: 'close', }, ], }); await actionSheet.present(); } else { this.writeValue(this.value); } } async writeValue(valueToWrite) { this.loading = true; await this.ctx.notifyValueChange(valueToWrite, true); this.loading = false; } }; /** @nocollapse */ TapVariablePushButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TapVariablePushButtonComponent, deps: [{ token: i1.ActionSheetController }, { token: i1.Platform }], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ TapVariablePushButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TapVariablePushButtonComponent, selector: "tap-variable-push-button", inputs: { mouseDownValue: "mouseDownValue", mouseUpValue: "mouseUpValue", value: "value", buttonText: "buttonText", size: "size", color: "color", icon: "icon", iconPosition: "iconPosition", fill: "fill", expand: "expand", strong: "strong", shape: "shape", confirm: "confirm", confirmMessage: "confirmMessage", editable: "editable", defineValueOnClick: "defineValueOnClick", fieldError: "fieldError", variable: "variable" }, host: { listeners: { "touchstart": "onTouchStart()", "mousedown": "onMouseDown()", "touchend": "onTouchEnd()" } }, viewQueries: [{ propertyName: "ctx", first: true, predicate: ["ctx"], descendants: true }], ngImport: i0, template: "<tap-value-editor-container #ctx [variable]=\"_variable\">\n <ion-button\n [disabled]=\"loading || !editable\"\n [color]=\"color\"\n [size]=\"size\"\n [fill]=\"fill\"\n [strong]=\"strong\"\n [shape]=\"shape\"\n [expand]=\"expand\"\n [ngClass]=\"{ 'full-width': expand === 'block' || expand === 'full' }\"\n (click)=\"onClick()\"\n >\n <span *ngIf=\"icon\" [slot]=\"iconPosition\">\n &nbsp;\n <app-common-icon [image]=\"icon\"> </app-common-icon>\n &nbsp;\n </span>\n <ion-text *ngIf=\"buttonText\">{{ buttonText }}</ion-text>\n </ion-button>\n</tap-value-editor-container>\n", styles: [".full-width{width:100%!important}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i1.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: i1.IonText, selector: "ion-text", inputs: ["color", "mode"] }, { kind: "component", type: i3.TapValueEditorContainerComponent, selector: "tap-value-editor-container", inputs: ["button", "variable", "inputOptions", "showRefreshButton", "showSubmitButton", "showEditButton", "error", "lines", "modalEdition", "value"], outputs: ["submit", "refresh"] }, { kind: "component", type: i4.IconComponent, selector: "app-common-icon", inputs: ["imageSize", "color", "image"] }] }); TapVariablePushButtonComponent = __decorate([ MonitoringAppGenComponent({ constraints: { isArray: 'NO', isNumber: 'YES', }, events: [ { name: 'submit', dataType: 'void', }, { dataType: 'void', name: 'mouseUp', }, { dataType: 'void', name: 'mouseDown', }, ], }), __metadata("design:paramtypes", [ActionSheetController, Platform]) ], TapVariablePushButtonComponent); export { TapVariablePushButtonComponent }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TapVariablePushButtonComponent, decorators: [{ type: Component, args: [{ selector: 'tap-variable-push-button', template: "<tap-value-editor-container #ctx [variable]=\"_variable\">\n <ion-button\n [disabled]=\"loading || !editable\"\n [color]=\"color\"\n [size]=\"size\"\n [fill]=\"fill\"\n [strong]=\"strong\"\n [shape]=\"shape\"\n [expand]=\"expand\"\n [ngClass]=\"{ 'full-width': expand === 'block' || expand === 'full' }\"\n (click)=\"onClick()\"\n >\n <span *ngIf=\"icon\" [slot]=\"iconPosition\">\n &nbsp;\n <app-common-icon [image]=\"icon\"> </app-common-icon>\n &nbsp;\n </span>\n <ion-text *ngIf=\"buttonText\">{{ buttonText }}</ion-text>\n </ion-button>\n</tap-value-editor-container>\n", styles: [".full-width{width:100%!important}\n"] }] }], ctorParameters: function () { return [{ type: i1.ActionSheetController }, { type: i1.Platform }]; }, propDecorators: { ctx: [{ type: ViewChild, args: ['ctx'] }], onTouchStart: [{ type: HostListener, args: ['touchstart'] }], onMouseDown: [{ type: HostListener, args: ['mousedown'] }], onTouchEnd: [{ type: HostListener, args: ['touchend'] }], mouseDownValue: [{ type: Input }], mouseUpValue: [{ type: Input }], value: [{ type: Input }], buttonText: [{ type: Input }], size: [{ type: Input }], color: [{ type: Input }], icon: [{ type: Input }], iconPosition: [{ type: Input }], fill: [{ type: Input }], expand: [{ type: Input }], strong: [{ type: Input }], shape: [{ type: Input }], confirm: [{ type: Input }], confirmMessage: [{ type: Input }], editable: [{ type: Input }], defineValueOnClick: [{ type: Input }], fieldError: [{ type: Input }], variable: [{ type: Input }] } }); function isConfiguredValue(value) { return value !== undefined && value !== null; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tap-variable-push-button.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-push-button/tap-variable-push-button.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-push-button/tap-variable-push-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  HostListener,\n  Input,\n  OnDestroy,\n  ViewChild,\n} from '@angular/core';\nimport { ActionSheetController, Platform } from '@ionic/angular';\nimport { TapValueEditorContainerComponent } from '@iotize/ionic';\nimport { AbstractVariable } from '@iotize/tap/data';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { MonitoringAppGenComponent } from '../../metadata/decorators';\n\n@MonitoringAppGenComponent({\n  constraints: {\n    isArray: 'NO',\n    isNumber: 'YES',\n  },\n  events: [\n    {\n      name: 'submit',\n      dataType: 'void',\n    },\n    {\n      dataType: 'void',\n      name: 'mouseUp',\n    },\n    {\n      dataType: 'void',\n      name: 'mouseDown',\n    },\n  ],\n})\n@Component({\n  selector: 'tap-variable-push-button',\n  templateUrl: './tap-variable-push-button.component.html',\n  styleUrls: ['./tap-variable-push-button.component.scss'],\n})\nexport class TapVariablePushButtonComponent implements OnDestroy {\n  @ViewChild('ctx') ctx!: TapValueEditorContainerComponent;\n\n  private _handleMouseUp?: (\n    this: Document,\n    ev: DocumentEventMap['mouseup']\n  ) => any;\n\n  @HostListener('touchstart') onTouchStart() {\n    this._onTouchStartOrMouseDown();\n  }\n\n  @HostListener('mousedown') onMouseDown() {\n    if (this.platform.is('desktop')) {\n      this._onTouchStartOrMouseDown();\n      if (this._handleMouseUp) {\n        document.removeEventListener('mouseup', this._handleMouseUp);\n      }\n      this._handleMouseUp = () => {\n        if (this._handleMouseUp) {\n          document.removeEventListener('mouseup', this._handleMouseUp);\n        }\n        this._onTouchEndOrMouseUp();\n      };\n      document.addEventListener('mouseup', this._handleMouseUp);\n    }\n  }\n\n  @HostListener('touchend') onTouchEnd() {\n    this._onTouchEndOrMouseUp();\n  }\n\n  private _onTouchStartOrMouseDown() {\n    if (isConfiguredValue(this.mouseDownValue))\n      this.writeValue(this.mouseDownValue);\n  }\n\n  private _onTouchEndOrMouseUp() {\n    if (isConfiguredValue(this.mouseUpValue))\n      this.writeValue(this.mouseUpValue);\n  }\n\n  @Input()\n  mouseDownValue?: number = undefined;\n\n  @Input()\n  mouseUpValue?: number = undefined;\n\n  @Input()\n  value = 1;\n\n  @Input()\n  buttonText = 'Write';\n\n  @Input()\n  size = 'default';\n\n  @Input()\n  color: string = 'primary';\n\n  @Input()\n  icon?: string;\n\n  @Input()\n  iconPosition: string = 'start';\n\n  @Input()\n  fill?: string;\n\n  @Input()\n  expand?: string;\n\n  @Input()\n  strong = false;\n\n  @Input()\n  shape?: boolean;\n\n  @Input()\n  confirm = false;\n\n  @Input()\n  confirmMessage = 'Are you sure ?';\n\n  @Input()\n  editable = true;\n\n  /**\n   * @deprecated\n   */\n  @Input()\n  set defineValueOnClick(v: number) {\n    this.value = v;\n  }\n\n  @Input() set fieldError(err: Error) {\n    this.error = err;\n  }\n\n  @Input()\n  set variable(variable: AbstractVariable<any | any[]> | undefined) {\n    this._variable = variable;\n  }\n\n  private destroyed = new Subject<void>();\n\n  public error?: Error;\n  pendingSubmitValue: any;\n  loading = false;\n  _variable?: AbstractVariable<any>;\n\n  constructor(\n    public actionSheetController: ActionSheetController,\n    private platform: Platform\n  ) {}\n\n  ngAfterViewInit() {\n    this.ctx?.valueToDisplay\n      ?.pipe(takeUntil(this.destroyed))\n      .subscribe((newValue) => {});\n  }\n\n  ngOnDestroy() {\n    this.destroyed.next();\n  }\n\n  async onClick() {\n    if (!isConfiguredValue(this.value)) {\n      return;\n    }\n    if (this.confirm) {\n      const actionSheet = await this.actionSheetController.create({\n        header: this.confirmMessage,\n        buttons: [\n          {\n            text: 'Confirm',\n            icon: 'checkmark',\n            handler: () => {\n              this.writeValue(this.value);\n            },\n          },\n          {\n            text: 'Cancel',\n            icon: 'close',\n          },\n        ],\n      });\n      await actionSheet.present();\n    } else {\n      this.writeValue(this.value);\n    }\n  }\n\n  public async writeValue(valueToWrite: number) {\n    this.loading = true;\n    await this.ctx.notifyValueChange(valueToWrite, true);\n    this.loading = false;\n  }\n}\n\nfunction isConfiguredValue(value: number | undefined): value is number {\n  return value !== undefined && value !== null;\n}\n","<tap-value-editor-container #ctx [variable]=\"_variable\">\n  <ion-button\n    [disabled]=\"loading || !editable\"\n    [color]=\"color\"\n    [size]=\"size\"\n    [fill]=\"fill\"\n    [strong]=\"strong\"\n    [shape]=\"shape\"\n    [expand]=\"expand\"\n    [ngClass]=\"{ 'full-width': expand === 'block' || expand === 'full' }\"\n    (click)=\"onClick()\"\n  >\n    <span *ngIf=\"icon\" [slot]=\"iconPosition\">\n      &nbsp;\n      <app-common-icon [image]=\"icon\"> </app-common-icon>\n      &nbsp;\n    </span>\n    <ion-text *ngIf=\"buttonText\">{{ buttonText }}</ion-text>\n  </ion-button>\n</tap-value-editor-container>\n"]}