@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
195 lines • 22.4 kB
JavaScript
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 \n <app-common-icon [image]=\"icon\"> </app-common-icon>\n \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 \n <app-common-icon [image]=\"icon\"> </app-common-icon>\n \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"]}