@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
149 lines • 24.2 kB
JavaScript
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"]}