vcomply-workflow-engine 3.4.31 → 3.4.32

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -65,7 +65,6 @@ export class FrequencyDialogTopComponent {
65
65
  onTimeChanged(event) {
66
66
  try {
67
67
  event = event.selectedValue;
68
- console.log('event ===>', event);
69
68
  this.timeData = event;
70
69
  if (typeof this.dateObjectData == 'object') {
71
70
  this.dateObjectData = moment(this.dateObjectData).toDate();
@@ -126,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
126
125
  }], yearlyDateChanged: [{
127
126
  type: Output
128
127
  }] } });
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frequency-dialog-top.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency-dialog/frequency-dialog-top/frequency-dialog-top.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency-dialog/frequency-dialog-top/frequency-dialog-top.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport moment from 'moment/moment';\r\nimport { DEFAULT_TIME } from '../../../constants/time.constants';\r\n\r\n@Component({\r\n  selector: 'app-frequency-dialog-top',\r\n  templateUrl: './frequency-dialog-top.component.html',\r\n  styleUrls: ['./frequency-dialog-top.component.less'],\r\n})\r\nexport class FrequencyDialogTopComponent implements OnInit {\r\n  @Input() occurrenceFirst = 0;\r\n  @Input() id = 0; // 0 = Daily, 1: weekly, 5: Annually\r\n  @Input() inputTime = '11:00 pm';\r\n  @Input() frequencyType = 0; // 0 = days, 1 = weeks & 2 = years\r\n  @Input() yearlyDay = new Date().getDate();\r\n\r\n  @Output() valueChangedFirst: EventEmitter<any> = new EventEmitter();\r\n  @Output() nextDisable: EventEmitter<any> = new EventEmitter();\r\n  @Output() timeChanged: EventEmitter<any> = new EventEmitter();\r\n  @Output() yearlyDateChanged: EventEmitter<any> = new EventEmitter();\r\n\r\n  todayDate = new Date();\r\n  dateObjectData = new Date();\r\n  timeData = '11:00 pm';\r\n  DEFAULT_TIME = DEFAULT_TIME;\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {}\r\n\r\n  enterValueFirst(event: any, actionType: string) {\r\n    if (this.id !== 0 && this.id !== 1 && this.id !== 5) {\r\n      this.enterValue(this.occurrenceFirst, actionType);\r\n      return;\r\n    }\r\n    if (\r\n      !Number.isNaN(Number(this.occurrenceFirst)) &&\r\n      this.occurrenceFirst !== 0 &&\r\n      Number(this.occurrenceFirst) > 0\r\n    ) {\r\n      this.occurrenceFirst = Number(this.occurrenceFirst);\r\n      this.valueChangedFirst.emit({\r\n        type: actionType,\r\n        value: Number(this.occurrenceFirst),\r\n        pageName: '',\r\n      });\r\n    } else {\r\n      this.occurrenceFirst = 1;\r\n    }\r\n  }\r\n\r\n  enterValue(event: any, actionType: any) {\r\n    if (\r\n      !Number.isNaN(Number(event)) &&\r\n      event !== 0 &&\r\n      Number(event) > 0 &&\r\n      Number(event) < 32\r\n    ) {\r\n      this.occurrenceFirst = Number(event);\r\n      this.valueChangedFirst.emit({\r\n        type: actionType,\r\n        value: Number(event),\r\n        pageName: '',\r\n      });\r\n    } else {\r\n      this.occurrenceFirst = new Date().getDate();\r\n    }\r\n  }\r\n\r\n  getToday(): string {\r\n    return moment(Date.now()).format('YYYY-MM-DD HH:mm:ss')?.split(' ')[0];\r\n  }\r\n\r\n  onTimeChanged(event: any) {\r\n    try {\r\n      event = event.selectedValue;\r\n      console.log('event ===>', event);\r\n      this.timeData = event;\r\n      if (typeof this.dateObjectData == 'object') {\r\n        this.dateObjectData = moment(this.dateObjectData).toDate();\r\n      }\r\n      let timeStamp = moment(\r\n        this.dateObjectData.getDate() +\r\n          '-' +\r\n          (this.dateObjectData.getMonth() + 1) +\r\n          '-' +\r\n          this.dateObjectData.getFullYear() +\r\n          ' ' +\r\n          this.timeData,\r\n        'DD-MM-YYYY hh:mm a'\r\n      ).unix();\r\n      if (Date.now() / 1000 > timeStamp) {\r\n        this.nextDisable.emit(true);\r\n      } else {\r\n        this.nextDisable.emit(false);\r\n      }\r\n      this.timeChanged.emit(event);\r\n    } catch (e) {\r\n      console.error(e);\r\n    }\r\n  }\r\n\r\n  enterYearDay(event: any) {\r\n    if (\r\n      !Number.isNaN(Number(this.yearlyDay)) &&\r\n      this.yearlyDay !== 0 &&\r\n      Number(this.yearlyDay) > 0 &&\r\n      Number(this.yearlyDay) < 32\r\n    ) {\r\n      //this.yearlyDay = Number(event.target.value);\r\n      this.yearlyDateChanged.emit(this.yearlyDay);\r\n    } else {\r\n      this.yearlyDay = new Date().getDate();\r\n    }\r\n  }\r\n}\r\n","<div class=\"frequency-dialog-top vx-p-3 vx-d-flex vx-align-center\">\r\n  <div class=\"vx-fs-13 vx-paragraph-txt vx-mr-3\">\r\n    {{ id === 0 || id === 1 || id === 5 ? \"Every\" : \"Day\" }}\r\n  </div>\r\n  <input\r\n    type=\"number\"\r\n    [id]=\"'occurrence' + id\"\r\n    [(ngModel)]=\"occurrenceFirst\"\r\n    class=\"day-counter\"\r\n    onkeydown=\"return event.keyCode !== 190\"\r\n    min=\"0\"\r\n    oninput=\"this.value = Math.abs(this.value)\"\r\n    (focusout)=\"enterValueFirst($event, 'occurrenceFirst')\"\r\n  />\r\n  <div\r\n    *ngIf=\"frequencyType === 1\"\r\n    class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\"\r\n  >\r\n    {{ occurrenceFirst > 1 ? \"weeks\" : \"week\" }} by\r\n  </div>\r\n  <div\r\n    class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\"\r\n    *ngIf=\"id !== 0 && id !== 1 && id !== 5\"\r\n  >\r\n    by\r\n  </div>\r\n  <ng-container *ngIf=\"frequencyType === 2\">\r\n    <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">\r\n      {{ occurrenceFirst > 1 ? \"years\" : \"year\" }} on day\r\n    </div>\r\n    <input\r\n      type=\"number\"\r\n      type=\"number\"\r\n      [id]=\"'occurrence-day' + id\"\r\n      [(ngModel)]=\"yearlyDay\"\r\n      (focusout)=\"enterYearDay($event)\"\r\n      onkeydown=\"return event.keyCode !== 190\"\r\n      min=\"0\"\r\n      oninput=\"this.value = Math.abs(this.value)\"\r\n    />\r\n    <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">by</div>\r\n  </ng-container>\r\n  <div\r\n    class=\"time-picker vx-d-flex vx-align-center vx-justify-end vx-pr-3\"\r\n    appPopover\r\n    (click)=\"timePicker.popover()\"\r\n    placement=\"right\"\r\n  >\r\n    <input\r\n      type=\"text\"\r\n      [id]=\"'time-picker-input-top' + id\"\r\n      [(ngModel)]=\"inputTime\"\r\n      readonly\r\n      [placeholder]=\"DEFAULT_TIME\"\r\n    />\r\n    <div class=\"clock-icon vx-d-flex vx-align-center vx-justify-center\">\r\n      <i class=\"icons vx-fs-12 vx-paragraph-txt\">&#xe955;</i>\r\n    </div>\r\n  </div>\r\n  <app-popover #timePicker [dontCloseonClick]=\"true\">\r\n    <app-time-picker\r\n      [time]=\"inputTime\"\r\n      (onTimeSelection)=\"onTimeChanged($event); timePicker.closePopover('top')\"\r\n    ></app-time-picker>\r\n  </app-popover>\r\n</div>\r\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frequency-dialog-top.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency-dialog/frequency-dialog-top/frequency-dialog-top.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency-dialog/frequency-dialog-top/frequency-dialog-top.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport moment from 'moment/moment';\r\nimport { DEFAULT_TIME } from '../../../constants/time.constants';\r\n\r\n@Component({\r\n  selector: 'app-frequency-dialog-top',\r\n  templateUrl: './frequency-dialog-top.component.html',\r\n  styleUrls: ['./frequency-dialog-top.component.less'],\r\n})\r\nexport class FrequencyDialogTopComponent implements OnInit {\r\n  @Input() occurrenceFirst = 0;\r\n  @Input() id = 0; // 0 = Daily, 1: weekly, 5: Annually\r\n  @Input() inputTime = '11:00 pm';\r\n  @Input() frequencyType = 0; // 0 = days, 1 = weeks & 2 = years\r\n  @Input() yearlyDay = new Date().getDate();\r\n\r\n  @Output() valueChangedFirst: EventEmitter<any> = new EventEmitter();\r\n  @Output() nextDisable: EventEmitter<any> = new EventEmitter();\r\n  @Output() timeChanged: EventEmitter<any> = new EventEmitter();\r\n  @Output() yearlyDateChanged: EventEmitter<any> = new EventEmitter();\r\n\r\n  todayDate = new Date();\r\n  dateObjectData = new Date();\r\n  timeData = '11:00 pm';\r\n  DEFAULT_TIME = DEFAULT_TIME;\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {}\r\n\r\n  enterValueFirst(event: any, actionType: string) {\r\n    if (this.id !== 0 && this.id !== 1 && this.id !== 5) {\r\n      this.enterValue(this.occurrenceFirst, actionType);\r\n      return;\r\n    }\r\n    if (\r\n      !Number.isNaN(Number(this.occurrenceFirst)) &&\r\n      this.occurrenceFirst !== 0 &&\r\n      Number(this.occurrenceFirst) > 0\r\n    ) {\r\n      this.occurrenceFirst = Number(this.occurrenceFirst);\r\n      this.valueChangedFirst.emit({\r\n        type: actionType,\r\n        value: Number(this.occurrenceFirst),\r\n        pageName: '',\r\n      });\r\n    } else {\r\n      this.occurrenceFirst = 1;\r\n    }\r\n  }\r\n\r\n  enterValue(event: any, actionType: any) {\r\n    if (\r\n      !Number.isNaN(Number(event)) &&\r\n      event !== 0 &&\r\n      Number(event) > 0 &&\r\n      Number(event) < 32\r\n    ) {\r\n      this.occurrenceFirst = Number(event);\r\n      this.valueChangedFirst.emit({\r\n        type: actionType,\r\n        value: Number(event),\r\n        pageName: '',\r\n      });\r\n    } else {\r\n      this.occurrenceFirst = new Date().getDate();\r\n    }\r\n  }\r\n\r\n  getToday(): string {\r\n    return moment(Date.now()).format('YYYY-MM-DD HH:mm:ss')?.split(' ')[0];\r\n  }\r\n\r\n  onTimeChanged(event: any) {\r\n    try {\r\n      event = event.selectedValue;\r\n      this.timeData = event;\r\n      if (typeof this.dateObjectData == 'object') {\r\n        this.dateObjectData = moment(this.dateObjectData).toDate();\r\n      }\r\n      let timeStamp = moment(\r\n        this.dateObjectData.getDate() +\r\n          '-' +\r\n          (this.dateObjectData.getMonth() + 1) +\r\n          '-' +\r\n          this.dateObjectData.getFullYear() +\r\n          ' ' +\r\n          this.timeData,\r\n        'DD-MM-YYYY hh:mm a'\r\n      ).unix();\r\n      if (Date.now() / 1000 > timeStamp) {\r\n        this.nextDisable.emit(true);\r\n      } else {\r\n        this.nextDisable.emit(false);\r\n      }\r\n      this.timeChanged.emit(event);\r\n    } catch (e) {\r\n      console.error(e);\r\n    }\r\n  }\r\n\r\n  enterYearDay(event: any) {\r\n    if (\r\n      !Number.isNaN(Number(this.yearlyDay)) &&\r\n      this.yearlyDay !== 0 &&\r\n      Number(this.yearlyDay) > 0 &&\r\n      Number(this.yearlyDay) < 32\r\n    ) {\r\n      //this.yearlyDay = Number(event.target.value);\r\n      this.yearlyDateChanged.emit(this.yearlyDay);\r\n    } else {\r\n      this.yearlyDay = new Date().getDate();\r\n    }\r\n  }\r\n}\r\n","<div class=\"frequency-dialog-top vx-p-3 vx-d-flex vx-align-center\">\r\n  <div class=\"vx-fs-13 vx-paragraph-txt vx-mr-3\">\r\n    {{ id === 0 || id === 1 || id === 5 ? \"Every\" : \"Day\" }}\r\n  </div>\r\n  <input\r\n    type=\"number\"\r\n    [id]=\"'occurrence' + id\"\r\n    [(ngModel)]=\"occurrenceFirst\"\r\n    class=\"day-counter\"\r\n    onkeydown=\"return event.keyCode !== 190\"\r\n    min=\"0\"\r\n    oninput=\"this.value = Math.abs(this.value)\"\r\n    (focusout)=\"enterValueFirst($event, 'occurrenceFirst')\"\r\n  />\r\n  <div\r\n    *ngIf=\"frequencyType === 1\"\r\n    class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\"\r\n  >\r\n    {{ occurrenceFirst > 1 ? \"weeks\" : \"week\" }} by\r\n  </div>\r\n  <div\r\n    class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\"\r\n    *ngIf=\"id !== 0 && id !== 1 && id !== 5\"\r\n  >\r\n    by\r\n  </div>\r\n  <ng-container *ngIf=\"frequencyType === 2\">\r\n    <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">\r\n      {{ occurrenceFirst > 1 ? \"years\" : \"year\" }} on day\r\n    </div>\r\n    <input\r\n      type=\"number\"\r\n      type=\"number\"\r\n      [id]=\"'occurrence-day' + id\"\r\n      [(ngModel)]=\"yearlyDay\"\r\n      (focusout)=\"enterYearDay($event)\"\r\n      onkeydown=\"return event.keyCode !== 190\"\r\n      min=\"0\"\r\n      oninput=\"this.value = Math.abs(this.value)\"\r\n    />\r\n    <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">by</div>\r\n  </ng-container>\r\n  <div\r\n    class=\"time-picker vx-d-flex vx-align-center vx-justify-end vx-pr-3\"\r\n    appPopover\r\n    (click)=\"timePicker.popover()\"\r\n    placement=\"right\"\r\n  >\r\n    <input\r\n      type=\"text\"\r\n      [id]=\"'time-picker-input-top' + id\"\r\n      [(ngModel)]=\"inputTime\"\r\n      readonly\r\n      [placeholder]=\"DEFAULT_TIME\"\r\n    />\r\n    <div class=\"clock-icon vx-d-flex vx-align-center vx-justify-center\">\r\n      <i class=\"icons vx-fs-12 vx-paragraph-txt\">&#xe955;</i>\r\n    </div>\r\n  </div>\r\n  <app-popover #timePicker [dontCloseonClick]=\"true\">\r\n    <app-time-picker\r\n      [time]=\"inputTime\"\r\n      (onTimeSelection)=\"onTimeChanged($event); timePicker.closePopover('top')\"\r\n    ></app-time-picker>\r\n  </app-popover>\r\n</div>\r\n"]}
@@ -22,7 +22,6 @@ export class TimePickerComponent {
22
22
  if (!['00', '30'].includes(time[1])) {
23
23
  time[1] = '00';
24
24
  }
25
- console.log('time ===>', time);
26
25
  this.selectedTime = {
27
26
  HOURS: parseInt(time[0]),
28
27
  MINUTES: time[1],
@@ -34,7 +33,7 @@ export class TimePickerComponent {
34
33
  const scrollStatus = this.getScrollDirection(event);
35
34
  switch (type) {
36
35
  case this.TIME_VARIABLE[0]:
37
- this.hourArray = this.handleMouseWheelEvent(this.hourArray, scrollStatus);
36
+ this.hourArray = this.getNextValuesOnMouseWheel(this.hourArray, scrollStatus);
38
37
  break;
39
38
  case this.TIME_VARIABLE[1]:
40
39
  this.setMinutes(scrollStatus);
@@ -50,32 +49,56 @@ export class TimePickerComponent {
50
49
  this.setDefault();
51
50
  }
52
51
  }
53
- handleMouseWheelEvent(currentValues, direction) {
52
+ /**
53
+ * The function `handleMouseWheelEvent` takes an array of current values and a direction ('up' or
54
+ * 'down') as input, and returns an array of next values based on the direction and the maximum and
55
+ * minimum values.
56
+ * @param {number[]} currentValues - An array of numbers representing the current values.
57
+ * @param {'up' | 'down'} direction - The direction parameter is a string that can have two possible
58
+ * values: 'up' or 'down'. It indicates the direction of the mouse wheel event, whether it is
59
+ * scrolling up or scrolling down.
60
+ * @returns an array of numbers representing the next values based on the current values and the
61
+ * direction of the mouse wheel event.
62
+ */
63
+ getNextValuesOnMouseWheel(currentValues, direction) {
64
+ // Define the maximum and minimum values
54
65
  const maxValue = 12;
55
66
  const minValue = 1;
67
+ // Define the maximum number of elements in the returned array
56
68
  const maxElements = 5;
57
69
  if (direction === 'up') {
58
70
  let nextValues = [];
59
71
  for (let i = 0; i < maxElements; i++) {
60
- let nextValue = currentValues[0] - 1 + i;
72
+ // Calculate the next value by subtracting 1 from the current value
73
+ let nextValue = currentValues[i] - 1;
74
+ // Wrap around if the next value is less than the minimum value
61
75
  if (nextValue < minValue) {
62
- nextValue = maxValue + nextValue;
76
+ // Calculate the wrapped value using modulo operator (%)
77
+ nextValue =
78
+ maxValue - ((minValue - nextValue - 1) % (maxValue - minValue + 1));
63
79
  }
80
+ // Add the next value to the array
64
81
  nextValues.push(nextValue);
65
82
  }
83
+ // Return the array with the next values
66
84
  return nextValues;
67
85
  }
68
86
  if (direction === 'down') {
69
87
  let nextValues = [];
70
88
  for (let i = 0; i < maxElements; i++) {
89
+ // Calculate the next value by adding 1 and the index
71
90
  let nextValue = currentValues[0] + 1 + i;
91
+ // Wrap around if the next value exceeds the maximum value
72
92
  if (nextValue > maxValue) {
73
- nextValue = nextValue - maxValue;
93
+ nextValue = minValue + ((nextValue - maxValue) % maxValue) - 1;
74
94
  }
95
+ // Add the next value to the array
75
96
  nextValues.push(nextValue);
76
97
  }
98
+ // Return the array with the next values
77
99
  return nextValues;
78
100
  }
101
+ // If the direction is neither 'up' nor 'down', return the current values unchanged
79
102
  return currentValues;
80
103
  }
81
104
  onCloseTimePicker(actionType) {
@@ -194,4 +217,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
194
217
  type: Input,
195
218
  args: ['time']
196
219
  }] } });
197
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/ui-kit/time-picker/time-picker/time-picker.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/ui-kit/time-picker/time-picker/time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input } from '@angular/core';\r\nimport { AM_PM, MINUTES, TIME_VARIABLE } from '../constants/constant';\r\nimport { DEFAULT_TIME } from '../../../constants/time.constants';\r\n\r\n@Component({\r\n  selector: 'app-time-picker',\r\n  templateUrl: './time-picker.component.html',\r\n  styleUrls: ['./time-picker.component.less'],\r\n  outputs: ['onTimeSelection'],\r\n})\r\nexport class TimePickerComponent {\r\n  public MINUTES: string[] = MINUTES;\r\n  public AM_PM: string[] = AM_PM;\r\n  private selectedTime: any;\r\n  public hourArray: number[] = [9, 10, 11, 12, 13];\r\n  public TIME_VARIABLE = TIME_VARIABLE; //['HOURS', 'MINUTES', 'MERIDIEM']\r\n  private defaultSelectedTime: string = '';\r\n  @Input('time') set defaultTime(inputTime: string) {\r\n    if (!inputTime) {\r\n      inputTime = DEFAULT_TIME;\r\n    }\r\n    this.defaultSelectedTime = inputTime;\r\n    const timeDetails = inputTime.split(' ');\r\n    let time = timeDetails[0].split(':');\r\n    if (!['00', '30'].includes(time[1])) {\r\n      time[1] = '00';\r\n    }\r\n    console.log('time ===>', time);\r\n    this.selectedTime = {\r\n      HOURS: parseInt(time[0]),\r\n      MINUTES: time[1],\r\n      MERIDIEM: timeDetails[1]?.toUpperCase(),\r\n    };\r\n    this.setDefault();\r\n  }\r\n  onTimeSelection: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor() {}\r\n\r\n  onScroll(event: any, type: any): void {\r\n    const scrollStatus = this.getScrollDirection(event);\r\n\r\n    switch (type) {\r\n      case this.TIME_VARIABLE[0]:\r\n        this.hourArray = this.handleMouseWheelEvent(\r\n          this.hourArray,\r\n          scrollStatus\r\n        );\r\n        break;\r\n      case this.TIME_VARIABLE[1]:\r\n        this.setMinutes(scrollStatus);\r\n        break;\r\n      case this.TIME_VARIABLE[2]:\r\n        this.setMeridiem(scrollStatus);\r\n        break;\r\n    }\r\n  }\r\n\r\n  onValueSelect(value: string | number, type: string): void {\r\n    if (value) {\r\n      this.selectedTime[type] = value;\r\n      this.setDefault();\r\n    }\r\n  }\r\n\r\n  handleMouseWheelEvent(\r\n    currentValues: number[],\r\n    direction: 'up' | 'down'\r\n  ): number[] {\r\n    const maxValue = 12;\r\n    const minValue = 1;\r\n    const maxElements = 5;\r\n\r\n    if (direction === 'up') {\r\n      let nextValues = [];\r\n      for (let i = 0; i < maxElements; i++) {\r\n        let nextValue = currentValues[0] - 1 + i;\r\n        if (nextValue < minValue) {\r\n          nextValue = maxValue + nextValue;\r\n        }\r\n        nextValues.push(nextValue);\r\n      }\r\n      return nextValues;\r\n    }\r\n\r\n    if (direction === 'down') {\r\n      let nextValues = [];\r\n      for (let i = 0; i < maxElements; i++) {\r\n        let nextValue = currentValues[0] + 1 + i;\r\n        if (nextValue > maxValue) {\r\n          nextValue = nextValue - maxValue;\r\n        }\r\n        nextValues.push(nextValue);\r\n      }\r\n      return nextValues;\r\n    }\r\n    return currentValues;\r\n  }\r\n\r\n  onCloseTimePicker(actionType: 'cancel' | 'ok'): void {\r\n    const time =\r\n      this.selectedTime.HOURS +\r\n      ':' +\r\n      this.selectedTime.MINUTES +\r\n      ' ' +\r\n      this.selectedTime.MERIDIEM;\r\n    this.onTimeSelection.emit({\r\n      actionType: actionType,\r\n      selectedValue: actionType === 'ok' ? time : this.defaultSelectedTime,\r\n    });\r\n  }\r\n\r\n  private getScrollDirection(event: any): 'up' | 'down' {\r\n    if (event.deltaY < 0) {\r\n      return 'up';\r\n    } else {\r\n      return 'down';\r\n    }\r\n  }\r\n\r\n  private setMinutes(type: 'up' | 'down') {\r\n    if (type === 'up') {\r\n      const index = this.MINUTES.indexOf('00');\r\n      if (index === 1) {\r\n        this.MINUTES.unshift('');\r\n        this.MINUTES.pop();\r\n      }\r\n    } else {\r\n      const index = this.MINUTES.indexOf('00');\r\n      if (index === 2) {\r\n        this.MINUTES.shift();\r\n        this.MINUTES.push('');\r\n      }\r\n    }\r\n    this.findSelectedValue(TIME_VARIABLE[1], this.MINUTES);\r\n  }\r\n\r\n  private setMeridiem(type: 'up' | 'down') {\r\n    if (type === 'up') {\r\n      const index = this.AM_PM.indexOf('AM');\r\n      if (index === 1) {\r\n        this.AM_PM.unshift('');\r\n        this.AM_PM.pop();\r\n      }\r\n    } else {\r\n      const index = this.AM_PM.indexOf('AM');\r\n      if (index === 2) {\r\n        this.AM_PM.shift();\r\n        this.AM_PM.push('');\r\n      }\r\n    }\r\n\r\n    this.findSelectedValue(TIME_VARIABLE[2], this.AM_PM);\r\n  }\r\n\r\n  private findSelectedValue(type: string, array: Array<any>) {\r\n    this.selectedTime[type] = array[2];\r\n  }\r\n\r\n  private setDefault(): void {\r\n    const defaultHours = this.selectedTime.HOURS;\r\n    const defaultMinutes = this.selectedTime.MINUTES;\r\n    const defaultMeridiem = this.selectedTime.MERIDIEM;\r\n    this.hourArray[2] = defaultHours;\r\n    this.setHoursToDefault(defaultHours);\r\n    if (defaultMinutes === '30') {\r\n      this.MINUTES[2] = defaultMinutes;\r\n      this.MINUTES[1] = '00';\r\n      this.MINUTES[3] = '';\r\n    } else {\r\n      this.MINUTES[1] = '';\r\n      this.MINUTES[2] = '00';\r\n      this.MINUTES[3] = '30';\r\n    }\r\n\r\n    if (defaultMeridiem === 'PM') {\r\n      this.AM_PM[2] = defaultMeridiem;\r\n      this.AM_PM[1] = 'AM';\r\n      this.AM_PM[3] = '';\r\n      // this.setMeridiem('up');\r\n    } else {\r\n      this.AM_PM[1] = '';\r\n      this.AM_PM[2] = 'AM';\r\n      this.AM_PM[3] = 'PM';\r\n    }\r\n  }\r\n\r\n  private setHoursToDefault(defaultHours: number): void {\r\n    let prevIndex = 2;\r\n    let nextIndex = 1;\r\n    this.hourArray = this.hourArray.map((value: number, index: number) => {\r\n      value = defaultHours;\r\n      if (index < 2) {\r\n        value = value - prevIndex;\r\n        if (value < 1) {\r\n          value = 12 + value;\r\n        }\r\n        prevIndex--;\r\n      } else if (index > 2) {\r\n        value = value + nextIndex;\r\n        if (value > 12) {\r\n          value = value - 12;\r\n        }\r\n        nextIndex++;\r\n      }\r\n\r\n      return value;\r\n    });\r\n  }\r\n}\r\n","<div class=\"timePicker\">\r\n  <div class=\"vx-d-flex vx-align-center vx-justify-center\">\r\n    <div class=\"timePicker-inner vx-d-flex vx-align-center vx-p-3\">\r\n      <div class=\"timePicker-column\" #hour_column>\r\n        <div\r\n          *ngFor=\"let eachHour of hourArray; let i = index\"\r\n          class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1\"\r\n          [class.active]=\"i === 2\"\r\n          (mousewheel)=\"onScroll($event, TIME_VARIABLE[0])\"\r\n          [id]=\"'hour_column_' + (i + 1)\"\r\n          (click)=\"onValueSelect(eachHour, TIME_VARIABLE[0])\"\r\n        >\r\n          <ng-container *ngIf=\"eachHour > 0 && eachHour < 13\">\r\n            {{ eachHour }}\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n      <div class=\"timePicker-column\" #minutes_column>\r\n        <div\r\n          *ngFor=\"let eachMinutes of MINUTES; let i = index\"\r\n          class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1\"\r\n          [class.active]=\"i === 2\"\r\n          [id]=\"'minutes_column_' + (i + 1)\"\r\n          (mousewheel)=\"onScroll($event, TIME_VARIABLE[1])\"\r\n          (click)=\"onValueSelect(eachMinutes, TIME_VARIABLE[1])\"\r\n        >\r\n          {{ eachMinutes }}\r\n        </div>\r\n      </div>\r\n      <div class=\"timePicker-column\" #meridiem_column>\r\n        <div\r\n          *ngFor=\"let eachMeridiem of AM_PM; let i = index\"\r\n          class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1 vx-tt-uppercase\"\r\n          [class.active]=\"i === 2\"\r\n          [id]=\"'meridiem_column_' + (i + 1)\"\r\n          (mousewheel)=\"onScroll($event, TIME_VARIABLE[2])\"\r\n          (click)=\"onValueSelect(eachMeridiem, TIME_VARIABLE[2])\"\r\n        >\r\n          {{ eachMeridiem }}\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div\r\n    class=\"timePicker-bottom vx-d-flex vx-align-center vx-justify-between vx-p-2\"\r\n  >\r\n    <button\r\n      (click)=\"onCloseTimePicker('cancel')\"\r\n      class=\"cancel-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-m-0 vx-d-flex vx-align-center vx-justify-center vx-lh-6\"\r\n    >\r\n      CANCEL\r\n    </button>\r\n    <button\r\n      (click)=\"onCloseTimePicker('ok')\"\r\n      class=\"ok-btn vx-fs-11 vx-fw-500 vx-txt-white vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-m-0 vx-d-flex vx-align-center vx-justify-center vx-lh-6\"\r\n    >\r\n      OK\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
220
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/ui-kit/time-picker/time-picker/time-picker.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/ui-kit/time-picker/time-picker/time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input } from '@angular/core';\r\nimport { AM_PM, MINUTES, TIME_VARIABLE } from '../constants/constant';\r\nimport { DEFAULT_TIME } from '../../../constants/time.constants';\r\n\r\n@Component({\r\n  selector: 'app-time-picker',\r\n  templateUrl: './time-picker.component.html',\r\n  styleUrls: ['./time-picker.component.less'],\r\n  outputs: ['onTimeSelection'],\r\n})\r\nexport class TimePickerComponent {\r\n  public MINUTES: string[] = MINUTES;\r\n  public AM_PM: string[] = AM_PM;\r\n  private selectedTime: any;\r\n  public hourArray: number[] = [9, 10, 11, 12, 13];\r\n  public TIME_VARIABLE = TIME_VARIABLE; //['HOURS', 'MINUTES', 'MERIDIEM']\r\n  private defaultSelectedTime: string = '';\r\n  @Input('time') set defaultTime(inputTime: string) {\r\n    if (!inputTime) {\r\n      inputTime = DEFAULT_TIME;\r\n    }\r\n    this.defaultSelectedTime = inputTime;\r\n    const timeDetails = inputTime.split(' ');\r\n    let time = timeDetails[0].split(':');\r\n    if (!['00', '30'].includes(time[1])) {\r\n      time[1] = '00';\r\n    }\r\n    this.selectedTime = {\r\n      HOURS: parseInt(time[0]),\r\n      MINUTES: time[1],\r\n      MERIDIEM: timeDetails[1]?.toUpperCase(),\r\n    };\r\n    this.setDefault();\r\n  }\r\n  onTimeSelection: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor() {}\r\n\r\n  onScroll(event: any, type: any): void {\r\n    const scrollStatus = this.getScrollDirection(event);\r\n\r\n    switch (type) {\r\n      case this.TIME_VARIABLE[0]:\r\n        this.hourArray = this.getNextValuesOnMouseWheel(\r\n          this.hourArray,\r\n          scrollStatus\r\n        );\r\n        break;\r\n      case this.TIME_VARIABLE[1]:\r\n        this.setMinutes(scrollStatus);\r\n        break;\r\n      case this.TIME_VARIABLE[2]:\r\n        this.setMeridiem(scrollStatus);\r\n        break;\r\n    }\r\n  }\r\n\r\n  onValueSelect(value: string | number, type: string): void {\r\n    if (value) {\r\n      this.selectedTime[type] = value;\r\n      this.setDefault();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * The function `handleMouseWheelEvent` takes an array of current values and a direction ('up' or\r\n   * 'down') as input, and returns an array of next values based on the direction and the maximum and\r\n   * minimum values.\r\n   * @param {number[]} currentValues - An array of numbers representing the current values.\r\n   * @param {'up' | 'down'} direction - The direction parameter is a string that can have two possible\r\n   * values: 'up' or 'down'. It indicates the direction of the mouse wheel event, whether it is\r\n   * scrolling up or scrolling down.\r\n   * @returns an array of numbers representing the next values based on the current values and the\r\n   * direction of the mouse wheel event.\r\n   */\r\n  getNextValuesOnMouseWheel(\r\n    currentValues: number[],\r\n    direction: 'up' | 'down'\r\n  ): number[] {\r\n    // Define the maximum and minimum values\r\n    const maxValue = 12;\r\n    const minValue = 1;\r\n\r\n    // Define the maximum number of elements in the returned array\r\n    const maxElements = 5;\r\n\r\n    if (direction === 'up') {\r\n      let nextValues = [];\r\n      for (let i = 0; i < maxElements; i++) {\r\n        // Calculate the next value by subtracting 1 from the current value\r\n        let nextValue = currentValues[i] - 1;\r\n        // Wrap around if the next value is less than the minimum value\r\n        if (nextValue < minValue) {\r\n          // Calculate the wrapped value using modulo operator (%)\r\n          nextValue =\r\n            maxValue - ((minValue - nextValue - 1) % (maxValue - minValue + 1));\r\n        }\r\n        // Add the next value to the array\r\n        nextValues.push(nextValue);\r\n      }\r\n      // Return the array with the next values\r\n      return nextValues;\r\n    }\r\n\r\n    if (direction === 'down') {\r\n      let nextValues = [];\r\n      for (let i = 0; i < maxElements; i++) {\r\n        // Calculate the next value by adding 1 and the index\r\n        let nextValue = currentValues[0] + 1 + i;\r\n        // Wrap around if the next value exceeds the maximum value\r\n        if (nextValue > maxValue) {\r\n          nextValue = minValue + ((nextValue - maxValue) % maxValue) - 1;\r\n        }\r\n        // Add the next value to the array\r\n        nextValues.push(nextValue);\r\n      }\r\n      // Return the array with the next values\r\n      return nextValues;\r\n    }\r\n\r\n    // If the direction is neither 'up' nor 'down', return the current values unchanged\r\n    return currentValues;\r\n  }\r\n\r\n  onCloseTimePicker(actionType: 'cancel' | 'ok'): void {\r\n    const time =\r\n      this.selectedTime.HOURS +\r\n      ':' +\r\n      this.selectedTime.MINUTES +\r\n      ' ' +\r\n      this.selectedTime.MERIDIEM;\r\n    this.onTimeSelection.emit({\r\n      actionType: actionType,\r\n      selectedValue: actionType === 'ok' ? time : this.defaultSelectedTime,\r\n    });\r\n  }\r\n\r\n  private getScrollDirection(event: any): 'up' | 'down' {\r\n    if (event.deltaY < 0) {\r\n      return 'up';\r\n    } else {\r\n      return 'down';\r\n    }\r\n  }\r\n\r\n  private setMinutes(type: 'up' | 'down') {\r\n    if (type === 'up') {\r\n      const index = this.MINUTES.indexOf('00');\r\n      if (index === 1) {\r\n        this.MINUTES.unshift('');\r\n        this.MINUTES.pop();\r\n      }\r\n    } else {\r\n      const index = this.MINUTES.indexOf('00');\r\n      if (index === 2) {\r\n        this.MINUTES.shift();\r\n        this.MINUTES.push('');\r\n      }\r\n    }\r\n    this.findSelectedValue(TIME_VARIABLE[1], this.MINUTES);\r\n  }\r\n\r\n  private setMeridiem(type: 'up' | 'down') {\r\n    if (type === 'up') {\r\n      const index = this.AM_PM.indexOf('AM');\r\n      if (index === 1) {\r\n        this.AM_PM.unshift('');\r\n        this.AM_PM.pop();\r\n      }\r\n    } else {\r\n      const index = this.AM_PM.indexOf('AM');\r\n      if (index === 2) {\r\n        this.AM_PM.shift();\r\n        this.AM_PM.push('');\r\n      }\r\n    }\r\n\r\n    this.findSelectedValue(TIME_VARIABLE[2], this.AM_PM);\r\n  }\r\n\r\n  private findSelectedValue(type: string, array: Array<any>) {\r\n    this.selectedTime[type] = array[2];\r\n  }\r\n\r\n  private setDefault(): void {\r\n    const defaultHours = this.selectedTime.HOURS;\r\n    const defaultMinutes = this.selectedTime.MINUTES;\r\n    const defaultMeridiem = this.selectedTime.MERIDIEM;\r\n    this.hourArray[2] = defaultHours;\r\n    this.setHoursToDefault(defaultHours);\r\n    if (defaultMinutes === '30') {\r\n      this.MINUTES[2] = defaultMinutes;\r\n      this.MINUTES[1] = '00';\r\n      this.MINUTES[3] = '';\r\n    } else {\r\n      this.MINUTES[1] = '';\r\n      this.MINUTES[2] = '00';\r\n      this.MINUTES[3] = '30';\r\n    }\r\n\r\n    if (defaultMeridiem === 'PM') {\r\n      this.AM_PM[2] = defaultMeridiem;\r\n      this.AM_PM[1] = 'AM';\r\n      this.AM_PM[3] = '';\r\n      // this.setMeridiem('up');\r\n    } else {\r\n      this.AM_PM[1] = '';\r\n      this.AM_PM[2] = 'AM';\r\n      this.AM_PM[3] = 'PM';\r\n    }\r\n  }\r\n\r\n  private setHoursToDefault(defaultHours: number): void {\r\n    let prevIndex = 2;\r\n    let nextIndex = 1;\r\n    this.hourArray = this.hourArray.map((value: number, index: number) => {\r\n      value = defaultHours;\r\n      if (index < 2) {\r\n        value = value - prevIndex;\r\n        if (value < 1) {\r\n          value = 12 + value;\r\n        }\r\n        prevIndex--;\r\n      } else if (index > 2) {\r\n        value = value + nextIndex;\r\n        if (value > 12) {\r\n          value = value - 12;\r\n        }\r\n        nextIndex++;\r\n      }\r\n\r\n      return value;\r\n    });\r\n  }\r\n}\r\n","<div class=\"timePicker\">\r\n  <div class=\"vx-d-flex vx-align-center vx-justify-center\">\r\n    <div class=\"timePicker-inner vx-d-flex vx-align-center vx-p-3\">\r\n      <div class=\"timePicker-column\" #hour_column>\r\n        <div\r\n          *ngFor=\"let eachHour of hourArray; let i = index\"\r\n          class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1\"\r\n          [class.active]=\"i === 2\"\r\n          (mousewheel)=\"onScroll($event, TIME_VARIABLE[0])\"\r\n          [id]=\"'hour_column_' + (i + 1)\"\r\n          (click)=\"onValueSelect(eachHour, TIME_VARIABLE[0])\"\r\n        >\r\n          <ng-container *ngIf=\"eachHour > 0 && eachHour < 13\">\r\n            {{ eachHour }}\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n      <div class=\"timePicker-column\" #minutes_column>\r\n        <div\r\n          *ngFor=\"let eachMinutes of MINUTES; let i = index\"\r\n          class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1\"\r\n          [class.active]=\"i === 2\"\r\n          [id]=\"'minutes_column_' + (i + 1)\"\r\n          (mousewheel)=\"onScroll($event, TIME_VARIABLE[1])\"\r\n          (click)=\"onValueSelect(eachMinutes, TIME_VARIABLE[1])\"\r\n        >\r\n          {{ eachMinutes }}\r\n        </div>\r\n      </div>\r\n      <div class=\"timePicker-column\" #meridiem_column>\r\n        <div\r\n          *ngFor=\"let eachMeridiem of AM_PM; let i = index\"\r\n          class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1 vx-tt-uppercase\"\r\n          [class.active]=\"i === 2\"\r\n          [id]=\"'meridiem_column_' + (i + 1)\"\r\n          (mousewheel)=\"onScroll($event, TIME_VARIABLE[2])\"\r\n          (click)=\"onValueSelect(eachMeridiem, TIME_VARIABLE[2])\"\r\n        >\r\n          {{ eachMeridiem }}\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div\r\n    class=\"timePicker-bottom vx-d-flex vx-align-center vx-justify-between vx-p-2\"\r\n  >\r\n    <button\r\n      (click)=\"onCloseTimePicker('cancel')\"\r\n      class=\"cancel-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-m-0 vx-d-flex vx-align-center vx-justify-center vx-lh-6\"\r\n    >\r\n      CANCEL\r\n    </button>\r\n    <button\r\n      (click)=\"onCloseTimePicker('ok')\"\r\n      class=\"ok-btn vx-fs-11 vx-fw-500 vx-txt-white vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-m-0 vx-d-flex vx-align-center vx-justify-center vx-lh-6\"\r\n    >\r\n      OK\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
@@ -8948,7 +8948,6 @@ class TimePickerComponent {
8948
8948
  if (!['00', '30'].includes(time[1])) {
8949
8949
  time[1] = '00';
8950
8950
  }
8951
- console.log('time ===>', time);
8952
8951
  this.selectedTime = {
8953
8952
  HOURS: parseInt(time[0]),
8954
8953
  MINUTES: time[1],
@@ -8960,7 +8959,7 @@ class TimePickerComponent {
8960
8959
  const scrollStatus = this.getScrollDirection(event);
8961
8960
  switch (type) {
8962
8961
  case this.TIME_VARIABLE[0]:
8963
- this.hourArray = this.handleMouseWheelEvent(this.hourArray, scrollStatus);
8962
+ this.hourArray = this.getNextValuesOnMouseWheel(this.hourArray, scrollStatus);
8964
8963
  break;
8965
8964
  case this.TIME_VARIABLE[1]:
8966
8965
  this.setMinutes(scrollStatus);
@@ -8976,32 +8975,56 @@ class TimePickerComponent {
8976
8975
  this.setDefault();
8977
8976
  }
8978
8977
  }
8979
- handleMouseWheelEvent(currentValues, direction) {
8978
+ /**
8979
+ * The function `handleMouseWheelEvent` takes an array of current values and a direction ('up' or
8980
+ * 'down') as input, and returns an array of next values based on the direction and the maximum and
8981
+ * minimum values.
8982
+ * @param {number[]} currentValues - An array of numbers representing the current values.
8983
+ * @param {'up' | 'down'} direction - The direction parameter is a string that can have two possible
8984
+ * values: 'up' or 'down'. It indicates the direction of the mouse wheel event, whether it is
8985
+ * scrolling up or scrolling down.
8986
+ * @returns an array of numbers representing the next values based on the current values and the
8987
+ * direction of the mouse wheel event.
8988
+ */
8989
+ getNextValuesOnMouseWheel(currentValues, direction) {
8990
+ // Define the maximum and minimum values
8980
8991
  const maxValue = 12;
8981
8992
  const minValue = 1;
8993
+ // Define the maximum number of elements in the returned array
8982
8994
  const maxElements = 5;
8983
8995
  if (direction === 'up') {
8984
8996
  let nextValues = [];
8985
8997
  for (let i = 0; i < maxElements; i++) {
8986
- let nextValue = currentValues[0] - 1 + i;
8998
+ // Calculate the next value by subtracting 1 from the current value
8999
+ let nextValue = currentValues[i] - 1;
9000
+ // Wrap around if the next value is less than the minimum value
8987
9001
  if (nextValue < minValue) {
8988
- nextValue = maxValue + nextValue;
9002
+ // Calculate the wrapped value using modulo operator (%)
9003
+ nextValue =
9004
+ maxValue - ((minValue - nextValue - 1) % (maxValue - minValue + 1));
8989
9005
  }
9006
+ // Add the next value to the array
8990
9007
  nextValues.push(nextValue);
8991
9008
  }
9009
+ // Return the array with the next values
8992
9010
  return nextValues;
8993
9011
  }
8994
9012
  if (direction === 'down') {
8995
9013
  let nextValues = [];
8996
9014
  for (let i = 0; i < maxElements; i++) {
9015
+ // Calculate the next value by adding 1 and the index
8997
9016
  let nextValue = currentValues[0] + 1 + i;
9017
+ // Wrap around if the next value exceeds the maximum value
8998
9018
  if (nextValue > maxValue) {
8999
- nextValue = nextValue - maxValue;
9019
+ nextValue = minValue + ((nextValue - maxValue) % maxValue) - 1;
9000
9020
  }
9021
+ // Add the next value to the array
9001
9022
  nextValues.push(nextValue);
9002
9023
  }
9024
+ // Return the array with the next values
9003
9025
  return nextValues;
9004
9026
  }
9027
+ // If the direction is neither 'up' nor 'down', return the current values unchanged
9005
9028
  return currentValues;
9006
9029
  }
9007
9030
  onCloseTimePicker(actionType) {
@@ -9180,7 +9203,6 @@ class FrequencyDialogTopComponent {
9180
9203
  onTimeChanged(event) {
9181
9204
  try {
9182
9205
  event = event.selectedValue;
9183
- console.log('event ===>', event);
9184
9206
  this.timeData = event;
9185
9207
  if (typeof this.dateObjectData == 'object') {
9186
9208
  this.dateObjectData = moment(this.dateObjectData).toDate();