@oneluiz/dual-datepicker 3.5.0 → 3.5.1

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.
@@ -3,13 +3,34 @@ import { CommonModule } from '@angular/common';
3
3
  import { FormsModule, ReactiveFormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
4
4
  import { DATE_ADAPTER } from './date-adapter';
5
5
  import { NativeDateAdapter } from './native-date-adapter';
6
+ import { DualDateRangeStore } from './core/dual-date-range.store';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "@angular/common";
8
9
  export class DualDatepickerComponent {
9
10
  elementRef;
10
11
  placeholder = 'Select date range';
11
- startDate = '';
12
- endDate = '';
12
+ set startDate(value) {
13
+ if (value) {
14
+ const date = this.dateAdapter.parse(value);
15
+ if (date)
16
+ this.rangeStore.setStart(date);
17
+ }
18
+ }
19
+ get startDate() {
20
+ const date = this.rangeStore.startDate();
21
+ return date ? this.formatDate(date) : '';
22
+ }
23
+ set endDate(value) {
24
+ if (value) {
25
+ const date = this.dateAdapter.parse(value);
26
+ if (date)
27
+ this.rangeStore.setEnd(date);
28
+ }
29
+ }
30
+ get endDate() {
31
+ const date = this.rangeStore.endDate();
32
+ return date ? this.formatDate(date) : '';
33
+ }
13
34
  showPresets = true;
14
35
  showClearButton = false;
15
36
  multiRange = false;
@@ -40,37 +61,71 @@ export class DualDatepickerComponent {
40
61
  multiDateRangeSelected = new EventEmitter();
41
62
  // Date adapter injection
42
63
  dateAdapter = inject(DATE_ADAPTER);
43
- // Signals for reactive state
64
+ // Headless store for date range state (v3.5.0+)
65
+ rangeStore = inject(DualDateRangeStore);
66
+ // UI-only signals
44
67
  showDatePicker = signal(false);
45
- dateRangeText = signal('');
46
- selectingStartDate = signal(true);
47
68
  currentMonth = signal(this.dateAdapter.today());
48
69
  previousMonth = signal(this.dateAdapter.today());
49
70
  currentMonthDays = signal([]);
50
71
  previousMonthDays = signal([]);
51
72
  isDisabled = signal(false);
52
- // Apply/Confirm support
53
- pendingStartDate = '';
54
- pendingEndDate = '';
55
- hasPendingChanges = signal(false);
56
- // Time picker support
57
- startHour = 0;
58
- startMinute = 0;
59
- endHour = 23;
60
- endMinute = 59;
61
73
  showStartTimePicker = signal(false);
62
74
  showEndTimePicker = signal(false);
63
- // Hover range preview
64
75
  hoverDate = signal(null);
65
- // Multi-range support
76
+ // Computed time properties from store
77
+ get startHour() {
78
+ const time = this.rangeStore.startTime();
79
+ return this.parseTime(time).hour;
80
+ }
81
+ get startMinute() {
82
+ const time = this.rangeStore.startTime();
83
+ return this.parseTime(time).minute;
84
+ }
85
+ get endHour() {
86
+ const time = this.rangeStore.endTime();
87
+ return this.parseTime(time).hour;
88
+ }
89
+ get endMinute() {
90
+ const time = this.rangeStore.endTime();
91
+ return this.parseTime(time).minute;
92
+ }
93
+ setStartHourMinute(hour, minute) {
94
+ const timeStr = this.formatTime(hour, minute);
95
+ this.rangeStore.setStartTime(timeStr);
96
+ }
97
+ setEndHourMinute(hour, minute) {
98
+ const timeStr = this.formatTime(hour, minute);
99
+ this.rangeStore.setEndTime(timeStr);
100
+ }
101
+ // Multi-range support (UI-specific)
66
102
  selectedRanges = signal([]);
67
103
  currentRangeIndex = signal(-1);
68
- // Keyboard navigation
69
- focusedDay = signal(null); // monthIndex: 0 = previous, 1 = current
104
+ // Keyboard navigation (UI-specific)
105
+ focusedDay = signal(null);
70
106
  // Computed values
71
107
  currentMonthName = computed(() => this.getMonthName(this.currentMonth()));
72
108
  previousMonthName = computed(() => this.getMonthName(this.previousMonth()));
73
109
  weekDayNames = computed(() => this.getDayNames());
110
+ // Computed from store
111
+ dateRangeText = computed(() => this.rangeStore.rangeText());
112
+ selectingStartDate = computed(() => this.rangeStore.selectingStart());
113
+ hasPendingChanges = computed(() => this.rangeStore.hasPendingChanges());
114
+ // Computed for template access to pending dates (requireApply mode)
115
+ get pendingStartDate() {
116
+ // In requireApply mode, store keeps pending values
117
+ // For now, use actual store values as pending (store handles this)
118
+ if (!this.requireApply)
119
+ return '';
120
+ const date = this.rangeStore.startDate();
121
+ return date && this.hasPendingChanges() ? this.formatDate(date) : '';
122
+ }
123
+ get pendingEndDate() {
124
+ if (!this.requireApply)
125
+ return '';
126
+ const date = this.rangeStore.endDate();
127
+ return date && this.hasPendingChanges() ? this.formatDate(date) : '';
128
+ }
74
129
  defaultMonthNames = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];
75
130
  defaultMonthNamesShort = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];
76
131
  defaultDayNames = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];
