@piserve-tech/form-submission 1.3.114 → 1.3.116

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.
@@ -398,13 +398,7 @@ export class DateTimeFieldsComponent {
398
398
  return date;
399
399
  }
400
400
  ngAfterViewInit() {
401
- if (this.fullTime3) {
402
- this.trackTimePicker(this.fullTime3, 'fullTime3');
403
- }
404
- if (this.fullTime4) {
405
- this.trackTimePicker(this.fullTime4, 'fullTime4');
406
- }
407
- // Subscribe to router events if not already done
401
+ this.initializeTimePickers();
408
402
  if (this.subscriptions.length === 0) {
409
403
  const routerSub = this.router.events.subscribe((event) => {
410
404
  if (event instanceof NavigationEnd) {
@@ -414,6 +408,10 @@ export class DateTimeFieldsComponent {
414
408
  this.subscriptions.push(routerSub);
415
409
  }
416
410
  }
411
+ ngAfterViewChecked() {
412
+ // Ensure time picker subscriptions are attached even after conditional rendering
413
+ this.initializeTimePickers();
414
+ }
417
415
  ngOnDestroy() {
418
416
  this.closeTimepickers();
419
417
  // Unsubscribe from all subscriptions
@@ -423,12 +421,24 @@ export class DateTimeFieldsComponent {
423
421
  }
424
422
  });
425
423
  }
424
+ /**
425
+ * Initialize and track time pickers
426
+ */
427
+ initializeTimePickers() {
428
+ // Track fullTime3 if available
429
+ if (this.fullTime3 && !this.timePickersOpened['fullTime3']) {
430
+ this.trackTimePicker(this.fullTime3, 'fullTime3');
431
+ }
432
+ // Track fullTime4 if it exists after conditional rendering
433
+ if (this.fullTime4 && !this.timePickersOpened['fullTime4']) {
434
+ this.trackTimePicker(this.fullTime4, 'fullTime4');
435
+ }
436
+ }
426
437
  trackTimePicker(picker, pickerName) {
427
438
  if (picker) {
428
- // Track if the picker has been opened
429
439
  const sub = picker.opened.subscribe(() => {
430
440
  console.log(`Timepicker opened:`, picker);
431
- this.timePickersOpened[pickerName] = true; // Mark picker as opened
441
+ this.timePickersOpened[pickerName] = true;
432
442
  });
433
443
  this.subscriptions.push(sub);
434
444
  }
@@ -436,11 +446,12 @@ export class DateTimeFieldsComponent {
436
446
  closeTimepickers() {
437
447
  if (this.fullTime3 && this.timePickersOpened['fullTime3'] && typeof this.fullTime3.close === 'function') {
438
448
  this.fullTime3.close();
439
- this.timePickersOpened['fullTime3'] = false; // Mark picker as closed
449
+ this.timePickersOpened['fullTime3'] = false;
440
450
  }
451
+ // Check for fullTime4 only if it exists
441
452
  if (this.fullTime4 && this.timePickersOpened['fullTime4'] && typeof this.fullTime4.close === 'function') {
442
453
  this.fullTime4.close();
443
- this.timePickersOpened['fullTime4'] = false; // Mark picker as closed
454
+ this.timePickersOpened['fullTime4'] = false;
444
455
  }
445
456
  }
446
457
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DateTimeFieldsComponent, deps: [{ token: i1.DatePipe }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component }); }
@@ -471,4 +482,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
471
482
  type: ViewChild,
472
483
  args: ['fullTime4']
473
484
  }] } });
