UNPKG

@iotize/ionic

Version:

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

149 lines 24.2 kB
import { __decorate, __metadata } from "tslib"; import { Component, Input, ViewChild, } from '@angular/core'; import { IonModal } from '@ionic/angular'; import { CurrentDeviceService, PendingCallManager, 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 "@iotize/ionic"; import * as i2 from "@angular/common"; import * as i3 from "@ionic/angular"; let TapVariableDateTimePickerComponent = class TapVariableDateTimePickerComponent { ctx; dateTimeModal; pendingCallManager; pendingSubmitValue; destroyed = new Subject(); error; // loaded = false; set fieldError(err) { this.error = err; } get pending() { return this.pendingCallManager.pendingCall !== undefined; } format = 'medium'; showCalendarPickerTitle = true; editable = true; color = 'primary'; showCalendarIcon = true; iconCalendarColor = 'primary'; set encodingType(type) { if (type in DATE_TIME_PICKER_ENCODING) { const converter = DATE_TIME_PICKER_ENCODING[type]; this.formatDataRead = converter.decode.bind(converter); this.formatDataWrite = converter.encode.bind(converter); } else { this.formatDataRead = undefined; this.formatDataWrite = undefined; } } formatDataRead; formatDataWrite; _variable; set variable(variable) { this._variable = variable; } dateTimeValue = '2023-01-01T00:00:00'; constructor(tapService) { this.pendingCallManager = PendingCallManager.create(tapService); } ngOnDestroy() { this.destroyed.next(); this.pendingCallManager.destroy(); } ngAfterViewInit() { this.ctx?.valueToDisplay ?.pipe(takeUntil(this.destroyed)) .subscribe((newValue) => { this.dateTimeValue = this.formatDataRead ? this.formatDataRead(newValue) : newValue; }); } async onPendingChange(event) { const value = event.detail.value; const timeStamp = this.formatDataWrite ? this.formatDataWrite(value) : value; await this.ctx.notifyValueChange(timeStamp); } onValueClick() { if (this.editable) { this.pendingSubmitValue = this.dateTimeValue; this.dateTimeModal.present(); } } /** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TapVariableDateTimePickerComponent, deps: [{ token: i1.CurrentDeviceService }], target: i0.ɵɵFactoryTarget.Component }); /** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: TapVariableDateTimePickerComponent, selector: "tap-variable-date-time-picker", inputs: { fieldError: "fieldError", format: "format", showCalendarPickerTitle: "showCalendarPickerTitle", editable: "editable", color: "color", showCalendarIcon: "showCalendarIcon", iconCalendarColor: "iconCalendarColor", encodingType: "encodingType", formatDataRead: "formatDataRead", formatDataWrite: "formatDataWrite", variable: "variable" }, viewQueries: [{ propertyName: "ctx", first: true, predicate: ["ctx"], descendants: true }, { propertyName: "dateTimeModal", first: true, predicate: ["dateTimeModal"], descendants: true }], ngImport: i0, template: "<tap-value-editor-container\n #ctx\n [button]=\"editable\"\n [variable]=\"_variable\"\n (click)=\"onValueClick()\"\n>\n <!-- <ion-spinner *ngIf=\"!loaded\" name=\"crescent\" color=\"primary\"></ion-spinner> -->\n\n <ion-modal #dateTimeModal>\n <ng-template>\n <ion-content>\n <ion-datetime\n #ionDateTime\n [showDefaultTitle]=\"showCalendarPickerTitle\"\n [showDefaultButtons]=\"true\"\n [color]=\"color\"\n size=\"cover\"\n [value]=\"pendingSubmitValue\"\n (ionChange)=\"onPendingChange($event)\"\n >\n <!-- <ion-buttons slot=\"buttons\">\n <ion-button\n fill=\"clear\"\n [color]=\"color\"\n (click)=\"ionDateTime.confirm(); onConfirm()\"\n >Confirm</ion-button\n >\n <ion-button\n fill=\"clear\"\n color=\"dark\"\n (click)=\"ionDateTime.cancel(); dateTimeModal.dismiss()\"\n >Cancel</ion-button\n >\n </ion-buttons> -->\n </ion-datetime>\n </ion-content>\n </ng-template>\n </ion-modal>\n <ion-icon\n [color]=\"iconCalendarColor\"\n slot=\"start\"\n name=\"calendar\"\n *ngIf=\"showCalendarIcon\"\n ></ion-icon>\n <ion-label>\n {{ dateTimeValue | date: (format ? format : 'MMM d, y, h:mm:ss a') }}\n </ion-label>\n <!--\n <ion-datetime\n *ngIf=\"loaded\"\n \n [displayFormat]=\"format\"\n [value]=\"dateTimeValue\"\n (ionChange)=\n ></ion-datetime>\n -->\n</tap-value-editor-container>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.IonContent, selector: "ion-content", inputs: ["color", "fixedSlotPlacement", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { kind: "component", type: i3.IonDatetime, selector: "ion-datetime", inputs: ["cancelText", "clearText", "color", "dayValues", "disabled", "doneText", "firstDayOfWeek", "formatOptions", "highlightedDates", "hourCycle", "hourValues", "isDateEnabled", "locale", "max", "min", "minuteValues", "mode", "monthValues", "multiple", "name", "preferWheel", "presentation", "readonly", "showAdjacentDays", "showClearButton", "showDefaultButtons", "showDefaultTimeLabel", "showDefaultTitle", "size", "titleSelectedDatesFormatter", "value", "yearValues"] }, { kind: "component", type: i3.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i3.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: i3.IonModal, selector: "ion-modal" }, { kind: "directive", type: i3.SelectValueAccessor, selector: "ion-select, ion-radio-group, ion-segment, ion-datetime" }, { kind: "component", type: i1.TapValueEditorContainerComponent, selector: "tap-value-editor-container", inputs: ["button", "variable", "inputOptions", "showRefreshButton", "showSubmitButton", "showEditButton", "error", "lines", "modalEdition", "value"], outputs: ["submit", "refresh"] }, { kind: "pipe", type: i2.DatePipe, name: "date" }] }); }; TapVariableDateTimePickerComponent = __decorate([ MonitoringAppGenComponent({ constraints: { isArray: 'NO', }, }), __metadata("design:paramtypes", [CurrentDeviceService]) ], TapVariableDateTimePickerComponent); export { TapVariableDateTimePickerComponent }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TapVariableDateTimePickerComponent, decorators: [{ type: Component, args: [{ selector: 'tap-variable-date-time-picker', template: "<tap-value-editor-container\n #ctx\n [button]=\"editable\"\n [variable]=\"_variable\"\n (click)=\"onValueClick()\"\n>\n <!-- <ion-spinner *ngIf=\"!loaded\" name=\"crescent\" color=\"primary\"></ion-spinner> -->\n\n <ion-modal #dateTimeModal>\n <ng-template>\n <ion-content>\n <ion-datetime\n #ionDateTime\n [showDefaultTitle]=\"showCalendarPickerTitle\"\n [showDefaultButtons]=\"true\"\n [color]=\"color\"\n size=\"cover\"\n [value]=\"pendingSubmitValue\"\n (ionChange)=\"onPendingChange($event)\"\n >\n <!-- <ion-buttons slot=\"buttons\">\n <ion-button\n fill=\"clear\"\n [color]=\"color\"\n (click)=\"ionDateTime.confirm(); onConfirm()\"\n >Confirm</ion-button\n >\n <ion-button\n fill=\"clear\"\n color=\"dark\"\n (click)=\"ionDateTime.cancel(); dateTimeModal.dismiss()\"\n >Cancel</ion-button\n >\n </ion-buttons> -->\n </ion-datetime>\n </ion-content>\n </ng-template>\n </ion-modal>\n <ion-icon\n [color]=\"iconCalendarColor\"\n slot=\"start\"\n name=\"calendar\"\n *ngIf=\"showCalendarIcon\"\n ></ion-icon>\n <ion-label>\n {{ dateTimeValue | date: (format ? format : 'MMM d, y, h:mm:ss a') }}\n </ion-label>\n <!--\n <ion-datetime\n *ngIf=\"loaded\"\n \n [displayFormat]=\"format\"\n [value]=\"dateTimeValue\"\n (ionChange)=\n ></ion-datetime>\n -->\n</tap-value-editor-container>\n" }] }], ctorParameters: () => [{ type: i1.CurrentDeviceService }], propDecorators: { ctx: [{ type: ViewChild, args: ['ctx'] }], dateTimeModal: [{ type: ViewChild, args: ['dateTimeModal'] }], fieldError: [{ type: Input }], format: [{ type: Input }], showCalendarPickerTitle: [{ type: Input }], editable: [{ type: Input }], color: [{ type: Input }], showCalendarIcon: [{ type: Input }], iconCalendarColor: [{ type: Input }], encodingType: [{ type: Input }], formatDataRead: [{ type: Input }], formatDataWrite: [{ type: Input }], variable: [{ type: Input }] } }); const DATE_TIME_PICKER_ENCODING = { timestamp_ms: createTimestampEncoder(1), timestamp_s: createTimestampEncoder(1000), }; function createTimestampEncoder(multiplier = 1) { return { decode: (timestampInSeconds) => { timestampInSeconds = typeof timestampInSeconds === 'string' ? parseInt(timestampInSeconds) : timestampInSeconds; if (timestampInSeconds === undefined || isNaN(timestampInSeconds)) { timestampInSeconds = 0; } const date = new Date(timestampInSeconds * multiplier); return date.toISOString().slice(0, -1); }, encode: (value) => { if (!value) { return 0; } const date = Date.parse(value); return new Date(date).getTime() / multiplier; }, }; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tap-variable-date-time-picker.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-date-time-picker/tap-variable-date-time-picker.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-date-time-picker/tap-variable-date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  Input,\n  OnDestroy,\n  ViewChild,\n} from '@angular/core';\nimport { IonModal } from '@ionic/angular';\nimport { EncoderDecoder } from '@iotize/common/converter/api';\nimport {\n  CurrentDeviceService,\n  PendingCallManager,\n  TapValueEditorContainerComponent,\n} from '@iotize/ionic';\nimport { AbstractVariable } from '@iotize/tap/data';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport {\n  AppGenField,\n  MonitoringAppGenComponent,\n} from '../../metadata/decorators';\nimport {\n  EDITABLE_SCHEMA,\n  IONIC_COLOR_SCHEMA,\n  TAP_VARIABLE_SCHEMA,\n} from '../shared-schema';\n\n@MonitoringAppGenComponent({\n  constraints: {\n    isArray: 'NO',\n  },\n})\n@Component({\n  selector: 'tap-variable-date-time-picker',\n  templateUrl: './tap-variable-date-time-picker.component.html',\n  styleUrls: ['./tap-variable-date-time-picker.component.scss'],\n})\nexport class TapVariableDateTimePickerComponent\n  implements AfterViewInit, OnDestroy\n{\n  @ViewChild('ctx') ctx!: TapValueEditorContainerComponent;\n  @ViewChild('dateTimeModal') dateTimeModal!: IonModal;\n\n  pendingCallManager: PendingCallManager;\n  pendingSubmitValue: any;\n  private destroyed = new Subject<void>();\n\n  public error?: Error;\n\n  // loaded = false;\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()\n  format: string = 'medium';\n\n  @Input()\n  showCalendarPickerTitle: boolean = true;\n\n  @Input()\n  editable: boolean = true;\n\n  @Input()\n  color = 'primary';\n\n  @Input()\n  showCalendarIcon: boolean = true;\n\n  @Input()\n  iconCalendarColor = 'primary';\n\n  @Input() set encodingType(type: string) {\n    if (type in DATE_TIME_PICKER_ENCODING) {\n      const converter =\n        DATE_TIME_PICKER_ENCODING[\n          type as keyof typeof DATE_TIME_PICKER_ENCODING\n        ];\n      this.formatDataRead = converter.decode.bind(converter);\n      this.formatDataWrite = converter.encode.bind(converter);\n    } else {\n      this.formatDataRead = undefined;\n      this.formatDataWrite = undefined;\n    }\n  }\n\n  @Input()\n  formatDataRead: ((date: number) => string) | undefined;\n\n  @Input()\n  formatDataWrite: ((date: string) => number) | undefined;\n\n  _variable?: AbstractVariable<any>;\n\n  @Input()\n  set variable(variable: AbstractVariable<any> | undefined) {\n    this._variable = variable;\n  }\n\n  dateTimeValue: string = '2023-01-01T00:00:00';\n\n  constructor(tapService: CurrentDeviceService) {\n    this.pendingCallManager = PendingCallManager.create(tapService);\n  }\n\n  ngOnDestroy(): void {\n    this.destroyed.next();\n    this.pendingCallManager.destroy();\n  }\n\n  ngAfterViewInit() {\n    this.ctx?.valueToDisplay\n      ?.pipe(takeUntil(this.destroyed))\n      .subscribe((newValue) => {\n        this.dateTimeValue = this.formatDataRead\n          ? this.formatDataRead(newValue)\n          : newValue;\n      });\n  }\n\n  async onPendingChange(event: CustomEvent<{ value: string }>) {\n    const value = event.detail.value;\n    const timeStamp = this.formatDataWrite\n      ? this.formatDataWrite(value)\n      : value;\n    await this.ctx.notifyValueChange(timeStamp);\n  }\n\n  onValueClick() {\n    if (this.editable) {\n      this.pendingSubmitValue = this.dateTimeValue;\n      this.dateTimeModal.present();\n    }\n  }\n}\n\nconst DATE_TIME_PICKER_ENCODING = {\n  timestamp_ms: createTimestampEncoder(1),\n  timestamp_s: createTimestampEncoder(1000),\n};\n\nfunction createTimestampEncoder(\n  multiplier = 1\n): EncoderDecoder<string, number> {\n  return {\n    decode: (timestampInSeconds: number | undefined | string): string => {\n      timestampInSeconds =\n        typeof timestampInSeconds === 'string'\n          ? parseInt(timestampInSeconds)\n          : timestampInSeconds;\n      if (timestampInSeconds === undefined || isNaN(timestampInSeconds)) {\n        timestampInSeconds = 0;\n      }\n      const date = new Date(timestampInSeconds * multiplier);\n      return date.toISOString().slice(0, -1);\n    },\n    encode: (value: string): number => {\n      if (!value) {\n        return 0;\n      }\n      const date = Date.parse(value);\n      return new Date(date).getTime() / multiplier;\n    },\n  };\n}\n","<tap-value-editor-container\n  #ctx\n  [button]=\"editable\"\n  [variable]=\"_variable\"\n  (click)=\"onValueClick()\"\n>\n  <!-- <ion-spinner *ngIf=\"!loaded\" name=\"crescent\" color=\"primary\"></ion-spinner> -->\n\n  <ion-modal #dateTimeModal>\n    <ng-template>\n      <ion-content>\n        <ion-datetime\n          #ionDateTime\n          [showDefaultTitle]=\"showCalendarPickerTitle\"\n          [showDefaultButtons]=\"true\"\n          [color]=\"color\"\n          size=\"cover\"\n          [value]=\"pendingSubmitValue\"\n          (ionChange)=\"onPendingChange($event)\"\n        >\n          <!-- <ion-buttons slot=\"buttons\">\n            <ion-button\n              fill=\"clear\"\n              [color]=\"color\"\n              (click)=\"ionDateTime.confirm(); onConfirm()\"\n              >Confirm</ion-button\n            >\n            <ion-button\n              fill=\"clear\"\n              color=\"dark\"\n              (click)=\"ionDateTime.cancel(); dateTimeModal.dismiss()\"\n              >Cancel</ion-button\n            >\n          </ion-buttons> -->\n        </ion-datetime>\n      </ion-content>\n    </ng-template>\n  </ion-modal>\n  <ion-icon\n    [color]=\"iconCalendarColor\"\n    slot=\"start\"\n    name=\"calendar\"\n    *ngIf=\"showCalendarIcon\"\n  ></ion-icon>\n  <ion-label>\n    {{ dateTimeValue | date: (format ? format : 'MMM d, y, h:mm:ss a') }}\n  </ion-label>\n  <!--\n    <ion-datetime\n      *ngIf=\"loaded\"\n     \n      [displayFormat]=\"format\"\n      [value]=\"dateTimeValue\"\n      (ionChange)=\n    ></ion-datetime>\n  -->\n</tap-value-editor-container>\n"]}