@@ -80,10 +135,10 @@ export class DualDatepickerComponent {
80
135
  onTouched = () => { };
81
136
  constructor(elementRef) {
82
137
  this.elementRef = elementRef;
83
- // Effect to emit changes when dates change
138
+ // Effect to emit changes when dates change in store
84
139
  effect(() => {
85
- const range = this.dateRangeText();
86
- if (this.startDate || this.endDate) {
140
+ const range = this.rangeStore.range();
141
+ if (range.start || range.end) {
87
142
  this.onChange(this.getDateRangeValue());
88
143
  }
89
144
  });
@@ -387,29 +442,54 @@ export class DualDatepickerComponent {
387
442
  return focused !== null && focused.date === date && focused.monthIndex === monthIndex;
388
443
  }
389
444
  ngOnInit() {
390
- // Initialize time picker with default times
391
- if (this.enableTimePicker) {
392
- const startTime = this.parseTime(this.defaultStartTime);
393
- this.startHour = startTime.hour;
394
- this.startMinute = startTime.minute;
395
- const endTime = this.parseTime(this.defaultEndTime);
396
- this.endHour = endTime.hour;
397
- this.endMinute = endTime.minute;
445
+ // Configure the headless store
446
+ this.rangeStore.configure({
447
+ enableTimePicker: this.enableTimePicker,
448
+ defaultStartTime: this.defaultStartTime,
449
+ defaultEndTime: this.defaultEndTime,
450
+ disabledDates: this.disabledDates
451
+ });
452
+ // Initialize dates in store if provided
453
+ if (this.startDate) {
454
+ const date = this.dateAdapter.parse(this.startDate);
455
+ if (date)
456
+ this.rangeStore.setStart(date);
457
+ }
458
+ if (this.endDate) {
459
+ const date = this.dateAdapter.parse(this.endDate);
460
+ if (date)
461
+ this.rangeStore.setEnd(date);
398
462
  }
399
463
  if (this.startDate && this.endDate) {
400
- this.updateDateRangeText();
401
464
  this.generateCalendars();
402
465
  }
403
466
  }
404
467
  ngOnChanges(changes) {
405
468
  if (changes['startDate'] || changes['endDate']) {
469
+ // Sync with store
470
+ if (changes['startDate'] && this.startDate) {
471
+ const date = this.dateAdapter.parse(this.startDate);
472
+ if (date)
473
+ this.rangeStore.setStart(date);
474
+ }
475
+ if (changes['endDate'] && this.endDate) {
476
+ const date = this.dateAdapter.parse(this.endDate);
477
+ if (date)
478
+ this.rangeStore.setEnd(date);
479
+ }
406
480
  if (this.startDate && this.endDate) {
407
- this.updateDateRangeText();
408
481
  this.generateCalendars();
409
482
  }
410
- else if (!this.startDate && !this.endDate) {
411
- this.dateRangeText.set('');
412
- }
483
+ }
484
+ // Update store configuration if relevant inputs change
485
+ if (changes['enableTimePicker'] || changes['defaultStartTime'] ||
486
+ changes['defaultEndTime'] || changes['disabledDates']) {
487
+ this.rangeStore.configure({
488
+ enableTimePicker: this.enableTimePicker,
489
+ defaultStartTime: this.defaultStartTime,
490
+ defaultEndTime: this.defaultEndTime,
491
+ disabledDates: this.disabledDates
492
+ });
413
493
  }
414
494
  }
415
495
  formatDate(date) {
@@ -444,20 +524,15 @@ export class DualDatepickerComponent {
444
524
  formatted = formatted.replace(/D/g, String(day));
445
525
  return formatted;
446
526
  }
527
+ // Note: updateDateRangeText is now handled by computed dateRangeText from store
528
+ // Keeping this method for backward compatibility but it's a no-op
447
529
  updateDateRangeText() {
448
- if (this.startDate && this.endDate) {
449
- const start = this.formatDateDisplay(this.startDate);
450
- const end = this.formatDateDisplay(this.endDate);
451
- this.dateRangeText.set(`${start} - ${end}`);
452
- }
453
- else {
454
- this.dateRangeText.set('');
455
- }
530
+ // Text is now automatically computed from store.rangeText()
456
531
  }
457
532
  toggleDatePicker() {
458
533
  this.showDatePicker.update(value => !value);
459
534
  if (this.showDatePicker()) {
460
- this.selectingStartDate.set(true);
535
+ // selectingStart is managed by store, no need to set here
461
536
  const currentMonthValue = this.currentMonth();
462
537
  const year = this.dateAdapter.getYear(currentMonthValue);
463
538
  const month = this.dateAdapter.getMonth(currentMonthValue);
@@ -502,11 +577,15 @@ export class DualDatepickerComponent {
502
577
  for (let day = 1; day <= daysInMonth; day++) {
503
578
  const dayDate = this.dateAdapter.createDate(year, month, day);
504
579
  const dateStr = this.formatDate(dayDate);
505
- // Check if date is in pending range (for requireApply mode)
506
- const isPendingStart = this.requireApply && this.pendingStartDate === dateStr;
507
- const isPendingEnd = this.requireApply && this.pendingEndDate === dateStr;
508
- const inPendingRange = this.requireApply && this.pendingStartDate && this.pendingEndDate &&
509
- dateStr >= this.pendingStartDate && dateStr <= this.pendingEndDate;
580
+ // Get pending dates from store (for requireApply mode)
581
+ const pendingStart = this.rangeStore.startDate(); // In pending mode, store holds pending values
582
+ const pendingEnd = this.rangeStore.endDate();
583
+ const pendingStartStr = pendingStart ? this.formatDate(pendingStart) : '';
584
+ const pendingEndStr = pendingEnd ? this.formatDate(pendingEnd) : '';
585
+ const isPendingStart = this.requireApply && pendingStartStr === dateStr;
586
+ const isPendingEnd = this.requireApply && pendingEndStr === dateStr;
587
+ const inPendingRange = this.requireApply && pendingStartStr && pendingEndStr &&
588
+ dateStr >= pendingStartStr && dateStr <= pendingEndStr;
510
589
  // Check if date is in hover preview range
511
590
  const inHoverRange = this.isInHoverRange(dateStr);
512
591
  monthDays.push({
@@ -560,31 +639,34 @@ export class DualDatepickerComponent {
560
639
  if (this.multiRange) {
561
640
  if (this.selectingStartDate())
562
641
  return false;
563
- if (!this.startDate)
642
+ const currentStart = this.startDate;
643
+ if (!currentStart)
564
644
  return false;
565
- const minDate = this.startDate < hover ? this.startDate : hover;
566
- const maxDate = this.startDate > hover ? this.startDate : hover;
645
+ const minDate = currentStart < hover ? currentStart : hover;
646
+ const maxDate = currentStart > hover ? currentStart : hover;
567
647
  return dateStr >= minDate && dateStr <= maxDate;
568
648
  }
569
649
  else {
570
- // In single range mode with requireApply
650
+ // In single range mode
651
+ if (this.selectingStartDate())
652
+ return false;
571
653
  if (this.requireApply) {
572
- if (this.selectingStartDate())
654
+ // Use pending dates from store
655
+ const pendingStart = this.rangeStore.startDate();
656
+ if (!pendingStart)
573
657
  return false;
574
- if (!this.pendingStartDate)
575
- return false;
576
- const minDate = this.pendingStartDate < hover ? this.pendingStartDate : hover;
577
- const maxDate = this.pendingStartDate > hover ? this.pendingStartDate : hover;
658
+ const pendingStartStr = this.formatDate(pendingStart);
659
+ const minDate = pendingStartStr < hover ? pendingStartStr : hover;
660
+ const maxDate = pendingStartStr > hover ? pendingStartStr : hover;
578
661
  return dateStr >= minDate && dateStr <= maxDate;
579
662
  }
580
663
  else {
581
- // In single range mode without requireApply
582
- if (this.selectingStartDate())
583
- return false;
584
- if (!this.startDate)
664
+ // Use actual dates
665
+ const currentStart = this.startDate;
666
+ if (!currentStart)
585
667
  return false;
586
- const minDate = this.startDate < hover ? this.startDate : hover;
587
- const maxDate = this.startDate > hover ? this.startDate : hover;
668
+ const minDate = currentStart < hover ? currentStart : hover;
669
+ const maxDate = currentStart > hover ? currentStart : hover;
588
670
  return dateStr >= minDate && dateStr <= maxDate;
589
671
  }
590
672
  }
@@ -604,35 +686,38 @@ export class DualDatepickerComponent {
604
686
  selectDay(dayObj) {
605
687
  if (!dayObj.isCurrentMonth || this.isDisabled() || dayObj.isDisabled)
606
688
  return;
689
+ const selectedDate = this.dateAdapter.parse(dayObj.date);
690
+ if (!selectedDate)
691
+ return;
607
692
  if (this.multiRange) {
608
693
  // Multi-range mode: add ranges to array
609
694
  if (this.selectingStartDate()) {
610
- this.startDate = dayObj.date;
611
- this.endDate = '';
612
- this.dateRangeText.set('');
613
- this.selectingStartDate.set(false);
695
+ this.rangeStore.setStart(selectedDate);
696
+ this.rangeStore.setEnd(null);
614
697
  }
615
698
  else {
616
- if (dayObj.date < this.startDate) {
617
- this.endDate = this.startDate;
618
- this.startDate = dayObj.date;
699
+ const currentStart = this.rangeStore.startDate();
700
+ if (currentStart && selectedDate < currentStart) {
701
+ // Swap: selected becomes start, current start becomes end
702
+ this.rangeStore.setStart(selectedDate);
703
+ this.rangeStore.setEnd(currentStart);
619
704
  }
620
705
  else {
621
- this.endDate = dayObj.date;
706
+ this.rangeStore.setEnd(selectedDate);
622
707
  }
623
708
  // Add the new range to the array
709
+ const range = this.rangeStore.range();
624
710
  const newRange = {
625
- startDate: this.startDate,
626
- endDate: this.endDate,
627
- rangeText: this.formatDateDisplay(this.startDate) + ' – ' + this.formatDateDisplay(this.endDate)
711
+ startDate: range.start,
712
+ endDate: range.end,
713
+ rangeText: this.formatDateDisplay(range.start) + ' – ' + this.formatDateDisplay(range.end),
714
+ ...(this.enableTimePicker && { startTime: range.startTime, endTime: range.endTime })
628
715
  };
629
716
  const currentRanges = [...this.selectedRanges()];
630
717
  currentRanges.push(newRange);
631
718
  this.selectedRanges.set(currentRanges);
632
719
  // Reset for next range selection
633
- this.startDate = '';
634
- this.endDate = '';
635
- this.selectingStartDate.set(true);
720
+ this.rangeStore.reset();
636
721
  // Update display text
637
722
  this.updateMultiRangeText();
638
723
  // Don't close if multiRange, allow adding more ranges
@@ -645,50 +730,46 @@ export class DualDatepickerComponent {
645
730
  this.generateCalendars();
646
731
  }
647
732
  else {
648
- // Single range mode (original behavior)
733
+ // Single range mode
649
734
  if (this.requireApply) {
650
735
  // Apply mode: use pending dates, don't emit until Apply is clicked
651
736
  if (this.selectingStartDate()) {
652
- this.pendingStartDate = dayObj.date;
653
- this.pendingEndDate = '';
654
- this.selectingStartDate.set(false);
655
- this.hasPendingChanges.set(true);
737
+ this.rangeStore.setPendingStart(selectedDate);
738
+ this.rangeStore.setPendingEnd(null);
656
739
  }
657
740
  else {
658
- if (dayObj.date < this.pendingStartDate) {
659
- this.pendingEndDate = this.pendingStartDate;
660
- this.pendingStartDate = dayObj.date;
741
+ const pendingStart = this.rangeStore.startDate();
742
+ if (pendingStart && selectedDate < pendingStart) {
743
+ // Swap
744
+ this.rangeStore.setPendingStart(selectedDate);
745
+ this.rangeStore.setPendingEnd(pendingStart);
661
746
  }
662
747
  else {
663
- this.pendingEndDate = dayObj.date;
748
+ this.rangeStore.setPendingEnd(selectedDate);
664
749
  }
665
- this.selectingStartDate.set(true);
666
- this.hasPendingChanges.set(true);
667
750
  }
668
751
  this.generateCalendars();
669
752
  }
670
753
  else {
671
754
  // Immediate mode: emit changes immediately
672
755
  if (this.selectingStartDate()) {
673
- this.startDate = dayObj.date;
674
- this.endDate = '';
675
- this.dateRangeText.set('');
676
- this.selectingStartDate.set(false);
756
+ this.rangeStore.setStart(selectedDate);
757
+ this.rangeStore.setEnd(null);
677
758
  this.emitChange();
678
759
  }
679
760
  else {
680
- if (dayObj.date < this.startDate) {
681
- this.endDate = this.startDate;
682
- this.startDate = dayObj.date;
761
+ const currentStart = this.rangeStore.startDate();
762
+ if (currentStart && selectedDate < currentStart) {
763
+ // Swap
764
+ this.rangeStore.setStart(selectedDate);
765
+ this.rangeStore.setEnd(currentStart);
683
766
  }
684
767
  else {
685
- this.endDate = dayObj.date;
768
+ this.rangeStore.setEnd(selectedDate);
686
769
  }
687
- this.updateDateRangeText();
688
770
  if (this.closeOnSelection) {
689
771
  this.showDatePicker.set(false);
690
772
  }
691
- this.selectingStartDate.set(true);
692
773
  this.emitChange();
693
774
  this.emitSelection();
694
775
  }
@@ -699,27 +780,17 @@ export class DualDatepickerComponent {
699
780
  applySelection() {
700
781
  if (!this.hasPendingChanges())
701
782
  return;
702
- // Apply pending dates
703
- this.startDate = this.pendingStartDate;
704
- this.endDate = this.pendingEndDate;
705
- this.updateDateRangeText();
706
- // Clear pending state
707
- this.pendingStartDate = '';
708
- this.pendingEndDate = '';
709
- this.hasPendingChanges.set(false);
783
+ // Apply pending dates through store
784
+ this.rangeStore.applyPending();
710
785
  // Emit changes
711
786
  this.emitChange();
712
787
  this.emitSelection();
713
788
  // Close picker
714
789
  this.showDatePicker.set(false);
715
- this.selectingStartDate.set(true);
716
790
  }
717
791
  cancelSelection() {
718
- // Discard pending changes
719
- this.pendingStartDate = '';
720
- this.pendingEndDate = '';
721
- this.hasPendingChanges.set(false);
722
- this.selectingStartDate.set(true);
792
+ // Discard pending changes through store
793
+ this.rangeStore.cancelPending();
723
794
  // Regenerate calendars to clear pending visual state
724
795
  this.generateCalendars();
725
796
  }
@@ -748,9 +819,11 @@ export class DualDatepickerComponent {
748
819
  return;
749
820
  }
750
821
  const range = preset.getValue();
751
- this.startDate = range.start;
752
- this.endDate = range.end;
753
- this.updateDateRangeText();
822
+ const startDate = this.dateAdapter.parse(range.start);
823
+ const endDate = this.dateAdapter.parse(range.end);
824
+ if (startDate && endDate) {
825
+ this.rangeStore.setRange(startDate, endDate);
826
+ }
754
827
  this.generateCalendars();
755
828
  if (this.closeOnPresetSelection) {
756
829
  this.showDatePicker.set(false);
@@ -758,11 +831,8 @@ export class DualDatepickerComponent {
758
831
  this.emitSelection();
759
832
  }
760
833
  clear() {
761
- this.startDate = '';
762
- this.endDate = '';
763
- this.dateRangeText.set('');
834
+ this.rangeStore.reset();
764
835
  this.showDatePicker.set(false);
765
- this.selectingStartDate.set(true);
766
836
  if (this.multiRange) {
767
837
  this.selectedRanges.set([]);
768
838
  this.currentRangeIndex.set(-1);
@@ -787,37 +857,32 @@ export class DualDatepickerComponent {
787
857
  }
788
858
  updateMultiRangeText() {
789
859
  const count = this.selectedRanges().length;
790
- if (count === 0) {
791
- this.dateRangeText.set('');
792
- }
793
- else if (count === 1) {
794
- this.dateRangeText.set('1 range selected');
795
- }
796
- else {
797
- this.dateRangeText.set(`${count} ranges selected`);
798
- }
860
+ // Note: dateRangeText is now computed from store, this is for multi-range UI only
861
+ // We could store this in a separate signal if needed, but for now just track ranges count
799
862
  }
800
863
  emitChange() {
864
+ const storeRange = this.rangeStore.range();
801
865
  const range = {
802
- startDate: this.startDate,
803
- endDate: this.endDate,
866
+ startDate: storeRange.start,
867
+ endDate: storeRange.end,
804
868
  rangeText: this.dateRangeText()
805
869
  };
806
870
  if (this.enableTimePicker) {
807
- range.startTime = this.formatTime(this.startHour, this.startMinute);
808
- range.endTime = this.formatTime(this.endHour, this.endMinute);
871
+ range.startTime = storeRange.startTime;
872
+ range.endTime = storeRange.endTime;
809
873
  }
810
874
  this.dateRangeChange.emit(range);
811
875
  }
812
876
  emitSelection() {
877
+ const storeRange = this.rangeStore.range();
813
878
  const range = {
814
- startDate: this.startDate,
815
- endDate: this.endDate,
879
+ startDate: storeRange.start,
880
+ endDate: storeRange.end,
816
881
  rangeText: this.dateRangeText()
817
882
  };
818
883
  if (this.enableTimePicker) {
819
- range.startTime = this.formatTime(this.startHour, this.startMinute);
820
- range.endTime = this.formatTime(this.endHour, this.endMinute);
884
+ range.startTime = storeRange.startTime;
885
+ range.endTime = storeRange.endTime;
821
886
  }
822
887
  this.dateRangeSelected.emit(range);
823
888
  }
@@ -832,14 +897,15 @@ export class DualDatepickerComponent {
832
897
  });
833
898
  }
834
899
  getDateRangeValue() {
900
+ const storeRange = this.rangeStore.range();
835
901
  const range = {
836
- startDate: this.startDate,
837
- endDate: this.endDate,
902
+ startDate: storeRange.start,
903
+ endDate: storeRange.end,
838
904
  rangeText: this.dateRangeText()
839
905
  };
840
906
  if (this.enableTimePicker) {
841
- range.startTime = this.formatTime(this.startHour, this.startMinute);
842
- range.endTime = this.formatTime(this.endHour, this.endMinute);
907
+ range.startTime = storeRange.startTime;
908
+ range.endTime = storeRange.endTime;
843
909
  }
844
910
  return range;
845
911
  }
@@ -857,80 +923,64 @@ export class DualDatepickerComponent {
857
923
  this.showStartTimePicker.set(false);
858
924
  }
859
925
  incrementStartHour() {
860
- this.startHour = (this.startHour + 1) % 24;
861
- if (this.requireApply) {
862
- this.hasPendingChanges.set(true);
863
- }
864
- else {
926
+ const newHour = (this.startHour + 1) % 24;
927
+ this.setStartHourMinute(newHour, this.startMinute);
928
+ if (!this.requireApply) {
865
929
  this.emitChange();
866
930
  }
867
931
  }
868
932
  decrementStartHour() {
869
- this.startHour = this.startHour === 0 ? 23 : this.startHour - 1;
870
- if (this.requireApply) {
871
- this.hasPendingChanges.set(true);
872
- }
873
- else {
933
+ const newHour = this.startHour === 0 ? 23 : this.startHour - 1;
934
+ this.setStartHourMinute(newHour, this.startMinute);
935
+ if (!this.requireApply) {
874
936
  this.emitChange();
875
937
  }
876
938
  }
877
939
  incrementStartMinute() {
878
- this.startMinute = (this.startMinute + this.minuteStep) % 60;
879
- if (this.requireApply) {
880
- this.hasPendingChanges.set(true);
881
- }
882
- else {
940
+ const newMinute = (this.startMinute + this.minuteStep) % 60;
941
+ this.setStartHourMinute(this.startHour, newMinute);
942
+ if (!this.requireApply) {
883
943
  this.emitChange();
884
944
  }
885
945
  }
886
946
  decrementStartMinute() {
887
- this.startMinute = this.startMinute - this.minuteStep;
888
- if (this.startMinute < 0) {
889
- this.startMinute = 60 - this.minuteStep;
947
+ let newMinute = this.startMinute - this.minuteStep;
948
+ if (newMinute < 0) {
949
+ newMinute = 60 - this.minuteStep;
890
950
  }
891
- if (this.requireApply) {
892
- this.hasPendingChanges.set(true);
893
- }
894
- else {
951
+ this.setStartHourMinute(this.startHour, newMinute);
952
+ if (!this.requireApply) {
895
953
  this.emitChange();
896
954
  }
897
955
  }
898
956
  incrementEndHour() {
899
- this.endHour = (this.endHour + 1) % 24;
900
- if (this.requireApply) {
901
- this.hasPendingChanges.set(true);
902
- }
903
- else {
957
+ const newHour = (this.endHour + 1) % 24;
958
+ this.setEndHourMinute(newHour, this.endMinute);
959
+ if (!this.requireApply) {
904
960
  this.emitChange();
905
961
  }
906
962
  }
907
963
  decrementEndHour() {
908
- this.endHour = this.endHour === 0 ? 23 : this.endHour - 1;
909
- if (this.requireApply) {
910
- this.hasPendingChanges.set(true);
911
- }
912
- else {
964
+ const newHour = this.endHour === 0 ? 23 : this.endHour - 1;
965
+ this.setEndHourMinute(newHour, this.endMinute);
966
+ if (!this.requireApply) {
913
967
  this.emitChange();
914
968
  }
915
969
  }
916
970
  incrementEndMinute() {
917
- this.endMinute = (this.endMinute + this.minuteStep) % 60;
918
- if (this.requireApply) {
919
- this.hasPendingChanges.set(true);
920
- }
921
- else {
971
+ const newMinute = (this.endMinute + this.minuteStep) % 60;
972
+ this.setEndHourMinute(this.endHour, newMinute);
973
+ if (!this.requireApply) {
922
974
  this.emitChange();
923
975
  }
924
976
  }
925
977
  decrementEndMinute() {
926
- this.endMinute = this.endMinute - this.minuteStep;
927
- if (this.endMinute < 0) {
928
- this.endMinute = 60 - this.minuteStep;
929
- }
930
- if (this.requireApply) {
931
- this.hasPendingChanges.set(true);
978
+ let newMinute = this.endMinute - this.minuteStep;
979
+ if (newMinute < 0) {
980
+ newMinute = 60 - this.minuteStep;
932
981
  }
933
- else {
982
+ this.setEndHourMinute(this.endHour, newMinute);
983
+ if (!this.requireApply) {
934
984
  this.emitChange();
935
985
  }
936
986
  }
@@ -973,29 +1023,23 @@ export class DualDatepickerComponent {
973
1023
  // ControlValueAccessor implementation
974
1024
  writeValue(value) {
975
1025
  if (value) {
1026
+ // Use setters which delegate to store
976
1027
  this.startDate = value.startDate || '';
977
1028
  this.endDate = value.endDate || '';
978
1029
  if (this.enableTimePicker) {
979
1030
  if (value.startTime) {
980
- const startTime = this.parseTime(value.startTime);
981
- this.startHour = startTime.hour;
982
- this.startMinute = startTime.minute;
1031
+ this.rangeStore.setStartTime(value.startTime);
983
1032
  }
984
1033
  if (value.endTime) {
985
- const endTime = this.parseTime(value.endTime);
986
- this.endHour = endTime.hour;
987
- this.endMinute = endTime.minute;
1034
+ this.rangeStore.setEndTime(value.endTime);
988
1035
  }
989
1036
  }
990
1037
  if (this.startDate && this.endDate) {
991
- this.updateDateRangeText();
992
1038
  this.generateCalendars();
993
1039
  }
994
1040
  }
995
1041
  else {
996
- this.startDate = '';
997
- this.endDate = '';
998
- this.dateRangeText.set('');
1042
+ this.rangeStore.reset();
999
1043
  }
1000
1044
  }
1001
1045
  registerOnChange(fn) {
@@ -1102,4 +1146,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
1102
1146
  type: HostListener,
1103
1147
  args: ['keydown', ['$event']]
1104
1148
  }] } });
1105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dual-datepicker.component.js","sourceRoot":"","sources":["../../src/dual-datepicker.component.ts","../../src/dual-datepicker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAoC,YAAY,EAAc,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACjL,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAC3G,OAAO,EAAe,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;;;AAoD1D,MAAM,OAAO,uBAAuB;IAoFd;IAnFX,WAAW,GAAW,mBAAmB,CAAC;IAC1C,SAAS,GAAW,EAAE,CAAC;IACvB,OAAO,GAAW,EAAE,CAAC;IACrB,WAAW,GAAY,IAAI,CAAC;IAC5B,eAAe,GAAY,KAAK,CAAC;IACjC,UAAU,GAAY,KAAK,CAAC;IAC5B,gBAAgB,GAAY,IAAI,CAAC;IACjC,sBAAsB,GAAY,IAAI,CAAC;IACvC,mBAAmB,GAAY,IAAI,CAAC;IACpC,wBAAwB,GAAY,IAAI,CAAC;IACzC,OAAO,GAAmB,EAAE,CAAC;IAC7B,KAAK,GAAc,SAAS,CAAC;IAC7B,oBAAoB,GAAW,MAAM,CAAC;IACtC,cAAc,GAAW,SAAS,CAAC;IACnC,gBAAgB,GAAW,SAAS,CAAC;IACrC,qBAAqB,GAAW,SAAS,CAAC;IAC1C,qBAAqB,GAAW,SAAS,CAAC;IAC1C,YAAY,GAAW,kBAAkB,CAAC;IAC1C,MAAM,GAAiB,EAAE,CAAC;IAC1B,aAAa,CAAiD;IAC9D,aAAa,GAAW,OAAO,CAAC,CAAC,uCAAuC;IACxE,YAAY,GAAY,KAAK,CAAC,CAAC,oCAAoC;IACnE,gBAAgB,GAAY,KAAK,CAAC,CAAC,wBAAwB;IAC3D,UAAU,GAAkB,KAAK,CAAC,CAAC,cAAc;IACjD,UAAU,GAAW,EAAE,CAAC,CAAC,0CAA0C;IACnE,gBAAgB,GAAW,OAAO,CAAC,CAAC,2BAA2B;IAC/D,cAAc,GAAW,OAAO,CAAC,CAAC,yBAAyB;IAE1D,eAAe,GAAG,IAAI,YAAY,EAAa,CAAC;IAChD,iBAAiB,GAAG,IAAI,YAAY,EAAa,CAAC;IAClD,oBAAoB,GAAG,IAAI,YAAY,EAAkB,CAAC;IAC1D,sBAAsB,GAAG,IAAI,YAAY,EAAkB,CAAC;IAEtE,yBAAyB;IACjB,WAAW,GAAG,MAAM,CAAc,YAAY,CAAC,CAAC;IAExD,6BAA6B;IAC7B,cAAc,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAC/B,aAAa,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;IAC3B,kBAAkB,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;IAClC,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC;IAChD,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC;IACjD,gBAAgB,GAAG,MAAM,CAAQ,EAAE,CAAC,CAAC;IACrC,iBAAiB,GAAG,MAAM,CAAQ,EAAE,CAAC,CAAC;IACtC,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAE3B,wBAAwB;IACxB,gBAAgB,GAAW,EAAE,CAAC;IAC9B,cAAc,GAAW,EAAE,CAAC;IAC5B,iBAAiB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAElC,sBAAsB;IACtB,SAAS,GAAW,CAAC,CAAC;IACtB,WAAW,GAAW,CAAC,CAAC;IACxB,OAAO,GAAW,EAAE,CAAC;IACrB,SAAS,GAAW,EAAE,CAAC;IACvB,mBAAmB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IACpC,iBAAiB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAElC,sBAAsB;IACtB,SAAS,GAAG,MAAM,CAAgB,IAAI,CAAC,CAAC;IAExC,sBAAsB;IACtB,cAAc,GAAG,MAAM,CAAc,EAAE,CAAC,CAAC;IACzC,iBAAiB,GAAG,MAAM,CAAS,CAAC,CAAC,CAAC,CAAC;IAEvC,sBAAsB;IACtB,UAAU,GAAG,MAAM,CAA8C,IAAI,CAAC,CAAC,CAAC,wCAAwC;IAEhH,kBAAkB;IAClB,gBAAgB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;IAC1E,iBAAiB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;IAC5E,YAAY,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IAEjC,iBAAiB,GAAG,CAAC,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;IAC/I,sBAAsB,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IAC9G,eAAe,GAAG,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,UAAU,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;IACjG,oBAAoB,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;IAE5E,iCAAiC;IACzB,QAAQ,GAAsC,GAAG,EAAE,GAAE,CAAC,CAAC;IACvD,SAAS,GAAe,GAAG,EAAE,GAAE,CAAC,CAAC;IAEzC,YAAoB,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;QACxC,2CAA2C;QAC3C,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;YACnC,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACnC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC;YAC1C,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAGD,cAAc,CAAC,KAAiB;QAC9B,IAAI,IAAI,CAAC,cAAc,EAAE,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YACtD,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAC3E,IAAI,CAAC,aAAa,EAAE,CAAC;gBACnB,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,CAAC;QACH,CAAC;IACH,CAAC;IAGD,wBAAwB,CAAC,KAAoB;QAC3C,IAAI,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAAC;YACnC,OAAO;QACT,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;YAC3B,sDAAsD;YACtD,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,IAAI,KAAK,CAAC,GAAG,KAAK,GAAG,EAAE,CAAC;gBAC/C,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;gBAC3C,IAAI,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAAE,CAAC;oBAClD,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBAC1B,CAAC;YACH,CAAC;YACD,OAAO;QACT,CAAC;QAED,sBAAsB;QACtB,QAAQ,KAAK,CAAC,GAAG,EAAE,CAAC;YAClB,KAAK,QAAQ;gBACX,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,eAAe,EAAE,CAAC;gBACvB,MAAM;YAER,KAAK,SAAS;gBACZ,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC3B,MAAM;YAER,KAAK,WAAW;gBACd,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;gBAC1B,MAAM;YAER,KAAK,WAAW;gBACd,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC7B,MAAM;YAER,KAAK,YAAY;gBACf,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;gBAC5B,MAAM;YAER,KAAK,OAAO,CAAC;YACb,KAAK,GAAG;gBACN,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACxB,MAAM;YAER,KAAK,MAAM;gBACT,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBAC3B,MAAM;YAER,KAAK,KAAK;gBACR,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBAC1B,MAAM;YAER,KAAK,QAAQ;gBACX,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;oBACnB,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;gBACzB,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;oBACrB,IAAI,CAAC,2BAA2B,EAAE,CAAC;gBACrC,CAAC;gBACD,MAAM;YAER,KAAK,UAAU;gBACb,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;oBACnB,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;gBACxB,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;oBACpB,IAAI,CAAC,2BAA2B,EAAE,CAAC;gBACrC,CAAC;gBACD,MAAM;QACV,CAAC;IACH,CAAC;IAED,8BAA8B;IACtB,eAAe;QACrB,oEAAoE;QACpE,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;YAC7E,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;YAE5E,IAAI,WAAW,IAAI,WAAW,EAAE,CAAC;gBAC/B,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,EAAE,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YACjF,CAAC;iBAAM,CAAC;gBACN,sDAAsD;gBACtD,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,EAAE,YAAY,CAAC,CAAC;gBAC9E,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;gBAEnE,IAAI,WAAW,EAAE,CAAC;oBAChB,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;gBACtD,CAAC;qBAAM,CAAC;oBACN,MAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBACjD,MAAM,QAAQ,GAAG,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;oBAClE,IAAI,QAAQ,EAAE,CAAC;wBACb,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;oBAC9D,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;aAAM,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACxB,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;YAC3E,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;YAE1E,IAAI,WAAW,IAAI,WAAW,EAAE,CAAC;gBAC/B,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YAC/E,CAAC;iBAAM,CAAC;gBACN,oDAAoD;gBACpD,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,EAAE,YAAY,CAAC,CAAC;gBAC9E,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;gBAEnE,IAAI,WAAW,EAAE,CAAC;oBAChB,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;gBACtD,CAAC;qBAAM,CAAC;oBACN,MAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBACjD,MAAM,QAAQ,GAAG,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;oBAClE,IAAI,QAAQ,EAAE,CAAC;wBACb,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;oBAC9D,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;aAAM,CAAC;YACN,kEAAkE;YAClE,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,EAAE,YAAY,CAAC,CAAC;YAC9E,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;YAEnE,IAAI,WAAW,EAAE,CAAC;gBAChB,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;YACtD,CAAC;iBAAM,CAAC;gBACN,qEAAqE;gBACrE,MAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACjD,MAAM,QAAQ,GAAG,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;gBAClE,IAAI,QAAQ,EAAE,CAAC;oBACb,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;gBAC9D,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAEO,aAAa,CAAC,OAAe,EAAE,SAAe;QACpD,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC7C,IAAI,CAAC,IAAI;YAAE,OAAO,KAAK,CAAC;QACxB,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC9C,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACtD,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QACxD,OAAO,IAAI,KAAK,SAAS,IAAI,KAAK,KAAK,UAAU,CAAC;IACpD,CAAC;IAEO,mBAAmB,CAAC,SAAiB;QAC3C,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,OAAO;QACT,CAAC;QAED,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACzD,IAAI,CAAC,WAAW;YAAE,OAAO;QAEzB,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;QACjE,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAE5C,gDAAgD;QAChD,IAAI,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;QACvE,IAAI,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QAEtE,IAAI,WAAW,IAAI,WAAW,EAAE,CAAC;YAC/B,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC;gBAClB,IAAI,EAAE,UAAU;gBAChB,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aAChC,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,iDAAiD;YACjD,IAAI,SAAS,GAAG,CAAC,EAAE,CAAC;gBAClB,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACtB,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;YACvB,CAAC;YAED,iCAAiC;YACjC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;YACnE,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;YAElE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC;gBAClB,IAAI,EAAE,UAAU;gBAChB,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aACpD,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAEO,iBAAiB,CAAC,SAAiB;QACzC,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,OAAO;QACT,CAAC;QAED,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACzD,IAAI,CAAC,WAAW;YAAE,OAAO;QAEzB,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,WAAW,EAAE,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,eAAe;QACrF,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAE5C,IAAI,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;QACvE,IAAI,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QAEtE,IAAI,WAAW,IAAI,WAAW,EAAE,CAAC;YAC/B,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC;gBAClB,IAAI,EAAE,UAAU;gBAChB,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aAChC,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,4CAA4C;YAC5C,IAAI,SAAS,GAAG,CAAC,EAAE,CAAC;gBAClB,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACtB,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;YACvB,CAAC;YAED,iCAAiC;YACjC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;YACnE,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;YAElE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC;gBAClB,IAAI,EAAE,UAAU;gBAChB,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aACpD,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAEO,mBAAmB;QACzB,MAAM,aAAa,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QAC/D,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;QAC9D,CAAC;IACH,CAAC;IAEO,kBAAkB;QACxB,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC9C,MAAM,SAAS,GAAG,aAAa,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QAClE,MAAM,OAAO,GAAG,SAAS,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAChD,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;QAC7D,CAAC;IACH,CAAC;IAEO,aAAa,CAAC,SAAiB;QACrC,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,OAAO;QACT,CAAC;QAED,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACzD,IAAI,CAAC,WAAW;YAAE,OAAO;QAEzB,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAC1D,MAAM,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;QAC5D,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAEzD,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,WAAW,GAAG,SAAS,EAAE,YAAY,EAAE,UAAU,CAAC,CAAC;QAC/F,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAE5C,qCAAqC;QACrC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,WAAW,GAAG,SAAS,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7F,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,WAAW,GAAG,SAAS,EAAE,YAAY,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAClG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;QACzE,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC;YAClB,IAAI,EAAE,UAAU;YAChB,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SAChC,CAAC,CAAC;IACL,CAAC;IAEO,2BAA2B;QACjC,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,IAAI,CAAC,OAAO;YAAE,OAAO;QAErB,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;QAC3E,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QAE1E,IAAI,CAAC,WAAW,IAAI,CAAC,WAAW,EAAE,CAAC;YACjC,6EAA6E;YAC7E,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,CAAC;aAAM,CAAC;YACN,+BAA+B;YAC/B,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC;gBAClB,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aAChC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAEO,gBAAgB;QACtB,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,IAAI,CAAC,OAAO;YAAE,OAAO;QAErB,MAAM,SAAS,GAAG,OAAO,CAAC,UAAU,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAChG,MAAM,MAAM,GAAG,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,OAAO,CAAC,IAAI,IAAI,GAAG,CAAC,cAAc,CAAC,CAAC;QAEtF,IAAI,MAAM,EAAE,CAAC;YACX,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACzB,CAAC;IACH,CAAC;IAED,gBAAgB,CAAC,IAAY,EAAE,UAAkB;QAC/C,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,OAAO,OAAO,KAAK,IAAI,IAAI,OAAO,CAAC,IAAI,KAAK,IAAI,IAAI,OAAO,CAAC,UAAU,KAAK,UAAU,CAAC;IACxF,CAAC;IAED,QAAQ;QACN,4CAA4C;QAC5C,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YACxD,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,IAAI,CAAC;YAChC,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC,MAAM,CAAC;YAEpC,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YACpD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;YAC5B,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC;QAClC,CAAC;QAED,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACnC,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,WAAW,CAAC,IAAI,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;YAC/C,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACnC,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBAC3B,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,CAAC;iBAAM,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;gBAC5C,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAC7B,CAAC;QACH,CAAC;IACH,CAAC;IAED,UAAU,CAAC,IAAU;QACnB,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC5C,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAC3E,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QACpE,OAAO,GAAG,IAAI,IAAI,KAAK,IAAI,GAAG,EAAE,CAAC;IACnC,CAAC;IAED,iBAAiB,CAAC,OAAe;QAC/B,IAAI,CAAC,OAAO;YAAE,OAAO,EAAE,CAAC;QACxB,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC7C,IAAI,CAAC,IAAI;YAAE,OAAO,EAAE,CAAC;QAErB,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC9C,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAE3C,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,IAAI,CAAC,iBAAiB,CAAC;QACpE,MAAM,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,IAAI,IAAI,CAAC,sBAAsB,CAAC;QAEnF,oCAAoC;QACpC,IAAI,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC;QAEnC,cAAc;QACd,SAAS,GAAG,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QACrD,SAAS,GAAG,SAAS,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE7D,mEAAmE;QACnE,SAAS,GAAG,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;QAC1D,SAAS,GAAG,SAAS,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC;QAC9D,SAAS,GAAG,SAAS,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;QACzE,SAAS,GAAG,SAAS,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;QAEvD,0CAA0C;QAC1C,SAAS,GAAG,SAAS,CAAC,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;QACnE,SAAS,GAAG,SAAS,CAAC,OAAO,CAAC,IAAI,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;QAEjD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,mBAAmB;QACjB,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACnC,MAAM,KAAK,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YACrD,MAAM,GAAG,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACjD,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,GAAG,KAAK,MAAM,GAAG,EAAE,CAAC,CAAC;QAC9C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC;QAC5C,IAAI,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;YAC1B,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAClC,MAAM,iBAAiB,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YAC9C,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;YACzD,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CAAC;YAC3D,MAAM,iBAAiB,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;YAC1E,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;YAC1C,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,mEAAmE;YACnE,IAAI,IAAI,CAAC,wBAAwB,EAAE,CAAC;gBAClC,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,CAAC;QACH,CAAC;aAAM,CAAC;YACN,2BAA2B;YAC3B,IAAI,IAAI,CAAC,wBAAwB,EAAE,CAAC;gBAClC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC5B,CAAC;QACH,CAAC;QACD,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,eAAe;QACb,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAClC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC5B,CAAC;QACD,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;QAC7E,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;IAC7E,CAAC;IAED,qBAAqB,CAAC,IAAU;QAC9B,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC9C,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QAC7D,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAChE,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QACtD,MAAM,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAEzD,MAAM,SAAS,GAAG,EAAE,CAAC;QAErB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,cAAc,EAAE,CAAC,EAAE,EAAE,CAAC;YACxC,SAAS,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,CAAC,CAAC;QACvD,CAAC;QAED,KAAK,IAAI,GAAG,GAAG,CAAC,EAAE,GAAG,IAAI,WAAW,EAAE,GAAG,EAAE,EAAE,CAAC;YAC5C,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;YAC9D,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;YAEzC,4DAA4D;YAC5D,MAAM,cAAc,GAAG,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,gBAAgB,KAAK,OAAO,CAAC;YAC9E,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,cAAc,KAAK,OAAO,CAAC;YAC1E,MAAM,cAAc,GAAG,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,cAAc;gBACjE,OAAO,IAAI,IAAI,CAAC,gBAAgB,IAAI,OAAO,IAAI,IAAI,CAAC,cAAc,CAAC;YAE1F,0CAA0C;YAC1C,MAAM,YAAY,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;YAElD,SAAS,CAAC,IAAI,CAAC;gBACb,GAAG,EAAE,GAAG;gBACR,IAAI,EAAE,OAAO;gBACb,cAAc,EAAE,IAAI;gBACpB,OAAO,EAAE,IAAI,CAAC,SAAS,KAAK,OAAO,IAAI,cAAc;gBACrD,KAAK,EAAE,IAAI,CAAC,OAAO,KAAK,OAAO,IAAI,YAAY;gBAC/C,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,cAAc;gBAClD,YAAY,EAAE,YAAY;gBAC1B,UAAU,EAAE,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;aACzC,CAAC,CAAC;QACL,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,SAAS,CAAC,OAAe;QACvB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,iDAAiD;YACjD,OAAO,IAAI,CAAC,cAAc,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;gBACxC,OAAO,OAAO,IAAI,KAAK,CAAC,SAAS,IAAI,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC;YAChE,CAAC,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,OAAO;gBAAE,OAAO,KAAK,CAAC;YACnD,OAAO,OAAO,IAAI,IAAI,CAAC,SAAS,IAAI,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC;QAC9D,CAAC;IACH,CAAC;IAED,cAAc,CAAC,IAAU;QACvB,IAAI,CAAC,IAAI,CAAC,aAAa;YAAE,OAAO,KAAK,CAAC;QAEtC,IAAI,OAAO,IAAI,CAAC,aAAa,KAAK,UAAU,EAAE,CAAC;YAC7C,4CAA4C;YAC5C,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC;aAAM,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC;YAC7C,gEAAgE;YAChE,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE;gBAC5C,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,YAAY,CAAC;oBACzE,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,YAAY,CAAC;oBAC3E,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;YACnF,CAAC,CAAC,CAAC;QACL,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED,cAAc,CAAC,OAAe;QAC5B,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QAC/B,IAAI,CAAC,KAAK;YAAE,OAAO,KAAK,CAAC;QAEzB,sEAAsE;QACtE,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,IAAI,IAAI,CAAC,kBAAkB,EAAE;gBAAE,OAAO,KAAK,CAAC;YAC5C,IAAI,CAAC,IAAI,CAAC,SAAS;gBAAE,OAAO,KAAK,CAAC;YAClC,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC;YAChE,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC;YAChE,OAAO,OAAO,IAAI,OAAO,IAAI,OAAO,IAAI,OAAO,CAAC;QAClD,CAAC;aAAM,CAAC;YACN,yCAAyC;YACzC,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;gBACtB,IAAI,IAAI,CAAC,kBAAkB,EAAE;oBAAE,OAAO,KAAK,CAAC;gBAC5C,IAAI,CAAC,IAAI,CAAC,gBAAgB;oBAAE,OAAO,KAAK,CAAC;gBACzC,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,KAAK,CAAC;gBAC9E,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,KAAK,CAAC;gBAC9E,OAAO,OAAO,IAAI,OAAO,IAAI,OAAO,IAAI,OAAO,CAAC;YAClD,CAAC;iBAAM,CAAC;gBACN,4CAA4C;gBAC5C,IAAI,IAAI,CAAC,kBAAkB,EAAE;oBAAE,OAAO,KAAK,CAAC;gBAC5C,IAAI,CAAC,IAAI,CAAC,SAAS;oBAAE,OAAO,KAAK,CAAC;gBAClC,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC;gBAChE,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC;gBAChE,OAAO,OAAO,IAAI,OAAO,IAAI,OAAO,IAAI,OAAO,CAAC;YAClD,CAAC;QACH,CAAC;IACH,CAAC;IAED,UAAU,CAAC,MAAW;QACpB,IAAI,CAAC,MAAM,CAAC,cAAc,IAAI,IAAI,CAAC,UAAU,EAAE,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;YACrE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACzB,OAAO;QACT,CAAC;QACD,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAChC,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,aAAa;QACX,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,SAAS,CAAC,MAAW;QACnB,IAAI,CAAC,MAAM,CAAC,cAAc,IAAI,IAAI,CAAC,UAAU,EAAE,IAAI,MAAM,CAAC,UAAU;YAAE,OAAO;QAE7E,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,wCAAwC;YACxC,IAAI,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC;gBAC9B,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC;gBAC7B,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;gBAClB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBAC3B,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YACrC,CAAC;iBAAM,CAAC;gBACN,IAAI,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;oBACjC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;oBAC9B,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC;gBAC/B,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC;gBAC7B,CAAC;gBAED,iCAAiC;gBACjC,MAAM,QAAQ,GAAc;oBAC1B,SAAS,EAAE,IAAI,CAAC,SAAS;oBACzB,OAAO,EAAE,IAAI,CAAC,OAAO;oBACrB,SAAS,EAAE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,KAAK,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC;iBACjG,CAAC;gBAEF,MAAM,aAAa,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;gBACjD,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC7B,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;gBAEvC,iCAAiC;gBACjC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;gBACpB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;gBAClB,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBAElC,sBAAsB;gBACtB,IAAI,CAAC,oBAAoB,EAAE,CAAC;gBAE5B,sDAAsD;gBACtD,IAAI,IAAI,CAAC,gBAAgB,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;oBAC9C,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBACjC,CAAC;gBAED,IAAI,CAAC,eAAe,EAAE,CAAC;gBACvB,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC5B,CAAC;YACD,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;aAAM,CAAC;YACN,wCAAwC;YACxC,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;gBACtB,mEAAmE;gBACnE,IAAI,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC;oBAC9B,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC;oBACpC,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;oBACzB,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBACnC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBACnC,CAAC;qBAAM,CAAC;oBACN,IAAI,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;wBACxC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,gBAAgB,CAAC;wBAC5C,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC;oBACtC,CAAC;yBAAM,CAAC;wBACN,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,IAAI,CAAC;oBACpC,CAAC;oBACD,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;oBAClC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBACnC,CAAC;gBACD,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,CAAC;iBAAM,CAAC;gBACN,2CAA2C;gBAC3C,IAAI,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC;oBAC9B,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC;oBAC7B,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;oBAClB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;oBAC3B,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBACnC,IAAI,CAAC,UAAU,EAAE,CAAC;gBACpB,CAAC;qBAAM,CAAC;oBACN,IAAI,MAAM,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;wBACjC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;wBAC9B,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC;oBAC/B,CAAC;yBAAM,CAAC;wBACN,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC;oBAC7B,CAAC;oBACD,IAAI,CAAC,mBAAmB,EAAE,CAAC;oBAC3B,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;wBAC1B,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBACjC,CAAC;oBACD,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;oBAClC,IAAI,CAAC,UAAU,EAAE,CAAC;oBAClB,IAAI,CAAC,aAAa,EAAE,CAAC;gBACvB,CAAC;gBACD,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,CAAC;QACH,CAAC;IACH,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;YAAE,OAAO;QAEtC,sBAAsB;QACtB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC;QACvC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC;QACnC,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAE3B,sBAAsB;QACtB,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;QAC3B,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;QACzB,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAElC,eAAe;QACf,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,aAAa,EAAE,CAAC;QAErB,eAAe;QACf,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,eAAe;QACb,0BAA0B;QAC1B,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;QAC3B,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;QACzB,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAClC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAElC,qDAAqD;QACrD,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW,CAAC,SAAiB;QAC3B,MAAM,iBAAiB,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAC9C,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;QACzD,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CAAC;QAC3D,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,GAAG,SAAS,EAAE,CAAC,CAAC,CAAC;QAChF,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;QAEvC,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;QAC1D,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;QAC5D,MAAM,gBAAgB,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,OAAO,EAAE,QAAQ,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAC/E,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;QACzC,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,YAAY,CAAC,IAAU;QACrB,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,IAAI,CAAC,iBAAiB,CAAC;QACpE,OAAO,GAAG,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;IAC5F,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,MAAM,CAAC,aAAa,IAAI,IAAI,CAAC,oBAAoB,CAAC;IAChE,CAAC;IAED,iBAAiB,CAAC,MAAoB;QACpC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;YACrB,OAAO,CAAC,KAAK,CAAC,4CAA4C,CAAC,CAAC;YAC5D,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC;QAChC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC;QAC7B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,GAAG,CAAC;QACzB,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;QACD,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,KAAK;QACH,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;QAClB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAC3B,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAElC,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAC5B,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YAC/B,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;QAED,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW,CAAC,KAAa;QACvB,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,OAAO;QAE7B,MAAM,aAAa,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;QACjD,aAAa,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAC/B,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;QAEvC,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAEO,oBAAoB;QAC1B,MAAM,KAAK,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC;QAC3C,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;YAChB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAC7B,CAAC;aAAM,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;YACvB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;QAC7C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,GAAG,KAAK,kBAAkB,CAAC,CAAC;QACrD,CAAC;IACH,CAAC;IAEO,UAAU;QAChB,MAAM,KAAK,GAAc;YACvB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,SAAS,EAAE,IAAI,CAAC,aAAa,EAAE;SAChC,CAAC;QAEF,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;YACpE,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QAChE,CAAC;QAED,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAEO,aAAa;QACnB,MAAM,KAAK,GAAc;YACvB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,SAAS,EAAE,IAAI,CAAC,aAAa,EAAE;SAChC,CAAC;QAEF,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;YACpE,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QAChE,CAAC;QAED,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC;YAC7B,MAAM,EAAE,IAAI,CAAC,cAAc,EAAE;SAC9B,CAAC,CAAC;IACL,CAAC;IAEO,kBAAkB;QACxB,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC;YAC/B,MAAM,EAAE,IAAI,CAAC,cAAc,EAAE;SAC9B,CAAC,CAAC;IACL,CAAC;IAEO,iBAAiB;QACvB,MAAM,KAAK,GAAc;YACvB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,SAAS,EAAE,IAAI,CAAC,aAAa,EAAE;SAChC,CAAC;QAEF,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;YACpE,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QAChE,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED,sBAAsB;IACtB,qBAAqB;QACnB,IAAI,CAAC,IAAI,CAAC,gBAAgB;YAAE,OAAO;QACnC,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC,CAAC;QAC1D,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,IAAI,CAAC,gBAAgB;YAAE,OAAO;QACnC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC;QACtD,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;QAC3C,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;IACH,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QAChE,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;IACH,CAAC;IAED,oBAAoB;QAClB,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC;QAC7D,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;IACH,CAAC;IAED,oBAAoB;QAClB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC;QACtD,IAAI,IAAI,CAAC,WAAW,GAAG,CAAC,EAAE,CAAC;YACzB,IAAI,CAAC,WAAW,GAAG,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC;QAC1C,CAAC;QACD,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;QACvC,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;QAC1D,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;IACH,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC;QACzD,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;IACH,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC;QAClD,IAAI,IAAI,CAAC,SAAS,GAAG,CAAC,EAAE,CAAC;YACvB,IAAI,CAAC,SAAS,GAAG,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC;QACxC,CAAC;QACD,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;IACH,CAAC;IAED,UAAU,CAAC,IAAY,EAAE,MAAc;QACrC,MAAM,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAC3C,MAAM,CAAC,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QAE7C,IAAI,IAAI,CAAC,UAAU,KAAK,KAAK,EAAE,CAAC;YAC9B,MAAM,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC;YACxB,MAAM,MAAM,GAAG,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;YAC9D,MAAM,MAAM,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;YAClC,OAAO,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI,MAAM,EAAE,CAAC;QAChE,CAAC;QAED,OAAO,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;IACrB,CAAC;IAED,SAAS,CAAC,UAAkB;QAC1B,IAAI,CAAC,UAAU;YAAE,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;QAE/C,MAAM,YAAY,GAAG,gCAAgC,CAAC;QACtD,MAAM,YAAY,GAAG,qBAAqB,CAAC;QAE3C,IAAI,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QAC3C,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,IAAI,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YAClC,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACtC,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;YAEtC,IAAI,MAAM,KAAK,IAAI,IAAI,IAAI,KAAK,EAAE;gBAAE,IAAI,IAAI,EAAE,CAAC;YAC/C,IAAI,MAAM,KAAK,IAAI,IAAI,IAAI,KAAK,EAAE;gBAAE,IAAI,GAAG,CAAC,CAAC;YAE7C,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;QAC1B,CAAC;QAED,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QACvC,IAAI,KAAK,EAAE,CAAC;YACV,OAAO;gBACL,IAAI,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;gBAC5B,MAAM,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;aAC/B,CAAC;QACJ,CAAC;QAED,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;IAChC,CAAC;IAED,sCAAsC;IACtC,UAAU,CAAC,KAAuB;QAChC,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,SAAS,IAAI,EAAE,CAAC;YACvC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,OAAO,IAAI,EAAE,CAAC;YAEnC,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBAC1B,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC;oBACpB,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;oBAClD,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,IAAI,CAAC;oBAChC,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC,MAAM,CAAC;gBACtC,CAAC;gBACD,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;oBAClB,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;oBAC9C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;oBAC5B,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC;gBAClC,CAAC;YACH,CAAC;YAED,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACnC,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBAC3B,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;YACpB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;YAClB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;IAED,gBAAgB,CAAC,EAAqC;QACpD,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IAClC,CAAC;wGAtkCU,uBAAuB;4FAAvB,uBAAuB,iwCAZvB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,uBAAuB,CAAC;gBACtD,KAAK,EAAE,IAAI;aACZ;YACD;gBACE,OAAO,EAAE,YAAY;gBACrB,QAAQ,EAAE,iBAAiB;aAC5B;SACF,+CCtDH,0kdAyVA,8oWDhTY,YAAY,mHAAE,WAAW,8BAAE,mBAAmB;;4FAe7C,uBAAuB;kBAlBnC,SAAS;+BACE,qBAAqB,cACnB,IAAI,WACP,CAAC,YAAY,EAAE,WAAW,EAAE,mBAAmB,CAAC,aAG9C;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,wBAAwB,CAAC;4BACtD,KAAK,EAAE,IAAI;yBACZ;wBACD;4BACE,OAAO,EAAE,YAAY;4BACrB,QAAQ,EAAE,iBAAiB;yBAC5B;qBACF;+EAGQ,WAAW;sBAAnB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,sBAAsB;sBAA9B,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,wBAAwB;sBAAhC,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBAEI,eAAe;sBAAxB,MAAM;gBACG,iBAAiB;sBAA1B,MAAM;gBACG,oBAAoB;sBAA7B,MAAM;gBACG,sBAAsB;sBAA/B,MAAM;gBA+DP,cAAc;sBADb,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC;gBAW1C,wBAAwB;sBADvB,YAAY;uBAAC,SAAS,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges, HostListener, ElementRef, forwardRef, signal, computed, effect, inject } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule, ReactiveFormsModule, ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DateAdapter, DATE_ADAPTER } from './date-adapter';\nimport { NativeDateAdapter } from './native-date-adapter';\n\nexport interface DateRange {\n  startDate: string;\n  endDate: string;\n  rangeText: string;\n  startTime?: string; // HH:mm format (optional)\n  endTime?: string; // HH:mm format (optional)\n}\n\nexport interface MultiDateRange {\n  ranges: DateRange[];\n}\n\nexport interface PresetRange {\n  start: string;\n  end: string;\n}\n\nexport interface PresetConfig {\n  label: string;\n  getValue: () => PresetRange;\n}\n\nexport interface LocaleConfig {\n  monthNames?: string[];\n  monthNamesShort?: string[];\n  dayNames?: string[];\n  dayNamesShort?: string[];\n  firstDayOfWeek?: number; // 0 = Sunday, 1 = Monday, etc.\n}\n\nexport type ThemeType = 'default' | 'bootstrap' | 'bulma' | 'foundation' | 'tailwind' | 'custom';\n\n@Component({\n  selector: 'ngx-dual-datepicker',\n  standalone: true,\n  imports: [CommonModule, FormsModule, ReactiveFormsModule],\n  templateUrl: './dual-datepicker.component.html',\n  styleUrl: './dual-datepicker.component.scss',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DualDatepickerComponent),\n      multi: true\n    },\n    {\n      provide: DATE_ADAPTER,\n      useClass: NativeDateAdapter\n    }\n  ]\n})\nexport class DualDatepickerComponent implements OnInit, OnChanges, ControlValueAccessor {\n  @Input() placeholder: string = 'Select date range';\n  @Input() startDate: string = '';\n  @Input() endDate: string = '';\n  @Input() showPresets: boolean = true;\n  @Input() showClearButton: boolean = false;\n  @Input() multiRange: boolean = false;\n  @Input() closeOnSelection: boolean = true;\n  @Input() closeOnPresetSelection: boolean = true;\n  @Input() closeOnClickOutside: boolean = true;\n  @Input() enableKeyboardNavigation: boolean = true;\n  @Input() presets: PresetConfig[] = [];\n  @Input() theme: ThemeType = 'default';\n  @Input() inputBackgroundColor: string = '#fff';\n  @Input() inputTextColor: string = '#495057';\n  @Input() inputBorderColor: string = '#ced4da';\n  @Input() inputBorderColorHover: string = '#ced4da';\n  @Input() inputBorderColorFocus: string = '#80bdff';\n  @Input() inputPadding: string = '0.375rem 0.75rem';\n  @Input() locale: LocaleConfig = {};\n  @Input() disabledDates: Date[] | ((date: Date) => boolean) | undefined;\n  @Input() displayFormat: string = 'D MMM'; // Format for displaying dates in input\n  @Input() requireApply: boolean = false; // Require Apply button confirmation\n  @Input() enableTimePicker: boolean = false; // Enable time selection\n  @Input() timeFormat: '12h' | '24h' = '24h'; // Time format\n  @Input() minuteStep: number = 15; // Step for minute selector (1, 5, 15, 30)\n  @Input() defaultStartTime: string = '00:00'; // Default start time HH:mm\n  @Input() defaultEndTime: string = '23:59'; // Default end time HH:mm\n\n  @Output() dateRangeChange = new EventEmitter<DateRange>();\n  @Output() dateRangeSelected = new EventEmitter<DateRange>();\n  @Output() multiDateRangeChange = new EventEmitter<MultiDateRange>();\n  @Output() multiDateRangeSelected = new EventEmitter<MultiDateRange>();\n\n  // Date adapter injection\n  private dateAdapter = inject<DateAdapter>(DATE_ADAPTER);\n\n  // Signals for reactive state\n  showDatePicker = signal(false);\n  dateRangeText = signal('');\n  selectingStartDate = signal(true);\n  currentMonth = signal(this.dateAdapter.today());\n  previousMonth = signal(this.dateAdapter.today());\n  currentMonthDays = signal<any[]>([]);\n  previousMonthDays = signal<any[]>([]);\n  isDisabled = signal(false);\n  \n  // Apply/Confirm support\n  pendingStartDate: string = '';\n  pendingEndDate: string = '';\n  hasPendingChanges = signal(false);\n  \n  // Time picker support\n  startHour: number = 0;\n  startMinute: number = 0;\n  endHour: number = 23;\n  endMinute: number = 59;\n  showStartTimePicker = signal(false);\n  showEndTimePicker = signal(false);\n  \n  // Hover range preview\n  hoverDate = signal<string | null>(null);\n  \n  // Multi-range support\n  selectedRanges = signal<DateRange[]>([]);\n  currentRangeIndex = signal<number>(-1);\n\n  // Keyboard navigation\n  focusedDay = signal<{ date: string; monthIndex: number } | null>(null); // monthIndex: 0 = previous, 1 = current\n  \n  // Computed values\n  currentMonthName = computed(() => this.getMonthName(this.currentMonth()));\n  previousMonthName = computed(() => this.getMonthName(this.previousMonth()));\n  weekDayNames = computed(() => this.getDayNames());\n\n  private readonly defaultMonthNames = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];\n  private readonly defaultMonthNamesShort = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];\n  private readonly defaultDayNames = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];\n  private readonly defaultDayNamesShort = ['S', 'M', 'T', 'W', 'T', 'F', 'S'];\n\n  // ControlValueAccessor callbacks\n  private onChange: (value: DateRange | null) => void = () => {};\n  private onTouched: () => void = () => {};\n\n  constructor(private elementRef: ElementRef) {\n    // Effect to emit changes when dates change\n    effect(() => {\n      const range = this.dateRangeText();\n      if (this.startDate || this.endDate) {\n        this.onChange(this.getDateRangeValue());\n      }\n    });\n  }\n\n  @HostListener('document:click', ['$event'])\n  onClickOutside(event: MouseEvent): void {\n    if (this.showDatePicker() && this.closeOnClickOutside) {\n      const clickedInside = this.elementRef.nativeElement.contains(event.target);\n      if (!clickedInside) {\n        this.closeDatePicker();\n      }\n    }\n  }\n\n  @HostListener('keydown', ['$event'])\n  handleKeyboardNavigation(event: KeyboardEvent): void {\n    if (!this.enableKeyboardNavigation) {\n      return;\n    }\n\n    if (!this.showDatePicker()) {\n      // When picker is closed, allow Enter/Space to open it\n      if (event.key === 'Enter' || event.key === ' ') {\n        const target = event.target as HTMLElement;\n        if (target.classList.contains('datepicker-input')) {\n          event.preventDefault();\n          this.toggleDatePicker();\n        }\n      }\n      return;\n    }\n\n    // When picker is open\n    switch (event.key) {\n      case 'Escape':\n        event.preventDefault();\n        this.closeDatePicker();\n        break;\n\n      case 'ArrowUp':\n        event.preventDefault();\n        this.moveFocusVertical(-1);\n        break;\n\n      case 'ArrowDown':\n        event.preventDefault();\n        this.moveFocusVertical(1);\n        break;\n\n      case 'ArrowLeft':\n        event.preventDefault();\n        this.moveFocusHorizontal(-1);\n        break;\n\n      case 'ArrowRight':\n        event.preventDefault();\n        this.moveFocusHorizontal(1);\n        break;\n\n      case 'Enter':\n      case ' ':\n        event.preventDefault();\n        this.selectFocusedDay();\n        break;\n\n      case 'Home':\n        event.preventDefault();\n        this.moveFocusToFirstDay();\n        break;\n\n      case 'End':\n        event.preventDefault();\n        this.moveFocusToLastDay();\n        break;\n\n      case 'PageUp':\n        event.preventDefault();\n        if (event.shiftKey) {\n          this.moveFocusYear(-1);\n        } else {\n          this.changeMonth(-1);\n          this.adjustFocusAfterMonthChange();\n        }\n        break;\n\n      case 'PageDown':\n        event.preventDefault();\n        if (event.shiftKey) {\n          this.moveFocusYear(1);\n        } else {\n          this.changeMonth(1);\n          this.adjustFocusAfterMonthChange();\n        }\n        break;\n    }\n  }\n\n  // Keyboard navigation methods\n  private initializeFocus(): void {\n    // Set initial focus to start date, end date, or first available day\n    if (this.startDate) {\n      const inPrevMonth = this.isDateInMonth(this.startDate, this.previousMonth());\n      const inCurrMonth = this.isDateInMonth(this.startDate, this.currentMonth());\n      \n      if (inPrevMonth || inCurrMonth) {\n        this.focusedDay.set({ date: this.startDate, monthIndex: inPrevMonth ? 0 : 1 });\n      } else {\n        // startDate is not visible, focus on today if visible\n        const today = this.dateAdapter.format(this.dateAdapter.today(), 'yyyy-MM-dd');\n        const inCurrMonth = this.isDateInMonth(today, this.currentMonth());\n        \n        if (inCurrMonth) {\n          this.focusedDay.set({ date: today, monthIndex: 1 });\n        } else {\n          const currentMonthDays = this.currentMonthDays();\n          const firstDay = currentMonthDays.find(day => day.isCurrentMonth);\n          if (firstDay) {\n            this.focusedDay.set({ date: firstDay.date, monthIndex: 1 });\n          }\n        }\n      }\n    } else if (this.endDate) {\n      const inPrevMonth = this.isDateInMonth(this.endDate, this.previousMonth());\n      const inCurrMonth = this.isDateInMonth(this.endDate, this.currentMonth());\n      \n      if (inPrevMonth || inCurrMonth) {\n        this.focusedDay.set({ date: this.endDate, monthIndex: inPrevMonth ? 0 : 1 });\n      } else {\n        // endDate is not visible, focus on today if visible\n        const today = this.dateAdapter.format(this.dateAdapter.today(), 'yyyy-MM-dd');\n        const inCurrMonth = this.isDateInMonth(today, this.currentMonth());\n        \n        if (inCurrMonth) {\n          this.focusedDay.set({ date: today, monthIndex: 1 });\n        } else {\n          const currentMonthDays = this.currentMonthDays();\n          const firstDay = currentMonthDays.find(day => day.isCurrentMonth);\n          if (firstDay) {\n            this.focusedDay.set({ date: firstDay.date, monthIndex: 1 });\n          }\n        }\n      }\n    } else {\n      // Focus on today if visible, otherwise first day of current month\n      const today = this.dateAdapter.format(this.dateAdapter.today(), 'yyyy-MM-dd');\n      const inCurrMonth = this.isDateInMonth(today, this.currentMonth());\n      \n      if (inCurrMonth) {\n        this.focusedDay.set({ date: today, monthIndex: 1 });\n      } else {\n        // Today is not in current month, focus on first day of current month\n        const currentMonthDays = this.currentMonthDays();\n        const firstDay = currentMonthDays.find(day => day.isCurrentMonth);\n        if (firstDay) {\n          this.focusedDay.set({ date: firstDay.date, monthIndex: 1 });\n        }\n      }\n    }\n  }\n\n  private isDateInMonth(dateStr: string, monthDate: Date): boolean {\n    const date = this.dateAdapter.parse(dateStr);\n    if (!date) return false;\n    const year = this.dateAdapter.getYear(date);\n    const month = this.dateAdapter.getMonth(date);\n    const monthYear = this.dateAdapter.getYear(monthDate);\n    const monthMonth = this.dateAdapter.getMonth(monthDate);\n    return year === monthYear && month === monthMonth;\n  }\n\n  private moveFocusHorizontal(direction: number): void {\n    const focused = this.focusedDay();\n    if (!focused) {\n      this.initializeFocus();\n      return;\n    }\n\n    const currentDate = this.dateAdapter.parse(focused.date);\n    if (!currentDate) return;\n\n    const newDate = this.dateAdapter.addDays(currentDate, direction);\n    const newDateStr = this.formatDate(newDate);\n\n    // Determine which month the new date belongs to\n    let inPrevMonth = this.isDateInMonth(newDateStr, this.previousMonth());\n    let inCurrMonth = this.isDateInMonth(newDateStr, this.currentMonth());\n\n    if (inPrevMonth || inCurrMonth) {\n      this.focusedDay.set({ \n        date: newDateStr, \n        monthIndex: inPrevMonth ? 0 : 1 \n      });\n    } else {\n      // Date is outside visible months, navigate month\n      if (direction > 0) {\n        this.changeMonth(1);\n      } else {\n        this.changeMonth(-1);\n      }\n      \n      // Recalculate after month change\n      inPrevMonth = this.isDateInMonth(newDateStr, this.previousMonth());\n      inCurrMonth = this.isDateInMonth(newDateStr, this.currentMonth());\n      \n      this.focusedDay.set({ \n        date: newDateStr, \n        monthIndex: inPrevMonth ? 0 : (inCurrMonth ? 1 : 0)\n      });\n    }\n  }\n\n  private moveFocusVertical(direction: number): void {\n    const focused = this.focusedDay();\n    if (!focused) {\n      this.initializeFocus();\n      return;\n    }\n\n    const currentDate = this.dateAdapter.parse(focused.date);\n    if (!currentDate) return;\n\n    const newDate = this.dateAdapter.addDays(currentDate, direction * 7); // Move by week\n    const newDateStr = this.formatDate(newDate);\n\n    let inPrevMonth = this.isDateInMonth(newDateStr, this.previousMonth());\n    let inCurrMonth = this.isDateInMonth(newDateStr, this.currentMonth());\n\n    if (inPrevMonth || inCurrMonth) {\n      this.focusedDay.set({ \n        date: newDateStr, \n        monthIndex: inPrevMonth ? 0 : 1 \n      });\n    } else {\n      // Navigate to month containing the new date\n      if (direction > 0) {\n        this.changeMonth(1);\n      } else {\n        this.changeMonth(-1);\n      }\n      \n      // Recalculate after month change\n      inPrevMonth = this.isDateInMonth(newDateStr, this.previousMonth());\n      inCurrMonth = this.isDateInMonth(newDateStr, this.currentMonth());\n      \n      this.focusedDay.set({ \n        date: newDateStr, \n        monthIndex: inPrevMonth ? 0 : (inCurrMonth ? 1 : 0)\n      });\n    }\n  }\n\n  private moveFocusToFirstDay(): void {\n    const prevMonthDays = this.previousMonthDays();\n    const firstDay = prevMonthDays.find(day => day.isCurrentMonth);\n    if (firstDay) {\n      this.focusedDay.set({ date: firstDay.date, monthIndex: 0 });\n    }\n  }\n\n  private moveFocusToLastDay(): void {\n    const currMonthDays = this.currentMonthDays();\n    const validDays = currMonthDays.filter(day => day.isCurrentMonth);\n    const lastDay = validDays[validDays.length - 1];\n    if (lastDay) {\n      this.focusedDay.set({ date: lastDay.date, monthIndex: 1 });\n    }\n  }\n\n  private moveFocusYear(direction: number): void {\n    const focused = this.focusedDay();\n    if (!focused) {\n      this.initializeFocus();\n      return;\n    }\n\n    const currentDate = this.dateAdapter.parse(focused.date);\n    if (!currentDate) return;\n\n    const currentYear = this.dateAdapter.getYear(currentDate);\n    const currentMonth = this.dateAdapter.getMonth(currentDate);\n    const currentDay = this.dateAdapter.getDate(currentDate);\n    \n    const newDate = this.dateAdapter.createDate(currentYear + direction, currentMonth, currentDay);\n    const newDateStr = this.formatDate(newDate);\n\n    // Update months to show the new year\n    this.currentMonth.set(this.dateAdapter.createDate(currentYear + direction, currentMonth, 1));\n    this.previousMonth.set(this.dateAdapter.createDate(currentYear + direction, currentMonth - 1, 1));\n    this.generateCalendars();\n\n    const inPrevMonth = this.isDateInMonth(newDateStr, this.previousMonth());\n    this.focusedDay.set({ \n      date: newDateStr, \n      monthIndex: inPrevMonth ? 0 : 1 \n    });\n  }\n\n  private adjustFocusAfterMonthChange(): void {\n    const focused = this.focusedDay();\n    if (!focused) return;\n\n    const inPrevMonth = this.isDateInMonth(focused.date, this.previousMonth());\n    const inCurrMonth = this.isDateInMonth(focused.date, this.currentMonth());\n\n    if (!inPrevMonth && !inCurrMonth) {\n      // Focused day is no longer visible, move to equivalent day in visible months\n      this.initializeFocus();\n    } else {\n      // Update month index if needed\n      this.focusedDay.set({\n        date: focused.date,\n        monthIndex: inPrevMonth ? 0 : 1\n      });\n    }\n  }\n\n  private selectFocusedDay(): void {\n    const focused = this.focusedDay();\n    if (!focused) return;\n\n    const monthDays = focused.monthIndex === 0 ? this.previousMonthDays() : this.currentMonthDays();\n    const dayObj = monthDays.find(day => day.date === focused.date && day.isCurrentMonth);\n    \n    if (dayObj) {\n      this.selectDay(dayObj);\n    }\n  }\n\n  hasKeyboardFocus(date: string, monthIndex: number): boolean {\n    const focused = this.focusedDay();\n    return focused !== null && focused.date === date && focused.monthIndex === monthIndex;\n  }\n\n  ngOnInit(): void {\n    // Initialize time picker with default times\n    if (this.enableTimePicker) {\n      const startTime = this.parseTime(this.defaultStartTime);\n      this.startHour = startTime.hour;\n      this.startMinute = startTime.minute;\n      \n      const endTime = this.parseTime(this.defaultEndTime);\n      this.endHour = endTime.hour;\n      this.endMinute = endTime.minute;\n    }\n    \n    if (this.startDate && this.endDate) {\n      this.updateDateRangeText();\n      this.generateCalendars();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['startDate'] || changes['endDate']) {\n      if (this.startDate && this.endDate) {\n        this.updateDateRangeText();\n        this.generateCalendars();\n      } else if (!this.startDate && !this.endDate) {\n        this.dateRangeText.set('');\n      }\n    }\n  }\n\n  formatDate(date: Date): string {\n    const year = this.dateAdapter.getYear(date);\n    const month = String(this.dateAdapter.getMonth(date) + 1).padStart(2, '0');\n    const day = String(this.dateAdapter.getDate(date)).padStart(2, '0');\n    return `${year}-${month}-${day}`;\n  }\n\n  formatDateDisplay(dateStr: string): string {\n    if (!dateStr) return '';\n    const date = this.dateAdapter.parse(dateStr);\n    if (!date) return '';\n    \n    const year = this.dateAdapter.getYear(date);\n    const month = this.dateAdapter.getMonth(date);\n    const day = this.dateAdapter.getDate(date);\n    \n    const monthNames = this.locale.monthNames || this.defaultMonthNames;\n    const monthNamesShort = this.locale.monthNamesShort || this.defaultMonthNamesShort;\n    \n    // Replace format tokens with values\n    let formatted = this.displayFormat;\n    \n    // Year tokens\n    formatted = formatted.replace(/YYYY/g, String(year));\n    formatted = formatted.replace(/YY/g, String(year).slice(-2));\n    \n    // Month tokens (order matters: MMMM before MMM before MM before M)\n    formatted = formatted.replace(/MMMM/g, monthNames[month]);\n    formatted = formatted.replace(/MMM/g, monthNamesShort[month]);\n    formatted = formatted.replace(/MM/g, String(month + 1).padStart(2, '0'));\n    formatted = formatted.replace(/M/g, String(month + 1));\n    \n    // Day tokens (order matters: DD before D)\n    formatted = formatted.replace(/DD/g, String(day).padStart(2, '0'));\n    formatted = formatted.replace(/D/g, String(day));\n    \n    return formatted;\n  }\n\n  updateDateRangeText(): void {\n    if (this.startDate && this.endDate) {\n      const start = this.formatDateDisplay(this.startDate);\n      const end = this.formatDateDisplay(this.endDate);\n      this.dateRangeText.set(`${start} - ${end}`);\n    } else {\n      this.dateRangeText.set('');\n    }\n  }\n\n  toggleDatePicker(): void {\n    this.showDatePicker.update(value => !value);\n    if (this.showDatePicker()) {\n      this.selectingStartDate.set(true);\n      const currentMonthValue = this.currentMonth();\n      const year = this.dateAdapter.getYear(currentMonthValue);\n      const month = this.dateAdapter.getMonth(currentMonthValue);\n      const previousMonthDate = this.dateAdapter.createDate(year, month - 1, 1);\n      this.previousMonth.set(previousMonthDate);\n      this.generateCalendars();\n      // Initialize keyboard focus only if keyboard navigation is enabled\n      if (this.enableKeyboardNavigation) {\n        this.initializeFocus();\n      }\n    } else {\n      // Clear focus when closing\n      if (this.enableKeyboardNavigation) {\n        this.focusedDay.set(null);\n      }\n    }\n    this.onTouched();\n  }\n\n  closeDatePicker(): void {\n    this.showDatePicker.set(false);\n    if (this.enableKeyboardNavigation) {\n      this.focusedDay.set(null);\n    }\n    this.onTouched();\n  }\n\n  generateCalendars(): void {\n    this.previousMonthDays.set(this.generateMonthCalendar(this.previousMonth()));\n    this.currentMonthDays.set(this.generateMonthCalendar(this.currentMonth()));\n  }\n\n  generateMonthCalendar(date: Date): any[] {\n    const year = this.dateAdapter.getYear(date);\n    const month = this.dateAdapter.getMonth(date);\n    const firstDay = this.dateAdapter.createDate(year, month, 1);\n    const lastDay = this.dateAdapter.createDate(year, month + 1, 0);\n    const daysInMonth = this.dateAdapter.getDate(lastDay);\n    const firstDayOfWeek = this.dateAdapter.getDay(firstDay);\n\n    const monthDays = [];\n\n    for (let i = 0; i < firstDayOfWeek; i++) {\n      monthDays.push({ day: null, isCurrentMonth: false });\n    }\n\n    for (let day = 1; day <= daysInMonth; day++) {\n      const dayDate = this.dateAdapter.createDate(year, month, day);\n      const dateStr = this.formatDate(dayDate);\n      \n      // Check if date is in pending range (for requireApply mode)\n      const isPendingStart = this.requireApply && this.pendingStartDate === dateStr;\n      const isPendingEnd = this.requireApply && this.pendingEndDate === dateStr;\n      const inPendingRange = this.requireApply && this.pendingStartDate && this.pendingEndDate &&\n                             dateStr >= this.pendingStartDate && dateStr <= this.pendingEndDate;\n      \n      // Check if date is in hover preview range\n      const inHoverRange = this.isInHoverRange(dateStr);\n      \n      monthDays.push({\n        day: day,\n        date: dateStr,\n        isCurrentMonth: true,\n        isStart: this.startDate === dateStr || isPendingStart,\n        isEnd: this.endDate === dateStr || isPendingEnd,\n        inRange: this.isInRange(dateStr) || inPendingRange,\n        inHoverRange: inHoverRange,\n        isDisabled: this.isDateDisabled(dayDate)\n      });\n    }\n\n    return monthDays;\n  }\n\n  isInRange(dateStr: string): boolean {\n    if (this.multiRange) {\n      // Check if date is in any of the selected ranges\n      return this.selectedRanges().some(range => {\n        return dateStr >= range.startDate && dateStr <= range.endDate;\n      });\n    } else {\n      if (!this.startDate || !this.endDate) return false;\n      return dateStr >= this.startDate && dateStr <= this.endDate;\n    }\n  }\n\n  isDateDisabled(date: Date): boolean {\n    if (!this.disabledDates) return false;\n\n    if (typeof this.disabledDates === 'function') {\n      // If it's a function, call it with the date\n      return this.disabledDates(date);\n    } else if (Array.isArray(this.disabledDates)) {\n      // If it's an array, check if the date matches any disabled date\n      return this.disabledDates.some(disabledDate => {\n        return this.dateAdapter.getYear(date) === this.dateAdapter.getYear(disabledDate) &&\n               this.dateAdapter.getMonth(date) === this.dateAdapter.getMonth(disabledDate) &&\n               this.dateAdapter.getDate(date) === this.dateAdapter.getDate(disabledDate);\n      });\n    }\n    \n    return false;\n  }\n\n  isInHoverRange(dateStr: string): boolean {\n    const hover = this.hoverDate();\n    if (!hover) return false;\n\n    // In multiRange mode, only show hover preview when selecting end date\n    if (this.multiRange) {\n      if (this.selectingStartDate()) return false;\n      if (!this.startDate) return false;\n      const minDate = this.startDate < hover ? this.startDate : hover;\n      const maxDate = this.startDate > hover ? this.startDate : hover;\n      return dateStr >= minDate && dateStr <= maxDate;\n    } else {\n      // In single range mode with requireApply\n      if (this.requireApply) {\n        if (this.selectingStartDate()) return false;\n        if (!this.pendingStartDate) return false;\n        const minDate = this.pendingStartDate < hover ? this.pendingStartDate : hover;\n        const maxDate = this.pendingStartDate > hover ? this.pendingStartDate : hover;\n        return dateStr >= minDate && dateStr <= maxDate;\n      } else {\n        // In single range mode without requireApply\n        if (this.selectingStartDate()) return false;\n        if (!this.startDate) return false;\n        const minDate = this.startDate < hover ? this.startDate : hover;\n        const maxDate = this.startDate > hover ? this.startDate : hover;\n        return dateStr >= minDate && dateStr <= maxDate;\n      }\n    }\n  }\n\n  onDayHover(dayObj: any): void {\n    if (!dayObj.isCurrentMonth || this.isDisabled() || dayObj.isDisabled) {\n      this.hoverDate.set(null);\n      return;\n    }\n    this.hoverDate.set(dayObj.date);\n    this.generateCalendars();\n  }\n\n  clearDayHover(): void {\n    this.hoverDate.set(null);\n    this.generateCalendars();\n  }\n\n  selectDay(dayObj: any): void {\n    if (!dayObj.isCurrentMonth || this.isDisabled() || dayObj.isDisabled) return;\n\n    if (this.multiRange) {\n      // Multi-range mode: add ranges to array\n      if (this.selectingStartDate()) {\n        this.startDate = dayObj.date;\n        this.endDate = '';\n        this.dateRangeText.set('');\n        this.selectingStartDate.set(false);\n      } else {\n        if (dayObj.date < this.startDate) {\n          this.endDate = this.startDate;\n          this.startDate = dayObj.date;\n        } else {\n          this.endDate = dayObj.date;\n        }\n        \n        // Add the new range to the array\n        const newRange: DateRange = {\n          startDate: this.startDate,\n          endDate: this.endDate,\n          rangeText: this.formatDateDisplay(this.startDate) + ' – ' + this.formatDateDisplay(this.endDate)\n        };\n        \n        const currentRanges = [...this.selectedRanges()];\n        currentRanges.push(newRange);\n        this.selectedRanges.set(currentRanges);\n        \n        // Reset for next range selection\n        this.startDate = '';\n        this.endDate = '';\n        this.selectingStartDate.set(true);\n        \n        // Update display text\n        this.updateMultiRangeText();\n        \n        // Don't close if multiRange, allow adding more ranges\n        if (this.closeOnSelection && !this.multiRange) {\n          this.showDatePicker.set(false);\n        }\n        \n        this.emitMultiChange();\n        this.emitMultiSelection();\n      }\n      this.generateCalendars();\n    } else {\n      // Single range mode (original behavior)\n      if (this.requireApply) {\n        // Apply mode: use pending dates, don't emit until Apply is clicked\n        if (this.selectingStartDate()) {\n          this.pendingStartDate = dayObj.date;\n          this.pendingEndDate = '';\n          this.selectingStartDate.set(false);\n          this.hasPendingChanges.set(true);\n        } else {\n          if (dayObj.date < this.pendingStartDate) {\n            this.pendingEndDate = this.pendingStartDate;\n            this.pendingStartDate = dayObj.date;\n          } else {\n            this.pendingEndDate = dayObj.date;\n          }\n          this.selectingStartDate.set(true);\n          this.hasPendingChanges.set(true);\n        }\n        this.generateCalendars();\n      } else {\n        // Immediate mode: emit changes immediately\n        if (this.selectingStartDate()) {\n          this.startDate = dayObj.date;\n          this.endDate = '';\n          this.dateRangeText.set('');\n          this.selectingStartDate.set(false);\n          this.emitChange();\n        } else {\n          if (dayObj.date < this.startDate) {\n            this.endDate = this.startDate;\n            this.startDate = dayObj.date;\n          } else {\n            this.endDate = dayObj.date;\n          }\n          this.updateDateRangeText();\n          if (this.closeOnSelection) {\n            this.showDatePicker.set(false);\n          }\n          this.selectingStartDate.set(true);\n          this.emitChange();\n          this.emitSelection();\n        }\n        this.generateCalendars();\n      }\n    }\n  }\n\n  applySelection(): void {\n    if (!this.hasPendingChanges()) return;\n    \n    // Apply pending dates\n    this.startDate = this.pendingStartDate;\n    this.endDate = this.pendingEndDate;\n    this.updateDateRangeText();\n    \n    // Clear pending state\n    this.pendingStartDate = '';\n    this.pendingEndDate = '';\n    this.hasPendingChanges.set(false);\n    \n    // Emit changes\n    this.emitChange();\n    this.emitSelection();\n    \n    // Close picker\n    this.showDatePicker.set(false);\n    this.selectingStartDate.set(true);\n  }\n\n  cancelSelection(): void {\n    // Discard pending changes\n    this.pendingStartDate = '';\n    this.pendingEndDate = '';\n    this.hasPendingChanges.set(false);\n    this.selectingStartDate.set(true);\n    \n    // Regenerate calendars to clear pending visual state\n    this.generateCalendars();\n  }\n\n  changeMonth(direction: number): void {\n    const currentMonthValue = this.currentMonth();\n    const year = this.dateAdapter.getYear(currentMonthValue);\n    const month = this.dateAdapter.getMonth(currentMonthValue);\n    const newCurrentMonth = this.dateAdapter.createDate(year, month + direction, 1);\n    this.currentMonth.set(newCurrentMonth);\n    \n    const newYear = this.dateAdapter.getYear(newCurrentMonth);\n    const newMonth = this.dateAdapter.getMonth(newCurrentMonth);\n    const newPreviousMonth = this.dateAdapter.createDate(newYear, newMonth - 1, 1);\n    this.previousMonth.set(newPreviousMonth);\n    this.generateCalendars();\n  }\n\n  getMonthName(date: Date): string {\n    const monthNames = this.locale.monthNames || this.defaultMonthNames;\n    return `${monthNames[this.dateAdapter.getMonth(date)]} ${this.dateAdapter.getYear(date)}`;\n  }\n\n  getDayNames(): string[] {\n    return this.locale.dayNamesShort || this.defaultDayNamesShort;\n  }\n\n  selectPresetRange(preset: PresetConfig): void {\n    if (!preset.getValue) {\n      console.error('PresetConfig must have getValue() function');\n      return;\n    }\n\n    const range = preset.getValue();\n    this.startDate = range.start;\n    this.endDate = range.end;\n    this.updateDateRangeText();\n    this.generateCalendars();\n    if (this.closeOnPresetSelection) {\n      this.showDatePicker.set(false);\n    }\n    this.emitSelection();\n  }\n\n  clear(): void {\n    this.startDate = '';\n    this.endDate = '';\n    this.dateRangeText.set('');\n    this.showDatePicker.set(false);\n    this.selectingStartDate.set(true);\n    \n    if (this.multiRange) {\n      this.selectedRanges.set([]);\n      this.currentRangeIndex.set(-1);\n      this.emitMultiChange();\n    } else {\n      this.emitChange();\n    }\n    \n    this.onTouched();\n    this.generateCalendars();\n  }\n  \n  removeRange(index: number): void {\n    if (!this.multiRange) return;\n    \n    const currentRanges = [...this.selectedRanges()];\n    currentRanges.splice(index, 1);\n    this.selectedRanges.set(currentRanges);\n    \n    this.updateMultiRangeText();\n    this.emitMultiChange();\n    this.emitMultiSelection();\n    this.generateCalendars();\n  }\n  \n  private updateMultiRangeText(): void {\n    const count = this.selectedRanges().length;\n    if (count === 0) {\n      this.dateRangeText.set('');\n    } else if (count === 1) {\n      this.dateRangeText.set('1 range selected');\n    } else {\n      this.dateRangeText.set(`${count} ranges selected`);\n    }\n  }\n\n  private emitChange(): void {\n    const range: DateRange = {\n      startDate: this.startDate,\n      endDate: this.endDate,\n      rangeText: this.dateRangeText()\n    };\n    \n    if (this.enableTimePicker) {\n      range.startTime = this.formatTime(this.startHour, this.startMinute);\n      range.endTime = this.formatTime(this.endHour, this.endMinute);\n    }\n    \n    this.dateRangeChange.emit(range);\n  }\n\n  private emitSelection(): void {\n    const range: DateRange = {\n      startDate: this.startDate,\n      endDate: this.endDate,\n      rangeText: this.dateRangeText()\n    };\n    \n    if (this.enableTimePicker) {\n      range.startTime = this.formatTime(this.startHour, this.startMinute);\n      range.endTime = this.formatTime(this.endHour, this.endMinute);\n    }\n    \n    this.dateRangeSelected.emit(range);\n  }\n  \n  private emitMultiChange(): void {\n    this.multiDateRangeChange.emit({\n      ranges: this.selectedRanges()\n    });\n  }\n  \n  private emitMultiSelection(): void {\n    this.multiDateRangeSelected.emit({\n      ranges: this.selectedRanges()\n    });\n  }\n\n  private getDateRangeValue(): DateRange {\n    const range: DateRange = {\n      startDate: this.startDate,\n      endDate: this.endDate,\n      rangeText: this.dateRangeText()\n    };\n    \n    if (this.enableTimePicker) {\n      range.startTime = this.formatTime(this.startHour, this.startMinute);\n      range.endTime = this.formatTime(this.endHour, this.endMinute);\n    }\n    \n    return range;\n  }\n\n  // Time Picker Methods\n  toggleStartTimePicker(): void {\n    if (!this.enableTimePicker) return;\n    this.showStartTimePicker.set(!this.showStartTimePicker());\n    this.showEndTimePicker.set(false);\n  }\n\n  toggleEndTimePicker(): void {\n    if (!this.enableTimePicker) return;\n    this.showEndTimePicker.set(!this.showEndTimePicker());\n    this.showStartTimePicker.set(false);\n  }\n\n  incrementStartHour(): void {\n    this.startHour = (this.startHour + 1) % 24;\n    if (this.requireApply) {\n      this.hasPendingChanges.set(true);\n    } else {\n      this.emitChange();\n    }\n  }\n\n  decrementStartHour(): void {\n    this.startHour = this.startHour === 0 ? 23 : this.startHour - 1;\n    if (this.requireApply) {\n      this.hasPendingChanges.set(true);\n    } else {\n      this.emitChange();\n    }\n  }\n\n  incrementStartMinute(): void {\n    this.startMinute = (this.startMinute + this.minuteStep) % 60;\n    if (this.requireApply) {\n      this.hasPendingChanges.set(true);\n    } else {\n      this.emitChange();\n    }\n  }\n\n  decrementStartMinute(): void {\n    this.startMinute = this.startMinute - this.minuteStep;\n    if (this.startMinute < 0) {\n      this.startMinute = 60 - this.minuteStep;\n    }\n    if (this.requireApply) {\n      this.hasPendingChanges.set(true);\n    } else {\n      this.emitChange();\n    }\n  }\n\n  incrementEndHour(): void {\n    this.endHour = (this.endHour + 1) % 24;\n    if (this.requireApply) {\n      this.hasPendingChanges.set(true);\n    } else {\n      this.emitChange();\n    }\n  }\n\n  decrementEndHour(): void {\n    this.endHour = this.endHour === 0 ? 23 : this.endHour - 1;\n    if (this.requireApply) {\n      this.hasPendingChanges.set(true);\n    } else {\n      this.emitChange();\n    }\n  }\n\n  incrementEndMinute(): void {\n    this.endMinute = (this.endMinute + this.minuteStep) % 60;\n    if (this.requireApply) {\n      this.hasPendingChanges.set(true);\n    } else {\n      this.emitChange();\n    }\n  }\n\n  decrementEndMinute(): void {\n    this.endMinute = this.endMinute - this.minuteStep;\n    if (this.endMinute < 0) {\n      this.endMinute = 60 - this.minuteStep;\n    }\n    if (this.requireApply) {\n      this.hasPendingChanges.set(true);\n    } else {\n      this.emitChange();\n    }\n  }\n\n  formatTime(hour: number, minute: number): string {\n    const h = hour.toString().padStart(2, '0');\n    const m = minute.toString().padStart(2, '0');\n    \n    if (this.timeFormat === '12h') {\n      const isPM = hour >= 12;\n      const hour12 = hour === 0 ? 12 : hour > 12 ? hour - 12 : hour;\n      const period = isPM ? 'PM' : 'AM';\n      return `${hour12.toString().padStart(2, '0')}:${m} ${period}`;\n    }\n    \n    return `${h}:${m}`;\n  }\n\n  parseTime(timeString: string): { hour: number; minute: number } {\n    if (!timeString) return { hour: 0, minute: 0 };\n    \n    const time12hRegex = /^(\\d{1,2}):(\\d{2})\\s?(AM|PM)$/i;\n    const time24hRegex = /^(\\d{1,2}):(\\d{2})$/;\n    \n    let match = timeString.match(time12hRegex);\n    if (match) {\n      let hour = parseInt(match[1], 10);\n      const minute = parseInt(match[2], 10);\n      const period = match[3].toUpperCase();\n      \n      if (period === 'PM' && hour !== 12) hour += 12;\n      if (period === 'AM' && hour === 12) hour = 0;\n      \n      return { hour, minute };\n    }\n    \n    match = timeString.match(time24hRegex);\n    if (match) {\n      return {\n        hour: parseInt(match[1], 10),\n        minute: parseInt(match[2], 10)\n      };\n    }\n    \n    return { hour: 0, minute: 0 };\n  }\n\n  // ControlValueAccessor implementation\n  writeValue(value: DateRange | null): void {\n    if (value) {\n      this.startDate = value.startDate || '';\n      this.endDate = value.endDate || '';\n      \n      if (this.enableTimePicker) {\n        if (value.startTime) {\n          const startTime = this.parseTime(value.startTime);\n          this.startHour = startTime.hour;\n          this.startMinute = startTime.minute;\n        }\n        if (value.endTime) {\n          const endTime = this.parseTime(value.endTime);\n          this.endHour = endTime.hour;\n          this.endMinute = endTime.minute;\n        }\n      }\n      \n      if (this.startDate && this.endDate) {\n        this.updateDateRangeText();\n        this.generateCalendars();\n      }\n    } else {\n      this.startDate = '';\n      this.endDate = '';\n      this.dateRangeText.set('');\n    }\n  }\n\n  registerOnChange(fn: (value: DateRange | null) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.isDisabled.set(isDisabled);\n  }\n}\n","<div class=\"datepicker-wrapper\" \n  [class]=\"'theme-' + theme\"\n  [style.--input-border-hover]=\"inputBorderColorHover\"\n  [style.--input-border-focus]=\"inputBorderColorFocus\">\n  <input \n    type=\"text\" \n    class=\"datepicker-input\" \n    [value]=\"dateRangeText()\" \n    (click)=\"toggleDatePicker()\" \n    [placeholder]=\"placeholder\"\n    [disabled]=\"isDisabled()\"\n    [attr.aria-label]=\"placeholder\"\n    [attr.aria-expanded]=\"showDatePicker()\"\n    [attr.aria-haspopup]=\"'dialog'\"\n    role=\"combobox\"\n    [ngStyle]=\"{\n      'background-color': inputBackgroundColor,\n      'color': inputTextColor,\n      'border-color': inputBorderColor,\n      'padding': inputPadding\n    }\"\n    readonly>\n\n  @if (showDatePicker()) {\n  <div class=\"date-picker-dropdown\">\n    @if (showPresets) {\n    <div class=\"date-picker-presets\">\n      @for (preset of presets; track preset.label) {\n      <button type=\"button\" (click)=\"selectPresetRange(preset)\">{{ preset.label }}</button>\n      }\n      <button type=\"button\" class=\"btn-close-calendar\" (click)=\"closeDatePicker()\" title=\"Close\">\n        ×\n      </button>\n    </div>\n    }\n\n    @if (!showPresets) {\n    <div class=\"date-picker-header-only-close\">\n      <button type=\"button\" class=\"btn-close-calendar\" (click)=\"closeDatePicker()\" title=\"Close\">\n        ×\n      </button>\n    </div>\n    }\n\n    <!-- Calendars -->\n    <div class=\"date-picker-calendars\">\n      <!-- Previous month calendar -->\n      <div class=\"date-picker-calendar\">\n        <div class=\"date-picker-header\">\n          <button type=\"button\" (click)=\"changeMonth(-1)\">\n            <svg width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n              <path fill-rule=\"evenodd\" d=\"M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z\"/>\n            </svg>\n          </button>\n          <span>{{ previousMonthName() }}</span>\n          <button type=\"button\" style=\"visibility: hidden;\">\n            <svg width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n              <path fill-rule=\"evenodd\" d=\"M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z\"/>\n            </svg>\n          </button>\n        </div>\n        <div class=\"date-picker-weekdays\">\n          @for (dayName of weekDayNames(); track $index) {\n            <span>{{ dayName }}</span>\n          }\n        </div>\n        <div class=\"date-picker-days\">\n          @for (dayObj of previousMonthDays(); track dayObj.date || $index) {\n            <button \n              type=\"button\"\n              class=\"date-picker-day\" \n              [class.empty]=\"!dayObj.isCurrentMonth\"\n              [class.selected]=\"dayObj.isStart || dayObj.isEnd\"\n              [class.in-range]=\"dayObj.inRange && !dayObj.isStart && !dayObj.isEnd\"\n              [class.in-hover-range]=\"dayObj.inHoverRange && !dayObj.isStart && !dayObj.isEnd\"\n              [class.disabled]=\"dayObj.isDisabled\"\n              [class.keyboard-focused]=\"enableKeyboardNavigation && hasKeyboardFocus(dayObj.date, 0)\"\n              [attr.tabindex]=\"enableKeyboardNavigation && dayObj.isCurrentMonth && hasKeyboardFocus(dayObj.date, 0) ? 0 : -1\"\n              [attr.aria-label]=\"formatDateDisplay(dayObj.date)\"\n              [attr.aria-selected]=\"dayObj.isStart || dayObj.isEnd\"\n              [attr.aria-current]=\"dayObj.isStart ? 'date' : null\"\n              [attr.aria-disabled]=\"dayObj.isDisabled\"\n              (click)=\"selectDay(dayObj)\"\n              (mouseenter)=\"onDayHover(dayObj)\"\n              (mouseleave)=\"clearDayHover()\"\n              [disabled]=\"!dayObj.isCurrentMonth || dayObj.isDisabled\">\n              {{ dayObj.day }}\n            </button>\n          }\n        </div>\n      </div>\n\n      <!-- Current month calendar -->\n      <div class=\"date-picker-calendar\">\n        <div class=\"date-picker-header\">\n          <button type=\"button\" style=\"visibility: hidden;\">\n            <svg width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n              <path fill-rule=\"evenodd\" d=\"M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z\"/>\n            </svg>\n          </button>\n          <span>{{ currentMonthName() }}</span>\n          <button type=\"button\" (click)=\"changeMonth(1)\">\n            <svg width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n              <path fill-rule=\"evenodd\" d=\"M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z\"/>\n            </svg>\n          </button>\n        </div>\n        <div class=\"date-picker-weekdays\">\n          @for (dayName of weekDayNames(); track $index) {\n            <span>{{ dayName }}</span>\n          }\n        </div>\n        <div class=\"date-picker-days\">\n          @for (dayObj of currentMonthDays(); track dayObj.date || $index) {\n            <button \n              type=\"button\"\n              class=\"date-picker-day\" \n              [class.empty]=\"!dayObj.isCurrentMonth\"\n              [class.selected]=\"dayObj.isStart || dayObj.isEnd\"\n              [class.in-range]=\"dayObj.inRange && !dayObj.isStart && !dayObj.isEnd\"\n              [class.in-hover-range]=\"dayObj.inHoverRange && !dayObj.isStart && !dayObj.isEnd\"\n              [class.disabled]=\"dayObj.isDisabled\"\n              [class.keyboard-focused]=\"enableKeyboardNavigation && hasKeyboardFocus(dayObj.date, 1)\"\n              [attr.tabindex]=\"enableKeyboardNavigation && dayObj.isCurrentMonth && hasKeyboardFocus(dayObj.date, 1) ? 0 : -1\"\n              [attr.aria-label]=\"formatDateDisplay(dayObj.date)\"\n              [attr.aria-selected]=\"dayObj.isStart || dayObj.isEnd\"\n              [attr.aria-current]=\"dayObj.isStart ? 'date' : null\"\n              [attr.aria-disabled]=\"dayObj.isDisabled\"\n              (click)=\"selectDay(dayObj)\"\n              (mouseenter)=\"onDayHover(dayObj)\"\n              (mouseleave)=\"clearDayHover()\"\n              [disabled]=\"!dayObj.isCurrentMonth || dayObj.isDisabled\">\n              {{ dayObj.day }}\n            </button>\n          }\n        </div>\n      </div>\n    </div>\n\n    <!-- Multi-Range List -->\n    @if (multiRange && selectedRanges().length > 0) {\n    <div class=\"multi-range-list\">\n      <div class=\"multi-range-header\">\n        <span class=\"multi-range-title\">Selected Ranges ({{ selectedRanges().length }})</span>\n      </div>\n      <div class=\"multi-range-items\">\n        @for (range of selectedRanges(); track $index) {\n        <div class=\"multi-range-item\">\n          <span class=\"multi-range-text\">{{ range.rangeText }}</span>\n          <button \n            type=\"button\" \n            class=\"btn-remove-range\" \n            (click)=\"removeRange($index)\"\n            title=\"Remove this range\">\n            <svg width=\"14\" height=\"14\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n              <path d=\"M2.146 2.854a.5.5 0 1 1 .708-.708L8 7.293l5.146-5.147a.5.5 0 0 1 .708.708L8.707 8l5.147 5.146a.5.5 0 0 1-.708.708L8 8.707l-5.146 5.147a.5.5 0 0 1-.708-.708L7.293 8 2.146 2.854Z\"/>\n            </svg>\n          </button>\n        </div>\n        }\n      </div>\n    </div>\n    }\n\n    <!-- Time Picker -->\n    @if (enableTimePicker) {\n    <div class=\"time-picker-container\">\n      <!-- Start Time -->\n      <div class=\"time-picker-section\">\n        <div class=\"time-picker-label\">Start Time</div>\n        <div class=\"time-picker-inputs\">\n          <div class=\"time-input-group\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-up\" \n              (click)=\"incrementStartHour()\"\n              title=\"Increment hour\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 4.86l-4.796 5.481c-.566.647-.106 1.659.753 1.659h9.592a1 1 0 0 0 .753-1.659l-4.796-5.48a1 1 0 0 0-1.506 0z\"/>\n              </svg>\n            </button>\n            <input\n              type=\"text\"\n              class=\"time-input\"\n              [value]=\"startHour.toString().padStart(2, '0')\"\n              readonly\n              title=\"Start hour\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-down\" \n              (click)=\"decrementStartHour()\"\n              title=\"Decrement hour\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 11.14l-4.796-5.481C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z\"/>\n              </svg>\n            </button>\n          </div>\n          <span class=\"time-separator\">:</span>\n          <div class=\"time-input-group\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-up\" \n              (click)=\"incrementStartMinute()\"\n              title=\"Increment minute\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 4.86l-4.796 5.481c-.566.647-.106 1.659.753 1.659h9.592a1 1 0 0 0 .753-1.659l-4.796-5.48a1 1 0 0 0-1.506 0z\"/>\n              </svg>\n            </button>\n            <input\n              type=\"text\"\n              class=\"time-input\"\n              [value]=\"startMinute.toString().padStart(2, '0')\"\n              readonly\n              title=\"Start minute\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-down\" \n              (click)=\"decrementStartMinute()\"\n              title=\"Decrement minute\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 11.14l-4.796-5.481C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z\"/>\n              </svg>\n            </button>\n          </div>\n          @if (timeFormat === '12h') {\n          <div class=\"time-period\">\n            {{ startHour >= 12 ? 'PM' : 'AM' }}\n          </div>\n          }\n        </div>\n      </div>\n\n      <!-- Separator -->\n      <div class=\"time-separator-vertical\"></div>\n\n      <!-- End Time -->\n      <div class=\"time-picker-section\">\n        <div class=\"time-picker-label\">End Time</div>\n        <div class=\"time-picker-inputs\">\n          <div class=\"time-input-group\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-up\" \n              (click)=\"incrementEndHour()\"\n              title=\"Increment hour\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 4.86l-4.796 5.481c-.566.647-.106 1.659.753 1.659h9.592a1 1 0 0 0 .753-1.659l-4.796-5.48a1 1 0 0 0-1.506 0z\"/>\n              </svg>\n            </button>\n            <input\n              type=\"text\"\n              class=\"time-input\"\n              [value]=\"endHour.toString().padStart(2, '0')\"\n              readonly\n              title=\"End hour\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-down\" \n              (click)=\"decrementEndHour()\"\n              title=\"Decrement hour\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 11.14l-4.796-5.481C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z\"/>\n              </svg>\n            </button>\n          </div>\n          <span class=\"time-separator\">:</span>\n          <div class=\"time-input-group\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-up\" \n              (click)=\"incrementEndMinute()\"\n              title=\"Increment minute\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 4.86l-4.796 5.481c-.566.647-.106 1.659.753 1.659h9.592a1 1 0 0 0 .753-1.659l-4.796-5.48a1 1 0 0 0-1.506 0z\"/>\n              </svg>\n            </button>\n            <input\n              type=\"text\"\n              class=\"time-input\"\n              [value]=\"endMinute.toString().padStart(2, '0')\"\n              readonly\n              title=\"End minute\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-down\" \n              (click)=\"decrementEndMinute()\"\n              title=\"Decrement minute\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 11.14l-4.796-5.481C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z\"/>\n              </svg>\n            </button>\n          </div>\n          @if (timeFormat === '12h') {\n          <div class=\"time-period\">\n            {{ endHour >= 12 ? 'PM' : 'AM' }}\n          </div>\n          }\n        </div>\n      </div>\n    </div>\n    }\n\n    <!-- Footer with buttons -->\n    @if (showClearButton || multiRange || requireApply) {\n    <div class=\"date-picker-footer\">\n      @if (requireApply && !multiRange) {\n        <div class=\"apply-footer-actions\">\n          <button \n            type=\"button\" \n            class=\"btn-cancel\" \n            (click)=\"cancelSelection()\" \n            [disabled]=\"!hasPendingChanges()\"\n            title=\"Cancel selection\">\n            Cancel\n          </button>\n          <button \n            type=\"button\" \n            class=\"btn-apply\" \n            (click)=\"applySelection()\" \n            [disabled]=\"!hasPendingChanges() || !pendingStartDate || !pendingEndDate\"\n            title=\"Apply selection\">\n            Apply\n          </button>\n        </div>\n      }\n      @if (multiRange) {\n        <div class=\"multi-range-footer-actions\">\n          <button type=\"button\" class=\"btn-clear\" (click)=\"clear()\" title=\"Clear all ranges\">\n            Clear All\n          </button>\n          <button type=\"button\" class=\"btn-done\" (click)=\"closeDatePicker()\" title=\"Done selecting\">\n            Done\n          </button>\n        </div>\n      }\n      @if (!multiRange && !requireApply && showClearButton) {\n        <button type=\"button\" class=\"btn-clear\" (click)=\"clear()\" title=\"Clear selection\">\n          Clear\n        </button>\n      }\n    </div>\n    }\n  </div>\n  }\n</div>\n"]}
1149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dual-datepicker.component.js","sourceRoot":"","sources":["../../src/dual-datepicker.component.ts","../../src/dual-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges, HostListener, ElementRef, forwardRef, signal, computed, effect, inject } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule, ReactiveFormsModule, ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DateAdapter, DATE_ADAPTER } from './date-adapter';\nimport { NativeDateAdapter } from './native-date-adapter';\nimport { DualDateRangeStore } from './core/dual-date-range.store';\n\nexport interface DateRange {\n  startDate: string;\n  endDate: string;\n  rangeText: string;\n  startTime?: string; // HH:mm format (optional)\n  endTime?: string; // HH:mm format (optional)\n}\n\nexport interface MultiDateRange {\n  ranges: DateRange[];\n}\n\nexport interface PresetRange {\n  start: string;\n  end: string;\n}\n\nexport interface PresetConfig {\n  label: string;\n  getValue: () => PresetRange;\n}\n\nexport interface LocaleConfig {\n  monthNames?: string[];\n  monthNamesShort?: string[];\n  dayNames?: string[];\n  dayNamesShort?: string[];\n  firstDayOfWeek?: number; // 0 = Sunday, 1 = Monday, etc.\n}\n\nexport type ThemeType = 'default' | 'bootstrap' | 'bulma' | 'foundation' | 'tailwind' | 'custom';\n\n@Component({\n  selector: 'ngx-dual-datepicker',\n  standalone: true,\n  imports: [CommonModule, FormsModule, ReactiveFormsModule],\n  templateUrl: './dual-datepicker.component.html',\n  styleUrl: './dual-datepicker.component.scss',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DualDatepickerComponent),\n      multi: true\n    },\n    {\n      provide: DATE_ADAPTER,\n      useClass: NativeDateAdapter\n    }\n  ]\n})\nexport class DualDatepickerComponent implements OnInit, OnChanges, ControlValueAccessor {\n  @Input() placeholder: string = 'Select date range';\n  @Input() set startDate(value: string) {\n    if (value) {\n      const date = this.dateAdapter.parse(value);\n      if (date) this.rangeStore.setStart(date);\n    }\n  }\n  get startDate(): string {\n    const date = this.rangeStore.startDate();\n    return date ? this.formatDate(date) : '';\n  }\n  \n  @Input() set endDate(value: string) {\n    if (value) {\n      const date = this.dateAdapter.parse(value);\n      if (date) this.rangeStore.setEnd(date);\n    }\n  }\n  get endDate(): string {\n    const date = this.rangeStore.endDate();\n    return date ? this.formatDate(date) : '';\n  }\n  @Input() showPresets: boolean = true;\n  @Input() showClearButton: boolean = false;\n  @Input() multiRange: boolean = false;\n  @Input() closeOnSelection: boolean = true;\n  @Input() closeOnPresetSelection: boolean = true;\n  @Input() closeOnClickOutside: boolean = true;\n  @Input() enableKeyboardNavigation: boolean = true;\n  @Input() presets: PresetConfig[] = [];\n  @Input() theme: ThemeType = 'default';\n  @Input() inputBackgroundColor: string = '#fff';\n  @Input() inputTextColor: string = '#495057';\n  @Input() inputBorderColor: string = '#ced4da';\n  @Input() inputBorderColorHover: string = '#ced4da';\n  @Input() inputBorderColorFocus: string = '#80bdff';\n  @Input() inputPadding: string = '0.375rem 0.75rem';\n  @Input() locale: LocaleConfig = {};\n  @Input() disabledDates: Date[] | ((date: Date) => boolean) | undefined;\n  @Input() displayFormat: string = 'D MMM'; // Format for displaying dates in input\n  @Input() requireApply: boolean = false; // Require Apply button confirmation\n  @Input() enableTimePicker: boolean = false; // Enable time selection\n  @Input() timeFormat: '12h' | '24h' = '24h'; // Time format\n  @Input() minuteStep: number = 15; // Step for minute selector (1, 5, 15, 30)\n  @Input() defaultStartTime: string = '00:00'; // Default start time HH:mm\n  @Input() defaultEndTime: string = '23:59'; // Default end time HH:mm\n\n  @Output() dateRangeChange = new EventEmitter<DateRange>();\n  @Output() dateRangeSelected = new EventEmitter<DateRange>();\n  @Output() multiDateRangeChange = new EventEmitter<MultiDateRange>();\n  @Output() multiDateRangeSelected = new EventEmitter<MultiDateRange>();\n\n  // Date adapter injection\n  private dateAdapter = inject<DateAdapter>(DATE_ADAPTER);\n  \n  // Headless store for date range state (v3.5.0+)\n  protected readonly rangeStore = inject(DualDateRangeStore);\n\n  // UI-only signals\n  showDatePicker = signal(false);\n  currentMonth = signal(this.dateAdapter.today());\n  previousMonth = signal(this.dateAdapter.today());\n  currentMonthDays = signal<any[]>([]);\n  previousMonthDays = signal<any[]>([]);\n  isDisabled = signal(false);\n  showStartTimePicker = signal(false);\n  showEndTimePicker = signal(false);\n  hoverDate = signal<string | null>(null);\n  \n  // Computed time properties from store\n  get startHour(): number {\n    const time = this.rangeStore.startTime();\n    return this.parseTime(time).hour;\n  }\n  \n  get startMinute(): number {\n    const time = this.rangeStore.startTime();\n    return this.parseTime(time).minute;\n  }\n  \n  get endHour(): number {\n    const time = this.rangeStore.endTime();\n    return this.parseTime(time).hour;\n  }\n  \n  get endMinute(): number {\n    const time = this.rangeStore.endTime();\n    return this.parseTime(time).minute;\n  }\n  \n  private setStartHourMinute(hour: number, minute: number): void {\n    const timeStr = this.formatTime(hour, minute);\n    this.rangeStore.setStartTime(timeStr);\n  }\n  \n  private setEndHourMinute(hour: number, minute: number): void {\n    const timeStr = this.formatTime(hour, minute);\n    this.rangeStore.setEndTime(timeStr);\n  }\n  \n  // Multi-range support (UI-specific)\n  selectedRanges = signal<DateRange[]>([]);\n  currentRangeIndex = signal<number>(-1);\n\n  // Keyboard navigation (UI-specific)\n  focusedDay = signal<{ date: string; monthIndex: number } | null>(null);\n  \n  // Computed values\n  currentMonthName = computed(() => this.getMonthName(this.currentMonth()));\n  previousMonthName = computed(() => this.getMonthName(this.previousMonth()));\n  weekDayNames = computed(() => this.getDayNames());\n  \n  // Computed from store\n  dateRangeText = computed(() => this.rangeStore.rangeText());\n  selectingStartDate = computed(() => this.rangeStore.selectingStart());\n  hasPendingChanges = computed(() => this.rangeStore.hasPendingChanges());\n  \n  // Computed for template access to pending dates (requireApply mode)\n  get pendingStartDate(): string {\n    // In requireApply mode, store keeps pending values\n    // For now, use actual store values as pending (store handles this)\n    if (!this.requireApply) return '';\n    const date = this.rangeStore.startDate();\n    return date && this.hasPendingChanges() ? this.formatDate(date) : '';\n  }\n  \n  get pendingEndDate(): string {\n    if (!this.requireApply) return '';\n    const date = this.rangeStore.endDate();\n    return date && this.hasPendingChanges() ? this.formatDate(date) : '';\n  }\n\n  private readonly defaultMonthNames = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];\n  private readonly defaultMonthNamesShort = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];\n  private readonly defaultDayNames = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];\n  private readonly defaultDayNamesShort = ['S', 'M', 'T', 'W', 'T', 'F', 'S'];\n\n  // ControlValueAccessor callbacks\n  private onChange: (value: DateRange | null) => void = () => {};\n  private onTouched: () => void = () => {};\n\n  constructor(private elementRef: ElementRef) {\n    // Effect to emit changes when dates change in store\n    effect(() => {\n      const range = this.rangeStore.range();\n      if (range.start || range.end) {\n        this.onChange(this.getDateRangeValue());\n      }\n    });\n  }\n\n  @HostListener('document:click', ['$event'])\n  onClickOutside(event: MouseEvent): void {\n    if (this.showDatePicker() && this.closeOnClickOutside) {\n      const clickedInside = this.elementRef.nativeElement.contains(event.target);\n      if (!clickedInside) {\n        this.closeDatePicker();\n      }\n    }\n  }\n\n  @HostListener('keydown', ['$event'])\n  handleKeyboardNavigation(event: KeyboardEvent): void {\n    if (!this.enableKeyboardNavigation) {\n      return;\n    }\n\n    if (!this.showDatePicker()) {\n      // When picker is closed, allow Enter/Space to open it\n      if (event.key === 'Enter' || event.key === ' ') {\n        const target = event.target as HTMLElement;\n        if (target.classList.contains('datepicker-input')) {\n          event.preventDefault();\n          this.toggleDatePicker();\n        }\n      }\n      return;\n    }\n\n    // When picker is open\n    switch (event.key) {\n      case 'Escape':\n        event.preventDefault();\n        this.closeDatePicker();\n        break;\n\n      case 'ArrowUp':\n        event.preventDefault();\n        this.moveFocusVertical(-1);\n        break;\n\n      case 'ArrowDown':\n        event.preventDefault();\n        this.moveFocusVertical(1);\n        break;\n\n      case 'ArrowLeft':\n        event.preventDefault();\n        this.moveFocusHorizontal(-1);\n        break;\n\n      case 'ArrowRight':\n        event.preventDefault();\n        this.moveFocusHorizontal(1);\n        break;\n\n      case 'Enter':\n      case ' ':\n        event.preventDefault();\n        this.selectFocusedDay();\n        break;\n\n      case 'Home':\n        event.preventDefault();\n        this.moveFocusToFirstDay();\n        break;\n\n      case 'End':\n        event.preventDefault();\n        this.moveFocusToLastDay();\n        break;\n\n      case 'PageUp':\n        event.preventDefault();\n        if (event.shiftKey) {\n          this.moveFocusYear(-1);\n        } else {\n          this.changeMonth(-1);\n          this.adjustFocusAfterMonthChange();\n        }\n        break;\n\n      case 'PageDown':\n        event.preventDefault();\n        if (event.shiftKey) {\n          this.moveFocusYear(1);\n        } else {\n          this.changeMonth(1);\n          this.adjustFocusAfterMonthChange();\n        }\n        break;\n    }\n  }\n\n  // Keyboard navigation methods\n  private initializeFocus(): void {\n    // Set initial focus to start date, end date, or first available day\n    if (this.startDate) {\n      const inPrevMonth = this.isDateInMonth(this.startDate, this.previousMonth());\n      const inCurrMonth = this.isDateInMonth(this.startDate, this.currentMonth());\n      \n      if (inPrevMonth || inCurrMonth) {\n        this.focusedDay.set({ date: this.startDate, monthIndex: inPrevMonth ? 0 : 1 });\n      } else {\n        // startDate is not visible, focus on today if visible\n        const today = this.dateAdapter.format(this.dateAdapter.today(), 'yyyy-MM-dd');\n        const inCurrMonth = this.isDateInMonth(today, this.currentMonth());\n        \n        if (inCurrMonth) {\n          this.focusedDay.set({ date: today, monthIndex: 1 });\n        } else {\n          const currentMonthDays = this.currentMonthDays();\n          const firstDay = currentMonthDays.find(day => day.isCurrentMonth);\n          if (firstDay) {\n            this.focusedDay.set({ date: firstDay.date, monthIndex: 1 });\n          }\n        }\n      }\n    } else if (this.endDate) {\n      const inPrevMonth = this.isDateInMonth(this.endDate, this.previousMonth());\n      const inCurrMonth = this.isDateInMonth(this.endDate, this.currentMonth());\n      \n      if (inPrevMonth || inCurrMonth) {\n        this.focusedDay.set({ date: this.endDate, monthIndex: inPrevMonth ? 0 : 1 });\n      } else {\n        // endDate is not visible, focus on today if visible\n        const today = this.dateAdapter.format(this.dateAdapter.today(), 'yyyy-MM-dd');\n        const inCurrMonth = this.isDateInMonth(today, this.currentMonth());\n        \n        if (inCurrMonth) {\n          this.focusedDay.set({ date: today, monthIndex: 1 });\n        } else {\n          const currentMonthDays = this.currentMonthDays();\n          const firstDay = currentMonthDays.find(day => day.isCurrentMonth);\n          if (firstDay) {\n            this.focusedDay.set({ date: firstDay.date, monthIndex: 1 });\n          }\n        }\n      }\n    } else {\n      // Focus on today if visible, otherwise first day of current month\n      const today = this.dateAdapter.format(this.dateAdapter.today(), 'yyyy-MM-dd');\n      const inCurrMonth = this.isDateInMonth(today, this.currentMonth());\n      \n      if (inCurrMonth) {\n        this.focusedDay.set({ date: today, monthIndex: 1 });\n      } else {\n        // Today is not in current month, focus on first day of current month\n        const currentMonthDays = this.currentMonthDays();\n        const firstDay = currentMonthDays.find(day => day.isCurrentMonth);\n        if (firstDay) {\n          this.focusedDay.set({ date: firstDay.date, monthIndex: 1 });\n        }\n      }\n    }\n  }\n\n  private isDateInMonth(dateStr: string, monthDate: Date): boolean {\n    const date = this.dateAdapter.parse(dateStr);\n    if (!date) return false;\n    const year = this.dateAdapter.getYear(date);\n    const month = this.dateAdapter.getMonth(date);\n    const monthYear = this.dateAdapter.getYear(monthDate);\n    const monthMonth = this.dateAdapter.getMonth(monthDate);\n    return year === monthYear && month === monthMonth;\n  }\n\n  private moveFocusHorizontal(direction: number): void {\n    const focused = this.focusedDay();\n    if (!focused) {\n      this.initializeFocus();\n      return;\n    }\n\n    const currentDate = this.dateAdapter.parse(focused.date);\n    if (!currentDate) return;\n\n    const newDate = this.dateAdapter.addDays(currentDate, direction);\n    const newDateStr = this.formatDate(newDate);\n\n    // Determine which month the new date belongs to\n    let inPrevMonth = this.isDateInMonth(newDateStr, this.previousMonth());\n    let inCurrMonth = this.isDateInMonth(newDateStr, this.currentMonth());\n\n    if (inPrevMonth || inCurrMonth) {\n      this.focusedDay.set({ \n        date: newDateStr, \n        monthIndex: inPrevMonth ? 0 : 1 \n      });\n    } else {\n      // Date is outside visible months, navigate month\n      if (direction > 0) {\n        this.changeMonth(1);\n      } else {\n        this.changeMonth(-1);\n      }\n      \n      // Recalculate after month change\n      inPrevMonth = this.isDateInMonth(newDateStr, this.previousMonth());\n      inCurrMonth = this.isDateInMonth(newDateStr, this.currentMonth());\n      \n      this.focusedDay.set({ \n        date: newDateStr, \n        monthIndex: inPrevMonth ? 0 : (inCurrMonth ? 1 : 0)\n      });\n    }\n  }\n\n  private moveFocusVertical(direction: number): void {\n    const focused = this.focusedDay();\n    if (!focused) {\n      this.initializeFocus();\n      return;\n    }\n\n    const currentDate = this.dateAdapter.parse(focused.date);\n    if (!currentDate) return;\n\n    const newDate = this.dateAdapter.addDays(currentDate, direction * 7); // Move by week\n    const newDateStr = this.formatDate(newDate);\n\n    let inPrevMonth = this.isDateInMonth(newDateStr, this.previousMonth());\n    let inCurrMonth = this.isDateInMonth(newDateStr, this.currentMonth());\n\n    if (inPrevMonth || inCurrMonth) {\n      this.focusedDay.set({ \n        date: newDateStr, \n        monthIndex: inPrevMonth ? 0 : 1 \n      });\n    } else {\n      // Navigate to month containing the new date\n      if (direction > 0) {\n        this.changeMonth(1);\n      } else {\n        this.changeMonth(-1);\n      }\n      \n      // Recalculate after month change\n      inPrevMonth = this.isDateInMonth(newDateStr, this.previousMonth());\n      inCurrMonth = this.isDateInMonth(newDateStr, this.currentMonth());\n      \n      this.focusedDay.set({ \n        date: newDateStr, \n        monthIndex: inPrevMonth ? 0 : (inCurrMonth ? 1 : 0)\n      });\n    }\n  }\n\n  private moveFocusToFirstDay(): void {\n    const prevMonthDays = this.previousMonthDays();\n    const firstDay = prevMonthDays.find(day => day.isCurrentMonth);\n    if (firstDay) {\n      this.focusedDay.set({ date: firstDay.date, monthIndex: 0 });\n    }\n  }\n\n  private moveFocusToLastDay(): void {\n    const currMonthDays = this.currentMonthDays();\n    const validDays = currMonthDays.filter(day => day.isCurrentMonth);\n    const lastDay = validDays[validDays.length - 1];\n    if (lastDay) {\n      this.focusedDay.set({ date: lastDay.date, monthIndex: 1 });\n    }\n  }\n\n  private moveFocusYear(direction: number): void {\n    const focused = this.focusedDay();\n    if (!focused) {\n      this.initializeFocus();\n      return;\n    }\n\n    const currentDate = this.dateAdapter.parse(focused.date);\n    if (!currentDate) return;\n\n    const currentYear = this.dateAdapter.getYear(currentDate);\n    const currentMonth = this.dateAdapter.getMonth(currentDate);\n    const currentDay = this.dateAdapter.getDate(currentDate);\n    \n    const newDate = this.dateAdapter.createDate(currentYear + direction, currentMonth, currentDay);\n    const newDateStr = this.formatDate(newDate);\n\n    // Update months to show the new year\n    this.currentMonth.set(this.dateAdapter.createDate(currentYear + direction, currentMonth, 1));\n    this.previousMonth.set(this.dateAdapter.createDate(currentYear + direction, currentMonth - 1, 1));\n    this.generateCalendars();\n\n    const inPrevMonth = this.isDateInMonth(newDateStr, this.previousMonth());\n    this.focusedDay.set({ \n      date: newDateStr, \n      monthIndex: inPrevMonth ? 0 : 1 \n    });\n  }\n\n  private adjustFocusAfterMonthChange(): void {\n    const focused = this.focusedDay();\n    if (!focused) return;\n\n    const inPrevMonth = this.isDateInMonth(focused.date, this.previousMonth());\n    const inCurrMonth = this.isDateInMonth(focused.date, this.currentMonth());\n\n    if (!inPrevMonth && !inCurrMonth) {\n      // Focused day is no longer visible, move to equivalent day in visible months\n      this.initializeFocus();\n    } else {\n      // Update month index if needed\n      this.focusedDay.set({\n        date: focused.date,\n        monthIndex: inPrevMonth ? 0 : 1\n      });\n    }\n  }\n\n  private selectFocusedDay(): void {\n    const focused = this.focusedDay();\n    if (!focused) return;\n\n    const monthDays = focused.monthIndex === 0 ? this.previousMonthDays() : this.currentMonthDays();\n    const dayObj = monthDays.find(day => day.date === focused.date && day.isCurrentMonth);\n    \n    if (dayObj) {\n      this.selectDay(dayObj);\n    }\n  }\n\n  hasKeyboardFocus(date: string, monthIndex: number): boolean {\n    const focused = this.focusedDay();\n    return focused !== null && focused.date === date && focused.monthIndex === monthIndex;\n  }\n\n  ngOnInit(): void {\n    // Configure the headless store\n    this.rangeStore.configure({\n      enableTimePicker: this.enableTimePicker,\n      defaultStartTime: this.defaultStartTime,\n      defaultEndTime: this.defaultEndTime,\n      disabledDates: this.disabledDates\n    });\n    \n    // Initialize dates in store if provided\n    if (this.startDate) {\n      const date = this.dateAdapter.parse(this.startDate);\n      if (date) this.rangeStore.setStart(date);\n    }\n    if (this.endDate) {\n      const date = this.dateAdapter.parse(this.endDate);\n      if (date) this.rangeStore.setEnd(date);\n    }\n    \n    if (this.startDate && this.endDate) {\n      this.generateCalendars();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['startDate'] || changes['endDate']) {\n      // Sync with store\n      if (changes['startDate'] && this.startDate) {\n        const date = this.dateAdapter.parse(this.startDate);\n        if (date) this.rangeStore.setStart(date);\n      }\n      if (changes['endDate'] && this.endDate) {\n        const date = this.dateAdapter.parse(this.endDate);\n        if (date) this.rangeStore.setEnd(date);\n      }\n      \n      if (this.startDate && this.endDate) {\n        this.generateCalendars();\n      }\n    }\n    \n    // Update store configuration if relevant inputs change\n    if (changes['enableTimePicker'] || changes['defaultStartTime'] || \n        changes['defaultEndTime'] || changes['disabledDates']) {\n      this.rangeStore.configure({\n        enableTimePicker: this.enableTimePicker,\n        defaultStartTime: this.defaultStartTime,\n        defaultEndTime: this.defaultEndTime,\n        disabledDates: this.disabledDates\n      });\n    }\n  }\n\n  formatDate(date: Date): string {\n    const year = this.dateAdapter.getYear(date);\n    const month = String(this.dateAdapter.getMonth(date) + 1).padStart(2, '0');\n    const day = String(this.dateAdapter.getDate(date)).padStart(2, '0');\n    return `${year}-${month}-${day}`;\n  }\n\n  formatDateDisplay(dateStr: string): string {\n    if (!dateStr) return '';\n    const date = this.dateAdapter.parse(dateStr);\n    if (!date) return '';\n    \n    const year = this.dateAdapter.getYear(date);\n    const month = this.dateAdapter.getMonth(date);\n    const day = this.dateAdapter.getDate(date);\n    \n    const monthNames = this.locale.monthNames || this.defaultMonthNames;\n    const monthNamesShort = this.locale.monthNamesShort || this.defaultMonthNamesShort;\n    \n    // Replace format tokens with values\n    let formatted = this.displayFormat;\n    \n    // Year tokens\n    formatted = formatted.replace(/YYYY/g, String(year));\n    formatted = formatted.replace(/YY/g, String(year).slice(-2));\n    \n    // Month tokens (order matters: MMMM before MMM before MM before M)\n    formatted = formatted.replace(/MMMM/g, monthNames[month]);\n    formatted = formatted.replace(/MMM/g, monthNamesShort[month]);\n    formatted = formatted.replace(/MM/g, String(month + 1).padStart(2, '0'));\n    formatted = formatted.replace(/M/g, String(month + 1));\n    \n    // Day tokens (order matters: DD before D)\n    formatted = formatted.replace(/DD/g, String(day).padStart(2, '0'));\n    formatted = formatted.replace(/D/g, String(day));\n    \n    return formatted;\n  }\n\n  // Note: updateDateRangeText is now handled by computed dateRangeText from store\n  // Keeping this method for backward compatibility but it's a no-op\n  updateDateRangeText(): void {\n    // Text is now automatically computed from store.rangeText()\n  }\n\n  toggleDatePicker(): void {\n    this.showDatePicker.update(value => !value);\n    if (this.showDatePicker()) {\n      // selectingStart is managed by store, no need to set here\n      const currentMonthValue = this.currentMonth();\n      const year = this.dateAdapter.getYear(currentMonthValue);\n      const month = this.dateAdapter.getMonth(currentMonthValue);\n      const previousMonthDate = this.dateAdapter.createDate(year, month - 1, 1);\n      this.previousMonth.set(previousMonthDate);\n      this.generateCalendars();\n      // Initialize keyboard focus only if keyboard navigation is enabled\n      if (this.enableKeyboardNavigation) {\n        this.initializeFocus();\n      }\n    } else {\n      // Clear focus when closing\n      if (this.enableKeyboardNavigation) {\n        this.focusedDay.set(null);\n      }\n    }\n    this.onTouched();\n  }\n\n  closeDatePicker(): void {\n    this.showDatePicker.set(false);\n    if (this.enableKeyboardNavigation) {\n      this.focusedDay.set(null);\n    }\n    this.onTouched();\n  }\n\n  generateCalendars(): void {\n    this.previousMonthDays.set(this.generateMonthCalendar(this.previousMonth()));\n    this.currentMonthDays.set(this.generateMonthCalendar(this.currentMonth()));\n  }\n\n  generateMonthCalendar(date: Date): any[] {\n    const year = this.dateAdapter.getYear(date);\n    const month = this.dateAdapter.getMonth(date);\n    const firstDay = this.dateAdapter.createDate(year, month, 1);\n    const lastDay = this.dateAdapter.createDate(year, month + 1, 0);\n    const daysInMonth = this.dateAdapter.getDate(lastDay);\n    const firstDayOfWeek = this.dateAdapter.getDay(firstDay);\n\n    const monthDays = [];\n\n    for (let i = 0; i < firstDayOfWeek; i++) {\n      monthDays.push({ day: null, isCurrentMonth: false });\n    }\n\n    for (let day = 1; day <= daysInMonth; day++) {\n      const dayDate = this.dateAdapter.createDate(year, month, day);\n      const dateStr = this.formatDate(dayDate);\n      \n       // Get pending dates from store (for requireApply mode)\n      const pendingStart = this.rangeStore.startDate(); // In pending mode, store holds pending values\n      const pendingEnd = this.rangeStore.endDate();\n      const pendingStartStr = pendingStart ? this.formatDate(pendingStart) : '';\n      const pendingEndStr = pendingEnd ? this.formatDate(pendingEnd) : '';\n      \n      const isPendingStart = this.requireApply && pendingStartStr === dateStr;\n      const isPendingEnd = this.requireApply && pendingEndStr === dateStr;\n      const inPendingRange = this.requireApply && pendingStartStr && pendingEndStr &&\n                             dateStr >= pendingStartStr && dateStr <= pendingEndStr;\n      \n      // Check if date is in hover preview range\n      const inHoverRange = this.isInHoverRange(dateStr);\n      \n      monthDays.push({\n        day: day,\n        date: dateStr,\n        isCurrentMonth: true,\n        isStart: this.startDate === dateStr || isPendingStart,\n        isEnd: this.endDate === dateStr || isPendingEnd,\n        inRange: this.isInRange(dateStr) || inPendingRange,\n        inHoverRange: inHoverRange,\n        isDisabled: this.isDateDisabled(dayDate)\n      });\n    }\n\n    return monthDays;\n  }\n\n  isInRange(dateStr: string): boolean {\n    if (this.multiRange) {\n      // Check if date is in any of the selected ranges\n      return this.selectedRanges().some(range => {\n        return dateStr >= range.startDate && dateStr <= range.endDate;\n      });\n    } else {\n      if (!this.startDate || !this.endDate) return false;\n      return dateStr >= this.startDate && dateStr <= this.endDate;\n    }\n  }\n\n  isDateDisabled(date: Date): boolean {\n    if (!this.disabledDates) return false;\n\n    if (typeof this.disabledDates === 'function') {\n      // If it's a function, call it with the date\n      return this.disabledDates(date);\n    } else if (Array.isArray(this.disabledDates)) {\n      // If it's an array, check if the date matches any disabled date\n      return this.disabledDates.some(disabledDate => {\n        return this.dateAdapter.getYear(date) === this.dateAdapter.getYear(disabledDate) &&\n               this.dateAdapter.getMonth(date) === this.dateAdapter.getMonth(disabledDate) &&\n               this.dateAdapter.getDate(date) === this.dateAdapter.getDate(disabledDate);\n      });\n    }\n    \n    return false;\n  }\n\n  isInHoverRange(dateStr: string): boolean {\n    const hover = this.hoverDate();\n    if (!hover) return false;\n\n    // In multiRange mode, only show hover preview when selecting end date\n    if (this.multiRange) {\n      if (this.selectingStartDate()) return false;\n      const currentStart = this.startDate;\n      if (!currentStart) return false;\n      const minDate = currentStart < hover ? currentStart : hover;\n      const maxDate = currentStart > hover ? currentStart : hover;\n      return dateStr >= minDate && dateStr <= maxDate;\n    } else {\n      // In single range mode  \n      if (this.selectingStartDate()) return false;\n      \n      if (this.requireApply) {\n        // Use pending dates from store\n        const pendingStart = this.rangeStore.startDate();\n        if (!pendingStart) return false;\n        const pendingStartStr = this.formatDate(pendingStart);\n        const minDate = pendingStartStr < hover ? pendingStartStr : hover;\n        const maxDate = pendingStartStr > hover ? pendingStartStr : hover;\n        return dateStr >= minDate && dateStr <= maxDate;\n      } else {\n        // Use actual dates\n        const currentStart = this.startDate;\n        if (!currentStart) return false;\n        const minDate = currentStart < hover ? currentStart : hover;\n        const maxDate = currentStart > hover ? currentStart : hover;\n        return dateStr >= minDate && dateStr <= maxDate;\n      }\n    }\n  }\n\n  onDayHover(dayObj: any): void {\n    if (!dayObj.isCurrentMonth || this.isDisabled() || dayObj.isDisabled) {\n      this.hoverDate.set(null);\n      return;\n    }\n    this.hoverDate.set(dayObj.date);\n    this.generateCalendars();\n  }\n\n  clearDayHover(): void {\n    this.hoverDate.set(null);\n    this.generateCalendars();\n  }\n\n  selectDay(dayObj: any): void {\n    if (!dayObj.isCurrentMonth || this.isDisabled() || dayObj.isDisabled) return;\n    \n    const selectedDate = this.dateAdapter.parse(dayObj.date);\n    if (!selectedDate) return;\n\n    if (this.multiRange) {\n      // Multi-range mode: add ranges to array\n      if (this.selectingStartDate()) {\n        this.rangeStore.setStart(selectedDate);\n        this.rangeStore.setEnd(null);\n      } else {\n        const currentStart = this.rangeStore.startDate();\n        if (currentStart && selectedDate < currentStart) {\n          // Swap: selected becomes start, current start becomes end\n          this.rangeStore.setStart(selectedDate);\n          this.rangeStore.setEnd(currentStart);\n        } else {\n          this.rangeStore.setEnd(selectedDate);\n        }\n        \n        // Add the new range to the array\n        const range = this.rangeStore.range();\n        const newRange: DateRange = {\n          startDate: range.start,\n          endDate: range.end,\n          rangeText: this.formatDateDisplay(range.start) + ' – ' + this.formatDateDisplay(range.end),\n          ...(this.enableTimePicker && { startTime: range.startTime, endTime: range.endTime })\n        };\n        \n        const currentRanges = [...this.selectedRanges()];\n        currentRanges.push(newRange);\n        this.selectedRanges.set(currentRanges);\n        \n        // Reset for next range selection\n        this.rangeStore.reset();\n        \n        // Update display text\n        this.updateMultiRangeText();\n        \n        // Don't close if multiRange, allow adding more ranges\n        if (this.closeOnSelection && !this.multiRange) {\n          this.showDatePicker.set(false);\n        }\n        \n        this.emitMultiChange();\n        this.emitMultiSelection();\n      }\n      this.generateCalendars();\n    } else {\n      // Single range mode\n      if (this.requireApply) {\n        // Apply mode: use pending dates, don't emit until Apply is clicked\n        if (this.selectingStartDate()) {\n          this.rangeStore.setPendingStart(selectedDate);\n          this.rangeStore.setPendingEnd(null);\n        } else {\n          const pendingStart = this.rangeStore.startDate();\n          if (pendingStart && selectedDate < pendingStart) {\n            // Swap\n            this.rangeStore.setPendingStart(selectedDate);\n            this.rangeStore.setPendingEnd(pendingStart);\n          } else {\n            this.rangeStore.setPendingEnd(selectedDate);\n          }\n        }\n        this.generateCalendars();\n      } else {\n        // Immediate mode: emit changes immediately\n        if (this.selectingStartDate()) {\n          this.rangeStore.setStart(selectedDate);\n          this.rangeStore.setEnd(null);\n          this.emitChange();\n        } else {\n          const currentStart = this.rangeStore.startDate();\n          if (currentStart && selectedDate < currentStart) {\n            // Swap\n            this.rangeStore.setStart(selectedDate);\n            this.rangeStore.setEnd(currentStart);\n          } else {\n            this.rangeStore.setEnd(selectedDate);\n          }\n          \n          if (this.closeOnSelection) {\n            this.showDatePicker.set(false);\n          }\n          this.emitChange();\n          this.emitSelection();\n        }\n        this.generateCalendars();\n      }\n    }\n  }\n\n  applySelection(): void {\n    if (!this.hasPendingChanges()) return;\n    \n    // Apply pending dates through store\n    this.rangeStore.applyPending();\n    \n    // Emit changes\n    this.emitChange();\n    this.emitSelection();\n    \n    // Close picker\n    this.showDatePicker.set(false);\n  }\n\n  cancelSelection(): void {\n    // Discard pending changes through store\n    this.rangeStore.cancelPending();\n    \n    // Regenerate calendars to clear pending visual state\n    this.generateCalendars();\n  }\n\n  changeMonth(direction: number): void {\n    const currentMonthValue = this.currentMonth();\n    const year = this.dateAdapter.getYear(currentMonthValue);\n    const month = this.dateAdapter.getMonth(currentMonthValue);\n    const newCurrentMonth = this.dateAdapter.createDate(year, month + direction, 1);\n    this.currentMonth.set(newCurrentMonth);\n    \n    const newYear = this.dateAdapter.getYear(newCurrentMonth);\n    const newMonth = this.dateAdapter.getMonth(newCurrentMonth);\n    const newPreviousMonth = this.dateAdapter.createDate(newYear, newMonth - 1, 1);\n    this.previousMonth.set(newPreviousMonth);\n    this.generateCalendars();\n  }\n\n  getMonthName(date: Date): string {\n    const monthNames = this.locale.monthNames || this.defaultMonthNames;\n    return `${monthNames[this.dateAdapter.getMonth(date)]} ${this.dateAdapter.getYear(date)}`;\n  }\n\n  getDayNames(): string[] {\n    return this.locale.dayNamesShort || this.defaultDayNamesShort;\n  }\n\n  selectPresetRange(preset: PresetConfig): void {\n    if (!preset.getValue) {\n      console.error('PresetConfig must have getValue() function');\n      return;\n    }\n\n    const range = preset.getValue();\n    const startDate = this.dateAdapter.parse(range.start);\n    const endDate = this.dateAdapter.parse(range.end);\n    \n    if (startDate && endDate) {\n      this.rangeStore.setRange(startDate, endDate);\n    }\n    \n    this.generateCalendars();\n    if (this.closeOnPresetSelection) {\n      this.showDatePicker.set(false);\n    }\n    this.emitSelection();\n  }\n\n  clear(): void {\n    this.rangeStore.reset();\n    this.showDatePicker.set(false);\n    \n    if (this.multiRange) {\n      this.selectedRanges.set([]);\n      this.currentRangeIndex.set(-1);\n      this.emitMultiChange();\n    } else {\n      this.emitChange();\n    }\n    \n    this.onTouched();\n    this.generateCalendars();\n  }\n  \n  removeRange(index: number): void {\n    if (!this.multiRange) return;\n    \n    const currentRanges = [...this.selectedRanges()];\n    currentRanges.splice(index, 1);\n    this.selectedRanges.set(currentRanges);\n    \n    this.updateMultiRangeText();\n    this.emitMultiChange();\n    this.emitMultiSelection();\n    this.generateCalendars();\n  }\n  \n  private updateMultiRangeText(): void {\n    const count = this.selectedRanges().length;\n    // Note: dateRangeText is now computed from store, this is for multi-range UI only\n    // We could store this in a separate signal if needed, but for now just track ranges count\n  }\n\n  private emitChange(): void {\n    const storeRange = this.rangeStore.range();\n    const range: DateRange = {\n      startDate: storeRange.start,\n      endDate: storeRange.end,\n      rangeText: this.dateRangeText()\n    };\n    \n    if (this.enableTimePicker) {\n      range.startTime = storeRange.startTime;\n      range.endTime = storeRange.endTime;\n    }\n    \n    this.dateRangeChange.emit(range);\n  }\n\n  private emitSelection(): void {\n    const storeRange = this.rangeStore.range();\n    const range: DateRange = {\n      startDate: storeRange.start,\n      endDate: storeRange.end,\n      rangeText: this.dateRangeText()\n    };\n    \n    if (this.enableTimePicker) {\n      range.startTime = storeRange.startTime;\n      range.endTime = storeRange.endTime;\n    }\n    \n    this.dateRangeSelected.emit(range);\n  }\n  \n  private emitMultiChange(): void {\n    this.multiDateRangeChange.emit({\n      ranges: this.selectedRanges()\n    });\n  }\n  \n  private emitMultiSelection(): void {\n    this.multiDateRangeSelected.emit({\n      ranges: this.selectedRanges()\n    });\n  }\n\n  private getDateRangeValue(): DateRange {\n    const storeRange = this.rangeStore.range();\n    const range: DateRange = {\n      startDate: storeRange.start,\n      endDate: storeRange.end,\n      rangeText: this.dateRangeText()\n    };\n    \n    if (this.enableTimePicker) {\n      range.startTime = storeRange.startTime;\n      range.endTime = storeRange.endTime;\n    }\n    \n    return range;\n  }\n\n  // Time Picker Methods\n  toggleStartTimePicker(): void {\n    if (!this.enableTimePicker) return;\n    this.showStartTimePicker.set(!this.showStartTimePicker());\n    this.showEndTimePicker.set(false);\n  }\n\n  toggleEndTimePicker(): void {\n    if (!this.enableTimePicker) return;\n    this.showEndTimePicker.set(!this.showEndTimePicker());\n    this.showStartTimePicker.set(false);\n  }\n\n  incrementStartHour(): void {\n    const newHour = (this.startHour + 1) % 24;\n    this.setStartHourMinute(newHour, this.startMinute);\n    if (!this.requireApply) {\n      this.emitChange();\n    }\n  }\n\n  decrementStartHour(): void {\n    const newHour = this.startHour === 0 ? 23 : this.startHour - 1;\n    this.setStartHourMinute(newHour, this.startMinute);\n    if (!this.requireApply) {\n      this.emitChange();\n    }\n  }\n\n  incrementStartMinute(): void {\n    const newMinute = (this.startMinute + this.minuteStep) % 60;\n    this.setStartHourMinute(this.startHour, newMinute);\n    if (!this.requireApply) {\n      this.emitChange();\n    }\n  }\n\n  decrementStartMinute(): void {\n    let newMinute = this.startMinute - this.minuteStep;\n    if (newMinute < 0) {\n      newMinute = 60 - this.minuteStep;\n    }\n    this.setStartHourMinute(this.startHour, newMinute);\n    if (!this.requireApply) {\n      this.emitChange();\n    }\n  }\n\n  incrementEndHour(): void {\n    const newHour = (this.endHour + 1) % 24;\n    this.setEndHourMinute(newHour, this.endMinute);\n    if (!this.requireApply) {\n      this.emitChange();\n    }\n  }\n\n  decrementEndHour(): void {\n    const newHour = this.endHour === 0 ? 23 : this.endHour - 1;\n    this.setEndHourMinute(newHour, this.endMinute);\n    if (!this.requireApply) {\n      this.emitChange();\n    }\n  }\n\n  incrementEndMinute(): void {\n    const newMinute = (this.endMinute + this.minuteStep) % 60;\n    this.setEndHourMinute(this.endHour, newMinute);\n    if (!this.requireApply) {\n      this.emitChange();\n    }\n  }\n\n  decrementEndMinute(): void {\n    let newMinute = this.endMinute - this.minuteStep;\n    if (newMinute < 0) {\n      newMinute = 60 - this.minuteStep;\n    }\n    this.setEndHourMinute(this.endHour, newMinute);\n    if (!this.requireApply) {\n      this.emitChange();\n    }\n  }\n\n  formatTime(hour: number, minute: number): string {\n    const h = hour.toString().padStart(2, '0');\n    const m = minute.toString().padStart(2, '0');\n    \n    if (this.timeFormat === '12h') {\n      const isPM = hour >= 12;\n      const hour12 = hour === 0 ? 12 : hour > 12 ? hour - 12 : hour;\n      const period = isPM ? 'PM' : 'AM';\n      return `${hour12.toString().padStart(2, '0')}:${m} ${period}`;\n    }\n    \n    return `${h}:${m}`;\n  }\n\n  parseTime(timeString: string): { hour: number; minute: number } {\n    if (!timeString) return { hour: 0, minute: 0 };\n    \n    const time12hRegex = /^(\\d{1,2}):(\\d{2})\\s?(AM|PM)$/i;\n    const time24hRegex = /^(\\d{1,2}):(\\d{2})$/;\n    \n    let match = timeString.match(time12hRegex);\n    if (match) {\n      let hour = parseInt(match[1], 10);\n      const minute = parseInt(match[2], 10);\n      const period = match[3].toUpperCase();\n      \n      if (period === 'PM' && hour !== 12) hour += 12;\n      if (period === 'AM' && hour === 12) hour = 0;\n      \n      return { hour, minute };\n    }\n    \n    match = timeString.match(time24hRegex);\n    if (match) {\n      return {\n        hour: parseInt(match[1], 10),\n        minute: parseInt(match[2], 10)\n      };\n    }\n    \n    return { hour: 0, minute: 0 };\n  }\n\n  // ControlValueAccessor implementation\n  writeValue(value: DateRange | null): void {\n    if (value) {\n      // Use setters which delegate to store\n      this.startDate = value.startDate || '';\n      this.endDate = value.endDate || '';\n      \n      if (this.enableTimePicker) {\n        if (value.startTime) {\n          this.rangeStore.setStartTime(value.startTime);\n        }\n        if (value.endTime) {\n          this.rangeStore.setEndTime(value.endTime);\n        }\n      }\n      \n      if (this.startDate && this.endDate) {\n        this.generateCalendars();\n      }\n    } else {\n      this.rangeStore.reset();\n    }\n  }\n\n  registerOnChange(fn: (value: DateRange | null) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.isDisabled.set(isDisabled);\n  }\n}\n","<div class=\"datepicker-wrapper\" \n  [class]=\"'theme-' + theme\"\n  [style.--input-border-hover]=\"inputBorderColorHover\"\n  [style.--input-border-focus]=\"inputBorderColorFocus\">\n  <input \n    type=\"text\" \n    class=\"datepicker-input\" \n    [value]=\"dateRangeText()\" \n    (click)=\"toggleDatePicker()\" \n    [placeholder]=\"placeholder\"\n    [disabled]=\"isDisabled()\"\n    [attr.aria-label]=\"placeholder\"\n    [attr.aria-expanded]=\"showDatePicker()\"\n    [attr.aria-haspopup]=\"'dialog'\"\n    role=\"combobox\"\n    [ngStyle]=\"{\n      'background-color': inputBackgroundColor,\n      'color': inputTextColor,\n      'border-color': inputBorderColor,\n      'padding': inputPadding\n    }\"\n    readonly>\n\n  @if (showDatePicker()) {\n  <div class=\"date-picker-dropdown\">\n    @if (showPresets) {\n    <div class=\"date-picker-presets\">\n      @for (preset of presets; track preset.label) {\n      <button type=\"button\" (click)=\"selectPresetRange(preset)\">{{ preset.label }}</button>\n      }\n      <button type=\"button\" class=\"btn-close-calendar\" (click)=\"closeDatePicker()\" title=\"Close\">\n        ×\n      </button>\n    </div>\n    }\n\n    @if (!showPresets) {\n    <div class=\"date-picker-header-only-close\">\n      <button type=\"button\" class=\"btn-close-calendar\" (click)=\"closeDatePicker()\" title=\"Close\">\n        ×\n      </button>\n    </div>\n    }\n\n    <!-- Calendars -->\n    <div class=\"date-picker-calendars\">\n      <!-- Previous month calendar -->\n      <div class=\"date-picker-calendar\">\n        <div class=\"date-picker-header\">\n          <button type=\"button\" (click)=\"changeMonth(-1)\">\n            <svg width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n              <path fill-rule=\"evenodd\" d=\"M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z\"/>\n            </svg>\n          </button>\n          <span>{{ previousMonthName() }}</span>\n          <button type=\"button\" style=\"visibility: hidden;\">\n            <svg width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n              <path fill-rule=\"evenodd\" d=\"M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z\"/>\n            </svg>\n          </button>\n        </div>\n        <div class=\"date-picker-weekdays\">\n          @for (dayName of weekDayNames(); track $index) {\n            <span>{{ dayName }}</span>\n          }\n        </div>\n        <div class=\"date-picker-days\">\n          @for (dayObj of previousMonthDays(); track dayObj.date || $index) {\n            <button \n              type=\"button\"\n              class=\"date-picker-day\" \n              [class.empty]=\"!dayObj.isCurrentMonth\"\n              [class.selected]=\"dayObj.isStart || dayObj.isEnd\"\n              [class.in-range]=\"dayObj.inRange && !dayObj.isStart && !dayObj.isEnd\"\n              [class.in-hover-range]=\"dayObj.inHoverRange && !dayObj.isStart && !dayObj.isEnd\"\n              [class.disabled]=\"dayObj.isDisabled\"\n              [class.keyboard-focused]=\"enableKeyboardNavigation && hasKeyboardFocus(dayObj.date, 0)\"\n              [attr.tabindex]=\"enableKeyboardNavigation && dayObj.isCurrentMonth && hasKeyboardFocus(dayObj.date, 0) ? 0 : -1\"\n              [attr.aria-label]=\"formatDateDisplay(dayObj.date)\"\n              [attr.aria-selected]=\"dayObj.isStart || dayObj.isEnd\"\n              [attr.aria-current]=\"dayObj.isStart ? 'date' : null\"\n              [attr.aria-disabled]=\"dayObj.isDisabled\"\n              (click)=\"selectDay(dayObj)\"\n              (mouseenter)=\"onDayHover(dayObj)\"\n              (mouseleave)=\"clearDayHover()\"\n              [disabled]=\"!dayObj.isCurrentMonth || dayObj.isDisabled\">\n              {{ dayObj.day }}\n            </button>\n          }\n        </div>\n      </div>\n\n      <!-- Current month calendar -->\n      <div class=\"date-picker-calendar\">\n        <div class=\"date-picker-header\">\n          <button type=\"button\" style=\"visibility: hidden;\">\n            <svg width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n              <path fill-rule=\"evenodd\" d=\"M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z\"/>\n            </svg>\n          </button>\n          <span>{{ currentMonthName() }}</span>\n          <button type=\"button\" (click)=\"changeMonth(1)\">\n            <svg width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n              <path fill-rule=\"evenodd\" d=\"M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z\"/>\n            </svg>\n          </button>\n        </div>\n        <div class=\"date-picker-weekdays\">\n          @for (dayName of weekDayNames(); track $index) {\n            <span>{{ dayName }}</span>\n          }\n        </div>\n        <div class=\"date-picker-days\">\n          @for (dayObj of currentMonthDays(); track dayObj.date || $index) {\n            <button \n              type=\"button\"\n              class=\"date-picker-day\" \n              [class.empty]=\"!dayObj.isCurrentMonth\"\n              [class.selected]=\"dayObj.isStart || dayObj.isEnd\"\n              [class.in-range]=\"dayObj.inRange && !dayObj.isStart && !dayObj.isEnd\"\n              [class.in-hover-range]=\"dayObj.inHoverRange && !dayObj.isStart && !dayObj.isEnd\"\n              [class.disabled]=\"dayObj.isDisabled\"\n              [class.keyboard-focused]=\"enableKeyboardNavigation && hasKeyboardFocus(dayObj.date, 1)\"\n              [attr.tabindex]=\"enableKeyboardNavigation && dayObj.isCurrentMonth && hasKeyboardFocus(dayObj.date, 1) ? 0 : -1\"\n              [attr.aria-label]=\"formatDateDisplay(dayObj.date)\"\n              [attr.aria-selected]=\"dayObj.isStart || dayObj.isEnd\"\n              [attr.aria-current]=\"dayObj.isStart ? 'date' : null\"\n              [attr.aria-disabled]=\"dayObj.isDisabled\"\n              (click)=\"selectDay(dayObj)\"\n              (mouseenter)=\"onDayHover(dayObj)\"\n              (mouseleave)=\"clearDayHover()\"\n              [disabled]=\"!dayObj.isCurrentMonth || dayObj.isDisabled\">\n              {{ dayObj.day }}\n            </button>\n          }\n        </div>\n      </div>\n    </div>\n\n    <!-- Multi-Range List -->\n    @if (multiRange && selectedRanges().length > 0) {\n    <div class=\"multi-range-list\">\n      <div class=\"multi-range-header\">\n        <span class=\"multi-range-title\">Selected Ranges ({{ selectedRanges().length }})</span>\n      </div>\n      <div class=\"multi-range-items\">\n        @for (range of selectedRanges(); track $index) {\n        <div class=\"multi-range-item\">\n          <span class=\"multi-range-text\">{{ range.rangeText }}</span>\n          <button \n            type=\"button\" \n            class=\"btn-remove-range\" \n            (click)=\"removeRange($index)\"\n            title=\"Remove this range\">\n            <svg width=\"14\" height=\"14\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n              <path d=\"M2.146 2.854a.5.5 0 1 1 .708-.708L8 7.293l5.146-5.147a.5.5 0 0 1 .708.708L8.707 8l5.147 5.146a.5.5 0 0 1-.708.708L8 8.707l-5.146 5.147a.5.5 0 0 1-.708-.708L7.293 8 2.146 2.854Z\"/>\n            </svg>\n          </button>\n        </div>\n        }\n      </div>\n    </div>\n    }\n\n    <!-- Time Picker -->\n    @if (enableTimePicker) {\n    <div class=\"time-picker-container\">\n      <!-- Start Time -->\n      <div class=\"time-picker-section\">\n        <div class=\"time-picker-label\">Start Time</div>\n        <div class=\"time-picker-inputs\">\n          <div class=\"time-input-group\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-up\" \n              (click)=\"incrementStartHour()\"\n              title=\"Increment hour\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 4.86l-4.796 5.481c-.566.647-.106 1.659.753 1.659h9.592a1 1 0 0 0 .753-1.659l-4.796-5.48a1 1 0 0 0-1.506 0z\"/>\n              </svg>\n            </button>\n            <input\n              type=\"text\"\n              class=\"time-input\"\n              [value]=\"startHour.toString().padStart(2, '0')\"\n              readonly\n              title=\"Start hour\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-down\" \n              (click)=\"decrementStartHour()\"\n              title=\"Decrement hour\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 11.14l-4.796-5.481C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z\"/>\n              </svg>\n            </button>\n          </div>\n          <span class=\"time-separator\">:</span>\n          <div class=\"time-input-group\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-up\" \n              (click)=\"incrementStartMinute()\"\n              title=\"Increment minute\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 4.86l-4.796 5.481c-.566.647-.106 1.659.753 1.659h9.592a1 1 0 0 0 .753-1.659l-4.796-5.48a1 1 0 0 0-1.506 0z\"/>\n              </svg>\n            </button>\n            <input\n              type=\"text\"\n              class=\"time-input\"\n              [value]=\"startMinute.toString().padStart(2, '0')\"\n              readonly\n              title=\"Start minute\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-down\" \n              (click)=\"decrementStartMinute()\"\n              title=\"Decrement minute\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 11.14l-4.796-5.481C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z\"/>\n              </svg>\n            </button>\n          </div>\n          @if (timeFormat === '12h') {\n          <div class=\"time-period\">\n            {{ startHour >= 12 ? 'PM' : 'AM' }}\n          </div>\n          }\n        </div>\n      </div>\n\n      <!-- Separator -->\n      <div class=\"time-separator-vertical\"></div>\n\n      <!-- End Time -->\n      <div class=\"time-picker-section\">\n        <div class=\"time-picker-label\">End Time</div>\n        <div class=\"time-picker-inputs\">\n          <div class=\"time-input-group\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-up\" \n              (click)=\"incrementEndHour()\"\n              title=\"Increment hour\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 4.86l-4.796 5.481c-.566.647-.106 1.659.753 1.659h9.592a1 1 0 0 0 .753-1.659l-4.796-5.48a1 1 0 0 0-1.506 0z\"/>\n              </svg>\n            </button>\n            <input\n              type=\"text\"\n              class=\"time-input\"\n              [value]=\"endHour.toString().padStart(2, '0')\"\n              readonly\n              title=\"End hour\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-down\" \n              (click)=\"decrementEndHour()\"\n              title=\"Decrement hour\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 11.14l-4.796-5.481C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z\"/>\n              </svg>\n            </button>\n          </div>\n          <span class=\"time-separator\">:</span>\n          <div class=\"time-input-group\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-up\" \n              (click)=\"incrementEndMinute()\"\n              title=\"Increment minute\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 4.86l-4.796 5.481c-.566.647-.106 1.659.753 1.659h9.592a1 1 0 0 0 .753-1.659l-4.796-5.48a1 1 0 0 0-1.506 0z\"/>\n              </svg>\n            </button>\n            <input\n              type=\"text\"\n              class=\"time-input\"\n              [value]=\"endMinute.toString().padStart(2, '0')\"\n              readonly\n              title=\"End minute\">\n            <button \n              type=\"button\" \n              class=\"time-btn time-btn-down\" \n              (click)=\"decrementEndMinute()\"\n              title=\"Decrement minute\">\n              <svg width=\"12\" height=\"12\" fill=\"currentColor\" viewBox=\"0 0 16 16\">\n                <path d=\"M7.247 11.14l-4.796-5.481C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z\"/>\n              </svg>\n            </button>\n          </div>\n          @if (timeFormat === '12h') {\n          <div class=\"time-period\">\n            {{ endHour >= 12 ? 'PM' : 'AM' }}\n          </div>\n          }\n        </div>\n      </div>\n    </div>\n    }\n\n    <!-- Footer with buttons -->\n    @if (showClearButton || multiRange || requireApply) {\n    <div class=\"date-picker-footer\">\n      @if (requireApply && !multiRange) {\n        <div class=\"apply-footer-actions\">\n          <button \n            type=\"button\" \n            class=\"btn-cancel\" \n            (click)=\"cancelSelection()\" \n            [disabled]=\"!hasPendingChanges()\"\n            title=\"Cancel selection\">\n            Cancel\n          </button>\n          <button \n            type=\"button\" \n            class=\"btn-apply\" \n            (click)=\"applySelection()\" \n            [disabled]=\"!hasPendingChanges() || !pendingStartDate || !pendingEndDate\"\n            title=\"Apply selection\">\n            Apply\n          </button>\n        </div>\n      }\n      @if (multiRange) {\n        <div class=\"multi-range-footer-actions\">\n          <button type=\"button\" class=\"btn-clear\" (click)=\"clear()\" title=\"Clear all ranges\">\n            Clear All\n          </button>\n          <button type=\"button\" class=\"btn-done\" (click)=\"closeDatePicker()\" title=\"Done selecting\">\n            Done\n          </button>\n        </div>\n      }\n      @if (!multiRange && !requireApply && showClearButton) {\n        <button type=\"button\" class=\"btn-clear\" (click)=\"clear()\" title=\"Clear selection\">\n          Clear\n        </button>\n      }\n    </div>\n    }\n  </div>\n  }\n</div>\n"]}