474
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/date-time-fields/date-time-fields.component.ts","../../../../../projects/form-submission/src/form-fields/date-time-fields/date-time-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe } from '@angular/common';\nimport { Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { NavigationEnd, Router } from '@angular/router';\nimport {\n  BsDatepickerConfig,\n  BsDatepickerDirective,\n} from 'ngx-bootstrap/datepicker';\nimport { NgxMaterialTimepickerComponent } from 'ngx-material-timepicker';\nimport { Subscription } from 'rxjs';\n\n@Component({\n  selector: 'lib-date-time-fields',\n  templateUrl: './date-time-fields.component.html',\n  styleUrls: ['./date-time-fields.component.scss'],\n  providers: [DatePipe],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class DateTimeFieldsComponent {\n  bsConfig: Partial<BsDatepickerConfig> = {\n    containerClass: 'theme-custom',\n    isAnimated: true,\n    adaptivePosition: true,\n    showWeekNumbers: false,\n  };\n\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Output() answerChange = new EventEmitter<any>();\n\n  required: boolean = false;\n  hint: string = '';\n  count: number = 0;\n  minTime: string = '';\n  maxTime: string = '';\n  dateType: string = '';\n  format: string = '';\n  Dateformat: string = '';\n  timeFormat: string = '';\n  minDateOption: string = '';\n  minDate: Date | undefined;\n  maxDateOption: string = '';\n  maxDate: Date | undefined;\n  todayDate: Date = new Date();\n  selectedDate: Date | null = null;\n  selectedTime: string = '';\n  selectedDateRange: string = '';\n  selectedDateAndTime: Date | null = null;\n  validationFailed!: boolean;\n  timeValidationFailed!: boolean;\n  validationMessage: string = '';\n  maxTimeOption: string = '';\n  minTimeOption: string = '';\n  private timePickerOpened = false;\n  private subscriptions: Subscription[] = [];\n  private timePickersOpened: { [key: string]: boolean } = {};\n\n  @ViewChild('datepickerYMD') datepicker!: BsDatepickerDirective;\n  @ViewChild('daterangepicker') dateRangePicker!: BsDatepickerDirective;\n  @ViewChild('dateAndTimePicker') dateAndTimePicker!: BsDatepickerDirective;\n  @ViewChild('fullTime3') fullTime3!: NgxMaterialTimepickerComponent;\n  @ViewChild('fullTime4') fullTime4!: NgxMaterialTimepickerComponent;\n\n  constructor(private datePipe: DatePipe,private router: Router) { }\n\n  ngOnInit() {\n    this.valueAssigned();\n  }\n\n  valueAssigned() {\n    this.count = this.question.count;\n    this.required = this.question.required;\n    this.hint = this.question.hint;\n    this.dateType = this.question.formElement.appearance.dateType;\n    this.minDateOption = this.question.formElement.validation.minDateOption;\n    this.Dateformat = this.question.formElement.appearance.format.replace(\n      /DD/g,\n      'dd'\n    );\n\n    this.minDate = this.getMinDate();\n\n    this.maxDateOption = this.question.formElement.validation.maxDateOption;\n    this.maxDate = this.getMaxDate();\n    this.setDateTimeFormat();\n    if (this.question?.answer && (this.question?.answer).length > 0)\n      this.selectedDate = this.question?.answer;\n    this.selectedTime = this.question.answer;\n    if (this.question?.answer && (this.question?.answer).length > 0)\n      this.selectedDateAndTime = new Date(this.question.answer);\n    this.selectedDateRange = this.question.answer;\n    this.minTimeOption = this.question.formElement.validation.minTimeOption;\n    this.maxTimeOption = this.question.formElement.validation.maxTimeOption;\n    if (this.dateType !== 'DATE_AND_TIME') {\n      this.minTime = this.getMinTime().toString();\n      this.maxTime = this.getMaxTime().toString();\n    }\n    if (this.dateType === 'DATE_AND_TIME' && this.question?.answer) {\n      const dateTimeArray = this.question.answer\n        ? this.question.answer.split(',')\n        : []; // Fallback to an empty array if `this.question.answer` is undefined\n\n      if (dateTimeArray.length === 2) {\n        const fetchedDate = dateTimeArray[0].trim();\n        const fetchedTime = dateTimeArray[1].trim();\n        this.selectedDate = fetchedDate;\n        this.selectedTime = fetchedTime;\n      }\n\n      const formattedDate = this.datePipe.transform(\n        this.selectedDateAndTime,\n        this.Dateformat\n      );\n      const formatteminDate = this.datePipe.transform(\n        this.minDate,\n        this.Dateformat\n      );\n      const formattemaxDate = this.datePipe.transform(\n        this.maxDate,\n        this.Dateformat\n      );\n\n      if (formattedDate === formatteminDate) {\n        this.minTime = this.getMinTime().toString();\n        if (this.timeFormat === '12') {\n          this.maxTime = '12:00 pm';\n        } else {\n          this.maxTime = '23:59';\n        }\n      }\n      if (formattedDate === formattemaxDate) {\n        this.maxTime = this.getMaxTime().toString();\n        if (this.timeFormat === '12') {\n          this.minTime = '12:00 am';\n        } else {\n          this.minTime = '00:00';\n        }\n      }\n      if (\n        formattedDate !== formatteminDate &&\n        formattedDate !== formattemaxDate\n      ) {\n        if (this.timeFormat === '12') {\n          this.minTime = '12:00 am';\n          this.maxTime = '12:00 pm';\n        } else {\n          this.minTime = '00:00';\n          this.maxTime = '23:59';\n        }\n      }\n    }\n\n    if (!this.minTime || this.minTime.length === 0) {\n      if (this.timeFormat === '12') {\n        this.minTime = '12:00 am';\n      } else {\n        this.minTime = '00:00';\n      }\n    }\n\n    if (!this.maxTime || this.maxTime.length === 0) {\n      if (this.timeFormat === '12') {\n        this.maxTime = '11:59 pm';\n      } else {\n        this.maxTime = '23:59';\n      }\n    }\n  }\n\n  setDateTimeFormat() {\n    switch (this.dateType) {\n      case 'DATE_ONLY':\n        this.format = this.question.formElement.appearance.format;\n        break;\n      case 'TIME_ONLY':\n        this.timeFormat = this.question.formElement.appearance.timeFormat;\n        break;\n      case 'DATE_AND_TIME':\n        this.format = this.question.formElement.appearance.format;\n        this.timeFormat = this.question.formElement.appearance.timeFormat;\n        break;\n      case 'DATE_RANGE':\n        this.format = this.question.formElement.appearance.format;\n        break;\n      default:\n        this.format = 'DD/MM/YYYY';\n    }\n  }\n\n  getMinDate(): Date | undefined {\n    if (this.minDateOption === 'CURRENT_DATE') {\n      return this.todayDate;\n    } else if (this.minDateOption === 'CUSTOM') {\n      return new Date(this.question.formElement.validation.minDate);\n    }\n    return undefined; // Return undefined if no valid option\n  }\n\n  getMaxDate(): Date | undefined {\n    if (this.maxDateOption === 'CURRENT_DATE') {\n      return this.todayDate;\n    } else if (this.maxDateOption === 'CUSTOM') {\n      return new Date(this.question.formElement.validation.maxDate);\n    }\n    return undefined;\n  }\n\n  getMinTime() {\n    if (this.minTimeOption) {\n      const format = this.timeFormat === '24' ? 'HH:mm' : 'hh:mm a';\n\n      if (this.minTimeOption === 'CURRENT_TIME') {\n        const now = new Date();\n        return this.datePipe.transform(now, format) || '';\n      } else if (this.minTimeOption === 'CUSTOM') {\n        const customTime = this.question.formElement.validation.minTime;\n        const [hours, minutes] = customTime.split(':'); // Split by colon to get hours and minutes\n\n        // Create a Date object with a fixed date and custom time\n        const customDate = new Date();\n        customDate.setHours(parseInt(hours, 10), parseInt(minutes, 10), 0, 0); // Set hours and minutes\n\n        return this.datePipe.transform(customDate, format) || '';\n      }\n    }\n\n    // Ensure a default return if no condition is met\n    return '';\n  }\n\n  getMaxTime() {\n    if (this.maxTimeOption) {\n      const format = this.timeFormat === '24' ? 'HH:mm' : 'hh:mm a';\n      if (this.maxTimeOption === 'CURRENT_TIME') {\n        const now = new Date();\n        return this.datePipe.transform(now, format) || '';\n      } else if (this.maxTimeOption === 'CUSTOM') {\n        const customTime = this.question.formElement.validation.maxTime;\n        const [hours, minutes] = customTime.split(':'); // Split by colon to get hours and minutes\n\n        // Create a Date object with a fixed date and custom time\n        const customDate = new Date();\n        customDate.setHours(parseInt(hours, 10), parseInt(minutes, 10), 0, 0); // Set hours and minutes\n\n        return this.datePipe.transform(customDate, format) || '';\n      }\n    }\n\n    return '';\n  }\n\n  openDatePicker() {\n    this.datepicker.toggle();\n  }\n\n  openDateRangePicker() {\n    this.dateRangePicker.toggle();\n  }\n\n  openDateAndTimePicker() {\n    this.dateAndTimePicker.toggle();\n  }\n\n  closeDatepicker() {\n    if (this.dateAndTimePicker) {\n      this.dateAndTimePicker.hide(); // Close the datepicker\n    }\n  }\n\n  validateField() {\n    if (this.dateType === 'DATE_ONLY') {\n      if (this.selectedDate) {\n        this.question.answer = this.formatDate(this.selectedDate.toString());\n      } else {\n        this.question.answer = '';\n      }\n\n      this.validateDateOnly();\n    } else if (this.dateType === 'TIME_ONLY') {\n      this.question.answer = String(this.selectedTime);\n      this.validateTimeOnly();\n    } else if (this.dateType === 'DATE_AND_TIME') {\n      if (this.selectedDateAndTime) {\n        this.question.answer = this.formatDate(\n          this.selectedDateAndTime.toString()\n        );\n      } else {\n        this.question.answer = '';\n      }\n\n      this.validateDateAndTime();\n    } else {\n      this.question.answer = this.formatDate(this.selectedDateRange);\n      this.validateDateRange();\n    }\n    this.answerChange.emit( this.question.answer);\n  }\n\n  formatDate(date: string | Date, type: string = 'dateTime'): string {\n    switch (this.dateType) {\n      case 'DATE_ONLY':\n        return (\n          this.datePipe.transform(this.selectedDate, this.Dateformat) || ''\n        );\n      case 'DATE_AND_TIME':\n        const formattedDate = this.datePipe.transform(\n          this.selectedDateAndTime,\n          this.Dateformat\n        );\n        const formatteminDate = this.datePipe.transform(\n          this.minDate,\n          this.Dateformat\n        );\n        const formattemaxDate = this.datePipe.transform(\n          this.maxDate,\n          this.Dateformat\n        );\n\n        if (formattedDate === formatteminDate) {\n          this.minTime = this.getMinTime().toString();\n          this.maxTime = this.timeFormat === '12' ? '11:59 pm' : '23:59';\n        }\n\n        if (formattedDate === formattemaxDate) {\n          this.maxTime = this.getMaxTime().toString();\n          this.minTime = this.timeFormat === '12' ? '12:00 am' : '00:00';\n        }\n\n        if (\n          formattedDate !== formatteminDate &&\n          formattedDate !== formattemaxDate\n        ) {\n          this.minTime = this.timeFormat === '12' ? '12:00 am' : '00:00';\n          this.maxTime = this.timeFormat === '12' ? '11:59 pm' : '23:59';\n        }\n\n        const formattedTime = this.selectedTime || ''; // Ensure selectedTime is handled properly\n        if (formattedDate && formattedTime) {\n          return `${formattedDate}, ${formattedTime}`;\n        }\n        return '';\n      case 'DATE_RANGE':\n        const dates = date as unknown as Date[];\n\n        // Ensure dates is defined and is an array\n        if (Array.isArray(dates) && dates.length === 2) {\n          const start = this.datePipe.transform(dates[0], this.Dateformat);\n          const end = this.datePipe.transform(dates[1], this.Dateformat);\n          return `${start} - ${end}`;\n        }\n\n        return '';\n      default:\n        return this.datePipe.transform(date, this.Dateformat) || '';\n    }\n  }\n\n  validateDateOnly() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n    if (this.required && !this.selectedDate) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else {\n      this.question.validation = true;\n    }\n  }\n  validateTimeOnly() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n    if (this.required && !this.selectedTime) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else {\n      this.question.validation = true;\n    }\n  }\n  validateDateRange() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n    if (this.required && !this.selectedDateRange) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else {\n      this.question.validation = true;\n    }\n  }\n  validateDateAndTime() {\n    this.validationFailed = false;\n    this.timeValidationFailed = false;\n    this.validationMessage = '';\n    if (this.required && !this.selectedDateAndTime) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else if (this.required && !this.selectedTime) {\n      this.timeValidationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else {\n      this.question.validation = true;\n    }\n  }\n\n  convertToISODate(\n    dateInput: [number, number, number] | string | null | undefined\n  ): Date | null {\n    if (!dateInput) {\n      return null; // Return null if dateInput is null, undefined, or any falsy value\n    }\n\n    let year, month, day;\n\n    if (Array.isArray(dateInput)) {\n      // Extract year, month, and day from array input\n      [year, month, day] = dateInput;\n\n      // Validate the array format\n      if (\n        typeof year !== 'number' ||\n        typeof month !== 'number' ||\n        typeof day !== 'number' ||\n        isNaN(year) ||\n        isNaN(month) ||\n        isNaN(day) ||\n        !Number.isInteger(year) ||\n        !Number.isInteger(month) ||\n        !Number.isInteger(day) ||\n        month < 1 ||\n        month > 12 ||\n        day < 1 ||\n        day > 31\n      ) {\n        return null;\n      }\n    } else if (typeof dateInput === 'string') {\n      // Check if the string matches the YYYY-MM-DD format\n      const dateParts = dateInput.split('-');\n      if (dateParts.length !== 3) return null;\n\n      [year, month, day] = dateParts.map(Number);\n\n      // Validate the parsed parts\n      if (\n        isNaN(year) ||\n        isNaN(month) ||\n        isNaN(day) ||\n        !Number.isInteger(year) ||\n        !Number.isInteger(month) ||\n        !Number.isInteger(day) ||\n        month < 1 ||\n        month > 12 ||\n        day < 1 ||\n        day > 31\n      ) {\n        return null;\n      }\n    } else {\n      return null; // Unsupported input type\n    }\n\n    // Create a Date object (month is 0-based, so subtract 1)\n    const date = new Date(year, month - 1, day);\n\n    // Verify if the Date object matches the provided year, month, and day\n    if (\n      date.getFullYear() !== year ||\n      date.getMonth() !== month - 1 ||\n      date.getDate() !== day\n    ) {\n      return null;\n    }\n\n    return date;\n  }\n\n  ngAfterViewInit(): void {\n    if (this.fullTime3) {\n      this.trackTimePicker(this.fullTime3, 'fullTime3');\n    }\n    if (this.fullTime4) {\n      this.trackTimePicker(this.fullTime4, 'fullTime4');\n    }\n\n    // Subscribe to router events if not already done\n    if (this.subscriptions.length === 0) {\n      const routerSub = this.router.events.subscribe((event) => {\n        if (event instanceof NavigationEnd) {\n          this.closeTimepickers();\n        }\n      });\n      this.subscriptions.push(routerSub);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.closeTimepickers();\n\n    // Unsubscribe from all subscriptions\n    this.subscriptions.forEach((sub) => {\n      if (sub && typeof sub.unsubscribe === 'function') {\n        sub.unsubscribe();\n      }\n    });\n  }\n\n  private trackTimePicker(picker: NgxMaterialTimepickerComponent, pickerName: string): void {\n    if (picker) {\n      // Track if the picker has been opened\n      const sub = picker.opened.subscribe(() => {\n        console.log(`Timepicker opened:`, picker);\n        this.timePickersOpened[pickerName] = true; // Mark picker as opened\n      });\n\n      this.subscriptions.push(sub);\n    }\n  }\n\n  private closeTimepickers(): void {\n    if (this.fullTime3 && this.timePickersOpened['fullTime3'] && typeof this.fullTime3.close === 'function') {\n      this.fullTime3.close();\n      this.timePickersOpened['fullTime3'] = false; // Mark picker as closed\n    }\n    if (this.fullTime4 && this.timePickersOpened['fullTime4'] && typeof this.fullTime4.close === 'function') {\n      this.fullTime4.close();\n      this.timePickersOpened['fullTime4'] = false; // Mark picker as closed\n    }\n  }\n}\n","<div [ngClass]=\"{ 'mb-5': !inLine }\" class=\"px-3\">\n  <div  class=\"input-wrapper mb-2\" *ngIf=\"!inLine\">\n    <div [innerHTML]=\"question.questionNumber\"></div>\n    &nbsp;&nbsp; <label>{{ question.question }}</label\n    >&nbsp;\n    <span class=\"text-danger\" *ngIf=\"required\">*</span>\n    <div\n      class=\"svg-wrapper mb-2 hintIcon\"\n      [attr.data-title]=\"hint\"\n      *ngIf=\"hint\"\n    >\n      <svg\n        class=\"hintSvg\"\n        viewBox=\"0 0 30 30\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n      </svg>\n    </div>\n  </div>\n  <ng-container *ngIf=\"dateType === 'DATE_ONLY'\">\n    <!-- Date only picker -->\n    <div class=\"input-container\">\n      <input\n        class=\"form-control height\"\n        #datepickerYMD=\"bsDatepicker\"\n        bsDatepicker\n        [minDate]=\"minDate ? minDate : undefined\"\n        [maxDate]=\"maxDate ? maxDate : undefined\"\n        [bsConfig]=\"{ dateInputFormat: format, containerClass: 'theme-custom' }\"\n        [(ngModel)]=\"selectedDate\"\n        (blur)=\"validateField()\"\n        (ngModelChange)=\"validateField()\"\n        [class.invalid]=\"validationFailed\"\n        placeholder=\"Select date\"\n      />\n      <i\n        class=\"fa-solid fa-calendar-days calendar-icon text-primary fs-5\"\n        (click)=\"openDatePicker()\"\n      ></i>\n    </div>\n    <div *ngIf=\"validationFailed\" class=\"text-danger mt-2\">\n      <svg\n        class=\"validationSvg\"\n        viewBox=\"0 0 24 24\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\"\n          fill=\"#FF0000\"\n          stroke=\"#FF0000\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M12 12.75L12 7.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n      </svg>\n      {{ validationMessage }}\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"dateType === 'TIME_ONLY'\">\n    <!-- Time picker -->\n\n\n<div class=\"input-container\">\n      <input\n      class=\"form-control height appearanceInput mt-3\"\n      aria-label=\"Select time\"\n      placeholder=\"Select time\"\n      readonly\n      [format]=\"timeFormat==='24'?24:12\"\n      [ngxTimepicker]=\"fullTime3\"\n      [(ngModel)]=\"selectedTime\"\n      [max]=\"maxTime\"\n      [min]=\"minTime\"\n      (ngModelChange)=\"validateField()\"\n      [class.invalid]=\"validationFailed\"\n  />\n  \n  <i\n  id=\"startDateIcon\"\n  class=\"fa-solid fa-clock text-primary fs-6 clock-icon\"\n  (click)=\"fullTime3.open()\"\n  style=\"cursor: pointer;\"\n></i>\n  <ngx-material-timepicker #fullTime3></ngx-material-timepicker>\n</div>\n    <div *ngIf=\"validationFailed\" class=\"text-danger mt-2\">\n      <svg\n        class=\"validationSvg\"\n        viewBox=\"0 0 24 24\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\"\n          fill=\"#FF0000\"\n          stroke=\"#FF0000\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M12 12.75L12 7.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n      </svg>\n      {{ validationMessage }}\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"dateType === 'DATE_AND_TIME'\">\n    <!-- Date and time picker -->\n    <div class=\"input-container\">\n      <input\n        #dateAndTimePicker=\"bsDatepicker\"\n        type=\"text\"\n        class=\"form-control height\"\n        [minDate]=\"minDate ? minDate : undefined\"\n        [maxDate]=\"maxDate ? maxDate : undefined\"\n        [bsConfig]=\"{\n          dateInputFormat: format, containerClass: 'theme-custom' \n        }\"\n        placeholder=\"Select date\"\n        bsDatepicker\n        [class.invalid]=\"validationFailed\"\n        [(ngModel)]=\"selectedDateAndTime\"\n        (blur)=\"validateField()\"\n        (ngModelChange)=\"validateField()\"\n      />\n      <i\n        class=\"fa-solid fa-calendar-days calendar-icon text-primary fs-5\"\n        (click)=\"openDateAndTimePicker()\"\n      ></i>\n    </div>\n      <div class=\"input-container\" *ngIf=\"selectedDateAndTime && selectedDateAndTime != null\">\n        <input\n        \n        class=\"form-control height appearanceInput mt-3\"\n        aria-label=\"Select time\"\n        placeholder=\"Select time\"\n        readonly\n        [format]=\"timeFormat==='24'?24:12\"\n        [ngxTimepicker]=\"fullTime4\"\n        [(ngModel)]=\"selectedTime\"\n        [max]=\"maxTime\"\n        [min]=\"minTime\"\n        (ngModelChange)=\"validateField()\"\n        (focus)=\"closeDatepicker()\"\n        [class.invalid]=\"timeValidationFailed\"\n    />\n    \n    <i\n    id=\"startDateIcon\"\n    class=\"fa-solid fa-clock text-primary fs-6 clock-icon\"\n    (click)=\"fullTime4.open()\"\n    style=\"cursor: pointer;\"\n  ></i>\n    <ngx-material-timepicker #fullTime4></ngx-material-timepicker>\n  </div>\n   \n    <div *ngIf=\"validationFailed || timeValidationFailed\" class=\"text-danger mt-2\">\n      <svg\n        class=\"validationSvg\"\n        viewBox=\"0 0 24 24\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\"\n          fill=\"#FF0000\"\n          stroke=\"#FF0000\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M12 12.75L12 7.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n      </svg>\n      {{ validationMessage }}\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"dateType === 'DATE_RANGE'\">\n    <!-- Date range picker -->\n    <div class=\"input-container\">\n      <input\n        type=\"text\"\n        class=\"form-control height\"\n        #daterangepicker=\"bsDaterangepicker\"\n        bsDaterangepicker\n        placeholder=\"Select date\"\n        [minDate]=\"minDate ? minDate : undefined\"\n        [maxDate]=\"maxDate ? maxDate : undefined\"\n        [bsConfig]=\"{\n          rangeInputFormat: format,\n          dateInputFormat: format, containerClass: 'theme-custom' \n        }\"\n        [(ngModel)]=\"selectedDateRange\"\n        (blur)=\"validateField()\"\n        (ngModelChange)=\"validateField()\"\n        [class.invalid]=\"validationFailed\"\n      />\n      <i\n        class=\"fa-solid fa-calendar-days calendar-icon text-primary fs-5\"\n        (click)=\"openDateRangePicker()\"\n      ></i>\n    </div>\n    <div *ngIf=\"validationFailed\" class=\"text-danger mt-2\">\n      <svg\n        class=\"validationSvg\"\n        viewBox=\"0 0 24 24\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\"\n          fill=\"#FF0000\"\n          stroke=\"#FF0000\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M12 12.75L12 7.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n      </svg>\n      {{ validationMessage }}\n    </div>\n  </ng-container>\n</div>\n"]}
485
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-time-fields.component.js","sourceRoot":"","sources":["../../../../../projects/form-submission/src/form-fields/date-time-fields/date-time-fields.component.ts","../../../../../projects/form-submission/src/form-fields/date-time-fields/date-time-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe } from '@angular/common';\nimport { Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { NavigationEnd, Router } from '@angular/router';\nimport {\n  BsDatepickerConfig,\n  BsDatepickerDirective,\n} from 'ngx-bootstrap/datepicker';\nimport { NgxMaterialTimepickerComponent } from 'ngx-material-timepicker';\nimport { Subscription } from 'rxjs';\n\n@Component({\n  selector: 'lib-date-time-fields',\n  templateUrl: './date-time-fields.component.html',\n  styleUrls: ['./date-time-fields.component.scss'],\n  providers: [DatePipe],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class DateTimeFieldsComponent {\n  bsConfig: Partial<BsDatepickerConfig> = {\n    containerClass: 'theme-custom',\n    isAnimated: true,\n    adaptivePosition: true,\n    showWeekNumbers: false,\n  };\n\n  @Input() question: any = {};\n  @Input() inLine: boolean = false;\n  @Output() answerChange = new EventEmitter<any>();\n\n  required: boolean = false;\n  hint: string = '';\n  count: number = 0;\n  minTime: string = '';\n  maxTime: string = '';\n  dateType: string = '';\n  format: string = '';\n  Dateformat: string = '';\n  timeFormat: string = '';\n  minDateOption: string = '';\n  minDate: Date | undefined;\n  maxDateOption: string = '';\n  maxDate: Date | undefined;\n  todayDate: Date = new Date();\n  selectedDate: Date | null = null;\n  selectedTime: string = '';\n  selectedDateRange: string = '';\n  selectedDateAndTime: Date | null = null;\n  validationFailed!: boolean;\n  timeValidationFailed!: boolean;\n  validationMessage: string = '';\n  maxTimeOption: string = '';\n  minTimeOption: string = '';\n  private timePickerOpened = false;\n  private subscriptions: Subscription[] = [];\n  private timePickersOpened: { [key: string]: boolean } = {};\n\n  @ViewChild('datepickerYMD') datepicker!: BsDatepickerDirective;\n  @ViewChild('daterangepicker') dateRangePicker!: BsDatepickerDirective;\n  @ViewChild('dateAndTimePicker') dateAndTimePicker!: BsDatepickerDirective;\n  @ViewChild('fullTime3') fullTime3!: NgxMaterialTimepickerComponent;\n  @ViewChild('fullTime4') fullTime4!: NgxMaterialTimepickerComponent;\n\n  constructor(private datePipe: DatePipe,private router: Router) { }\n\n  ngOnInit() {\n    this.valueAssigned();\n  }\n\n  valueAssigned() {\n    this.count = this.question.count;\n    this.required = this.question.required;\n    this.hint = this.question.hint;\n    this.dateType = this.question.formElement.appearance.dateType;\n    this.minDateOption = this.question.formElement.validation.minDateOption;\n    this.Dateformat = this.question.formElement.appearance.format.replace(\n      /DD/g,\n      'dd'\n    );\n\n    this.minDate = this.getMinDate();\n\n    this.maxDateOption = this.question.formElement.validation.maxDateOption;\n    this.maxDate = this.getMaxDate();\n    this.setDateTimeFormat();\n    if (this.question?.answer && (this.question?.answer).length > 0)\n      this.selectedDate = this.question?.answer;\n    this.selectedTime = this.question.answer;\n    if (this.question?.answer && (this.question?.answer).length > 0)\n      this.selectedDateAndTime = new Date(this.question.answer);\n    this.selectedDateRange = this.question.answer;\n    this.minTimeOption = this.question.formElement.validation.minTimeOption;\n    this.maxTimeOption = this.question.formElement.validation.maxTimeOption;\n    if (this.dateType !== 'DATE_AND_TIME') {\n      this.minTime = this.getMinTime().toString();\n      this.maxTime = this.getMaxTime().toString();\n    }\n    if (this.dateType === 'DATE_AND_TIME' && this.question?.answer) {\n      const dateTimeArray = this.question.answer\n        ? this.question.answer.split(',')\n        : []; // Fallback to an empty array if `this.question.answer` is undefined\n\n      if (dateTimeArray.length === 2) {\n        const fetchedDate = dateTimeArray[0].trim();\n        const fetchedTime = dateTimeArray[1].trim();\n        this.selectedDate = fetchedDate;\n        this.selectedTime = fetchedTime;\n      }\n\n      const formattedDate = this.datePipe.transform(\n        this.selectedDateAndTime,\n        this.Dateformat\n      );\n      const formatteminDate = this.datePipe.transform(\n        this.minDate,\n        this.Dateformat\n      );\n      const formattemaxDate = this.datePipe.transform(\n        this.maxDate,\n        this.Dateformat\n      );\n\n      if (formattedDate === formatteminDate) {\n        this.minTime = this.getMinTime().toString();\n        if (this.timeFormat === '12') {\n          this.maxTime = '12:00 pm';\n        } else {\n          this.maxTime = '23:59';\n        }\n      }\n      if (formattedDate === formattemaxDate) {\n        this.maxTime = this.getMaxTime().toString();\n        if (this.timeFormat === '12') {\n          this.minTime = '12:00 am';\n        } else {\n          this.minTime = '00:00';\n        }\n      }\n      if (\n        formattedDate !== formatteminDate &&\n        formattedDate !== formattemaxDate\n      ) {\n        if (this.timeFormat === '12') {\n          this.minTime = '12:00 am';\n          this.maxTime = '12:00 pm';\n        } else {\n          this.minTime = '00:00';\n          this.maxTime = '23:59';\n        }\n      }\n    }\n\n    if (!this.minTime || this.minTime.length === 0) {\n      if (this.timeFormat === '12') {\n        this.minTime = '12:00 am';\n      } else {\n        this.minTime = '00:00';\n      }\n    }\n\n    if (!this.maxTime || this.maxTime.length === 0) {\n      if (this.timeFormat === '12') {\n        this.maxTime = '11:59 pm';\n      } else {\n        this.maxTime = '23:59';\n      }\n    }\n  }\n\n  setDateTimeFormat() {\n    switch (this.dateType) {\n      case 'DATE_ONLY':\n        this.format = this.question.formElement.appearance.format;\n        break;\n      case 'TIME_ONLY':\n        this.timeFormat = this.question.formElement.appearance.timeFormat;\n        break;\n      case 'DATE_AND_TIME':\n        this.format = this.question.formElement.appearance.format;\n        this.timeFormat = this.question.formElement.appearance.timeFormat;\n        break;\n      case 'DATE_RANGE':\n        this.format = this.question.formElement.appearance.format;\n        break;\n      default:\n        this.format = 'DD/MM/YYYY';\n    }\n  }\n\n  getMinDate(): Date | undefined {\n    if (this.minDateOption === 'CURRENT_DATE') {\n      return this.todayDate;\n    } else if (this.minDateOption === 'CUSTOM') {\n      return new Date(this.question.formElement.validation.minDate);\n    }\n    return undefined; // Return undefined if no valid option\n  }\n\n  getMaxDate(): Date | undefined {\n    if (this.maxDateOption === 'CURRENT_DATE') {\n      return this.todayDate;\n    } else if (this.maxDateOption === 'CUSTOM') {\n      return new Date(this.question.formElement.validation.maxDate);\n    }\n    return undefined;\n  }\n\n  getMinTime() {\n    if (this.minTimeOption) {\n      const format = this.timeFormat === '24' ? 'HH:mm' : 'hh:mm a';\n\n      if (this.minTimeOption === 'CURRENT_TIME') {\n        const now = new Date();\n        return this.datePipe.transform(now, format) || '';\n      } else if (this.minTimeOption === 'CUSTOM') {\n        const customTime = this.question.formElement.validation.minTime;\n        const [hours, minutes] = customTime.split(':'); // Split by colon to get hours and minutes\n\n        // Create a Date object with a fixed date and custom time\n        const customDate = new Date();\n        customDate.setHours(parseInt(hours, 10), parseInt(minutes, 10), 0, 0); // Set hours and minutes\n\n        return this.datePipe.transform(customDate, format) || '';\n      }\n    }\n\n    // Ensure a default return if no condition is met\n    return '';\n  }\n\n  getMaxTime() {\n    if (this.maxTimeOption) {\n      const format = this.timeFormat === '24' ? 'HH:mm' : 'hh:mm a';\n      if (this.maxTimeOption === 'CURRENT_TIME') {\n        const now = new Date();\n        return this.datePipe.transform(now, format) || '';\n      } else if (this.maxTimeOption === 'CUSTOM') {\n        const customTime = this.question.formElement.validation.maxTime;\n        const [hours, minutes] = customTime.split(':'); // Split by colon to get hours and minutes\n\n        // Create a Date object with a fixed date and custom time\n        const customDate = new Date();\n        customDate.setHours(parseInt(hours, 10), parseInt(minutes, 10), 0, 0); // Set hours and minutes\n\n        return this.datePipe.transform(customDate, format) || '';\n      }\n    }\n\n    return '';\n  }\n\n  openDatePicker() {\n    this.datepicker.toggle();\n  }\n\n  openDateRangePicker() {\n    this.dateRangePicker.toggle();\n  }\n\n  openDateAndTimePicker() {\n    this.dateAndTimePicker.toggle();\n  }\n\n  closeDatepicker() {\n    if (this.dateAndTimePicker) {\n      this.dateAndTimePicker.hide(); // Close the datepicker\n    }\n  }\n\n  validateField() {\n    if (this.dateType === 'DATE_ONLY') {\n      if (this.selectedDate) {\n        this.question.answer = this.formatDate(this.selectedDate.toString());\n      } else {\n        this.question.answer = '';\n      }\n\n      this.validateDateOnly();\n    } else if (this.dateType === 'TIME_ONLY') {\n      this.question.answer = String(this.selectedTime);\n      this.validateTimeOnly();\n    } else if (this.dateType === 'DATE_AND_TIME') {\n      if (this.selectedDateAndTime) {\n        this.question.answer = this.formatDate(\n          this.selectedDateAndTime.toString()\n        );\n      } else {\n        this.question.answer = '';\n      }\n\n      this.validateDateAndTime();\n    } else {\n      this.question.answer = this.formatDate(this.selectedDateRange);\n      this.validateDateRange();\n    }\n    this.answerChange.emit( this.question.answer);\n  }\n\n  formatDate(date: string | Date, type: string = 'dateTime'): string {\n    switch (this.dateType) {\n      case 'DATE_ONLY':\n        return (\n          this.datePipe.transform(this.selectedDate, this.Dateformat) || ''\n        );\n      case 'DATE_AND_TIME':\n        const formattedDate = this.datePipe.transform(\n          this.selectedDateAndTime,\n          this.Dateformat\n        );\n        const formatteminDate = this.datePipe.transform(\n          this.minDate,\n          this.Dateformat\n        );\n        const formattemaxDate = this.datePipe.transform(\n          this.maxDate,\n          this.Dateformat\n        );\n\n        if (formattedDate === formatteminDate) {\n          this.minTime = this.getMinTime().toString();\n          this.maxTime = this.timeFormat === '12' ? '11:59 pm' : '23:59';\n        }\n\n        if (formattedDate === formattemaxDate) {\n          this.maxTime = this.getMaxTime().toString();\n          this.minTime = this.timeFormat === '12' ? '12:00 am' : '00:00';\n        }\n\n        if (\n          formattedDate !== formatteminDate &&\n          formattedDate !== formattemaxDate\n        ) {\n          this.minTime = this.timeFormat === '12' ? '12:00 am' : '00:00';\n          this.maxTime = this.timeFormat === '12' ? '11:59 pm' : '23:59';\n        }\n\n        const formattedTime = this.selectedTime || ''; // Ensure selectedTime is handled properly\n        if (formattedDate && formattedTime) {\n          return `${formattedDate}, ${formattedTime}`;\n        }\n        return '';\n      case 'DATE_RANGE':\n        const dates = date as unknown as Date[];\n\n        // Ensure dates is defined and is an array\n        if (Array.isArray(dates) && dates.length === 2) {\n          const start = this.datePipe.transform(dates[0], this.Dateformat);\n          const end = this.datePipe.transform(dates[1], this.Dateformat);\n          return `${start} - ${end}`;\n        }\n\n        return '';\n      default:\n        return this.datePipe.transform(date, this.Dateformat) || '';\n    }\n  }\n\n  validateDateOnly() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n    if (this.required && !this.selectedDate) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else {\n      this.question.validation = true;\n    }\n  }\n  validateTimeOnly() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n    if (this.required && !this.selectedTime) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else {\n      this.question.validation = true;\n    }\n  }\n  validateDateRange() {\n    this.validationFailed = false;\n    this.validationMessage = '';\n    if (this.required && !this.selectedDateRange) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else {\n      this.question.validation = true;\n    }\n  }\n  validateDateAndTime() {\n    this.validationFailed = false;\n    this.timeValidationFailed = false;\n    this.validationMessage = '';\n    if (this.required && !this.selectedDateAndTime) {\n      this.validationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else if (this.required && !this.selectedTime) {\n      this.timeValidationFailed = true;\n      this.validationMessage = 'This is a required question';\n      this.question.validation = false;\n    } else {\n      this.question.validation = true;\n    }\n  }\n\n  convertToISODate(\n    dateInput: [number, number, number] | string | null | undefined\n  ): Date | null {\n    if (!dateInput) {\n      return null; // Return null if dateInput is null, undefined, or any falsy value\n    }\n\n    let year, month, day;\n\n    if (Array.isArray(dateInput)) {\n      // Extract year, month, and day from array input\n      [year, month, day] = dateInput;\n\n      // Validate the array format\n      if (\n        typeof year !== 'number' ||\n        typeof month !== 'number' ||\n        typeof day !== 'number' ||\n        isNaN(year) ||\n        isNaN(month) ||\n        isNaN(day) ||\n        !Number.isInteger(year) ||\n        !Number.isInteger(month) ||\n        !Number.isInteger(day) ||\n        month < 1 ||\n        month > 12 ||\n        day < 1 ||\n        day > 31\n      ) {\n        return null;\n      }\n    } else if (typeof dateInput === 'string') {\n      // Check if the string matches the YYYY-MM-DD format\n      const dateParts = dateInput.split('-');\n      if (dateParts.length !== 3) return null;\n\n      [year, month, day] = dateParts.map(Number);\n\n      // Validate the parsed parts\n      if (\n        isNaN(year) ||\n        isNaN(month) ||\n        isNaN(day) ||\n        !Number.isInteger(year) ||\n        !Number.isInteger(month) ||\n        !Number.isInteger(day) ||\n        month < 1 ||\n        month > 12 ||\n        day < 1 ||\n        day > 31\n      ) {\n        return null;\n      }\n    } else {\n      return null; // Unsupported input type\n    }\n\n    // Create a Date object (month is 0-based, so subtract 1)\n    const date = new Date(year, month - 1, day);\n\n    // Verify if the Date object matches the provided year, month, and day\n    if (\n      date.getFullYear() !== year ||\n      date.getMonth() !== month - 1 ||\n      date.getDate() !== day\n    ) {\n      return null;\n    }\n\n    return date;\n  }\n\n  ngAfterViewInit(): void {\n    this.initializeTimePickers();\n    \n    if (this.subscriptions.length === 0) {\n      const routerSub = this.router.events.subscribe((event) => {\n        if (event instanceof NavigationEnd) {\n          this.closeTimepickers();\n        }\n      });\n      this.subscriptions.push(routerSub);\n    }\n  }\n\n  ngAfterViewChecked(): void {\n    // Ensure time picker subscriptions are attached even after conditional rendering\n    this.initializeTimePickers();\n  }\n\n  ngOnDestroy(): void {\n    this.closeTimepickers();\n\n    // Unsubscribe from all subscriptions\n    this.subscriptions.forEach((sub) => {\n      if (sub && typeof sub.unsubscribe === 'function') {\n        sub.unsubscribe();\n      }\n    });\n  }\n\n  /**\n   * Initialize and track time pickers\n   */\n  private initializeTimePickers(): void {\n    // Track fullTime3 if available\n    if (this.fullTime3 && !this.timePickersOpened['fullTime3']) {\n      this.trackTimePicker(this.fullTime3, 'fullTime3');\n    }\n\n    // Track fullTime4 if it exists after conditional rendering\n    if (this.fullTime4 && !this.timePickersOpened['fullTime4']) {\n      this.trackTimePicker(this.fullTime4, 'fullTime4');\n    }\n  }\n\n  private trackTimePicker(picker: NgxMaterialTimepickerComponent, pickerName: string): void {\n    if (picker) {\n      const sub = picker.opened.subscribe(() => {\n        console.log(`Timepicker opened:`, picker);\n        this.timePickersOpened[pickerName] = true; \n      });\n\n      this.subscriptions.push(sub);\n    }\n  }\n\n  private closeTimepickers(): void {\n    if (this.fullTime3 && this.timePickersOpened['fullTime3'] && typeof this.fullTime3.close === 'function') {\n      this.fullTime3.close();\n      this.timePickersOpened['fullTime3'] = false;\n    }\n\n    // Check for fullTime4 only if it exists\n    if (this.fullTime4 && this.timePickersOpened['fullTime4'] && typeof this.fullTime4.close === 'function') {\n      this.fullTime4.close();\n      this.timePickersOpened['fullTime4'] = false;\n    }\n  }\n}\n","<div [ngClass]=\"{ 'mb-5': !inLine }\" class=\"px-3\">\n  <div  class=\"input-wrapper mb-2\" *ngIf=\"!inLine\">\n    <div [innerHTML]=\"question.questionNumber\"></div>\n    &nbsp;&nbsp; <label>{{ question.question }}</label\n    >&nbsp;\n    <span class=\"text-danger\" *ngIf=\"required\">*</span>\n    <div\n      class=\"svg-wrapper mb-2 hintIcon\"\n      [attr.data-title]=\"hint\"\n      *ngIf=\"hint\"\n    >\n      <svg\n        class=\"hintSvg\"\n        viewBox=\"0 0 30 30\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M15 26.25V26.25C8.78625 26.25 3.75 21.2138 3.75 15V15C3.75 8.78625 8.78625 3.75 15 3.75V3.75C21.2138 3.75 26.25 8.78625 26.25 15V15C26.25 21.2138 21.2138 26.25 15 26.25Z\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M15 16.5623V16.2498C15 15.2285 15.6312 14.6748 16.2637 14.2498C16.8812 13.8335 17.5 13.291 17.5 12.291C17.5 10.9098 16.3813 9.79102 15 9.79102C13.6187 9.79102 12.5 10.9098 12.5 12.291\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M14.9988 20C14.8263 20 14.6863 20.14 14.6875 20.3125C14.6875 20.485 14.8275 20.625 15 20.625C15.1725 20.625 15.3125 20.485 15.3125 20.3125C15.3125 20.14 15.1725 20 14.9988 20\"\n          stroke=\"#323232\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n      </svg>\n    </div>\n  </div>\n  <ng-container *ngIf=\"dateType === 'DATE_ONLY'\">\n    <!-- Date only picker -->\n    <div class=\"input-container\">\n      <input\n        class=\"form-control height\"\n        #datepickerYMD=\"bsDatepicker\"\n        bsDatepicker\n        [minDate]=\"minDate ? minDate : undefined\"\n        [maxDate]=\"maxDate ? maxDate : undefined\"\n        [bsConfig]=\"{ dateInputFormat: format, containerClass: 'theme-custom' }\"\n        [(ngModel)]=\"selectedDate\"\n        (blur)=\"validateField()\"\n        (ngModelChange)=\"validateField()\"\n        [class.invalid]=\"validationFailed\"\n        placeholder=\"Select date\"\n      />\n      <i\n        class=\"fa-solid fa-calendar-days calendar-icon text-primary fs-5\"\n        (click)=\"openDatePicker()\"\n      ></i>\n    </div>\n    <div *ngIf=\"validationFailed\" class=\"text-danger mt-2\">\n      <svg\n        class=\"validationSvg\"\n        viewBox=\"0 0 24 24\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\"\n          fill=\"#FF0000\"\n          stroke=\"#FF0000\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M12 12.75L12 7.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n      </svg>\n      {{ validationMessage }}\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"dateType === 'TIME_ONLY'\">\n    <!-- Time picker -->\n\n\n<div class=\"input-container\">\n      <input\n      class=\"form-control height appearanceInput mt-3\"\n      aria-label=\"Select time\"\n      placeholder=\"Select time\"\n      readonly\n      [format]=\"timeFormat==='24'?24:12\"\n      [ngxTimepicker]=\"fullTime3\"\n      [(ngModel)]=\"selectedTime\"\n      [max]=\"maxTime\"\n      [min]=\"minTime\"\n      (ngModelChange)=\"validateField()\"\n      [class.invalid]=\"validationFailed\"\n  />\n  \n  <i\n  id=\"startDateIcon\"\n  class=\"fa-solid fa-clock text-primary fs-6 clock-icon\"\n  (click)=\"fullTime3.open()\"\n  style=\"cursor: pointer;\"\n></i>\n  <ngx-material-timepicker #fullTime3></ngx-material-timepicker>\n</div>\n    <div *ngIf=\"validationFailed\" class=\"text-danger mt-2\">\n      <svg\n        class=\"validationSvg\"\n        viewBox=\"0 0 24 24\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\"\n          fill=\"#FF0000\"\n          stroke=\"#FF0000\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M12 12.75L12 7.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n      </svg>\n      {{ validationMessage }}\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"dateType === 'DATE_AND_TIME'\">\n    <!-- Date and time picker -->\n    <div class=\"input-container\">\n      <input\n        #dateAndTimePicker=\"bsDatepicker\"\n        type=\"text\"\n        class=\"form-control height\"\n        [minDate]=\"minDate ? minDate : undefined\"\n        [maxDate]=\"maxDate ? maxDate : undefined\"\n        [bsConfig]=\"{\n          dateInputFormat: format, containerClass: 'theme-custom' \n        }\"\n        placeholder=\"Select date\"\n        bsDatepicker\n        [class.invalid]=\"validationFailed\"\n        [(ngModel)]=\"selectedDateAndTime\"\n        (blur)=\"validateField()\"\n        (ngModelChange)=\"validateField()\"\n      />\n      <i\n        class=\"fa-solid fa-calendar-days calendar-icon text-primary fs-5\"\n        (click)=\"openDateAndTimePicker()\"\n      ></i>\n    </div>\n      <div class=\"input-container\" *ngIf=\"selectedDateAndTime && selectedDateAndTime != null\">\n        <input\n        \n        class=\"form-control height appearanceInput mt-3\"\n        aria-label=\"Select time\"\n        placeholder=\"Select time\"\n        readonly\n        [format]=\"timeFormat==='24'?24:12\"\n        [ngxTimepicker]=\"fullTime4\"\n        [(ngModel)]=\"selectedTime\"\n        [max]=\"maxTime\"\n        [min]=\"minTime\"\n        (ngModelChange)=\"validateField()\"\n        (focus)=\"closeDatepicker()\"\n        [class.invalid]=\"timeValidationFailed\"\n    />\n    \n    <i\n    id=\"startDateIcon\"\n    class=\"fa-solid fa-clock text-primary fs-6 clock-icon\"\n    (click)=\"fullTime4.open()\"\n    style=\"cursor: pointer;\"\n  ></i>\n    <ngx-material-timepicker #fullTime4></ngx-material-timepicker>\n  </div>\n   \n    <div *ngIf=\"validationFailed || timeValidationFailed\" class=\"text-danger mt-2\">\n      <svg\n        class=\"validationSvg\"\n        viewBox=\"0 0 24 24\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\"\n          fill=\"#FF0000\"\n          stroke=\"#FF0000\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M12 12.75L12 7.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n      </svg>\n      {{ validationMessage }}\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"dateType === 'DATE_RANGE'\">\n    <!-- Date range picker -->\n    <div class=\"input-container\">\n      <input\n        type=\"text\"\n        class=\"form-control height\"\n        #daterangepicker=\"bsDaterangepicker\"\n        bsDaterangepicker\n        placeholder=\"Select date\"\n        [minDate]=\"minDate ? minDate : undefined\"\n        [maxDate]=\"maxDate ? maxDate : undefined\"\n        [bsConfig]=\"{\n          rangeInputFormat: format,\n          dateInputFormat: format, containerClass: 'theme-custom' \n        }\"\n        [(ngModel)]=\"selectedDateRange\"\n        (blur)=\"validateField()\"\n        (ngModelChange)=\"validateField()\"\n        [class.invalid]=\"validationFailed\"\n      />\n      <i\n        class=\"fa-solid fa-calendar-days calendar-icon text-primary fs-5\"\n        (click)=\"openDateRangePicker()\"\n      ></i>\n    </div>\n    <div *ngIf=\"validationFailed\" class=\"text-danger mt-2\">\n      <svg\n        class=\"validationSvg\"\n        viewBox=\"0 0 24 24\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n      >\n        <path\n          d=\"M12.001 16.75C12.139 16.75 12.251 16.638 12.25 16.5C12.25 16.362 12.138 16.25 12 16.25C11.862 16.25 11.75 16.362 11.75 16.5C11.75 16.638 11.862 16.75 12.001 16.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          fill-rule=\"evenodd\"\n          clip-rule=\"evenodd\"\n          d=\"M12 21C7.029 21 3 16.971 3 12C3 7.029 7.029 3 12 3C16.971 3 21 7.029 21 12C21 16.971 16.971 21 12 21Z\"\n          fill=\"#FF0000\"\n          stroke=\"#FF0000\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <path\n          d=\"M12 12.75L12 7.75\"\n          stroke=\"white\"\n          stroke-width=\"1.5\"\n          stroke-linecap=\"round\"\n          stroke-linejoin=\"round\"\n        />\n        <circle cx=\"12\" cy=\"16\" r=\"1\" fill=\"white\" />\n      </svg>\n      {{ validationMessage }}\n    </div>\n  </ng-container>\n</div>\n"]}
@@ -1446,13 +1446,7 @@ class DateTimeFieldsComponent {
1446
1446
  return date;
1447
1447
  }
1448
1448
  ngAfterViewInit() {
1449
- if (this.fullTime3) {
1450
- this.trackTimePicker(this.fullTime3, 'fullTime3');
1451
- }
1452
- if (this.fullTime4) {
1453
- this.trackTimePicker(this.fullTime4, 'fullTime4');
1454
- }
1455
- // Subscribe to router events if not already done
1449
+ this.initializeTimePickers();
1456
1450
  if (this.subscriptions.length === 0) {
1457
1451
  const routerSub = this.router.events.subscribe((event) => {
1458
1452
  if (event instanceof NavigationEnd) {
@@ -1462,6 +1456,10 @@ class DateTimeFieldsComponent {
1462
1456
  this.subscriptions.push(routerSub);
1463
1457
  }
1464
1458
  }
1459
+ ngAfterViewChecked() {
1460
+ // Ensure time picker subscriptions are attached even after conditional rendering
1461
+ this.initializeTimePickers();
1462
+ }
1465
1463
  ngOnDestroy() {
1466
1464
  this.closeTimepickers();
1467
1465
  // Unsubscribe from all subscriptions
@@ -1471,12 +1469,24 @@ class DateTimeFieldsComponent {
1471
1469
  }
1472
1470
  });
1473
1471
  }
1472
+ /**
1473
+ * Initialize and track time pickers
1474
+ */
1475
+ initializeTimePickers() {
1476
+ // Track fullTime3 if available
1477
+ if (this.fullTime3 && !this.timePickersOpened['fullTime3']) {
1478
+ this.trackTimePicker(this.fullTime3, 'fullTime3');
1479
+ }
1480
+ // Track fullTime4 if it exists after conditional rendering
1481
+ if (this.fullTime4 && !this.timePickersOpened['fullTime4']) {
1482
+ this.trackTimePicker(this.fullTime4, 'fullTime4');
1483
+ }
1484
+ }
1474
1485
  trackTimePicker(picker, pickerName) {
1475
1486
  if (picker) {
1476
- // Track if the picker has been opened
1477
1487
  const sub = picker.opened.subscribe(() => {
1478
1488
  console.log(`Timepicker opened:`, picker);
1479
- this.timePickersOpened[pickerName] = true; // Mark picker as opened
1489
+ this.timePickersOpened[pickerName] = true;
1480
1490
  });
1481
1491
  this.subscriptions.push(sub);
1482
1492
  }
@@ -1484,11 +1494,12 @@ class DateTimeFieldsComponent {
1484
1494
  closeTimepickers() {
1485
1495
  if (this.fullTime3 && this.timePickersOpened['fullTime3'] && typeof this.fullTime3.close === 'function') {
1486
1496
  this.fullTime3.close();
1487
- this.timePickersOpened['fullTime3'] = false; // Mark picker as closed
1497
+ this.timePickersOpened['fullTime3'] = false;
1488
1498
  }
1499
+ // Check for fullTime4 only if it exists
1489
1500
  if (this.fullTime4 && this.timePickersOpened['fullTime4'] && typeof this.fullTime4.close === 'function') {
1490
1501
  this.fullTime4.close();
1491
- this.timePickersOpened['fullTime4'] = false; // Mark picker as closed
1502
+ this.timePickersOpened['fullTime4'] = false;
1492
1503
  }
1493
1504
  }
1494
1505
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DateTimeFieldsComponent, deps: [{ token: i1$1.DatePipe }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component }); }