@skyux/datetime 11.27.0 → 11.29.0

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.
Files changed (63) hide show
  1. package/documentation.json +2639 -2621
  2. package/esm2022/index.mjs +4 -4
  3. package/esm2022/lib/modules/date-pipe/fuzzy-date.pipe.mjs +2 -2
  4. package/esm2022/lib/modules/date-range-picker/date-range-picker.component.mjs +22 -9
  5. package/esm2022/lib/modules/date-range-picker/date-range.service.mjs +8 -10
  6. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator.mjs +19 -3
  7. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar-change.mjs +2 -0
  8. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar-inner.component.mjs +383 -0
  9. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar-label.pipe.mjs +39 -0
  10. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar.component.mjs +100 -0
  11. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar.service.mjs +22 -0
  12. package/esm2022/lib/modules/datepicker/calendar/daypicker-button.component.mjs +23 -0
  13. package/esm2022/lib/modules/datepicker/calendar/daypicker-cell.component.mjs +129 -0
  14. package/esm2022/lib/modules/datepicker/calendar/daypicker-context.mjs +2 -0
  15. package/esm2022/lib/modules/datepicker/calendar/daypicker.component.mjs +221 -0
  16. package/esm2022/lib/modules/datepicker/calendar/monthpicker.component.mjs +80 -0
  17. package/esm2022/lib/modules/datepicker/calendar/yearpicker.component.mjs +87 -0
  18. package/esm2022/lib/modules/datepicker/datepicker-input.directive.mjs +5 -4
  19. package/esm2022/lib/modules/datepicker/datepicker.component.mjs +24 -8
  20. package/esm2022/lib/modules/datepicker/datepicker.module.mjs +31 -67
  21. package/esm2022/lib/modules/datepicker/fuzzy/datepicker-input-fuzzy.directive.mjs +516 -0
  22. package/esm2022/lib/modules/datepicker/fuzzy/fuzzy-date.mjs +2 -0
  23. package/esm2022/lib/modules/datepicker/fuzzy/fuzzy-date.service.mjs +411 -0
  24. package/fesm2022/skyux-datetime.mjs +584 -564
  25. package/fesm2022/skyux-datetime.mjs.map +1 -1
  26. package/index.d.ts +5 -5
  27. package/lib/modules/date-pipe/fuzzy-date.pipe.d.ts +2 -2
  28. package/lib/modules/date-range-picker/date-range-picker.component.d.ts +6 -1
  29. package/lib/modules/date-range-picker/date-range.service.d.ts +0 -1
  30. package/lib/modules/date-range-picker/types/date-range-calculator.d.ts +7 -6
  31. package/lib/modules/datepicker/{datepicker-calendar-change.d.ts → calendar/datepicker-calendar-change.d.ts} +1 -1
  32. package/lib/modules/datepicker/{datepicker-calendar-inner.component.d.ts → calendar/datepicker-calendar-inner.component.d.ts} +6 -6
  33. package/lib/modules/datepicker/{datepicker-calendar.component.d.ts → calendar/datepicker-calendar.component.d.ts} +3 -3
  34. package/lib/modules/datepicker/calendar/datepicker-calendar.service.d.ts +16 -0
  35. package/lib/modules/datepicker/{daypicker-button.component.d.ts → calendar/daypicker-button.component.d.ts} +3 -3
  36. package/lib/modules/datepicker/{daypicker-cell.component.d.ts → calendar/daypicker-cell.component.d.ts} +5 -5
  37. package/lib/modules/datepicker/{datepicker-date.d.ts → calendar/daypicker-context.d.ts} +2 -1
  38. package/lib/modules/datepicker/{daypicker.component.d.ts → calendar/daypicker.component.d.ts} +4 -4
  39. package/lib/modules/datepicker/{monthpicker.component.d.ts → calendar/monthpicker.component.d.ts} +3 -3
  40. package/lib/modules/datepicker/{yearpicker.component.d.ts → calendar/yearpicker.component.d.ts} +3 -3
  41. package/lib/modules/datepicker/datepicker-input.directive.d.ts +1 -1
  42. package/lib/modules/datepicker/datepicker.component.d.ts +8 -3
  43. package/lib/modules/datepicker/datepicker.module.d.ts +11 -22
  44. package/lib/modules/datepicker/{datepicker-input-fuzzy.directive.d.ts → fuzzy/datepicker-input-fuzzy.directive.d.ts} +3 -3
  45. package/package.json +9 -9
  46. package/esm2022/lib/modules/datepicker/datepicker-calendar-change.mjs +0 -2
  47. package/esm2022/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +0 -381
  48. package/esm2022/lib/modules/datepicker/datepicker-calendar-label.pipe.mjs +0 -39
  49. package/esm2022/lib/modules/datepicker/datepicker-calendar.component.mjs +0 -96
  50. package/esm2022/lib/modules/datepicker/datepicker-date.mjs +0 -2
  51. package/esm2022/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +0 -515
  52. package/esm2022/lib/modules/datepicker/datepicker.service.mjs +0 -21
  53. package/esm2022/lib/modules/datepicker/daypicker-button.component.mjs +0 -22
  54. package/esm2022/lib/modules/datepicker/daypicker-cell.component.mjs +0 -128
  55. package/esm2022/lib/modules/datepicker/daypicker.component.mjs +0 -220
  56. package/esm2022/lib/modules/datepicker/fuzzy-date.mjs +0 -2
  57. package/esm2022/lib/modules/datepicker/fuzzy-date.service.mjs +0 -411
  58. package/esm2022/lib/modules/datepicker/monthpicker.component.mjs +0 -79
  59. package/esm2022/lib/modules/datepicker/yearpicker.component.mjs +0 -86
  60. package/lib/modules/datepicker/datepicker.service.d.ts +0 -15
  61. /package/lib/modules/datepicker/{datepicker-calendar-label.pipe.d.ts → calendar/datepicker-calendar-label.pipe.d.ts} +0 -0
  62. /package/lib/modules/datepicker/{fuzzy-date.d.ts → fuzzy/fuzzy-date.d.ts} +0 -0
  63. /package/lib/modules/datepicker/{fuzzy-date.service.d.ts → fuzzy/fuzzy-date.service.d.ts} +0 -0
package/esm2022/index.mjs CHANGED
@@ -9,15 +9,15 @@ export { SkyDateRangeCalculatorId } from './lib/modules/date-range-picker/types/
9
9
  export { SkyDateRangeCalculatorType } from './lib/modules/date-range-picker/types/date-range-calculator-type';
10
10
  export { SkyDatepickerConfigService } from './lib/modules/datepicker/datepicker-config.service';
11
11
  export { SkyDatepickerModule } from './lib/modules/datepicker/datepicker.module';
12
- export { SkyFuzzyDateService } from './lib/modules/datepicker/fuzzy-date.service';
12
+ export { SkyFuzzyDateService } from './lib/modules/datepicker/fuzzy/fuzzy-date.service';
13
13
  export { SkyTimepickerModule } from './lib/modules/timepicker/timepicker.module';
14
14
  // Components and directives must be exported to support Angular’s “partial” Ivy compiler.
15
15
  // Obscure names are used to indicate types are not part of the public API.
16
16
  export { SkyDateRangePickerComponent as λ5 } from './lib/modules/date-range-picker/date-range-picker.component';
17
- export { SkyDatepickerCalendarComponent as λ1 } from './lib/modules/datepicker/datepicker-calendar.component';
18
- export { SkyFuzzyDatepickerInputDirective as λ4 } from './lib/modules/datepicker/datepicker-input-fuzzy.directive';
17
+ export { SkyDatepickerCalendarComponent as λ1 } from './lib/modules/datepicker/calendar/datepicker-calendar.component';
18
+ export { SkyFuzzyDatepickerInputDirective as λ4 } from './lib/modules/datepicker/fuzzy/datepicker-input-fuzzy.directive';
19
19
  export { SkyDatepickerInputDirective as λ3 } from './lib/modules/datepicker/datepicker-input.directive';
20
20
  export { SkyDatepickerComponent as λ2 } from './lib/modules/datepicker/datepicker.component';
21
21
  export { SkyTimepickerComponent as λ6 } from './lib/modules/timepicker/timepicker.component';
22
22
  export { SkyTimepickerInputDirective as λ7 } from './lib/modules/timepicker/timepicker.directive';
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZGF0ZXRpbWUvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUVoRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDdEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFFM0UsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMERBQTBELENBQUM7QUFDcEcsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sb0RBQW9ELENBQUM7QUFHekYsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNkRBQTZELENBQUM7QUFHckcsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sZ0VBQWdFLENBQUM7QUFDMUcsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sa0VBQWtFLENBQUM7QUFJOUcsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sb0RBQW9ELENBQUM7QUFFaEcsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFFakYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFJbEYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFFakYsMEZBQTBGO0FBQzFGLDJFQUEyRTtBQUMzRSxPQUFPLEVBQUUsMkJBQTJCLElBQUksRUFBRSxFQUFFLE1BQU0sNkRBQTZELENBQUM7QUFDaEgsT0FBTyxFQUFFLDhCQUE4QixJQUFJLEVBQUUsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBQzlHLE9BQU8sRUFBRSxnQ0FBZ0MsSUFBSSxFQUFFLEVBQUUsTUFBTSwyREFBMkQsQ0FBQztBQUNuSCxPQUFPLEVBQUUsMkJBQTJCLElBQUksRUFBRSxFQUFFLE1BQU0scURBQXFELENBQUM7QUFDeEcsT0FBTyxFQUFFLHNCQUFzQixJQUFJLEVBQUUsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQzdGLE9BQU8sRUFBRSxzQkFBc0IsSUFBSSxFQUFFLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUM3RixPQUFPLEVBQUUsMkJBQTJCLElBQUksRUFBRSxFQUFFLE1BQU0sK0NBQStDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBTa3lEYXRlUGlwZU1vZHVsZSB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZS1waXBlL2RhdGUtcGlwZS5tb2R1bGUnO1xuZXhwb3J0IHsgU2t5RGF0ZVBpcGUgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2RhdGUtcGlwZS9kYXRlLnBpcGUnO1xuXG5leHBvcnQgeyBTa3lEYXRlU2VydmljZSB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZS1waXBlL2RhdGUuc2VydmljZSc7XG5leHBvcnQgeyBTa3lGdXp6eURhdGVQaXBlIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kYXRlLXBpcGUvZnV6enktZGF0ZS5waXBlJztcblxuZXhwb3J0IHsgU2t5RGF0ZVJhbmdlUGlja2VyTW9kdWxlIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kYXRlLXJhbmdlLXBpY2tlci9kYXRlLXJhbmdlLXBpY2tlci5tb2R1bGUnO1xuZXhwb3J0IHsgU2t5RGF0ZVJhbmdlU2VydmljZSB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZS1yYW5nZS1waWNrZXIvZGF0ZS1yYW5nZS5zZXJ2aWNlJztcbmV4cG9ydCB7IFNreURhdGVSYW5nZSB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZS1yYW5nZS1waWNrZXIvdHlwZXMvZGF0ZS1yYW5nZSc7XG5leHBvcnQgeyBTa3lEYXRlUmFuZ2VDYWxjdWxhdGlvbiB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZS1yYW5nZS1waWNrZXIvdHlwZXMvZGF0ZS1yYW5nZS1jYWxjdWxhdGlvbic7XG5leHBvcnQgeyBTa3lEYXRlUmFuZ2VDYWxjdWxhdG9yIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kYXRlLXJhbmdlLXBpY2tlci90eXBlcy9kYXRlLXJhbmdlLWNhbGN1bGF0b3InO1xuZXhwb3J0IHsgU2t5RGF0ZVJhbmdlQ2FsY3VsYXRvckNvbmZpZyB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZS1yYW5nZS1waWNrZXIvdHlwZXMvZGF0ZS1yYW5nZS1jYWxjdWxhdG9yLWNvbmZpZyc7XG5leHBvcnQgeyBTa3lEYXRlUmFuZ2VDYWxjdWxhdG9yR2V0VmFsdWVGdW5jdGlvbiB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZS1yYW5nZS1waWNrZXIvdHlwZXMvZGF0ZS1yYW5nZS1jYWxjdWxhdG9yLWRhdGUtcmFuZ2UtZnVuY3Rpb24nO1xuZXhwb3J0IHsgU2t5RGF0ZVJhbmdlQ2FsY3VsYXRvcklkIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kYXRlLXJhbmdlLXBpY2tlci90eXBlcy9kYXRlLXJhbmdlLWNhbGN1bGF0b3ItaWQnO1xuZXhwb3J0IHsgU2t5RGF0ZVJhbmdlQ2FsY3VsYXRvclR5cGUgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2RhdGUtcmFuZ2UtcGlja2VyL3R5cGVzL2RhdGUtcmFuZ2UtY2FsY3VsYXRvci10eXBlJztcbmV4cG9ydCB7IFNreURhdGVSYW5nZUNhbGN1bGF0b3JWYWxpZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kYXRlLXJhbmdlLXBpY2tlci90eXBlcy9kYXRlLXJhbmdlLWNhbGN1bGF0b3ItdmFsaWRhdGUtZnVuY3Rpb24nO1xuXG5leHBvcnQgeyBTa3lEYXRlcGlja2VyQ2FsZW5kYXJDaGFuZ2UgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2RhdGVwaWNrZXIvZGF0ZXBpY2tlci1jYWxlbmRhci1jaGFuZ2UnO1xuZXhwb3J0IHsgU2t5RGF0ZXBpY2tlckNvbmZpZ1NlcnZpY2UgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2RhdGVwaWNrZXIvZGF0ZXBpY2tlci1jb25maWcuc2VydmljZSc7XG5leHBvcnQgeyBTa3lEYXRlcGlja2VyQ3VzdG9tRGF0ZSB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLWN1c3RvbS1kYXRlJztcbmV4cG9ydCB7IFNreURhdGVwaWNrZXJNb2R1bGUgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2RhdGVwaWNrZXIvZGF0ZXBpY2tlci5tb2R1bGUnO1xuZXhwb3J0IHsgU2t5RnV6enlEYXRlIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kYXRlcGlja2VyL2Z1enp5LWRhdGUnO1xuZXhwb3J0IHsgU2t5RnV6enlEYXRlU2VydmljZSB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZXBpY2tlci9mdXp6eS1kYXRlLnNlcnZpY2UnO1xuXG5leHBvcnQgeyBTa3lUaW1lcGlja2VyVGltZUZvcm1hdFR5cGUgfSBmcm9tICcuL2xpYi9tb2R1bGVzL3RpbWVwaWNrZXIvdGltZXBpY2tlci10aW1lLWZvcm1hdC10eXBlJztcbmV4cG9ydCB7IFNreVRpbWVwaWNrZXJUaW1lT3V0cHV0IH0gZnJvbSAnLi9saWIvbW9kdWxlcy90aW1lcGlja2VyL3RpbWVwaWNrZXItdGltZS1vdXRwdXQnO1xuZXhwb3J0IHsgU2t5VGltZXBpY2tlck1vZHVsZSB9IGZyb20gJy4vbGliL21vZHVsZXMvdGltZXBpY2tlci90aW1lcGlja2VyLm1vZHVsZSc7XG5cbi8vIENvbXBvbmVudHMgYW5kIGRpcmVjdGl2ZXMgbXVzdCBiZSBleHBvcnRlZCB0byBzdXBwb3J0IEFuZ3VsYXLigJlzIOKAnHBhcnRpYWzigJ0gSXZ5IGNvbXBpbGVyLlxuLy8gT2JzY3VyZSBuYW1lcyBhcmUgdXNlZCB0byBpbmRpY2F0ZSB0eXBlcyBhcmUgbm90IHBhcnQgb2YgdGhlIHB1YmxpYyBBUEkuXG5leHBvcnQgeyBTa3lEYXRlUmFuZ2VQaWNrZXJDb21wb25lbnQgYXMgzrs1IH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kYXRlLXJhbmdlLXBpY2tlci9kYXRlLXJhbmdlLXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5RGF0ZXBpY2tlckNhbGVuZGFyQ29tcG9uZW50IGFzIM67MSB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLWNhbGVuZGFyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lGdXp6eURhdGVwaWNrZXJJbnB1dERpcmVjdGl2ZSBhcyDOuzQgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2RhdGVwaWNrZXIvZGF0ZXBpY2tlci1pbnB1dC1mdXp6eS5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgU2t5RGF0ZXBpY2tlcklucHV0RGlyZWN0aXZlIGFzIM67MyB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLWlucHV0LmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBTa3lEYXRlcGlja2VyQ29tcG9uZW50IGFzIM67MiB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lUaW1lcGlja2VyQ29tcG9uZW50IGFzIM67NiB9IGZyb20gJy4vbGliL21vZHVsZXMvdGltZXBpY2tlci90aW1lcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lUaW1lcGlja2VySW5wdXREaXJlY3RpdmUgYXMgzrs3IH0gZnJvbSAnLi9saWIvbW9kdWxlcy90aW1lcGlja2VyL3RpbWVwaWNrZXIuZGlyZWN0aXZlJztcbiJdfQ==
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZGF0ZXRpbWUvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUVoRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDdEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFFM0UsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMERBQTBELENBQUM7QUFDcEcsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sb0RBQW9ELENBQUM7QUFHekYsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNkRBQTZELENBQUM7QUFHckcsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sZ0VBQWdFLENBQUM7QUFDMUcsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sa0VBQWtFLENBQUM7QUFJOUcsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sb0RBQW9ELENBQUM7QUFFaEcsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFFakYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sbURBQW1ELENBQUM7QUFJeEYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFFakYsMEZBQTBGO0FBQzFGLDJFQUEyRTtBQUMzRSxPQUFPLEVBQUUsMkJBQTJCLElBQUksRUFBRSxFQUFFLE1BQU0sNkRBQTZELENBQUM7QUFDaEgsT0FBTyxFQUFFLDhCQUE4QixJQUFJLEVBQUUsRUFBRSxNQUFNLGlFQUFpRSxDQUFDO0FBQ3ZILE9BQU8sRUFBRSxnQ0FBZ0MsSUFBSSxFQUFFLEVBQUUsTUFBTSxpRUFBaUUsQ0FBQztBQUN6SCxPQUFPLEVBQUUsMkJBQTJCLElBQUksRUFBRSxFQUFFLE1BQU0scURBQXFELENBQUM7QUFDeEcsT0FBTyxFQUFFLHNCQUFzQixJQUFJLEVBQUUsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQzdGLE9BQU8sRUFBRSxzQkFBc0IsSUFBSSxFQUFFLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQztBQUM3RixPQUFPLEVBQUUsMkJBQTJCLElBQUksRUFBRSxFQUFFLE1BQU0sK0NBQStDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBTa3lEYXRlUGlwZU1vZHVsZSB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZS1waXBlL2RhdGUtcGlwZS5tb2R1bGUnO1xuZXhwb3J0IHsgU2t5RGF0ZVBpcGUgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2RhdGUtcGlwZS9kYXRlLnBpcGUnO1xuXG5leHBvcnQgeyBTa3lEYXRlU2VydmljZSB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZS1waXBlL2RhdGUuc2VydmljZSc7XG5leHBvcnQgeyBTa3lGdXp6eURhdGVQaXBlIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kYXRlLXBpcGUvZnV6enktZGF0ZS5waXBlJztcblxuZXhwb3J0IHsgU2t5RGF0ZVJhbmdlUGlja2VyTW9kdWxlIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kYXRlLXJhbmdlLXBpY2tlci9kYXRlLXJhbmdlLXBpY2tlci5tb2R1bGUnO1xuZXhwb3J0IHsgU2t5RGF0ZVJhbmdlU2VydmljZSB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZS1yYW5nZS1waWNrZXIvZGF0ZS1yYW5nZS5zZXJ2aWNlJztcbmV4cG9ydCB7IFNreURhdGVSYW5nZSB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZS1yYW5nZS1waWNrZXIvdHlwZXMvZGF0ZS1yYW5nZSc7XG5leHBvcnQgeyBTa3lEYXRlUmFuZ2VDYWxjdWxhdGlvbiB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZS1yYW5nZS1waWNrZXIvdHlwZXMvZGF0ZS1yYW5nZS1jYWxjdWxhdGlvbic7XG5leHBvcnQgeyBTa3lEYXRlUmFuZ2VDYWxjdWxhdG9yIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kYXRlLXJhbmdlLXBpY2tlci90eXBlcy9kYXRlLXJhbmdlLWNhbGN1bGF0b3InO1xuZXhwb3J0IHsgU2t5RGF0ZVJhbmdlQ2FsY3VsYXRvckNvbmZpZyB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZS1yYW5nZS1waWNrZXIvdHlwZXMvZGF0ZS1yYW5nZS1jYWxjdWxhdG9yLWNvbmZpZyc7XG5leHBvcnQgeyBTa3lEYXRlUmFuZ2VDYWxjdWxhdG9yR2V0VmFsdWVGdW5jdGlvbiB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZS1yYW5nZS1waWNrZXIvdHlwZXMvZGF0ZS1yYW5nZS1jYWxjdWxhdG9yLWRhdGUtcmFuZ2UtZnVuY3Rpb24nO1xuZXhwb3J0IHsgU2t5RGF0ZVJhbmdlQ2FsY3VsYXRvcklkIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kYXRlLXJhbmdlLXBpY2tlci90eXBlcy9kYXRlLXJhbmdlLWNhbGN1bGF0b3ItaWQnO1xuZXhwb3J0IHsgU2t5RGF0ZVJhbmdlQ2FsY3VsYXRvclR5cGUgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2RhdGUtcmFuZ2UtcGlja2VyL3R5cGVzL2RhdGUtcmFuZ2UtY2FsY3VsYXRvci10eXBlJztcbmV4cG9ydCB7IFNreURhdGVSYW5nZUNhbGN1bGF0b3JWYWxpZGF0ZUZ1bmN0aW9uIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kYXRlLXJhbmdlLXBpY2tlci90eXBlcy9kYXRlLXJhbmdlLWNhbGN1bGF0b3ItdmFsaWRhdGUtZnVuY3Rpb24nO1xuXG5leHBvcnQgeyBTa3lEYXRlcGlja2VyQ2FsZW5kYXJDaGFuZ2UgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2RhdGVwaWNrZXIvY2FsZW5kYXIvZGF0ZXBpY2tlci1jYWxlbmRhci1jaGFuZ2UnO1xuZXhwb3J0IHsgU2t5RGF0ZXBpY2tlckNvbmZpZ1NlcnZpY2UgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2RhdGVwaWNrZXIvZGF0ZXBpY2tlci1jb25maWcuc2VydmljZSc7XG5leHBvcnQgeyBTa3lEYXRlcGlja2VyQ3VzdG9tRGF0ZSB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLWN1c3RvbS1kYXRlJztcbmV4cG9ydCB7IFNreURhdGVwaWNrZXJNb2R1bGUgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2RhdGVwaWNrZXIvZGF0ZXBpY2tlci5tb2R1bGUnO1xuZXhwb3J0IHsgU2t5RnV6enlEYXRlIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kYXRlcGlja2VyL2Z1enp5L2Z1enp5LWRhdGUnO1xuZXhwb3J0IHsgU2t5RnV6enlEYXRlU2VydmljZSB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZXBpY2tlci9mdXp6eS9mdXp6eS1kYXRlLnNlcnZpY2UnO1xuXG5leHBvcnQgeyBTa3lUaW1lcGlja2VyVGltZUZvcm1hdFR5cGUgfSBmcm9tICcuL2xpYi9tb2R1bGVzL3RpbWVwaWNrZXIvdGltZXBpY2tlci10aW1lLWZvcm1hdC10eXBlJztcbmV4cG9ydCB7IFNreVRpbWVwaWNrZXJUaW1lT3V0cHV0IH0gZnJvbSAnLi9saWIvbW9kdWxlcy90aW1lcGlja2VyL3RpbWVwaWNrZXItdGltZS1vdXRwdXQnO1xuZXhwb3J0IHsgU2t5VGltZXBpY2tlck1vZHVsZSB9IGZyb20gJy4vbGliL21vZHVsZXMvdGltZXBpY2tlci90aW1lcGlja2VyLm1vZHVsZSc7XG5cbi8vIENvbXBvbmVudHMgYW5kIGRpcmVjdGl2ZXMgbXVzdCBiZSBleHBvcnRlZCB0byBzdXBwb3J0IEFuZ3VsYXLigJlzIOKAnHBhcnRpYWzigJ0gSXZ5IGNvbXBpbGVyLlxuLy8gT2JzY3VyZSBuYW1lcyBhcmUgdXNlZCB0byBpbmRpY2F0ZSB0eXBlcyBhcmUgbm90IHBhcnQgb2YgdGhlIHB1YmxpYyBBUEkuXG5leHBvcnQgeyBTa3lEYXRlUmFuZ2VQaWNrZXJDb21wb25lbnQgYXMgzrs1IH0gZnJvbSAnLi9saWIvbW9kdWxlcy9kYXRlLXJhbmdlLXBpY2tlci9kYXRlLXJhbmdlLXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5RGF0ZXBpY2tlckNhbGVuZGFyQ29tcG9uZW50IGFzIM67MSB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZXBpY2tlci9jYWxlbmRhci9kYXRlcGlja2VyLWNhbGVuZGFyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lGdXp6eURhdGVwaWNrZXJJbnB1dERpcmVjdGl2ZSBhcyDOuzQgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2RhdGVwaWNrZXIvZnV6enkvZGF0ZXBpY2tlci1pbnB1dC1mdXp6eS5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgU2t5RGF0ZXBpY2tlcklucHV0RGlyZWN0aXZlIGFzIM67MyB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLWlucHV0LmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBTa3lEYXRlcGlja2VyQ29tcG9uZW50IGFzIM67MiB9IGZyb20gJy4vbGliL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lUaW1lcGlja2VyQ29tcG9uZW50IGFzIM67NiB9IGZyb20gJy4vbGliL21vZHVsZXMvdGltZXBpY2tlci90aW1lcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBTa3lUaW1lcGlja2VySW5wdXREaXJlY3RpdmUgYXMgzrs3IH0gZnJvbSAnLi9saWIvbW9kdWxlcy90aW1lcGlja2VyL3RpbWVwaWNrZXIuZGlyZWN0aXZlJztcbiJdfQ==
@@ -1,6 +1,6 @@
1
1
  import { Pipe } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
- import * as i1 from "../datepicker/fuzzy-date.service";
3
+ import * as i1 from "../datepicker/fuzzy/fuzzy-date.service";
4
4
  /**
5
5
  * Formats date values using two or more date tokens that represent the day, month,
6
6
  * and year. The tokens are described in the [moment.js values](https://momentjs.com/docs/#/displaying/).
@@ -44,4 +44,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
44
44
  pure: false,
45
45
  }]
46
46
  }], ctorParameters: () => [{ type: i1.SkyFuzzyDateService }] });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnV6enktZGF0ZS5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2RhdGV0aW1lL3NyYy9saWIvbW9kdWxlcy9kYXRlLXBpcGUvZnV6enktZGF0ZS5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOzs7QUFLcEQ7Ozs7Ozs7O0dBUUc7QUFLSCxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLGlCQUFpQixDQUFzQjtJQUV2QyxZQUFZLGdCQUFxQztRQUMvQyxJQUFJLENBQUMsaUJBQWlCLEdBQUcsZ0JBQWdCLENBQUM7SUFDNUMsQ0FBQztJQUVEOzs7Ozs7Ozs7O09BVUc7SUFDSSxTQUFTLENBQ2QsS0FBbUIsRUFDbkIsTUFBZSxFQUNmLE1BQWU7UUFFZixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDWCxPQUFPLEVBQUUsQ0FBQztRQUNaLENBQUM7UUFDRCxNQUFNLGVBQWUsR0FDbkIsTUFBTSxJQUFJLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxvQkFBb0IsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNoRSxNQUFNLGVBQWUsR0FBRyxNQUFNLElBQUksSUFBSSxDQUFDLGlCQUFpQixDQUFDLGdCQUFnQixFQUFFLENBQUM7UUFDNUUsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUMsTUFBTSxDQUNsQyxLQUFLLEVBQ0wsZUFBZSxFQUNmLGVBQWUsQ0FDaEIsQ0FBQztJQUNKLENBQUM7K0dBbENVLGdCQUFnQjs2R0FBaEIsZ0JBQWdCOzs0RkFBaEIsZ0JBQWdCO2tCQUo1QixJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSxjQUFjO29CQUNwQixJQUFJLEVBQUUsS0FBSztpQkFDWiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgU2t5RnV6enlEYXRlIH0gZnJvbSAnLi4vZGF0ZXBpY2tlci9mdXp6eS1kYXRlJztcbmltcG9ydCB7IFNreUZ1enp5RGF0ZVNlcnZpY2UgfSBmcm9tICcuLi9kYXRlcGlja2VyL2Z1enp5LWRhdGUuc2VydmljZSc7XG5cbi8qKlxuICogRm9ybWF0cyBkYXRlIHZhbHVlcyB1c2luZyB0d28gb3IgbW9yZSBkYXRlIHRva2VucyB0aGF0IHJlcHJlc2VudCB0aGUgZGF5LCBtb250aCxcbiAqIGFuZCB5ZWFyLiBUaGUgdG9rZW5zIGFyZSBkZXNjcmliZWQgaW4gdGhlIFttb21lbnQuanMgdmFsdWVzXShodHRwczovL21vbWVudGpzLmNvbS9kb2NzLyMvZGlzcGxheWluZy8pLlxuICogQGV4YW1wbGVcbiAqIGBgYG1hcmt1cFxuICoge3sgbXlGdXp6eURhdGUgfCBza3lGdXp6eURhdGU6J01NTSBZJyB9fVxuICoge3sgbXlGdXp6eURhdGUgfCBza3lGdXp6eURhdGU6J01NTSBZJzonZW4tQ0EnIH19XG4gKiBgYGBcbiAqL1xuQFBpcGUoe1xuICBuYW1lOiAnc2t5RnV6enlEYXRlJyxcbiAgcHVyZTogZmFsc2UsXG59KVxuZXhwb3J0IGNsYXNzIFNreUZ1enp5RGF0ZVBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgI2Z1enp5RGF0ZVNlcnZpY2U6IFNreUZ1enp5RGF0ZVNlcnZpY2U7XG5cbiAgY29uc3RydWN0b3IoZnV6enlEYXRlU2VydmljZTogU2t5RnV6enlEYXRlU2VydmljZSkge1xuICAgIHRoaXMuI2Z1enp5RGF0ZVNlcnZpY2UgPSBmdXp6eURhdGVTZXJ2aWNlO1xuICB9XG5cbiAgLyoqXG4gICAqIFRyYW5zZm9ybXMgZnV6enkgZGF0ZSB2YWx1ZXMgdXNpbmcgdHdvIG9yIG1vcmUgZGF0ZSB0b2tlbnMgdGhhdCByZXByZXNlbnQgdGhlIGRheSwgbW9udGgsXG4gICAqIGFuZCB5ZWFyLlxuICAgKiBAcGFyYW0gdmFsdWUgU3BlY2lmaWVzIHRoZSBkYXRlIHZhbHVlIHRvIHRyYW5zZm9ybS5cbiAgICogQHBhcmFtIGZvcm1hdCBTcGVjaWZpZXMgdGhlIGZvcm1hdCB0byBhcHBseSB0byB0aGUgdHJhbnNmb3JtLiBZb3UgY29uc3RydWN0IHRoZSBmb3JtYXRcbiAgICogc3RyaW5nIHdpdGggYSB0d28gb3IgbW9yZSB0b2tlbnMgdGhhdCBzcGVjaWZ5IHRoZSBjb21wb25lbnRzIG9mIGRhdGUtdGltZSB2YWx1ZS4gVGhlXG4gICAqIHRva2VucyBhcmUgZGVzY3JpYmVkIGluIHRoZSBbbW9tZW50LmpzIHZhbHVlc10oaHR0cHM6Ly9tb21lbnRqcy5jb20vZG9jcy8jL2Rpc3BsYXlpbmcvKS5cbiAgICogSWYgeW91IGRvbid0IHByb3ZpZGUgYSBmb3JtYXQsIGBTa3lGdXp6eURhdGVQaXBlYCBhdHRlbXB0cyB0byBmb3JtYXQgZnV6enkgZGF0ZXMgYmFzZWRcbiAgICogb24gdGhlIGJyb3dzZXIncyBkZWZhdWx0IGxvY2FsZS5cbiAgICogQHBhcmFtIGxvY2FsZSBTcGVjaWZpZXMgdGhlIGxvY2FsZSBjb2RlIHRvIHVzZSBpbiB0aGUgdHJhbnNmb3JtLlxuICAgKi9cbiAgcHVibGljIHRyYW5zZm9ybShcbiAgICB2YWx1ZTogU2t5RnV6enlEYXRlLFxuICAgIGZvcm1hdD86IHN0cmluZyxcbiAgICBsb2NhbGU/OiBzdHJpbmcsXG4gICk6IHN0cmluZyB7XG4gICAgaWYgKCF2YWx1ZSkge1xuICAgICAgcmV0dXJuICcnO1xuICAgIH1cbiAgICBjb25zdCBmdXp6eURhdGVGb3JtYXQgPVxuICAgICAgZm9ybWF0IHx8IHRoaXMuI2Z1enp5RGF0ZVNlcnZpY2UuZ2V0TG9jYWxlU2hvcnRGb3JtYXQobG9jYWxlKTtcbiAgICBjb25zdCBmdXp6eURhdGVMb2NhbGUgPSBsb2NhbGUgfHwgdGhpcy4jZnV6enlEYXRlU2VydmljZS5nZXRDdXJyZW50TG9jYWxlKCk7XG4gICAgcmV0dXJuIHRoaXMuI2Z1enp5RGF0ZVNlcnZpY2UuZm9ybWF0KFxuICAgICAgdmFsdWUsXG4gICAgICBmdXp6eURhdGVGb3JtYXQsXG4gICAgICBmdXp6eURhdGVMb2NhbGUsXG4gICAgKTtcbiAgfVxufVxuIl19
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnV6enktZGF0ZS5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2RhdGV0aW1lL3NyYy9saWIvbW9kdWxlcy9kYXRlLXBpcGUvZnV6enktZGF0ZS5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOzs7QUFLcEQ7Ozs7Ozs7O0dBUUc7QUFLSCxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLGlCQUFpQixDQUFzQjtJQUV2QyxZQUFZLGdCQUFxQztRQUMvQyxJQUFJLENBQUMsaUJBQWlCLEdBQUcsZ0JBQWdCLENBQUM7SUFDNUMsQ0FBQztJQUVEOzs7Ozs7Ozs7O09BVUc7SUFDSSxTQUFTLENBQ2QsS0FBbUIsRUFDbkIsTUFBZSxFQUNmLE1BQWU7UUFFZixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDWCxPQUFPLEVBQUUsQ0FBQztRQUNaLENBQUM7UUFDRCxNQUFNLGVBQWUsR0FDbkIsTUFBTSxJQUFJLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxvQkFBb0IsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNoRSxNQUFNLGVBQWUsR0FBRyxNQUFNLElBQUksSUFBSSxDQUFDLGlCQUFpQixDQUFDLGdCQUFnQixFQUFFLENBQUM7UUFDNUUsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUMsTUFBTSxDQUNsQyxLQUFLLEVBQ0wsZUFBZSxFQUNmLGVBQWUsQ0FDaEIsQ0FBQztJQUNKLENBQUM7K0dBbENVLGdCQUFnQjs2R0FBaEIsZ0JBQWdCOzs0RkFBaEIsZ0JBQWdCO2tCQUo1QixJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSxjQUFjO29CQUNwQixJQUFJLEVBQUUsS0FBSztpQkFDWiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgU2t5RnV6enlEYXRlIH0gZnJvbSAnLi4vZGF0ZXBpY2tlci9mdXp6eS9mdXp6eS1kYXRlJztcbmltcG9ydCB7IFNreUZ1enp5RGF0ZVNlcnZpY2UgfSBmcm9tICcuLi9kYXRlcGlja2VyL2Z1enp5L2Z1enp5LWRhdGUuc2VydmljZSc7XG5cbi8qKlxuICogRm9ybWF0cyBkYXRlIHZhbHVlcyB1c2luZyB0d28gb3IgbW9yZSBkYXRlIHRva2VucyB0aGF0IHJlcHJlc2VudCB0aGUgZGF5LCBtb250aCxcbiAqIGFuZCB5ZWFyLiBUaGUgdG9rZW5zIGFyZSBkZXNjcmliZWQgaW4gdGhlIFttb21lbnQuanMgdmFsdWVzXShodHRwczovL21vbWVudGpzLmNvbS9kb2NzLyMvZGlzcGxheWluZy8pLlxuICogQGV4YW1wbGVcbiAqIGBgYG1hcmt1cFxuICoge3sgbXlGdXp6eURhdGUgfCBza3lGdXp6eURhdGU6J01NTSBZJyB9fVxuICoge3sgbXlGdXp6eURhdGUgfCBza3lGdXp6eURhdGU6J01NTSBZJzonZW4tQ0EnIH19XG4gKiBgYGBcbiAqL1xuQFBpcGUoe1xuICBuYW1lOiAnc2t5RnV6enlEYXRlJyxcbiAgcHVyZTogZmFsc2UsXG59KVxuZXhwb3J0IGNsYXNzIFNreUZ1enp5RGF0ZVBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgI2Z1enp5RGF0ZVNlcnZpY2U6IFNreUZ1enp5RGF0ZVNlcnZpY2U7XG5cbiAgY29uc3RydWN0b3IoZnV6enlEYXRlU2VydmljZTogU2t5RnV6enlEYXRlU2VydmljZSkge1xuICAgIHRoaXMuI2Z1enp5RGF0ZVNlcnZpY2UgPSBmdXp6eURhdGVTZXJ2aWNlO1xuICB9XG5cbiAgLyoqXG4gICAqIFRyYW5zZm9ybXMgZnV6enkgZGF0ZSB2YWx1ZXMgdXNpbmcgdHdvIG9yIG1vcmUgZGF0ZSB0b2tlbnMgdGhhdCByZXByZXNlbnQgdGhlIGRheSwgbW9udGgsXG4gICAqIGFuZCB5ZWFyLlxuICAgKiBAcGFyYW0gdmFsdWUgU3BlY2lmaWVzIHRoZSBkYXRlIHZhbHVlIHRvIHRyYW5zZm9ybS5cbiAgICogQHBhcmFtIGZvcm1hdCBTcGVjaWZpZXMgdGhlIGZvcm1hdCB0byBhcHBseSB0byB0aGUgdHJhbnNmb3JtLiBZb3UgY29uc3RydWN0IHRoZSBmb3JtYXRcbiAgICogc3RyaW5nIHdpdGggYSB0d28gb3IgbW9yZSB0b2tlbnMgdGhhdCBzcGVjaWZ5IHRoZSBjb21wb25lbnRzIG9mIGRhdGUtdGltZSB2YWx1ZS4gVGhlXG4gICAqIHRva2VucyBhcmUgZGVzY3JpYmVkIGluIHRoZSBbbW9tZW50LmpzIHZhbHVlc10oaHR0cHM6Ly9tb21lbnRqcy5jb20vZG9jcy8jL2Rpc3BsYXlpbmcvKS5cbiAgICogSWYgeW91IGRvbid0IHByb3ZpZGUgYSBmb3JtYXQsIGBTa3lGdXp6eURhdGVQaXBlYCBhdHRlbXB0cyB0byBmb3JtYXQgZnV6enkgZGF0ZXMgYmFzZWRcbiAgICogb24gdGhlIGJyb3dzZXIncyBkZWZhdWx0IGxvY2FsZS5cbiAgICogQHBhcmFtIGxvY2FsZSBTcGVjaWZpZXMgdGhlIGxvY2FsZSBjb2RlIHRvIHVzZSBpbiB0aGUgdHJhbnNmb3JtLlxuICAgKi9cbiAgcHVibGljIHRyYW5zZm9ybShcbiAgICB2YWx1ZTogU2t5RnV6enlEYXRlLFxuICAgIGZvcm1hdD86IHN0cmluZyxcbiAgICBsb2NhbGU/OiBzdHJpbmcsXG4gICk6IHN0cmluZyB7XG4gICAgaWYgKCF2YWx1ZSkge1xuICAgICAgcmV0dXJuICcnO1xuICAgIH1cbiAgICBjb25zdCBmdXp6eURhdGVGb3JtYXQgPVxuICAgICAgZm9ybWF0IHx8IHRoaXMuI2Z1enp5RGF0ZVNlcnZpY2UuZ2V0TG9jYWxlU2hvcnRGb3JtYXQobG9jYWxlKTtcbiAgICBjb25zdCBmdXp6eURhdGVMb2NhbGUgPSBsb2NhbGUgfHwgdGhpcy4jZnV6enlEYXRlU2VydmljZS5nZXRDdXJyZW50TG9jYWxlKCk7XG4gICAgcmV0dXJuIHRoaXMuI2Z1enp5RGF0ZVNlcnZpY2UuZm9ybWF0KFxuICAgICAgdmFsdWUsXG4gICAgICBmdXp6eURhdGVGb3JtYXQsXG4gICAgICBmdXp6eURhdGVMb2NhbGUsXG4gICAgKTtcbiAgfVxufVxuIl19
@@ -1,10 +1,11 @@
1
1
  import { CommonModule } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, DestroyRef, HostBinding, Injector, Input, booleanAttribute, computed, inject, runInInjectionContext, signal, } from '@angular/core';
2
+ import { ChangeDetectionStrategy, Component, DestroyRef, ElementRef, HostBinding, Injector, Input, booleanAttribute, computed, inject, runInInjectionContext, signal, viewChildren, } from '@angular/core';
3
3
  import { takeUntilDestroyed, toSignal } from '@angular/core/rxjs-interop';
4
4
  import { FormBuilder, FormControl, FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, ReactiveFormsModule, StatusChangeEvent, TouchedChangeEvent, } from '@angular/forms';
5
5
  import { SkyLogService } from '@skyux/core';
6
6
  import { SKY_FORM_ERRORS_ENABLED, SkyFormErrorsModule, SkyInputBoxModule, } from '@skyux/forms';
7
7
  import { distinctUntilChanged, filter, map } from 'rxjs';
8
+ import { SkyDatepickerComponent } from '../datepicker/datepicker.component';
8
9
  import { SkyDatepickerModule } from '../datepicker/datepicker.module';
9
10
  import { SkyDatetimeResourcesModule } from '../shared/sky-datetime-resources.module';
10
11
  import { SkyDateRangePickerEndDateResourceKeyPipe } from './date-range-picker-end-date-resource-key.pipe';
@@ -51,6 +52,7 @@ export class SkyDateRangePickerComponent {
51
52
  constructor() {
52
53
  this.#dateRangeSvc = inject(SkyDateRangeService);
53
54
  this.#destroyRef = inject(DestroyRef);
55
+ this.#elementRef = inject(ElementRef);
54
56
  this.#injector = inject(Injector);
55
57
  this.#logger = inject(SkyLogService);
56
58
  /**
@@ -59,6 +61,7 @@ export class SkyDateRangePickerComponent {
59
61
  */
60
62
  this.stacked = false;
61
63
  this.calculators = this.#dateRangeSvc.calculators;
64
+ this.datepickers = viewChildren(SkyDatepickerComponent);
62
65
  this.selectedCalculator = this.calculators[0];
63
66
  this.showEndDatePicker = signal(false);
64
67
  this.showStartDatePicker = signal(false);
@@ -98,6 +101,7 @@ export class SkyDateRangePickerComponent {
98
101
  }
99
102
  #dateRangeSvc;
100
103
  #destroyRef;
104
+ #elementRef;
101
105
  #injector;
102
106
  #logger;
103
107
  /**
@@ -253,9 +257,6 @@ export class SkyDateRangePickerComponent {
253
257
  });
254
258
  }
255
259
  }
256
- onBlur() {
257
- this.#notifyTouched?.();
258
- }
259
260
  /**
260
261
  * Fires when a user changes the selected calculator ID.
261
262
  */
@@ -273,6 +274,16 @@ export class SkyDateRangePickerComponent {
273
274
  this.#notifyChange?.(this.formGroup.getRawValue());
274
275
  });
275
276
  }
277
+ /**
278
+ * Fires when the date range picker loses focus.
279
+ */
280
+ onFocusout({ relatedTarget }) {
281
+ if (relatedTarget &&
282
+ !this.#elementRef.nativeElement.contains(relatedTarget) &&
283
+ !this.datepickers().some((picker) => picker.containsTarget(relatedTarget))) {
284
+ this.#notifyTouched?.();
285
+ }
286
+ }
276
287
  #getCalculator(calculatorId) {
277
288
  const found = this.calculators.find((c) => c.calculatorId === calculatorId);
278
289
  /*istanbul ignore if: safety check*/
@@ -364,7 +375,7 @@ export class SkyDateRangePickerComponent {
364
375
  return toSignal(control.events.pipe(filter((evt) => evt instanceof TouchedChangeEvent), map((evt) => evt.touched), takeUntilDestroyed(this.#destroyRef)));
365
376
  }
366
377
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDateRangePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
367
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: SkyDateRangePickerComponent, isStandalone: true, selector: "sky-date-range-picker", inputs: { calculatorIds: "calculatorIds", dateFormat: "dateFormat", disabled: ["disabled", "disabled", booleanAttribute], helpPopoverContent: "helpPopoverContent", helpPopoverTitle: "helpPopoverTitle", hintText: "hintText", label: "label", labelText: "labelText", stacked: ["stacked", "stacked", booleanAttribute], helpKey: "helpKey" }, host: { properties: { "class.sky-form-field-stacked": "this.stacked" } }, providers: [
378
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: SkyDateRangePickerComponent, isStandalone: true, selector: "sky-date-range-picker", inputs: { calculatorIds: "calculatorIds", dateFormat: "dateFormat", disabled: ["disabled", "disabled", booleanAttribute], helpPopoverContent: "helpPopoverContent", helpPopoverTitle: "helpPopoverTitle", hintText: "hintText", label: "label", labelText: "labelText", stacked: ["stacked", "stacked", booleanAttribute], helpKey: "helpKey" }, host: { listeners: { "focusout": "onFocusout($event)" }, properties: { "class.sky-form-field-stacked": "this.stacked" } }, providers: [
368
379
  {
369
380
  provide: NG_VALIDATORS,
370
381
  useExisting: SkyDateRangePickerComponent,
@@ -376,11 +387,13 @@ export class SkyDateRangePickerComponent {
376
387
  multi: true,
377
388
  },
378
389
  { provide: SKY_FORM_ERRORS_ENABLED, useValue: true },
379
- ], ngImport: i0, template: "<div class=\"sky-date-range-picker\" [formGroup]=\"formGroup\">\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-picker-select-calculator\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n !showStartDatePicker() && !showEndDatePicker()\n }\"\n >\n <sky-input-box\n [hasErrors]=\"calculatorIdHasErrors()\"\n [helpKey]=\"helpKey\"\n [helpPopoverContent]=\"helpPopoverContent\"\n [helpPopoverTitle]=\"helpPopoverTitle\"\n [hintText]=\"hintText\"\n [labelText]=\"\n labelText ||\n label ||\n ('skyux_date_range_picker_default_label' | skyLibResources)\n \"\n >\n <select\n formControlName=\"calculatorId\"\n (blur)=\"onBlur()\"\n (change)=\"onCalculatorIdChange()\"\n >\n @for (calculator of calculators; track calculator.calculatorId) {\n <option [value]=\"calculator.calculatorId\">\n {{\n calculator._shortDescriptionResourceKey\n ? (calculator._shortDescriptionResourceKey | skyLibResources)\n : calculator.shortDescription\n }}\n </option>\n }\n </select>\n @if (\n hostControl?.errors?.['skyDateRange']?.errors?.[\n 'endDateBeforeStartDate'\n ] && labelText\n ) {\n <sky-form-error\n errorName=\"endDateBeforeStartDate\"\n [errorText]=\"\n 'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n | skyLibResources\n \"\n />\n }\n <span class=\"sky-input-box-descendent-form-error\">\n <ng-content select=\"sky-form-error\" />\n </span>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-start-date\"\n [hidden]=\"!showStartDatePicker()\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n showStartDatePicker() && !showEndDatePicker()\n }\"\n >\n <sky-input-box\n [hasErrors]=\"startDateHasErrors()\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n <input\n formControlName=\"startDate\"\n name=\"startDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showStartDatePicker()\"\n (change)=\"onDateChange()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-end-date\"\n [hidden]=\"!showEndDatePicker()\"\n [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker() }\"\n >\n <sky-input-box\n [hasErrors]=\"endDateHasErrors()\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n <input\n formControlName=\"endDate\"\n name=\"endDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showEndDatePicker()\"\n (change)=\"onDateChange()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n</div>\n", styles: [".sky-date-range-picker:not(.sky-theme-modern *){--sky-override-date-range-picker-margin-right: 0;--sky-override-date-range-picker-padding-left: 5px;--sky-override-date-range-picker-padding-right: 5px;--sky-override-date-range-picker-responsive-bottom-margin: var( --sky-margin-stacked-lg )}:host{display:block}.sky-date-range-picker{display:flex}:host .sky-date-range-picker{flex-direction:column}:host .sky-date-range-picker-form-group{flex-basis:100%}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-override-date-range-picker-responsive-bottom-margin, var(--sky-space-gap-form-l));margin-right:0}:host-context(.sky-responsive-container-xs) .sky-date-range-picker,:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:column}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:100%}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-override-date-range-picker-responsive-bottom-margin, var(--sky-space-gap-form-l));margin-right:0}@media (min-width: 768px){:host .sky-date-range-picker{flex-direction:initial}:host .sky-date-range-picker-form-group{flex-basis:33.3333333333%;padding:0}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:var(--sky-override-date-range-picker-padding-left, 0)}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:var(--sky-override-date-range-picker-padding-right, 0)}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0;margin-right:var(--sky-override-date-range-picker-margin-right, var(--sky-space-gap-form-l))}}:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:initial}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:33.3333333333%;padding:0}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:var(--sky-override-date-range-picker-padding-left, 0)}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:var(--sky-override-date-range-picker-padding-right, 0)}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0;margin-right:var(--sky-override-date-range-picker-margin-right, var(--sky-space-gap-form-l))}@media (min-width: 768px){:host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}}.sky-responsive-container-sm :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-md :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-lg :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: SkyDatepickerModule }, { kind: "component", type: i3.SkyDatepickerComponent, selector: "sky-datepicker", inputs: ["pickerClass"], outputs: ["calendarDateRangeChange", "dateFormatChange", "openChange", "calendarDateChange"] }, { kind: "directive", type: i4.SkyDatepickerInputDirective, selector: "[skyDatepickerInput]", inputs: ["dateFormat", "disabled", "maxDate", "minDate", "startAtDate", "skyDatepickerInput", "skyDatepickerNoValidate", "startingDay", "strict"] }, { kind: "pipe", type: SkyDateRangePickerEndDateResourceKeyPipe, name: "skyDateRangePickerEndDateResourceKey" }, { kind: "pipe", type: SkyDateRangePickerStartDateResourceKeyPipe, name: "skyDateRangePickerStartDateResourceKey" }, { kind: "ngmodule", type: SkyDatetimeResourcesModule }, { kind: "pipe", type: i5.SkyLibResourcesPipe, name: "skyLibResources" }, { kind: "ngmodule", type: SkyInputBoxModule }, { kind: "component", type: i6.λ10, selector: "sky-input-box", inputs: ["hasErrors", "disabled", "labelText", "characterLimit", "stacked", "helpPopoverTitle", "helpPopoverContent", "helpKey", "hintText"] }, { kind: "directive", type: i6.λ20, selector: "input:not([skyId]):not(.sky-form-control),select:not([skyId]):not(.sky-form-control),textarea:not([skyId]):not(.sky-form-control)", inputs: ["autocomplete"] }, { kind: "component", type: i6.λ22, selector: "sky-form-error", inputs: ["errorName", "errorText"] }, { kind: "ngmodule", type: SkyFormErrorsModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
390
+ ], viewQueries: [{ propertyName: "datepickers", predicate: SkyDatepickerComponent, descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"sky-date-range-picker\" [formGroup]=\"formGroup\">\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-picker-select-calculator\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n !showStartDatePicker() && !showEndDatePicker()\n }\"\n >\n <sky-input-box\n [hasErrors]=\"calculatorIdHasErrors()\"\n [helpKey]=\"helpKey\"\n [helpPopoverContent]=\"helpPopoverContent\"\n [helpPopoverTitle]=\"helpPopoverTitle\"\n [hintText]=\"hintText\"\n [labelText]=\"\n labelText ||\n label ||\n ('skyux_date_range_picker_default_label' | skyLibResources)\n \"\n >\n <select formControlName=\"calculatorId\" (change)=\"onCalculatorIdChange()\">\n @for (calculator of calculators; track calculator.calculatorId) {\n <option [value]=\"calculator.calculatorId\">\n {{ calculator.shortDescription$ | async }}\n </option>\n }\n </select>\n @if (\n hostControl?.errors?.['skyDateRange']?.errors?.[\n 'endDateBeforeStartDate'\n ] && labelText\n ) {\n <sky-form-error\n errorName=\"endDateBeforeStartDate\"\n [errorText]=\"\n 'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n | skyLibResources\n \"\n />\n }\n <span class=\"sky-input-box-descendent-form-error\">\n <ng-content select=\"sky-form-error\" />\n </span>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-start-date\"\n [hidden]=\"!showStartDatePicker()\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n showStartDatePicker() && !showEndDatePicker()\n }\"\n >\n <sky-input-box\n [hasErrors]=\"startDateHasErrors()\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n <input\n formControlName=\"startDate\"\n name=\"startDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showStartDatePicker()\"\n (change)=\"onDateChange()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-end-date\"\n [hidden]=\"!showEndDatePicker()\"\n [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker() }\"\n >\n <sky-input-box\n [hasErrors]=\"endDateHasErrors()\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n <input\n formControlName=\"endDate\"\n name=\"endDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showEndDatePicker()\"\n (change)=\"onDateChange()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n</div>\n", styles: [".sky-date-range-picker:not(.sky-theme-modern *){--sky-override-date-range-picker-margin-right: 0;--sky-override-date-range-picker-padding-left: 5px;--sky-override-date-range-picker-padding-right: 5px;--sky-override-date-range-picker-responsive-bottom-margin: var( --sky-margin-stacked-lg )}:host{display:block}.sky-date-range-picker{display:flex}:host .sky-date-range-picker{flex-direction:column}:host .sky-date-range-picker-form-group{flex-basis:100%}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-override-date-range-picker-responsive-bottom-margin, var(--sky-space-gap-form-l));margin-right:0}:host-context(.sky-responsive-container-xs) .sky-date-range-picker,:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:column}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:100%}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-override-date-range-picker-responsive-bottom-margin, var(--sky-space-gap-form-l));margin-right:0}@media (min-width: 768px){:host .sky-date-range-picker{flex-direction:initial}:host .sky-date-range-picker-form-group{flex-basis:33.3333333333%;padding:0}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:var(--sky-override-date-range-picker-padding-left, 0)}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:var(--sky-override-date-range-picker-padding-right, 0)}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0;margin-right:var(--sky-override-date-range-picker-margin-right, var(--sky-space-gap-form-l))}}:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:initial}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:33.3333333333%;padding:0}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:var(--sky-override-date-range-picker-padding-left, 0)}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:var(--sky-override-date-range-picker-padding-right, 0)}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0;margin-right:var(--sky-override-date-range-picker-margin-right, var(--sky-space-gap-form-l))}@media (min-width: 768px){:host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}}.sky-responsive-container-sm :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-md :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-lg :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: SkyDatepickerModule }, { kind: "component", type: i3.SkyDatepickerComponent, selector: "sky-datepicker", inputs: ["pickerClass"], outputs: ["calendarDateRangeChange", "dateFormatChange", "openChange", "calendarDateChange"] }, { kind: "directive", type: i4.SkyDatepickerInputDirective, selector: "[skyDatepickerInput]", inputs: ["dateFormat", "disabled", "maxDate", "minDate", "startAtDate", "skyDatepickerInput", "skyDatepickerNoValidate", "startingDay", "strict"] }, { kind: "pipe", type: SkyDateRangePickerEndDateResourceKeyPipe, name: "skyDateRangePickerEndDateResourceKey" }, { kind: "pipe", type: SkyDateRangePickerStartDateResourceKeyPipe, name: "skyDateRangePickerStartDateResourceKey" }, { kind: "ngmodule", type: SkyDatetimeResourcesModule }, { kind: "pipe", type: i5.SkyLibResourcesPipe, name: "skyLibResources" }, { kind: "ngmodule", type: SkyInputBoxModule }, { kind: "component", type: i6.λ10, selector: "sky-input-box", inputs: ["hasErrors", "disabled", "labelText", "characterLimit", "stacked", "helpPopoverTitle", "helpPopoverContent", "helpKey", "hintText"] }, { kind: "directive", type: i6.λ20, selector: "input:not([skyId]):not(.sky-form-control),select:not([skyId]):not(.sky-form-control),textarea:not([skyId]):not(.sky-form-control)", inputs: ["autocomplete"] }, { kind: "component", type: i6.λ22, selector: "sky-form-error", inputs: ["errorName", "errorText"] }, { kind: "ngmodule", type: SkyFormErrorsModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
380
391
  }
381
392
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDateRangePickerComponent, decorators: [{
382
393
  type: Component,
383
- args: [{ changeDetection: ChangeDetectionStrategy.OnPush, imports: [
394
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, host: {
395
+ '(focusout)': 'onFocusout($event)',
396
+ }, imports: [
384
397
  CommonModule,
385
398
  FormsModule,
386
399
  ReactiveFormsModule,
@@ -402,7 +415,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
402
415
  multi: true,
403
416
  },
404
417
  { provide: SKY_FORM_ERRORS_ENABLED, useValue: true },
405
- ], selector: 'sky-date-range-picker', standalone: true, template: "<div class=\"sky-date-range-picker\" [formGroup]=\"formGroup\">\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-picker-select-calculator\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n !showStartDatePicker() && !showEndDatePicker()\n }\"\n >\n <sky-input-box\n [hasErrors]=\"calculatorIdHasErrors()\"\n [helpKey]=\"helpKey\"\n [helpPopoverContent]=\"helpPopoverContent\"\n [helpPopoverTitle]=\"helpPopoverTitle\"\n [hintText]=\"hintText\"\n [labelText]=\"\n labelText ||\n label ||\n ('skyux_date_range_picker_default_label' | skyLibResources)\n \"\n >\n <select\n formControlName=\"calculatorId\"\n (blur)=\"onBlur()\"\n (change)=\"onCalculatorIdChange()\"\n >\n @for (calculator of calculators; track calculator.calculatorId) {\n <option [value]=\"calculator.calculatorId\">\n {{\n calculator._shortDescriptionResourceKey\n ? (calculator._shortDescriptionResourceKey | skyLibResources)\n : calculator.shortDescription\n }}\n </option>\n }\n </select>\n @if (\n hostControl?.errors?.['skyDateRange']?.errors?.[\n 'endDateBeforeStartDate'\n ] && labelText\n ) {\n <sky-form-error\n errorName=\"endDateBeforeStartDate\"\n [errorText]=\"\n 'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n | skyLibResources\n \"\n />\n }\n <span class=\"sky-input-box-descendent-form-error\">\n <ng-content select=\"sky-form-error\" />\n </span>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-start-date\"\n [hidden]=\"!showStartDatePicker()\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n showStartDatePicker() && !showEndDatePicker()\n }\"\n >\n <sky-input-box\n [hasErrors]=\"startDateHasErrors()\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n <input\n formControlName=\"startDate\"\n name=\"startDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showStartDatePicker()\"\n (change)=\"onDateChange()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-end-date\"\n [hidden]=\"!showEndDatePicker()\"\n [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker() }\"\n >\n <sky-input-box\n [hasErrors]=\"endDateHasErrors()\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n <input\n formControlName=\"endDate\"\n name=\"endDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showEndDatePicker()\"\n (change)=\"onDateChange()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n</div>\n", styles: [".sky-date-range-picker:not(.sky-theme-modern *){--sky-override-date-range-picker-margin-right: 0;--sky-override-date-range-picker-padding-left: 5px;--sky-override-date-range-picker-padding-right: 5px;--sky-override-date-range-picker-responsive-bottom-margin: var( --sky-margin-stacked-lg )}:host{display:block}.sky-date-range-picker{display:flex}:host .sky-date-range-picker{flex-direction:column}:host .sky-date-range-picker-form-group{flex-basis:100%}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-override-date-range-picker-responsive-bottom-margin, var(--sky-space-gap-form-l));margin-right:0}:host-context(.sky-responsive-container-xs) .sky-date-range-picker,:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:column}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:100%}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-override-date-range-picker-responsive-bottom-margin, var(--sky-space-gap-form-l));margin-right:0}@media (min-width: 768px){:host .sky-date-range-picker{flex-direction:initial}:host .sky-date-range-picker-form-group{flex-basis:33.3333333333%;padding:0}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:var(--sky-override-date-range-picker-padding-left, 0)}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:var(--sky-override-date-range-picker-padding-right, 0)}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0;margin-right:var(--sky-override-date-range-picker-margin-right, var(--sky-space-gap-form-l))}}:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:initial}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:33.3333333333%;padding:0}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:var(--sky-override-date-range-picker-padding-left, 0)}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:var(--sky-override-date-range-picker-padding-right, 0)}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0;margin-right:var(--sky-override-date-range-picker-margin-right, var(--sky-space-gap-form-l))}@media (min-width: 768px){:host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}}.sky-responsive-container-sm :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-md :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-lg :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}\n"] }]
418
+ ], selector: 'sky-date-range-picker', standalone: true, template: "<div class=\"sky-date-range-picker\" [formGroup]=\"formGroup\">\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-picker-select-calculator\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n !showStartDatePicker() && !showEndDatePicker()\n }\"\n >\n <sky-input-box\n [hasErrors]=\"calculatorIdHasErrors()\"\n [helpKey]=\"helpKey\"\n [helpPopoverContent]=\"helpPopoverContent\"\n [helpPopoverTitle]=\"helpPopoverTitle\"\n [hintText]=\"hintText\"\n [labelText]=\"\n labelText ||\n label ||\n ('skyux_date_range_picker_default_label' | skyLibResources)\n \"\n >\n <select formControlName=\"calculatorId\" (change)=\"onCalculatorIdChange()\">\n @for (calculator of calculators; track calculator.calculatorId) {\n <option [value]=\"calculator.calculatorId\">\n {{ calculator.shortDescription$ | async }}\n </option>\n }\n </select>\n @if (\n hostControl?.errors?.['skyDateRange']?.errors?.[\n 'endDateBeforeStartDate'\n ] && labelText\n ) {\n <sky-form-error\n errorName=\"endDateBeforeStartDate\"\n [errorText]=\"\n 'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n | skyLibResources\n \"\n />\n }\n <span class=\"sky-input-box-descendent-form-error\">\n <ng-content select=\"sky-form-error\" />\n </span>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-start-date\"\n [hidden]=\"!showStartDatePicker()\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n showStartDatePicker() && !showEndDatePicker()\n }\"\n >\n <sky-input-box\n [hasErrors]=\"startDateHasErrors()\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n <input\n formControlName=\"startDate\"\n name=\"startDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showStartDatePicker()\"\n (change)=\"onDateChange()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-end-date\"\n [hidden]=\"!showEndDatePicker()\"\n [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker() }\"\n >\n <sky-input-box\n [hasErrors]=\"endDateHasErrors()\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n <input\n formControlName=\"endDate\"\n name=\"endDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showEndDatePicker()\"\n (change)=\"onDateChange()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n</div>\n", styles: [".sky-date-range-picker:not(.sky-theme-modern *){--sky-override-date-range-picker-margin-right: 0;--sky-override-date-range-picker-padding-left: 5px;--sky-override-date-range-picker-padding-right: 5px;--sky-override-date-range-picker-responsive-bottom-margin: var( --sky-margin-stacked-lg )}:host{display:block}.sky-date-range-picker{display:flex}:host .sky-date-range-picker{flex-direction:column}:host .sky-date-range-picker-form-group{flex-basis:100%}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-override-date-range-picker-responsive-bottom-margin, var(--sky-space-gap-form-l));margin-right:0}:host-context(.sky-responsive-container-xs) .sky-date-range-picker,:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:column}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:100%}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-override-date-range-picker-responsive-bottom-margin, var(--sky-space-gap-form-l));margin-right:0}@media (min-width: 768px){:host .sky-date-range-picker{flex-direction:initial}:host .sky-date-range-picker-form-group{flex-basis:33.3333333333%;padding:0}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:var(--sky-override-date-range-picker-padding-left, 0)}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:var(--sky-override-date-range-picker-padding-right, 0)}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0;margin-right:var(--sky-override-date-range-picker-margin-right, var(--sky-space-gap-form-l))}}:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:initial}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:33.3333333333%;padding:0}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:var(--sky-override-date-range-picker-padding-left, 0)}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:var(--sky-override-date-range-picker-padding-right, 0)}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0;margin-right:var(--sky-override-date-range-picker-margin-right, var(--sky-space-gap-form-l))}@media (min-width: 768px){:host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}}.sky-responsive-container-sm :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-md :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-lg :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}\n"] }]
406
419
  }], propDecorators: { calculatorIds: [{
407
420
  type: Input
408
421
  }], dateFormat: [{
@@ -429,4 +442,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
429
442
  }], helpKey: [{
430
443
  type: Input
431
444
  }] } });
432
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-picker.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/date-range-picker/date-range-picker.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/date-range-picker/date-range-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  HostBinding,\n  Injector,\n  Input,\n  Signal,\n  TemplateRef,\n  booleanAttribute,\n  computed,\n  inject,\n  runInInjectionContext,\n  signal,\n} from '@angular/core';\nimport { takeUntilDestroyed, toSignal } from '@angular/core/rxjs-interop';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormBuilder,\n  FormControl,\n  FormsModule,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  NgControl,\n  ReactiveFormsModule,\n  StatusChangeEvent,\n  TouchedChangeEvent,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\nimport { SkyLogService } from '@skyux/core';\nimport {\n  SKY_FORM_ERRORS_ENABLED,\n  SkyFormErrorsModule,\n  SkyInputBoxModule,\n} from '@skyux/forms';\n\nimport { distinctUntilChanged, filter, map } from 'rxjs';\n\nimport { SkyDatepickerModule } from '../datepicker/datepicker.module';\nimport { SkyDatetimeResourcesModule } from '../shared/sky-datetime-resources.module';\n\nimport { SkyDateRangePickerEndDateResourceKeyPipe } from './date-range-picker-end-date-resource-key.pipe';\nimport { SkyDateRangePickerStartDateResourceKeyPipe } from './date-range-picker-start-date-resource-key.pipe';\nimport { SkyDateRangeService } from './date-range.service';\nimport { SkyDateRangeCalculation } from './types/date-range-calculation';\nimport { SkyDateRangeCalculator } from './types/date-range-calculator';\nimport { SkyDateRangeCalculatorId } from './types/date-range-calculator-id';\nimport { SkyDateRangeCalculatorType } from './types/date-range-calculator-type';\nimport { SKY_DEFAULT_CALCULATOR_IDS } from './types/date-range-default-calculator-configs';\n\ntype DateValue = Date | string | null | undefined;\n\nfunction areDateRangesEqual(\n  rangeA: SkyDateRangeCalculation | undefined,\n  rangeB: SkyDateRangeCalculation | undefined,\n): boolean {\n  return (\n    !!rangeA &&\n    !!rangeB &&\n    rangeA.calculatorId === rangeB.calculatorId &&\n    areDatesEqual(rangeA.startDate, rangeB.startDate) &&\n    areDatesEqual(rangeA.endDate, rangeB.endDate)\n  );\n}\n\nfunction areDatesEqual(a: DateValue, b: DateValue): boolean {\n  if (typeof a !== typeof b) {\n    return false;\n  }\n\n  if (!a && !b) {\n    return true;\n  }\n\n  if (typeof a === 'string' && a === b) {\n    return true;\n  }\n\n  return a instanceof Date && b instanceof Date && a.getTime() === b.getTime();\n}\n\nfunction isNullOrUndefined(value: unknown): value is undefined | null {\n  return value === undefined || value === null;\n}\n\nfunction isPartialValue(\n  value: Partial<SkyDateRangeCalculation> | null | undefined,\n): value is Partial<SkyDateRangeCalculation> | null | undefined {\n  return (\n    isNullOrUndefined(value) ||\n    isNullOrUndefined(value.calculatorId) ||\n    !('endDate' in value) ||\n    !('startDate' in value)\n  );\n}\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    SkyDatepickerModule,\n    SkyDateRangePickerEndDateResourceKeyPipe,\n    SkyDateRangePickerStartDateResourceKeyPipe,\n    SkyDatetimeResourcesModule,\n    SkyInputBoxModule,\n    SkyFormErrorsModule,\n  ],\n  providers: [\n    {\n      provide: NG_VALIDATORS,\n      useExisting: SkyDateRangePickerComponent,\n      multi: true,\n    },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: SkyDateRangePickerComponent,\n      multi: true,\n    },\n    { provide: SKY_FORM_ERRORS_ENABLED, useValue: true },\n  ],\n  selector: 'sky-date-range-picker',\n  standalone: true,\n  styleUrl: './date-range-picker.component.scss',\n  templateUrl: './date-range-picker.component.html',\n})\nexport class SkyDateRangePickerComponent\n  implements AfterViewInit, ControlValueAccessor, Validator\n{\n  readonly #dateRangeSvc = inject(SkyDateRangeService);\n  readonly #destroyRef = inject(DestroyRef);\n  readonly #injector = inject(Injector);\n  readonly #logger = inject(SkyLogService);\n\n  /**\n   * IDs for the date range options to include in the picker's dropdown.\n   * The options specify calculator objects that return two `Date` objects to represent date ranges.\n   * By default, this property includes all `SkyDateRangeCalculatorId` values.\n   */\n  @Input()\n  public set calculatorIds(\n    calculatorIds: SkyDateRangeCalculatorId[] | undefined,\n  ) {\n    const currentCalculatorId = this.#getValue().calculatorId;\n\n    this.#_calculatorIds = calculatorIds ?? SKY_DEFAULT_CALCULATOR_IDS;\n    this.calculators = this.#dateRangeSvc.filterCalculators(\n      this.#_calculatorIds,\n    );\n\n    // If the currently selected calculator isn't available anymore,\n    // select the first calculator in the new array.\n    if (!this.#_calculatorIds.includes(currentCalculatorId)) {\n      this.#setValue({ calculatorId: this.calculatorIds[0] });\n    }\n  }\n\n  public get calculatorIds(): SkyDateRangeCalculatorId[] {\n    return this.#_calculatorIds;\n  }\n\n  /**\n   * The date format for\n   * [the `sky-datepicker` components](https://developer.blackbaud.com/skyux/components/datepicker)\n   * that make up the date range picker. The text input is a composite component of\n   * up to two `sky-datepicker` components.\n   * @default \"MM/DD/YYYY\"\n   */\n  @Input()\n  public dateFormat: string | undefined;\n\n  /**\n   * Whether to disable the date range picker on template-driven forms. Don't use\n   * this input on reactive forms because they may overwrite the input or leave\n   * the control out of sync. To set the disabled state on reactive forms,\n   * use the `FormControl` instead.\n   * @default false\n   */\n  @Input({ transform: booleanAttribute })\n  public set disabled(value: boolean) {\n    if (value) {\n      this.formGroup.disable();\n    } else {\n      this.formGroup.enable();\n    }\n  }\n\n  /**\n   * The content of the help popover. When specified along with `labelText`, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is added to date range picker. The help inline button displays a [popover](https://developer.blackbaud.com/skyux/components/popover)\n   * when clicked using the specified content and optional title. This property only applies when `labelText` is also specified.\n   */\n  @Input()\n  public helpPopoverContent: string | TemplateRef<unknown> | undefined;\n\n  /**\n   * The title of the help popover. This property only applies when `helpPopoverContent` is\n   * also specified.\n   */\n  @Input()\n  public helpPopoverTitle: string | undefined;\n\n  /**\n   * [Persistent inline help text](https://developer.blackbaud.com/skyux/design/guidelines/user-assistance#inline-help) that provides\n   * additional context to the user.\n   */\n  @Input()\n  public hintText: string | undefined;\n\n  /**\n   * The label for the date range picker.\n   * @deprecated Use the `labelText` input instead.\n   */\n  @Input()\n  public set label(value: string | undefined) {\n    this.#_label = value;\n\n    if (value) {\n      this.#logger.deprecated('SkyDateRangePickerComponent.label', {\n        deprecationMajorVersion: 10,\n        replacementRecommendation: 'Use the `labelText` input instead.',\n      });\n    }\n  }\n\n  public get label(): string | undefined {\n    return this.#_label;\n  }\n\n  /**\n   * The text to display as the date range picker's label.\n   */\n  @Input()\n  public labelText: string | undefined;\n\n  /**\n   * Whether the date range picker is stacked on another form component. When specified, the appropriate\n   * vertical spacing is automatically added to the date range picker.\n   */\n  @Input({ transform: booleanAttribute })\n  @HostBinding('class.sky-form-field-stacked')\n  public stacked = false;\n\n  /**\n   * A help key that identifies the global help content to display. When specified along with `labelText`, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is placed beside the date range picker label. Clicking the button invokes [global help](https://developer.blackbaud.com/skyux/learn/develop/global-help)\n   * as configured by the application. This property only applies when `labelText` is also specified.\n   */\n  @Input()\n  public helpKey: string | undefined;\n\n  protected calculators = this.#dateRangeSvc.calculators;\n  protected hostControl: AbstractControl | null | undefined;\n  protected selectedCalculator = this.calculators[0];\n  protected showEndDatePicker = signal<boolean>(false);\n  protected showStartDatePicker = signal<boolean>(false);\n\n  #_calculatorIds = SKY_DEFAULT_CALCULATOR_IDS;\n  #_label: string | undefined;\n  #_value = this.selectedCalculator.getValue();\n\n  #hostHasCustomError: Signal<boolean | undefined> | undefined;\n  #notifyChange: ((_: SkyDateRangeCalculation) => void) | undefined;\n  #notifyTouched: (() => void) | undefined;\n\n  #calculatorIdControl = new FormControl<number>(\n    this.#getValue().calculatorId,\n    { nonNullable: true },\n  );\n  #calculatorIdInvalid = this.#createStatusChangeSignal(\n    this.#calculatorIdControl,\n  );\n  #calculatorIdTouched = this.#createTouchedChangeSignal(\n    this.#calculatorIdControl,\n  );\n\n  #endDateControl = new FormControl<DateValue>(this.#getValue().endDate);\n  #endDateInvalid = this.#createStatusChangeSignal(this.#endDateControl);\n  #endDateTouched = this.#createTouchedChangeSignal(this.#endDateControl);\n\n  #startDateControl = new FormControl<DateValue>(this.#getValue().startDate);\n  #startDateInvalid = this.#createStatusChangeSignal(this.#startDateControl);\n  #startDateTouched = this.#createTouchedChangeSignal(this.#startDateControl);\n\n  protected formGroup = inject(FormBuilder).group({\n    calculatorId: this.#calculatorIdControl,\n    startDate: this.#startDateControl,\n    endDate: this.#endDateControl,\n  });\n\n  protected readonly calculatorIdHasErrors = computed(() => {\n    const touched = this.#calculatorIdTouched();\n    const invalid = this.#calculatorIdInvalid() || this.#hostHasCustomError?.();\n    return touched && invalid;\n  });\n\n  protected readonly endDateHasErrors = computed(() => {\n    const calculatorIdHasErrors = this.calculatorIdHasErrors();\n    const touched = this.#endDateTouched();\n    const invalid = this.#endDateInvalid();\n\n    return calculatorIdHasErrors || (touched && invalid);\n  });\n\n  protected readonly startDateHasErrors = computed(() => {\n    const calculatorIdHasErrors = this.calculatorIdHasErrors();\n    const touched = this.#startDateTouched();\n    const invalid = this.#startDateInvalid();\n\n    return calculatorIdHasErrors || (touched && invalid);\n  });\n\n  public ngAfterViewInit(): void {\n    this.hostControl = this.#injector.get(NgControl, null, {\n      optional: true,\n      self: true,\n    })?.control;\n\n    runInInjectionContext(this.#injector, () => {\n      if (this.hostControl) {\n        this.#hostHasCustomError = this.#createHostCustomErrorChangeSignal(\n          this.hostControl,\n        );\n      }\n    });\n\n    // Set a default value on the control if it's undefined on init.\n    // We need to use setTimeout to avoid interfering with the first\n    // validation cycle.\n    if (isPartialValue(this.hostControl?.value)) {\n      setTimeout(() => {\n        this.hostControl?.setValue(this.#getValue(), {\n          emitEvent: false,\n        });\n      });\n    }\n\n    // If the datepickers' statuses change, we want to retrigger the host\n    // control's validation so that their errors are reflected back to the host.\n    this.formGroup.events\n      .pipe(\n        filter((evt) => evt instanceof StatusChangeEvent),\n        map((evt: StatusChangeEvent) => evt.status),\n        distinctUntilChanged(),\n        takeUntilDestroyed(this.#destroyRef),\n      )\n      .subscribe(() => {\n        this.hostControl?.updateValueAndValidity({\n          emitEvent: false,\n          onlySelf: true,\n        });\n      });\n\n    // Mark all fields as touched if the host control is touched.\n    this.hostControl?.events\n      .pipe(\n        filter((evt) => evt instanceof TouchedChangeEvent),\n        map((evt: TouchedChangeEvent) => evt.touched),\n        distinctUntilChanged(),\n        takeUntilDestroyed(this.#destroyRef),\n      )\n      .subscribe(() => {\n        this.formGroup.markAllAsTouched();\n      });\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public registerOnChange(fn: (_: unknown) => void): void {\n    this.#notifyChange = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public registerOnTouched(fn: () => void): void {\n    this.#notifyTouched = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  // Implemented as part of Validator.\n  public validate(control: AbstractControl): ValidationErrors | null {\n    let errors: ValidationErrors | null = null;\n\n    const calculatorErrors = this.selectedCalculator.validate(control.value);\n    const startDateErrors = this.#startDateControl.errors;\n    const endDateErrors = this.#endDateControl.errors;\n\n    if (calculatorErrors) {\n      errors = {\n        skyDateRange: {\n          calculatorId: this.#getValue().calculatorId,\n          errors: calculatorErrors,\n        },\n      };\n    }\n\n    // Set calculator errors on the select so that they appear beneath it.\n    this.#calculatorIdControl.setErrors(errors);\n\n    if (this.showStartDatePicker() && startDateErrors) {\n      errors ||= {};\n      errors = { ...errors, ...startDateErrors };\n    }\n\n    if (this.showEndDatePicker() && endDateErrors) {\n      errors ||= {};\n      errors = { ...errors, ...endDateErrors };\n    }\n\n    return errors;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  // The date range picker always has a value, so if the consumer passes in a\n  // partial value (via `patchValue`) or null, we need to update the host control's\n  // value with the complete value after it's been modified.\n  public writeValue(value: Partial<SkyDateRangeCalculation> | undefined): void {\n    this.#patchValue(value);\n\n    // Update the host control if it is set to a partial or null value.\n    if (isPartialValue(value)) {\n      this.hostControl?.setValue(this.#getValue(), {\n        emitEvent: false,\n        onlySelf: true,\n      });\n    }\n  }\n\n  protected onBlur(): void {\n    this.#notifyTouched?.();\n  }\n\n  /**\n   * Fires when a user changes the selected calculator ID.\n   */\n  protected onCalculatorIdChange(): void {\n    // Reset the value when the calculator ID changes.\n    this.#setValue({ calculatorId: +this.#calculatorIdControl.value });\n    this.onDateChange();\n  }\n\n  /**\n   * Fires when a user interacts with a date range picker.\n   */\n  protected onDateChange(): void {\n    // Wait until the form control is updated before retrieving its value.\n    setTimeout(() => {\n      this.#notifyChange?.(\n        this.formGroup.getRawValue() as SkyDateRangeCalculation,\n      );\n    });\n  }\n\n  #getCalculator(calculatorId: number): SkyDateRangeCalculator {\n    const found = this.calculators.find((c) => c.calculatorId === calculatorId);\n\n    /*istanbul ignore if: safety check*/\n    if (!found) {\n      throw new Error(\n        `A date range calculator with ID (${calculatorId}) could not be found.`,\n      );\n    }\n\n    return found;\n  }\n\n  #getValue(): SkyDateRangeCalculation {\n    // Important! Return a clone to avoid changing the properties by reference.\n    return { ...this.#_value };\n  }\n\n  #patchValue(\n    partialValue: Partial<SkyDateRangeCalculation> | null | undefined,\n  ): void {\n    if (isNullOrUndefined(partialValue)) {\n      this.#setValue(null);\n      return;\n    }\n\n    const oldValue = this.#getValue();\n\n    // If the new ID is distinct, erase the old start and end dates because\n    // they're no longer applicable.\n    if (\n      !isNullOrUndefined(partialValue.calculatorId) &&\n      oldValue.calculatorId !== partialValue.calculatorId\n    ) {\n      delete oldValue.endDate;\n      delete oldValue.startDate;\n    }\n\n    const value = {\n      ...oldValue,\n      ...partialValue,\n    };\n\n    this.#setValue(value);\n  }\n\n  /**\n   * Sets the value to be used by the date range picker form control.\n   */\n  #setValue(value: SkyDateRangeCalculation | null | undefined): void {\n    const oldValue = this.#getValue();\n\n    const isValueEmpty = !value || isNullOrUndefined(value.calculatorId);\n    const valueOrDefault = isValueEmpty\n      ? this.calculators[0].getValue()\n      : {\n          ...this.#getCalculator(value.calculatorId).getValue(),\n          ...value,\n        };\n\n    // Ensure falsy values are set to null.\n    valueOrDefault.endDate = valueOrDefault.endDate || null;\n    valueOrDefault.startDate = valueOrDefault.startDate || null;\n\n    if (!areDateRangesEqual(oldValue, valueOrDefault)) {\n      this.#_value = valueOrDefault;\n\n      if (oldValue.calculatorId !== valueOrDefault.calculatorId) {\n        this.selectedCalculator = this.#getCalculator(\n          valueOrDefault.calculatorId,\n        );\n\n        this.#updatePickerVisibility(this.selectedCalculator);\n      }\n\n      this.formGroup.patchValue(valueOrDefault);\n    }\n  }\n\n  #updatePickerVisibility(calculator: SkyDateRangeCalculator): void {\n    let showEndDatePicker = false;\n    let showStartDatePicker = false;\n\n    switch (calculator.type) {\n      case SkyDateRangeCalculatorType.Before:\n        showEndDatePicker = true;\n        break;\n\n      case SkyDateRangeCalculatorType.After:\n        showStartDatePicker = true;\n        break;\n\n      case SkyDateRangeCalculatorType.Range:\n        showEndDatePicker = true;\n        showStartDatePicker = true;\n        break;\n\n      default:\n        break;\n    }\n\n    this.showEndDatePicker.set(showEndDatePicker);\n    this.showStartDatePicker.set(showStartDatePicker);\n  }\n\n  #createHostCustomErrorChangeSignal(\n    control: AbstractControl,\n  ): Signal<boolean | undefined> {\n    return toSignal(\n      control.events.pipe(\n        filter((evt) => evt instanceof StatusChangeEvent),\n        map((evt: StatusChangeEvent) => {\n          const errors = evt.source.errors ?? [];\n          const knownErrors = ['required', 'skyDate'];\n\n          return Object.keys(errors).some((error) => {\n            return !knownErrors.includes(error);\n          });\n        }),\n      ),\n    );\n  }\n\n  #createStatusChangeSignal(control: FormControl): Signal<boolean | undefined> {\n    return toSignal(\n      control.events.pipe(\n        filter((evt) => evt instanceof StatusChangeEvent),\n        map((evt: StatusChangeEvent) => evt.status === 'INVALID'),\n        takeUntilDestroyed(this.#destroyRef),\n      ),\n    );\n  }\n\n  #createTouchedChangeSignal(\n    control: FormControl,\n  ): Signal<boolean | undefined> {\n    return toSignal(\n      control.events.pipe(\n        filter((evt) => evt instanceof TouchedChangeEvent),\n        map((evt: TouchedChangeEvent) => evt.touched),\n        takeUntilDestroyed(this.#destroyRef),\n      ),\n    );\n  }\n}\n","<div class=\"sky-date-range-picker\" [formGroup]=\"formGroup\">\n  <div\n    class=\"sky-date-range-picker-form-group sky-date-range-picker-select-calculator\"\n    [ngClass]=\"{\n      'sky-date-range-picker-last-input':\n        !showStartDatePicker() && !showEndDatePicker()\n    }\"\n  >\n    <sky-input-box\n      [hasErrors]=\"calculatorIdHasErrors()\"\n      [helpKey]=\"helpKey\"\n      [helpPopoverContent]=\"helpPopoverContent\"\n      [helpPopoverTitle]=\"helpPopoverTitle\"\n      [hintText]=\"hintText\"\n      [labelText]=\"\n        labelText ||\n        label ||\n        ('skyux_date_range_picker_default_label' | skyLibResources)\n      \"\n    >\n      <select\n        formControlName=\"calculatorId\"\n        (blur)=\"onBlur()\"\n        (change)=\"onCalculatorIdChange()\"\n      >\n        @for (calculator of calculators; track calculator.calculatorId) {\n          <option [value]=\"calculator.calculatorId\">\n            {{\n              calculator._shortDescriptionResourceKey\n                ? (calculator._shortDescriptionResourceKey | skyLibResources)\n                : calculator.shortDescription\n            }}\n          </option>\n        }\n      </select>\n      @if (\n        hostControl?.errors?.['skyDateRange']?.errors?.[\n          'endDateBeforeStartDate'\n        ] && labelText\n      ) {\n        <sky-form-error\n          errorName=\"endDateBeforeStartDate\"\n          [errorText]=\"\n            'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n              | skyLibResources\n          \"\n        />\n      }\n      <span class=\"sky-input-box-descendent-form-error\">\n        <ng-content select=\"sky-form-error\" />\n      </span>\n    </sky-input-box>\n  </div>\n  <div\n    class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-start-date\"\n    [hidden]=\"!showStartDatePicker()\"\n    [ngClass]=\"{\n      'sky-date-range-picker-last-input':\n        showStartDatePicker() && !showEndDatePicker()\n    }\"\n  >\n    <sky-input-box\n      [hasErrors]=\"startDateHasErrors()\"\n      [labelText]=\"\n        selectedCalculator.type\n          | skyDateRangePickerStartDateResourceKey\n          | skyLibResources\n      \"\n    >\n      <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n        <input\n          formControlName=\"startDate\"\n          name=\"startDate\"\n          skyDatepickerInput\n          type=\"text\"\n          [attr.aria-label]=\"\n            labelText || label\n              ? ('skyux_date_range_picker_default_aria_label'\n                | skyLibResources\n                  : (selectedCalculator.type\n                      | skyDateRangePickerStartDateResourceKey\n                      | skyLibResources)\n                  : (labelText ? labelText : label))\n              : (selectedCalculator.type\n                | skyDateRangePickerStartDateResourceKey\n                | skyLibResources)\n          \"\n          [dateFormat]=\"dateFormat\"\n          [required]=\"showStartDatePicker()\"\n          (change)=\"onDateChange()\"\n        />\n      </sky-datepicker>\n    </sky-input-box>\n  </div>\n  <div\n    class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-end-date\"\n    [hidden]=\"!showEndDatePicker()\"\n    [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker() }\"\n  >\n    <sky-input-box\n      [hasErrors]=\"endDateHasErrors()\"\n      [labelText]=\"\n        selectedCalculator.type\n          | skyDateRangePickerEndDateResourceKey\n          | skyLibResources\n      \"\n    >\n      <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n        <input\n          formControlName=\"endDate\"\n          name=\"endDate\"\n          skyDatepickerInput\n          type=\"text\"\n          [attr.aria-label]=\"\n            labelText || label\n              ? ('skyux_date_range_picker_default_aria_label'\n                | skyLibResources\n                  : (selectedCalculator.type\n                      | skyDateRangePickerEndDateResourceKey\n                      | skyLibResources)\n                  : (labelText ? labelText : label))\n              : (selectedCalculator.type\n                | skyDateRangePickerEndDateResourceKey\n                | skyLibResources)\n          \"\n          [dateFormat]=\"dateFormat\"\n          [required]=\"showEndDatePicker()\"\n          (change)=\"onDateChange()\"\n        />\n      </sky-datepicker>\n    </sky-input-box>\n  </div>\n</div>\n"]}
445
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-picker.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/date-range-picker/date-range-picker.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/date-range-picker/date-range-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  ElementRef,\n  HostBinding,\n  Injector,\n  Input,\n  Signal,\n  TemplateRef,\n  booleanAttribute,\n  computed,\n  inject,\n  runInInjectionContext,\n  signal,\n  viewChildren,\n} from '@angular/core';\nimport { takeUntilDestroyed, toSignal } from '@angular/core/rxjs-interop';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormBuilder,\n  FormControl,\n  FormsModule,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  NgControl,\n  ReactiveFormsModule,\n  StatusChangeEvent,\n  TouchedChangeEvent,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\nimport { SkyLogService } from '@skyux/core';\nimport {\n  SKY_FORM_ERRORS_ENABLED,\n  SkyFormErrorsModule,\n  SkyInputBoxModule,\n} from '@skyux/forms';\n\nimport { distinctUntilChanged, filter, map } from 'rxjs';\n\nimport { SkyDatepickerComponent } from '../datepicker/datepicker.component';\nimport { SkyDatepickerModule } from '../datepicker/datepicker.module';\nimport { SkyDatetimeResourcesModule } from '../shared/sky-datetime-resources.module';\n\nimport { SkyDateRangePickerEndDateResourceKeyPipe } from './date-range-picker-end-date-resource-key.pipe';\nimport { SkyDateRangePickerStartDateResourceKeyPipe } from './date-range-picker-start-date-resource-key.pipe';\nimport { SkyDateRangeService } from './date-range.service';\nimport { SkyDateRangeCalculation } from './types/date-range-calculation';\nimport { SkyDateRangeCalculator } from './types/date-range-calculator';\nimport { SkyDateRangeCalculatorId } from './types/date-range-calculator-id';\nimport { SkyDateRangeCalculatorType } from './types/date-range-calculator-type';\nimport { SKY_DEFAULT_CALCULATOR_IDS } from './types/date-range-default-calculator-configs';\n\ntype DateValue = Date | string | null | undefined;\n\nfunction areDateRangesEqual(\n  rangeA: SkyDateRangeCalculation | undefined,\n  rangeB: SkyDateRangeCalculation | undefined,\n): boolean {\n  return (\n    !!rangeA &&\n    !!rangeB &&\n    rangeA.calculatorId === rangeB.calculatorId &&\n    areDatesEqual(rangeA.startDate, rangeB.startDate) &&\n    areDatesEqual(rangeA.endDate, rangeB.endDate)\n  );\n}\n\nfunction areDatesEqual(a: DateValue, b: DateValue): boolean {\n  if (typeof a !== typeof b) {\n    return false;\n  }\n\n  if (!a && !b) {\n    return true;\n  }\n\n  if (typeof a === 'string' && a === b) {\n    return true;\n  }\n\n  return a instanceof Date && b instanceof Date && a.getTime() === b.getTime();\n}\n\nfunction isNullOrUndefined(value: unknown): value is undefined | null {\n  return value === undefined || value === null;\n}\n\nfunction isPartialValue(\n  value: Partial<SkyDateRangeCalculation> | null | undefined,\n): value is Partial<SkyDateRangeCalculation> | null | undefined {\n  return (\n    isNullOrUndefined(value) ||\n    isNullOrUndefined(value.calculatorId) ||\n    !('endDate' in value) ||\n    !('startDate' in value)\n  );\n}\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    '(focusout)': 'onFocusout($event)',\n  },\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    SkyDatepickerModule,\n    SkyDateRangePickerEndDateResourceKeyPipe,\n    SkyDateRangePickerStartDateResourceKeyPipe,\n    SkyDatetimeResourcesModule,\n    SkyInputBoxModule,\n    SkyFormErrorsModule,\n  ],\n  providers: [\n    {\n      provide: NG_VALIDATORS,\n      useExisting: SkyDateRangePickerComponent,\n      multi: true,\n    },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: SkyDateRangePickerComponent,\n      multi: true,\n    },\n    { provide: SKY_FORM_ERRORS_ENABLED, useValue: true },\n  ],\n  selector: 'sky-date-range-picker',\n  standalone: true,\n  styleUrl: './date-range-picker.component.scss',\n  templateUrl: './date-range-picker.component.html',\n})\nexport class SkyDateRangePickerComponent\n  implements AfterViewInit, ControlValueAccessor, Validator\n{\n  readonly #dateRangeSvc = inject(SkyDateRangeService);\n  readonly #destroyRef = inject(DestroyRef);\n  readonly #elementRef = inject(ElementRef);\n  readonly #injector = inject(Injector);\n  readonly #logger = inject(SkyLogService);\n\n  /**\n   * IDs for the date range options to include in the picker's dropdown.\n   * The options specify calculator objects that return two `Date` objects to represent date ranges.\n   * By default, this property includes all `SkyDateRangeCalculatorId` values.\n   */\n  @Input()\n  public set calculatorIds(\n    calculatorIds: SkyDateRangeCalculatorId[] | undefined,\n  ) {\n    const currentCalculatorId = this.#getValue().calculatorId;\n\n    this.#_calculatorIds = calculatorIds ?? SKY_DEFAULT_CALCULATOR_IDS;\n    this.calculators = this.#dateRangeSvc.filterCalculators(\n      this.#_calculatorIds,\n    );\n\n    // If the currently selected calculator isn't available anymore,\n    // select the first calculator in the new array.\n    if (!this.#_calculatorIds.includes(currentCalculatorId)) {\n      this.#setValue({ calculatorId: this.calculatorIds[0] });\n    }\n  }\n\n  public get calculatorIds(): SkyDateRangeCalculatorId[] {\n    return this.#_calculatorIds;\n  }\n\n  /**\n   * The date format for\n   * [the `sky-datepicker` components](https://developer.blackbaud.com/skyux/components/datepicker)\n   * that make up the date range picker. The text input is a composite component of\n   * up to two `sky-datepicker` components.\n   * @default \"MM/DD/YYYY\"\n   */\n  @Input()\n  public dateFormat: string | undefined;\n\n  /**\n   * Whether to disable the date range picker on template-driven forms. Don't use\n   * this input on reactive forms because they may overwrite the input or leave\n   * the control out of sync. To set the disabled state on reactive forms,\n   * use the `FormControl` instead.\n   * @default false\n   */\n  @Input({ transform: booleanAttribute })\n  public set disabled(value: boolean) {\n    if (value) {\n      this.formGroup.disable();\n    } else {\n      this.formGroup.enable();\n    }\n  }\n\n  /**\n   * The content of the help popover. When specified along with `labelText`, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is added to date range picker. The help inline button displays a [popover](https://developer.blackbaud.com/skyux/components/popover)\n   * when clicked using the specified content and optional title. This property only applies when `labelText` is also specified.\n   */\n  @Input()\n  public helpPopoverContent: string | TemplateRef<unknown> | undefined;\n\n  /**\n   * The title of the help popover. This property only applies when `helpPopoverContent` is\n   * also specified.\n   */\n  @Input()\n  public helpPopoverTitle: string | undefined;\n\n  /**\n   * [Persistent inline help text](https://developer.blackbaud.com/skyux/design/guidelines/user-assistance#inline-help) that provides\n   * additional context to the user.\n   */\n  @Input()\n  public hintText: string | undefined;\n\n  /**\n   * The label for the date range picker.\n   * @deprecated Use the `labelText` input instead.\n   */\n  @Input()\n  public set label(value: string | undefined) {\n    this.#_label = value;\n\n    if (value) {\n      this.#logger.deprecated('SkyDateRangePickerComponent.label', {\n        deprecationMajorVersion: 10,\n        replacementRecommendation: 'Use the `labelText` input instead.',\n      });\n    }\n  }\n\n  public get label(): string | undefined {\n    return this.#_label;\n  }\n\n  /**\n   * The text to display as the date range picker's label.\n   */\n  @Input()\n  public labelText: string | undefined;\n\n  /**\n   * Whether the date range picker is stacked on another form component. When specified, the appropriate\n   * vertical spacing is automatically added to the date range picker.\n   */\n  @Input({ transform: booleanAttribute })\n  @HostBinding('class.sky-form-field-stacked')\n  public stacked = false;\n\n  /**\n   * A help key that identifies the global help content to display. When specified along with `labelText`, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is placed beside the date range picker label. Clicking the button invokes [global help](https://developer.blackbaud.com/skyux/learn/develop/global-help)\n   * as configured by the application. This property only applies when `labelText` is also specified.\n   */\n  @Input()\n  public helpKey: string | undefined;\n\n  protected calculators = this.#dateRangeSvc.calculators;\n  protected datepickers = viewChildren(SkyDatepickerComponent);\n  protected hostControl: AbstractControl | null | undefined;\n  protected selectedCalculator = this.calculators[0];\n  protected showEndDatePicker = signal<boolean>(false);\n  protected showStartDatePicker = signal<boolean>(false);\n\n  #_calculatorIds = SKY_DEFAULT_CALCULATOR_IDS;\n  #_label: string | undefined;\n  #_value = this.selectedCalculator.getValue();\n\n  #hostHasCustomError: Signal<boolean | undefined> | undefined;\n  #notifyChange: ((_: SkyDateRangeCalculation) => void) | undefined;\n  #notifyTouched: (() => void) | undefined;\n\n  #calculatorIdControl = new FormControl<number>(\n    this.#getValue().calculatorId,\n    { nonNullable: true },\n  );\n  #calculatorIdInvalid = this.#createStatusChangeSignal(\n    this.#calculatorIdControl,\n  );\n  #calculatorIdTouched = this.#createTouchedChangeSignal(\n    this.#calculatorIdControl,\n  );\n\n  #endDateControl = new FormControl<DateValue>(this.#getValue().endDate);\n  #endDateInvalid = this.#createStatusChangeSignal(this.#endDateControl);\n  #endDateTouched = this.#createTouchedChangeSignal(this.#endDateControl);\n\n  #startDateControl = new FormControl<DateValue>(this.#getValue().startDate);\n  #startDateInvalid = this.#createStatusChangeSignal(this.#startDateControl);\n  #startDateTouched = this.#createTouchedChangeSignal(this.#startDateControl);\n\n  protected formGroup = inject(FormBuilder).group({\n    calculatorId: this.#calculatorIdControl,\n    startDate: this.#startDateControl,\n    endDate: this.#endDateControl,\n  });\n\n  protected readonly calculatorIdHasErrors = computed(() => {\n    const touched = this.#calculatorIdTouched();\n    const invalid = this.#calculatorIdInvalid() || this.#hostHasCustomError?.();\n    return touched && invalid;\n  });\n\n  protected readonly endDateHasErrors = computed(() => {\n    const calculatorIdHasErrors = this.calculatorIdHasErrors();\n    const touched = this.#endDateTouched();\n    const invalid = this.#endDateInvalid();\n\n    return calculatorIdHasErrors || (touched && invalid);\n  });\n\n  protected readonly startDateHasErrors = computed(() => {\n    const calculatorIdHasErrors = this.calculatorIdHasErrors();\n    const touched = this.#startDateTouched();\n    const invalid = this.#startDateInvalid();\n\n    return calculatorIdHasErrors || (touched && invalid);\n  });\n\n  public ngAfterViewInit(): void {\n    this.hostControl = this.#injector.get(NgControl, null, {\n      optional: true,\n      self: true,\n    })?.control;\n\n    runInInjectionContext(this.#injector, () => {\n      if (this.hostControl) {\n        this.#hostHasCustomError = this.#createHostCustomErrorChangeSignal(\n          this.hostControl,\n        );\n      }\n    });\n\n    // Set a default value on the control if it's undefined on init.\n    // We need to use setTimeout to avoid interfering with the first\n    // validation cycle.\n    if (isPartialValue(this.hostControl?.value)) {\n      setTimeout(() => {\n        this.hostControl?.setValue(this.#getValue(), {\n          emitEvent: false,\n        });\n      });\n    }\n\n    // If the datepickers' statuses change, we want to retrigger the host\n    // control's validation so that their errors are reflected back to the host.\n    this.formGroup.events\n      .pipe(\n        filter((evt) => evt instanceof StatusChangeEvent),\n        map((evt: StatusChangeEvent) => evt.status),\n        distinctUntilChanged(),\n        takeUntilDestroyed(this.#destroyRef),\n      )\n      .subscribe(() => {\n        this.hostControl?.updateValueAndValidity({\n          emitEvent: false,\n          onlySelf: true,\n        });\n      });\n\n    // Mark all fields as touched if the host control is touched.\n    this.hostControl?.events\n      .pipe(\n        filter((evt) => evt instanceof TouchedChangeEvent),\n        map((evt: TouchedChangeEvent) => evt.touched),\n        distinctUntilChanged(),\n        takeUntilDestroyed(this.#destroyRef),\n      )\n      .subscribe(() => {\n        this.formGroup.markAllAsTouched();\n      });\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public registerOnChange(fn: (_: unknown) => void): void {\n    this.#notifyChange = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public registerOnTouched(fn: () => void): void {\n    this.#notifyTouched = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  // Implemented as part of Validator.\n  public validate(control: AbstractControl): ValidationErrors | null {\n    let errors: ValidationErrors | null = null;\n\n    const calculatorErrors = this.selectedCalculator.validate(control.value);\n    const startDateErrors = this.#startDateControl.errors;\n    const endDateErrors = this.#endDateControl.errors;\n\n    if (calculatorErrors) {\n      errors = {\n        skyDateRange: {\n          calculatorId: this.#getValue().calculatorId,\n          errors: calculatorErrors,\n        },\n      };\n    }\n\n    // Set calculator errors on the select so that they appear beneath it.\n    this.#calculatorIdControl.setErrors(errors);\n\n    if (this.showStartDatePicker() && startDateErrors) {\n      errors ||= {};\n      errors = { ...errors, ...startDateErrors };\n    }\n\n    if (this.showEndDatePicker() && endDateErrors) {\n      errors ||= {};\n      errors = { ...errors, ...endDateErrors };\n    }\n\n    return errors;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  // The date range picker always has a value, so if the consumer passes in a\n  // partial value (via `patchValue`) or null, we need to update the host control's\n  // value with the complete value after it's been modified.\n  public writeValue(value: Partial<SkyDateRangeCalculation> | undefined): void {\n    this.#patchValue(value);\n\n    // Update the host control if it is set to a partial or null value.\n    if (isPartialValue(value)) {\n      this.hostControl?.setValue(this.#getValue(), {\n        emitEvent: false,\n        onlySelf: true,\n      });\n    }\n  }\n\n  /**\n   * Fires when a user changes the selected calculator ID.\n   */\n  protected onCalculatorIdChange(): void {\n    // Reset the value when the calculator ID changes.\n    this.#setValue({ calculatorId: +this.#calculatorIdControl.value });\n    this.onDateChange();\n  }\n\n  /**\n   * Fires when a user interacts with a date range picker.\n   */\n  protected onDateChange(): void {\n    // Wait until the form control is updated before retrieving its value.\n    setTimeout(() => {\n      this.#notifyChange?.(\n        this.formGroup.getRawValue() as SkyDateRangeCalculation,\n      );\n    });\n  }\n\n  /**\n   * Fires when the date range picker loses focus.\n   */\n  protected onFocusout({ relatedTarget }: FocusEvent): void {\n    if (\n      relatedTarget &&\n      !this.#elementRef.nativeElement.contains(relatedTarget) &&\n      !this.datepickers().some((picker) => picker.containsTarget(relatedTarget))\n    ) {\n      this.#notifyTouched?.();\n    }\n  }\n\n  #getCalculator(calculatorId: number): SkyDateRangeCalculator {\n    const found = this.calculators.find((c) => c.calculatorId === calculatorId);\n\n    /*istanbul ignore if: safety check*/\n    if (!found) {\n      throw new Error(\n        `A date range calculator with ID (${calculatorId}) could not be found.`,\n      );\n    }\n\n    return found;\n  }\n\n  #getValue(): SkyDateRangeCalculation {\n    // Important! Return a clone to avoid changing the properties by reference.\n    return { ...this.#_value };\n  }\n\n  #patchValue(\n    partialValue: Partial<SkyDateRangeCalculation> | null | undefined,\n  ): void {\n    if (isNullOrUndefined(partialValue)) {\n      this.#setValue(null);\n      return;\n    }\n\n    const oldValue = this.#getValue();\n\n    // If the new ID is distinct, erase the old start and end dates because\n    // they're no longer applicable.\n    if (\n      !isNullOrUndefined(partialValue.calculatorId) &&\n      oldValue.calculatorId !== partialValue.calculatorId\n    ) {\n      delete oldValue.endDate;\n      delete oldValue.startDate;\n    }\n\n    const value = {\n      ...oldValue,\n      ...partialValue,\n    };\n\n    this.#setValue(value);\n  }\n\n  /**\n   * Sets the value to be used by the date range picker form control.\n   */\n  #setValue(value: SkyDateRangeCalculation | null | undefined): void {\n    const oldValue = this.#getValue();\n\n    const isValueEmpty = !value || isNullOrUndefined(value.calculatorId);\n    const valueOrDefault = isValueEmpty\n      ? this.calculators[0].getValue()\n      : {\n          ...this.#getCalculator(value.calculatorId).getValue(),\n          ...value,\n        };\n\n    // Ensure falsy values are set to null.\n    valueOrDefault.endDate = valueOrDefault.endDate || null;\n    valueOrDefault.startDate = valueOrDefault.startDate || null;\n\n    if (!areDateRangesEqual(oldValue, valueOrDefault)) {\n      this.#_value = valueOrDefault;\n\n      if (oldValue.calculatorId !== valueOrDefault.calculatorId) {\n        this.selectedCalculator = this.#getCalculator(\n          valueOrDefault.calculatorId,\n        );\n\n        this.#updatePickerVisibility(this.selectedCalculator);\n      }\n\n      this.formGroup.patchValue(valueOrDefault);\n    }\n  }\n\n  #updatePickerVisibility(calculator: SkyDateRangeCalculator): void {\n    let showEndDatePicker = false;\n    let showStartDatePicker = false;\n\n    switch (calculator.type) {\n      case SkyDateRangeCalculatorType.Before:\n        showEndDatePicker = true;\n        break;\n\n      case SkyDateRangeCalculatorType.After:\n        showStartDatePicker = true;\n        break;\n\n      case SkyDateRangeCalculatorType.Range:\n        showEndDatePicker = true;\n        showStartDatePicker = true;\n        break;\n\n      default:\n        break;\n    }\n\n    this.showEndDatePicker.set(showEndDatePicker);\n    this.showStartDatePicker.set(showStartDatePicker);\n  }\n\n  #createHostCustomErrorChangeSignal(\n    control: AbstractControl,\n  ): Signal<boolean | undefined> {\n    return toSignal(\n      control.events.pipe(\n        filter((evt) => evt instanceof StatusChangeEvent),\n        map((evt: StatusChangeEvent) => {\n          const errors = evt.source.errors ?? [];\n          const knownErrors = ['required', 'skyDate'];\n\n          return Object.keys(errors).some((error) => {\n            return !knownErrors.includes(error);\n          });\n        }),\n      ),\n    );\n  }\n\n  #createStatusChangeSignal(control: FormControl): Signal<boolean | undefined> {\n    return toSignal(\n      control.events.pipe(\n        filter((evt) => evt instanceof StatusChangeEvent),\n        map((evt: StatusChangeEvent) => evt.status === 'INVALID'),\n        takeUntilDestroyed(this.#destroyRef),\n      ),\n    );\n  }\n\n  #createTouchedChangeSignal(\n    control: FormControl,\n  ): Signal<boolean | undefined> {\n    return toSignal(\n      control.events.pipe(\n        filter((evt) => evt instanceof TouchedChangeEvent),\n        map((evt: TouchedChangeEvent) => evt.touched),\n        takeUntilDestroyed(this.#destroyRef),\n      ),\n    );\n  }\n}\n","<div class=\"sky-date-range-picker\" [formGroup]=\"formGroup\">\n  <div\n    class=\"sky-date-range-picker-form-group sky-date-range-picker-select-calculator\"\n    [ngClass]=\"{\n      'sky-date-range-picker-last-input':\n        !showStartDatePicker() && !showEndDatePicker()\n    }\"\n  >\n    <sky-input-box\n      [hasErrors]=\"calculatorIdHasErrors()\"\n      [helpKey]=\"helpKey\"\n      [helpPopoverContent]=\"helpPopoverContent\"\n      [helpPopoverTitle]=\"helpPopoverTitle\"\n      [hintText]=\"hintText\"\n      [labelText]=\"\n        labelText ||\n        label ||\n        ('skyux_date_range_picker_default_label' | skyLibResources)\n      \"\n    >\n      <select formControlName=\"calculatorId\" (change)=\"onCalculatorIdChange()\">\n        @for (calculator of calculators; track calculator.calculatorId) {\n          <option [value]=\"calculator.calculatorId\">\n            {{ calculator.shortDescription$ | async }}\n          </option>\n        }\n      </select>\n      @if (\n        hostControl?.errors?.['skyDateRange']?.errors?.[\n          'endDateBeforeStartDate'\n        ] && labelText\n      ) {\n        <sky-form-error\n          errorName=\"endDateBeforeStartDate\"\n          [errorText]=\"\n            'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n              | skyLibResources\n          \"\n        />\n      }\n      <span class=\"sky-input-box-descendent-form-error\">\n        <ng-content select=\"sky-form-error\" />\n      </span>\n    </sky-input-box>\n  </div>\n  <div\n    class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-start-date\"\n    [hidden]=\"!showStartDatePicker()\"\n    [ngClass]=\"{\n      'sky-date-range-picker-last-input':\n        showStartDatePicker() && !showEndDatePicker()\n    }\"\n  >\n    <sky-input-box\n      [hasErrors]=\"startDateHasErrors()\"\n      [labelText]=\"\n        selectedCalculator.type\n          | skyDateRangePickerStartDateResourceKey\n          | skyLibResources\n      \"\n    >\n      <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n        <input\n          formControlName=\"startDate\"\n          name=\"startDate\"\n          skyDatepickerInput\n          type=\"text\"\n          [attr.aria-label]=\"\n            labelText || label\n              ? ('skyux_date_range_picker_default_aria_label'\n                | skyLibResources\n                  : (selectedCalculator.type\n                      | skyDateRangePickerStartDateResourceKey\n                      | skyLibResources)\n                  : (labelText ? labelText : label))\n              : (selectedCalculator.type\n                | skyDateRangePickerStartDateResourceKey\n                | skyLibResources)\n          \"\n          [dateFormat]=\"dateFormat\"\n          [required]=\"showStartDatePicker()\"\n          (change)=\"onDateChange()\"\n        />\n      </sky-datepicker>\n    </sky-input-box>\n  </div>\n  <div\n    class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-end-date\"\n    [hidden]=\"!showEndDatePicker()\"\n    [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker() }\"\n  >\n    <sky-input-box\n      [hasErrors]=\"endDateHasErrors()\"\n      [labelText]=\"\n        selectedCalculator.type\n          | skyDateRangePickerEndDateResourceKey\n          | skyLibResources\n      \"\n    >\n      <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n        <input\n          formControlName=\"endDate\"\n          name=\"endDate\"\n          skyDatepickerInput\n          type=\"text\"\n          [attr.aria-label]=\"\n            labelText || label\n              ? ('skyux_date_range_picker_default_aria_label'\n                | skyLibResources\n                  : (selectedCalculator.type\n                      | skyDateRangePickerEndDateResourceKey\n                      | skyLibResources)\n                  : (labelText ? labelText : label))\n              : (selectedCalculator.type\n                | skyDateRangePickerEndDateResourceKey\n                | skyLibResources)\n          \"\n          [dateFormat]=\"dateFormat\"\n          [required]=\"showEndDatePicker()\"\n          (change)=\"onDateChange()\"\n        />\n      </sky-datepicker>\n    </sky-input-box>\n  </div>\n</div>\n"]}