@skyux/datetime 8.6.0 → 9.0.0-alpha.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 (96) hide show
  1. package/documentation.json +8 -8
  2. package/esm2022/lib/modules/date-pipe/date-format-utility.mjs +45 -0
  3. package/{esm2020 → esm2022}/lib/modules/date-pipe/date-pipe.module.mjs +5 -5
  4. package/esm2022/lib/modules/date-pipe/date.pipe.mjs +67 -0
  5. package/esm2022/lib/modules/date-pipe/fuzzy-date.pipe.mjs +47 -0
  6. package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +4 -4
  7. package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +4 -4
  8. package/esm2022/lib/modules/date-range-picker/date-range-picker.component.mjs +518 -0
  9. package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker.module.mjs +19 -19
  10. package/esm2022/lib/modules/date-range-picker/date-range.service.mjs +97 -0
  11. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator.mjs +54 -0
  12. package/esm2022/lib/modules/datepicker/date-formatter.mjs +38 -0
  13. package/esm2022/lib/modules/datepicker/datepicker-adapter.service.mjs +23 -0
  14. package/esm2022/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +332 -0
  15. package/esm2022/lib/modules/datepicker/datepicker-calendar.component.mjs +95 -0
  16. package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-config.service.mjs +4 -4
  17. package/esm2022/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +487 -0
  18. package/esm2022/lib/modules/datepicker/datepicker-input.directive.mjs +534 -0
  19. package/esm2022/lib/modules/datepicker/datepicker.component.mjs +327 -0
  20. package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker.module.mjs +35 -35
  21. package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker.service.mjs +4 -4
  22. package/{esm2020 → esm2022}/lib/modules/datepicker/daypicker-button.component.mjs +4 -4
  23. package/esm2022/lib/modules/datepicker/daypicker-cell.component.mjs +128 -0
  24. package/esm2022/lib/modules/datepicker/daypicker.component.mjs +224 -0
  25. package/esm2022/lib/modules/datepicker/fuzzy-date.service.mjs +412 -0
  26. package/esm2022/lib/modules/datepicker/monthpicker.component.mjs +80 -0
  27. package/{esm2020 → esm2022}/lib/modules/datepicker/yearpicker.component.mjs +53 -54
  28. package/{esm2020 → esm2022}/lib/modules/shared/sky-datetime-resources.module.mjs +11 -11
  29. package/esm2022/lib/modules/timepicker/timepicker.component.mjs +396 -0
  30. package/esm2022/lib/modules/timepicker/timepicker.directive.mjs +237 -0
  31. package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker.module.mjs +17 -17
  32. package/esm2022/testing/datepicker-fixture.mjs +55 -0
  33. package/esm2022/testing/timepicker-fixture.mjs +52 -0
  34. package/fesm2022/skyux-datetime-testing.mjs +112 -0
  35. package/{fesm2020 → fesm2022}/skyux-datetime-testing.mjs.map +1 -1
  36. package/fesm2022/skyux-datetime.mjs +5030 -0
  37. package/fesm2022/skyux-datetime.mjs.map +1 -0
  38. package/lib/modules/date-range-picker/date-range-picker.component.d.ts +1 -1
  39. package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +1 -1
  40. package/lib/modules/datepicker/datepicker-calendar.component.d.ts +1 -1
  41. package/lib/modules/datepicker/datepicker-input-fuzzy.directive.d.ts +1 -1
  42. package/lib/modules/datepicker/datepicker-input.directive.d.ts +1 -1
  43. package/lib/modules/datepicker/datepicker.component.d.ts +1 -1
  44. package/lib/modules/datepicker/daypicker-button.component.d.ts +1 -1
  45. package/lib/modules/datepicker/daypicker-cell.component.d.ts +1 -1
  46. package/lib/modules/datepicker/daypicker.component.d.ts +1 -1
  47. package/lib/modules/timepicker/timepicker.directive.d.ts +1 -1
  48. package/package.json +19 -27
  49. package/esm2020/lib/modules/date-pipe/date-format-utility.mjs +0 -45
  50. package/esm2020/lib/modules/date-pipe/date.pipe.mjs +0 -70
  51. package/esm2020/lib/modules/date-pipe/fuzzy-date.pipe.mjs +0 -50
  52. package/esm2020/lib/modules/date-range-picker/date-range-picker.component.mjs +0 -494
  53. package/esm2020/lib/modules/date-range-picker/date-range.service.mjs +0 -100
  54. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator.mjs +0 -53
  55. package/esm2020/lib/modules/datepicker/date-formatter.mjs +0 -38
  56. package/esm2020/lib/modules/datepicker/datepicker-adapter.service.mjs +0 -26
  57. package/esm2020/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +0 -333
  58. package/esm2020/lib/modules/datepicker/datepicker-calendar.component.mjs +0 -96
  59. package/esm2020/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +0 -462
  60. package/esm2020/lib/modules/datepicker/datepicker-input.directive.mjs +0 -496
  61. package/esm2020/lib/modules/datepicker/datepicker.component.mjs +0 -319
  62. package/esm2020/lib/modules/datepicker/daypicker-cell.component.mjs +0 -126
  63. package/esm2020/lib/modules/datepicker/daypicker.component.mjs +0 -216
  64. package/esm2020/lib/modules/datepicker/fuzzy-date.service.mjs +0 -392
  65. package/esm2020/lib/modules/datepicker/monthpicker.component.mjs +0 -81
  66. package/esm2020/lib/modules/timepicker/timepicker.component.mjs +0 -389
  67. package/esm2020/lib/modules/timepicker/timepicker.directive.mjs +0 -236
  68. package/esm2020/testing/datepicker-fixture.mjs +0 -58
  69. package/esm2020/testing/timepicker-fixture.mjs +0 -55
  70. package/fesm2015/skyux-datetime-testing.mjs +0 -117
  71. package/fesm2015/skyux-datetime-testing.mjs.map +0 -1
  72. package/fesm2015/skyux-datetime.mjs +0 -4925
  73. package/fesm2015/skyux-datetime.mjs.map +0 -1
  74. package/fesm2020/skyux-datetime-testing.mjs +0 -117
  75. package/fesm2020/skyux-datetime.mjs +0 -4895
  76. package/fesm2020/skyux-datetime.mjs.map +0 -1
  77. /package/{esm2020 → esm2022}/index.mjs +0 -0
  78. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculation.mjs +0 -0
  79. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-config.mjs +0 -0
  80. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +0 -0
  81. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-id.mjs +0 -0
  82. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-type.mjs +0 -0
  83. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +0 -0
  84. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-default-calculator-config.mjs +0 -0
  85. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +0 -0
  86. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-relative-value.mjs +0 -0
  87. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range.mjs +0 -0
  88. /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-calendar-change.mjs +0 -0
  89. /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-custom-date.mjs +0 -0
  90. /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-date.mjs +0 -0
  91. /package/{esm2020 → esm2022}/lib/modules/datepicker/fuzzy-date.mjs +0 -0
  92. /package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker-time-format-type.mjs +0 -0
  93. /package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker-time-output.mjs +0 -0
  94. /package/{esm2020 → esm2022}/skyux-datetime.mjs +0 -0
  95. /package/{esm2020 → esm2022}/testing/public-api.mjs +0 -0
  96. /package/{esm2020 → esm2022}/testing/skyux-datetime-testing.mjs +0 -0
@@ -1,494 +0,0 @@
1
- var _SkyDateRangePickerComponent_instances, _SkyDateRangePickerComponent_calculatorIdControl_get, _SkyDateRangePickerComponent_defaultCalculator_get, _SkyDateRangePickerComponent_defaultValue_get, _SkyDateRangePickerComponent_endDateControl_get, _SkyDateRangePickerComponent_startDateControl_get, _SkyDateRangePickerComponent_value, _SkyDateRangePickerComponent_valueOrDefault_set, _SkyDateRangePickerComponent_valueOrDefault_get, _SkyDateRangePickerComponent_control, _SkyDateRangePickerComponent_preferredShortDateFormat, _SkyDateRangePickerComponent_ngUnsubscribe, _SkyDateRangePickerComponent__calculatorIds, _SkyDateRangePickerComponent__dateFormat, _SkyDateRangePickerComponent__disabled, _SkyDateRangePickerComponent__valueOrDefault, _SkyDateRangePickerComponent_changeDetector, _SkyDateRangePickerComponent_dateRangeService, _SkyDateRangePickerComponent_formBuilder, _SkyDateRangePickerComponent_localeProvider, _SkyDateRangePickerComponent_ngZone, _SkyDateRangePickerComponent_setValue, _SkyDateRangePickerComponent_patchValue, _SkyDateRangePickerComponent_createForm, _SkyDateRangePickerComponent_showRelevantFormFields, _SkyDateRangePickerComponent_resetFormGroupValue, _SkyDateRangePickerComponent_addEventListeners, _SkyDateRangePickerComponent_updateBasedOnControls, _SkyDateRangePickerComponent_updateCalculators, _SkyDateRangePickerComponent_getCalculatorById, _SkyDateRangePickerComponent_dateRangesEqual, _SkyDateRangePickerComponent_updateSelectedCalculator, _SkyDateRangePickerComponent_onChange, _SkyDateRangePickerComponent_onTouched;
2
- import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
- import { ChangeDetectionStrategy, Component, Input, Optional, forwardRef, } from '@angular/core';
4
- import { NG_VALIDATORS, NG_VALUE_ACCESSOR, UntypedFormControl, } from '@angular/forms';
5
- import { Subject, combineLatest } from 'rxjs';
6
- import { distinctUntilChanged, first, takeUntil } from 'rxjs/operators';
7
- import { SkyDateFormatter } from '../datepicker/date-formatter';
8
- import { SkyDateRangeCalculatorId } from './types/date-range-calculator-id';
9
- import { SkyDateRangeCalculatorType } from './types/date-range-calculator-type';
10
- import * as i0 from "@angular/core";
11
- import * as i1 from "./date-range.service";
12
- import * as i2 from "@angular/forms";
13
- import * as i3 from "@skyux/i18n";
14
- import * as i4 from "@skyux/theme";
15
- import * as i5 from "@angular/common";
16
- import * as i6 from "../datepicker/datepicker.component";
17
- import * as i7 from "../datepicker/datepicker-input.directive";
18
- import * as i8 from "@skyux/forms";
19
- import * as i9 from "./date-range-picker-end-date-resource-key.pipe";
20
- import * as i10 from "./date-range-picker-start-date-resource-key.pipe";
21
- const SKY_DATE_RANGE_PICKER_VALUE_ACCESSOR = {
22
- provide: NG_VALUE_ACCESSOR,
23
- useExisting: forwardRef(() => SkyDateRangePickerComponent),
24
- multi: true,
25
- };
26
- const SKY_DATE_RANGE_PICKER_VALIDATOR = {
27
- provide: NG_VALIDATORS,
28
- useExisting: forwardRef(() => SkyDateRangePickerComponent),
29
- multi: true,
30
- };
31
- let uniqueId = 0;
32
- /**
33
- * Acts as a form control with a form model of type `SkyDateRangeCalculation`.
34
- * @example
35
- * ```
36
- * <sky-date-range-picker
37
- * formControlName="myPicker"
38
- * >
39
- * </sky-date-range-picker>
40
- * ```
41
- */
42
- export class SkyDateRangePickerComponent {
43
- /**
44
- * IDs for the date range options to include in the picker's dropdown.
45
- * The options specify calculator objects that return two `Date` objects to represent date ranges.
46
- * By default, this property includes all `SkyDateRangeCalculatorId` values.
47
- */
48
- set calculatorIds(value) {
49
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent__calculatorIds, value || [
50
- SkyDateRangeCalculatorId.AnyTime,
51
- SkyDateRangeCalculatorId.Before,
52
- SkyDateRangeCalculatorId.After,
53
- SkyDateRangeCalculatorId.SpecificRange,
54
- SkyDateRangeCalculatorId.Yesterday,
55
- SkyDateRangeCalculatorId.Today,
56
- SkyDateRangeCalculatorId.Tomorrow,
57
- SkyDateRangeCalculatorId.LastWeek,
58
- SkyDateRangeCalculatorId.ThisWeek,
59
- SkyDateRangeCalculatorId.NextWeek,
60
- SkyDateRangeCalculatorId.LastMonth,
61
- SkyDateRangeCalculatorId.ThisMonth,
62
- SkyDateRangeCalculatorId.NextMonth,
63
- SkyDateRangeCalculatorId.LastQuarter,
64
- SkyDateRangeCalculatorId.ThisQuarter,
65
- SkyDateRangeCalculatorId.NextQuarter,
66
- SkyDateRangeCalculatorId.LastCalendarYear,
67
- SkyDateRangeCalculatorId.ThisCalendarYear,
68
- SkyDateRangeCalculatorId.NextCalendarYear,
69
- SkyDateRangeCalculatorId.LastFiscalYear,
70
- SkyDateRangeCalculatorId.ThisFiscalYear,
71
- SkyDateRangeCalculatorId.NextFiscalYear,
72
- ], "f");
73
- }
74
- get calculatorIds() {
75
- return __classPrivateFieldGet(this, _SkyDateRangePickerComponent__calculatorIds, "f");
76
- }
77
- /**
78
- * The date format for
79
- * [the `sky-datepicker` components](https://developer.blackbaud.com/skyux/components/datepicker)
80
- * that make up the date range picker. The text input is a composite component of
81
- * up to two `sky-datepicker` components.
82
- * @default "MM/DD/YYYY"
83
- */
84
- set dateFormat(value) {
85
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent__dateFormat, value, "f");
86
- this.dateFormatOrDefault = value || __classPrivateFieldGet(this, _SkyDateRangePickerComponent_preferredShortDateFormat, "f");
87
- }
88
- get dateFormat() {
89
- return __classPrivateFieldGet(this, _SkyDateRangePickerComponent__dateFormat, "f");
90
- }
91
- /**
92
- * Whether to disable the date range picker on template-driven forms. Don't use this input on reactive forms because they may overwrite the input or leave the control out of sync.
93
- * To set the disabled state on reactive forms, use the `FormControl` instead.
94
- * @default false
95
- */
96
- set disabled(value) {
97
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent__disabled, value, "f");
98
- if (this.formGroup) {
99
- if (__classPrivateFieldGet(this, _SkyDateRangePickerComponent__disabled, "f")) {
100
- this.formGroup.disable();
101
- }
102
- else {
103
- this.formGroup.enable();
104
- }
105
- }
106
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_changeDetector, "f").markForCheck();
107
- }
108
- get disabled() {
109
- return __classPrivateFieldGet(this, _SkyDateRangePickerComponent__disabled, "f");
110
- }
111
- constructor(changeDetector, dateRangeService, formBuilder, localeProvider, ngZone, themeSvc) {
112
- _SkyDateRangePickerComponent_instances.add(this);
113
- /**
114
- * Whether to require users to specify a start date.
115
- * @default false
116
- */
117
- this.startDateRequired = false;
118
- /**
119
- * Whether to require users to specify a end date.
120
- * @default false
121
- */
122
- this.endDateRequired = false;
123
- this.dateRangePickerId = `sky-date-range-picker-${uniqueId++}`;
124
- this.calculators = [];
125
- this.isReady = false;
126
- this.showEndDatePicker = false;
127
- this.showStartDatePicker = false;
128
- _SkyDateRangePickerComponent_value.set(this, void 0);
129
- _SkyDateRangePickerComponent_control.set(this, void 0);
130
- _SkyDateRangePickerComponent_preferredShortDateFormat.set(this, void 0);
131
- _SkyDateRangePickerComponent_ngUnsubscribe.set(this, new Subject());
132
- _SkyDateRangePickerComponent__calculatorIds.set(this, [
133
- SkyDateRangeCalculatorId.AnyTime,
134
- SkyDateRangeCalculatorId.Before,
135
- SkyDateRangeCalculatorId.After,
136
- SkyDateRangeCalculatorId.SpecificRange,
137
- SkyDateRangeCalculatorId.Yesterday,
138
- SkyDateRangeCalculatorId.Today,
139
- SkyDateRangeCalculatorId.Tomorrow,
140
- SkyDateRangeCalculatorId.LastWeek,
141
- SkyDateRangeCalculatorId.ThisWeek,
142
- SkyDateRangeCalculatorId.NextWeek,
143
- SkyDateRangeCalculatorId.LastMonth,
144
- SkyDateRangeCalculatorId.ThisMonth,
145
- SkyDateRangeCalculatorId.NextMonth,
146
- SkyDateRangeCalculatorId.LastQuarter,
147
- SkyDateRangeCalculatorId.ThisQuarter,
148
- SkyDateRangeCalculatorId.NextQuarter,
149
- SkyDateRangeCalculatorId.LastCalendarYear,
150
- SkyDateRangeCalculatorId.ThisCalendarYear,
151
- SkyDateRangeCalculatorId.NextCalendarYear,
152
- SkyDateRangeCalculatorId.LastFiscalYear,
153
- SkyDateRangeCalculatorId.ThisFiscalYear,
154
- SkyDateRangeCalculatorId.NextFiscalYear,
155
- ]);
156
- _SkyDateRangePickerComponent__dateFormat.set(this, void 0);
157
- _SkyDateRangePickerComponent__disabled.set(this, false);
158
- _SkyDateRangePickerComponent__valueOrDefault.set(this, void 0);
159
- _SkyDateRangePickerComponent_changeDetector.set(this, void 0);
160
- _SkyDateRangePickerComponent_dateRangeService.set(this, void 0);
161
- _SkyDateRangePickerComponent_formBuilder.set(this, void 0);
162
- _SkyDateRangePickerComponent_localeProvider.set(this, void 0);
163
- _SkyDateRangePickerComponent_ngZone.set(this, void 0);
164
- /* istanbul ignore next */
165
- // eslint-disable-next-line @typescript-eslint/no-empty-function, @typescript-eslint/no-unused-vars
166
- _SkyDateRangePickerComponent_onChange.set(this, (_) => { });
167
- /* istanbul ignore next */
168
- // eslint-disable-next-line @typescript-eslint/no-empty-function
169
- _SkyDateRangePickerComponent_onTouched.set(this, () => { });
170
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent_changeDetector, changeDetector, "f");
171
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent_dateRangeService, dateRangeService, "f");
172
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent_formBuilder, formBuilder, "f");
173
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent_localeProvider, localeProvider, "f");
174
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent_ngZone, ngZone, "f");
175
- this.dateFormatOrDefault = this.dateFormat;
176
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_localeProvider, "f")
177
- .getLocaleInfo()
178
- .pipe(takeUntil(__classPrivateFieldGet(this, _SkyDateRangePickerComponent_ngUnsubscribe, "f")))
179
- .subscribe((localeInfo) => {
180
- SkyDateFormatter.setLocale(localeInfo.locale);
181
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent_preferredShortDateFormat, SkyDateFormatter.getPreferredShortDateFormat(), "f");
182
- this.dateFormatOrDefault =
183
- this.dateFormat || __classPrivateFieldGet(this, _SkyDateRangePickerComponent_preferredShortDateFormat, "f");
184
- });
185
- // Update icons when theme changes.
186
- /* istanbul ignore next */
187
- themeSvc?.settingsChange
188
- .pipe(takeUntil(__classPrivateFieldGet(this, _SkyDateRangePickerComponent_ngUnsubscribe, "f")))
189
- .subscribe(() => {
190
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_changeDetector, "f").markForCheck();
191
- });
192
- }
193
- ngOnInit() {
194
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_createForm).call(this);
195
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_updateCalculators).call(this).then(() => {
196
- if (!__classPrivateFieldGet(this, _SkyDateRangePickerComponent_value, "f") || !__classPrivateFieldGet(this, _SkyDateRangePickerComponent_value, "f").calculatorId) {
197
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent_instances, __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_defaultValue_get), "a", _SkyDateRangePickerComponent_valueOrDefault_set);
198
- }
199
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_addEventListeners).call(this);
200
- this.isReady = true;
201
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_showRelevantFormFields).call(this);
202
- // We need to let Angular be stable and have rendered the components prior to setting the values and form controls. This ensures all initial validation will be ran correctly.
203
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_ngZone, "f").onStable.pipe(first()).subscribe(() => {
204
- // Fill in any unprovided values after the calculators have been initialized.
205
- // For example, if the control is initialized with only the `calculatorId`,
206
- // allow the calculator to fill in the missing start and end dates.
207
- const defaultValue = this.selectedCalculator?.getValue(__classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_valueOrDefault_get)?.startDate, __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_valueOrDefault_get)?.endDate);
208
- const newValue = Object.assign({}, defaultValue, __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_valueOrDefault_get));
209
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_setValue).call(this, newValue, false);
210
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_resetFormGroupValue).call(this);
211
- // This is needed to address a bug in Angular 4.
212
- // When a control value is set initially, its value is not represented on the view.
213
- // See: https://github.com/angular/angular/issues/13792
214
- /* istanbul ignore else */
215
- if (__classPrivateFieldGet(this, _SkyDateRangePickerComponent_control, "f")) {
216
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_control, "f").setValue(__classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_valueOrDefault_get), {
217
- emitEvent: false,
218
- });
219
- }
220
- });
221
- });
222
- }
223
- ngOnChanges(changes) {
224
- if (changes['calculatorIds'] &&
225
- changes['calculatorIds'].firstChange === false) {
226
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_updateCalculators).call(this).then(() => {
227
- const id = __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_calculatorIdControl_get)?.value;
228
- // Maintain the currently selected values if the calculators change after
229
- // a value has been chosen.
230
- const found = this.calculators.find((calculator) => {
231
- return calculator.calculatorId === id;
232
- });
233
- /* istanbul ignore else */
234
- if (!found) {
235
- const newValue = __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_defaultCalculator_get)?.getValue();
236
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_setValue).call(this, newValue);
237
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_resetFormGroupValue).call(this, newValue);
238
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_showRelevantFormFields).call(this);
239
- }
240
- });
241
- }
242
- }
243
- ngOnDestroy() {
244
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_ngUnsubscribe, "f").next();
245
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_ngUnsubscribe, "f").complete();
246
- }
247
- onFieldBlur() {
248
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_onTouched, "f").call(this);
249
- }
250
- writeValue(value) {
251
- // Only update the underlying controls when the calculators are ready.
252
- const notifyChange = false;
253
- // (We still need to save the initial value set by the consumer's form, however.)
254
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_setValue).call(this, value, notifyChange);
255
- if (this.isReady) {
256
- // When the control's value is set to `null`,
257
- // set it to the default value.
258
- if (!value) {
259
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_onChange, "f").call(this, __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_defaultValue_get));
260
- }
261
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_resetFormGroupValue).call(this);
262
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_showRelevantFormFields).call(this);
263
- }
264
- }
265
- validate(control) {
266
- if (!__classPrivateFieldGet(this, _SkyDateRangePickerComponent_control, "f")) {
267
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent_control, control, "f");
268
- }
269
- if (!this.isReady) {
270
- return null;
271
- }
272
- const value = control.value;
273
- const idControl = __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_calculatorIdControl_get);
274
- const result = this.selectedCalculator?.validate(value);
275
- let errors = null;
276
- if (result) {
277
- errors = {
278
- skyDateRange: {
279
- calculatorId: idControl?.value,
280
- errors: result,
281
- },
282
- };
283
- }
284
- else {
285
- let startErrors = null;
286
- let endErrors = null;
287
- if (__classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_startDateControl_get)) {
288
- startErrors = __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_startDateControl_get).errors;
289
- }
290
- if (__classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_endDateControl_get)) {
291
- endErrors = __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_endDateControl_get).errors;
292
- }
293
- errors = startErrors || endErrors;
294
- }
295
- if (!errors) {
296
- // Clear any errors on the calculator select.
297
- idControl?.setErrors(null);
298
- return null;
299
- }
300
- idControl?.setErrors(errors);
301
- idControl?.markAsTouched();
302
- idControl?.markAsDirty();
303
- // Need to mark the control as touched for the error messages to appear.
304
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_control, "f").markAsTouched();
305
- // Notify the view to display any errors.
306
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_changeDetector, "f").markForCheck();
307
- return errors;
308
- }
309
- registerOnChange(fn) {
310
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent_onChange, fn, "f");
311
- }
312
- registerOnTouched(fn) {
313
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent_onTouched, fn, "f");
314
- }
315
- setDisabledState(disabled) {
316
- this.disabled = disabled;
317
- }
318
- }
319
- _SkyDateRangePickerComponent_value = new WeakMap(), _SkyDateRangePickerComponent_control = new WeakMap(), _SkyDateRangePickerComponent_preferredShortDateFormat = new WeakMap(), _SkyDateRangePickerComponent_ngUnsubscribe = new WeakMap(), _SkyDateRangePickerComponent__calculatorIds = new WeakMap(), _SkyDateRangePickerComponent__dateFormat = new WeakMap(), _SkyDateRangePickerComponent__disabled = new WeakMap(), _SkyDateRangePickerComponent__valueOrDefault = new WeakMap(), _SkyDateRangePickerComponent_changeDetector = new WeakMap(), _SkyDateRangePickerComponent_dateRangeService = new WeakMap(), _SkyDateRangePickerComponent_formBuilder = new WeakMap(), _SkyDateRangePickerComponent_localeProvider = new WeakMap(), _SkyDateRangePickerComponent_ngZone = new WeakMap(), _SkyDateRangePickerComponent_onChange = new WeakMap(), _SkyDateRangePickerComponent_onTouched = new WeakMap(), _SkyDateRangePickerComponent_instances = new WeakSet(), _SkyDateRangePickerComponent_calculatorIdControl_get = function _SkyDateRangePickerComponent_calculatorIdControl_get() {
320
- return this.formGroup?.get('calculatorId');
321
- }, _SkyDateRangePickerComponent_defaultCalculator_get = function _SkyDateRangePickerComponent_defaultCalculator_get() {
322
- return this.calculators[0];
323
- }, _SkyDateRangePickerComponent_defaultValue_get = function _SkyDateRangePickerComponent_defaultValue_get() {
324
- return __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_defaultCalculator_get)?.getValue();
325
- }, _SkyDateRangePickerComponent_endDateControl_get = function _SkyDateRangePickerComponent_endDateControl_get() {
326
- return this.formGroup?.get('endDate');
327
- }, _SkyDateRangePickerComponent_startDateControl_get = function _SkyDateRangePickerComponent_startDateControl_get() {
328
- return this.formGroup?.get('startDate');
329
- }, _SkyDateRangePickerComponent_valueOrDefault_set = function _SkyDateRangePickerComponent_valueOrDefault_set(value) {
330
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent__valueOrDefault, value, "f");
331
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_updateSelectedCalculator).call(this);
332
- }, _SkyDateRangePickerComponent_valueOrDefault_get = function _SkyDateRangePickerComponent_valueOrDefault_get() {
333
- return __classPrivateFieldGet(this, _SkyDateRangePickerComponent__valueOrDefault, "f");
334
- }, _SkyDateRangePickerComponent_setValue = function _SkyDateRangePickerComponent_setValue(value, notifyChange = true) {
335
- const isNewValue = !__classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_dateRangesEqual).call(this, __classPrivateFieldGet(this, _SkyDateRangePickerComponent_value, "f"), value);
336
- if (isNewValue) {
337
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent_value, value, "f");
338
- if (!value || value.calculatorId === undefined) {
339
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent_instances, __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_defaultValue_get), "a", _SkyDateRangePickerComponent_valueOrDefault_set);
340
- }
341
- else {
342
- __classPrivateFieldSet(this, _SkyDateRangePickerComponent_instances, value, "a", _SkyDateRangePickerComponent_valueOrDefault_set);
343
- }
344
- if (notifyChange) {
345
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_onChange, "f").call(this, __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_valueOrDefault_get));
346
- }
347
- }
348
- }, _SkyDateRangePickerComponent_patchValue = function _SkyDateRangePickerComponent_patchValue(value) {
349
- const newValue = Object.assign({}, __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_valueOrDefault_get), value);
350
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_setValue).call(this, newValue);
351
- }, _SkyDateRangePickerComponent_createForm = function _SkyDateRangePickerComponent_createForm() {
352
- this.formGroup = __classPrivateFieldGet(this, _SkyDateRangePickerComponent_formBuilder, "f").group({
353
- calculatorId: new UntypedFormControl(),
354
- startDate: new UntypedFormControl(),
355
- endDate: new UntypedFormControl(),
356
- });
357
- if (this.disabled) {
358
- this.formGroup.disable();
359
- }
360
- }, _SkyDateRangePickerComponent_showRelevantFormFields = function _SkyDateRangePickerComponent_showRelevantFormFields() {
361
- const calculator = this.selectedCalculator;
362
- let showEndDatePicker = false;
363
- let showStartDatePicker = false;
364
- switch (calculator?.type) {
365
- case SkyDateRangeCalculatorType.Before:
366
- showEndDatePicker = true;
367
- break;
368
- case SkyDateRangeCalculatorType.After:
369
- showStartDatePicker = true;
370
- break;
371
- case SkyDateRangeCalculatorType.Range:
372
- showEndDatePicker = true;
373
- showStartDatePicker = true;
374
- break;
375
- default:
376
- break;
377
- }
378
- this.showEndDatePicker = showEndDatePicker;
379
- this.showStartDatePicker = showStartDatePicker;
380
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_changeDetector, "f").markForCheck();
381
- }, _SkyDateRangePickerComponent_resetFormGroupValue = function _SkyDateRangePickerComponent_resetFormGroupValue(value) {
382
- this.formGroup?.reset(value || __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_valueOrDefault_get));
383
- }, _SkyDateRangePickerComponent_addEventListeners = function _SkyDateRangePickerComponent_addEventListeners() {
384
- // Watch for selected calculator change.
385
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_calculatorIdControl_get)?.valueChanges
386
- .pipe(takeUntil(__classPrivateFieldGet(this, _SkyDateRangePickerComponent_ngUnsubscribe, "f")))
387
- .subscribe((value) => {
388
- if (value !== __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_valueOrDefault_get)?.calculatorId) {
389
- const id = parseInt(value, 10);
390
- // if the component is disabled during form creation, null is passed
391
- // as the value of the calculator id control
392
- // only handle the value changes if the calculator id is a number
393
- /* istanbul ignore else */
394
- if (!isNaN(id)) {
395
- const calculator = __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_getCalculatorById).call(this, id);
396
- const newValue = calculator?.getValue();
397
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_setValue).call(this, newValue);
398
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_resetFormGroupValue).call(this, newValue);
399
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_showRelevantFormFields).call(this);
400
- }
401
- }
402
- });
403
- // Watch for start date value changes.
404
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_startDateControl_get)?.valueChanges
405
- .pipe(distinctUntilChanged(), takeUntil(__classPrivateFieldGet(this, _SkyDateRangePickerComponent_ngUnsubscribe, "f")))
406
- .subscribe((startDate) => {
407
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_patchValue).call(this, { startDate });
408
- });
409
- // Watch for end date value changes.
410
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_endDateControl_get)?.valueChanges
411
- .pipe(distinctUntilChanged(), takeUntil(__classPrivateFieldGet(this, _SkyDateRangePickerComponent_ngUnsubscribe, "f")))
412
- .subscribe((endDate) => {
413
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_patchValue).call(this, { endDate });
414
- });
415
- // Safety check
416
- /* istanbul ignore else */
417
- if (__classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_startDateControl_get) && __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_endDateControl_get)) {
418
- // Detect errors from the date inputs and update ng- classes on picker.
419
- combineLatest([
420
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_startDateControl_get).statusChanges,
421
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_endDateControl_get).statusChanges,
422
- ])
423
- .pipe(takeUntil(__classPrivateFieldGet(this, _SkyDateRangePickerComponent_ngUnsubscribe, "f")))
424
- .subscribe(() => {
425
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_updateBasedOnControls).call(this);
426
- });
427
- }
428
- else if (__classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_startDateControl_get)) {
429
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_startDateControl_get).statusChanges
430
- .pipe(takeUntil(__classPrivateFieldGet(this, _SkyDateRangePickerComponent_ngUnsubscribe, "f")))
431
- .subscribe(() => {
432
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_updateBasedOnControls).call(this);
433
- });
434
- }
435
- else if (__classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_endDateControl_get)) {
436
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_endDateControl_get).statusChanges
437
- .pipe(takeUntil(__classPrivateFieldGet(this, _SkyDateRangePickerComponent_ngUnsubscribe, "f")))
438
- .subscribe(() => {
439
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_updateBasedOnControls).call(this);
440
- });
441
- }
442
- }, _SkyDateRangePickerComponent_updateBasedOnControls = function _SkyDateRangePickerComponent_updateBasedOnControls() {
443
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_changeDetector, "f").markForCheck();
444
- // Wait for initial validation to complete.
445
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_ngZone, "f").onStable.pipe(first()).subscribe(() => {
446
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_control, "f")?.updateValueAndValidity({ emitEvent: false });
447
- });
448
- }, _SkyDateRangePickerComponent_updateCalculators = function _SkyDateRangePickerComponent_updateCalculators() {
449
- return __classPrivateFieldGet(this, _SkyDateRangePickerComponent_dateRangeService, "f")
450
- .getCalculators(this.calculatorIds)
451
- .then((calculators) => {
452
- this.calculators = calculators;
453
- // Ensure that any previously set value is used to determine the selected calculator
454
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_updateSelectedCalculator).call(this);
455
- __classPrivateFieldGet(this, _SkyDateRangePickerComponent_changeDetector, "f").markForCheck();
456
- });
457
- }, _SkyDateRangePickerComponent_getCalculatorById = function _SkyDateRangePickerComponent_getCalculatorById(id) {
458
- return this.calculators.find((calculator) => {
459
- return calculator.calculatorId === id;
460
- });
461
- }, _SkyDateRangePickerComponent_dateRangesEqual = function _SkyDateRangePickerComponent_dateRangesEqual(rangeA, rangeB) {
462
- return (!!rangeA && !!rangeB && JSON.stringify(rangeA) === JSON.stringify(rangeB));
463
- }, _SkyDateRangePickerComponent_updateSelectedCalculator = function _SkyDateRangePickerComponent_updateSelectedCalculator() {
464
- this.selectedCalculator = __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_valueOrDefault_get)
465
- ? __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "m", _SkyDateRangePickerComponent_getCalculatorById).call(this, __classPrivateFieldGet(this, _SkyDateRangePickerComponent_instances, "a", _SkyDateRangePickerComponent_valueOrDefault_get).calculatorId)
466
- : undefined;
467
- };
468
- SkyDateRangePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyDateRangePickerComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.SkyDateRangeService }, { token: i2.UntypedFormBuilder }, { token: i3.SkyAppLocaleProvider }, { token: i0.NgZone }, { token: i4.SkyThemeService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
469
- SkyDateRangePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: SkyDateRangePickerComponent, selector: "sky-date-range-picker", inputs: { calculatorIds: "calculatorIds", dateFormat: "dateFormat", disabled: "disabled", label: "label", startDateRequired: "startDateRequired", endDateRequired: "endDateRequired" }, providers: [
470
- SKY_DATE_RANGE_PICKER_VALUE_ACCESSOR,
471
- SKY_DATE_RANGE_PICKER_VALIDATOR,
472
- ], usesOnChanges: true, ngImport: i0, template: "<div\n *ngIf=\"isReady && formGroup\"\n class=\"sky-date-range-picker\"\n [formGroup]=\"formGroup\"\n>\n <div class=\"sky-date-range-picker-form-group\">\n <sky-input-box [disabled]=\"disabled\">\n <label\n class=\"sky-control-label\"\n [attr.for]=\"dateRangePickerId + '-select-calculator'\"\n >\n {{ label || 'skyux_date_range_picker_default_label' | skyLibResources }}\n </label>\n <select\n class=\"sky-form-control\"\n formControlName=\"calculatorId\"\n [attr.id]=\"dateRangePickerId + '-select-calculator'\"\n (blur)=\"onFieldBlur()\"\n >\n <option\n *ngFor=\"let calculator of calculators\"\n [value]=\"calculator.calculatorId\"\n >\n {{ calculator.shortDescription }}\n </option>\n </select>\n </sky-input-box>\n </div>\n\n <div class=\"sky-date-range-picker-form-group\" [hidden]=\"!showStartDatePicker\">\n <sky-input-box [disabled]=\"disabled\">\n <label\n class=\"sky-control-label\"\n [attr.for]=\"dateRangePickerId + '-start-date'\"\n [ngClass]=\"{ 'sky-control-label-required': startDateRequired }\"\n >\n {{\n selectedCalculator?.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources\n }}\n </label>\n\n <sky-datepicker>\n <input\n formControlName=\"startDate\"\n [attr.aria-label]=\"\n selectedCalculator?.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources\n \"\n [attr.id]=\"dateRangePickerId + '-start-date'\"\n [attr.placeholder]=\"dateFormatOrDefault\"\n [required]=\"!!startDateRequired\"\n [dateFormat]=\"dateFormatOrDefault\"\n (blur)=\"onFieldBlur()\"\n skyDatepickerInput\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n\n <div class=\"sky-date-range-picker-form-group\" [hidden]=\"!showEndDatePicker\">\n <sky-input-box [disabled]=\"disabled\">\n <label\n class=\"sky-control-label\"\n [attr.for]=\"dateRangePickerId + '-end-date'\"\n [ngClass]=\"{ 'sky-control-label-required': endDateRequired }\"\n >\n {{\n selectedCalculator?.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources\n }}\n </label>\n\n <sky-datepicker>\n <input\n formControlName=\"endDate\"\n skyDatepickerInput\n [attr.aria-label]=\"\n selectedCalculator?.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources\n \"\n [attr.id]=\"dateRangePickerId + '-end-date'\"\n [attr.placeholder]=\"dateFormatOrDefault\"\n [dateFormat]=\"dateFormatOrDefault\"\n [required]=\"!!endDateRequired\"\n (blur)=\"onFieldBlur()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n</div>\n", styles: [".sky-date-range-picker{display:flex}.sky-date-range-picker-form-group:last-child{margin-bottom:0}: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-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}@media (min-width: 768px){:host .sky-date-range-picker{flex-direction:initial}:host .sky-date-range-picker-form-group{flex-basis:33.3333333333%;margin-bottom:0}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:5px}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:5px}}: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%;margin-bottom: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:5px}: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:5px}@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%}:host-context(.sky-theme-modern) .sky-date-range-picker-form-group{padding:0;margin:0 0 20px}@media (min-width: 768px){:host-context(.sky-theme-modern) .sky-date-range-picker-form-group{margin:0 20px 0 0}}.sky-theme-modern .sky-date-range-picker-form-group{padding:0;margin:0 0 20px}@media (min-width: 768px){.sky-theme-modern .sky-date-range-picker-form-group{margin:0 20px 0 0}}:host-context(.sky-theme-modern .sky-responsive-container-xs) .sky-date-range-picker-form-group{margin:0 0 20px}:host-context(.sky-theme-modern .sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-theme-modern .sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-theme-modern .sky-responsive-container-lg) .sky-date-range-picker-form-group{margin:0 20px 0 0}\n"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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: "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: "component", type: i6.SkyDatepickerComponent, selector: "sky-datepicker", inputs: ["pickerClass"], outputs: ["calendarDateRangeChange"] }, { kind: "directive", type: i7.SkyDatepickerInputDirective, selector: "[skyDatepickerInput]", inputs: ["dateFormat", "disabled", "maxDate", "minDate", "skyDatepickerInput", "skyDatepickerNoValidate", "startingDay", "strict"] }, { kind: "component", type: i8.λ10, selector: "sky-input-box", inputs: ["hasErrors", "disabled"] }, { kind: "pipe", type: i3.SkyLibResourcesPipe, name: "skyLibResources" }, { kind: "pipe", type: i9.SkyDateRangePickerEndDateResourceKeyPipe, name: "skyDateRangePickerEndDateResourceKey" }, { kind: "pipe", type: i10.SkyDateRangePickerStartDateResourceKeyPipe, name: "skyDateRangePickerStartDateResourceKey" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
473
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyDateRangePickerComponent, decorators: [{
474
- type: Component,
475
- args: [{ selector: 'sky-date-range-picker', providers: [
476
- SKY_DATE_RANGE_PICKER_VALUE_ACCESSOR,
477
- SKY_DATE_RANGE_PICKER_VALIDATOR,
478
- ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n *ngIf=\"isReady && formGroup\"\n class=\"sky-date-range-picker\"\n [formGroup]=\"formGroup\"\n>\n <div class=\"sky-date-range-picker-form-group\">\n <sky-input-box [disabled]=\"disabled\">\n <label\n class=\"sky-control-label\"\n [attr.for]=\"dateRangePickerId + '-select-calculator'\"\n >\n {{ label || 'skyux_date_range_picker_default_label' | skyLibResources }}\n </label>\n <select\n class=\"sky-form-control\"\n formControlName=\"calculatorId\"\n [attr.id]=\"dateRangePickerId + '-select-calculator'\"\n (blur)=\"onFieldBlur()\"\n >\n <option\n *ngFor=\"let calculator of calculators\"\n [value]=\"calculator.calculatorId\"\n >\n {{ calculator.shortDescription }}\n </option>\n </select>\n </sky-input-box>\n </div>\n\n <div class=\"sky-date-range-picker-form-group\" [hidden]=\"!showStartDatePicker\">\n <sky-input-box [disabled]=\"disabled\">\n <label\n class=\"sky-control-label\"\n [attr.for]=\"dateRangePickerId + '-start-date'\"\n [ngClass]=\"{ 'sky-control-label-required': startDateRequired }\"\n >\n {{\n selectedCalculator?.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources\n }}\n </label>\n\n <sky-datepicker>\n <input\n formControlName=\"startDate\"\n [attr.aria-label]=\"\n selectedCalculator?.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources\n \"\n [attr.id]=\"dateRangePickerId + '-start-date'\"\n [attr.placeholder]=\"dateFormatOrDefault\"\n [required]=\"!!startDateRequired\"\n [dateFormat]=\"dateFormatOrDefault\"\n (blur)=\"onFieldBlur()\"\n skyDatepickerInput\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n\n <div class=\"sky-date-range-picker-form-group\" [hidden]=\"!showEndDatePicker\">\n <sky-input-box [disabled]=\"disabled\">\n <label\n class=\"sky-control-label\"\n [attr.for]=\"dateRangePickerId + '-end-date'\"\n [ngClass]=\"{ 'sky-control-label-required': endDateRequired }\"\n >\n {{\n selectedCalculator?.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources\n }}\n </label>\n\n <sky-datepicker>\n <input\n formControlName=\"endDate\"\n skyDatepickerInput\n [attr.aria-label]=\"\n selectedCalculator?.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources\n \"\n [attr.id]=\"dateRangePickerId + '-end-date'\"\n [attr.placeholder]=\"dateFormatOrDefault\"\n [dateFormat]=\"dateFormatOrDefault\"\n [required]=\"!!endDateRequired\"\n (blur)=\"onFieldBlur()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n</div>\n", styles: [".sky-date-range-picker{display:flex}.sky-date-range-picker-form-group:last-child{margin-bottom:0}: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-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}@media (min-width: 768px){:host .sky-date-range-picker{flex-direction:initial}:host .sky-date-range-picker-form-group{flex-basis:33.3333333333%;margin-bottom:0}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:5px}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:5px}}: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%;margin-bottom: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:5px}: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:5px}@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%}:host-context(.sky-theme-modern) .sky-date-range-picker-form-group{padding:0;margin:0 0 20px}@media (min-width: 768px){:host-context(.sky-theme-modern) .sky-date-range-picker-form-group{margin:0 20px 0 0}}.sky-theme-modern .sky-date-range-picker-form-group{padding:0;margin:0 0 20px}@media (min-width: 768px){.sky-theme-modern .sky-date-range-picker-form-group{margin:0 20px 0 0}}:host-context(.sky-theme-modern .sky-responsive-container-xs) .sky-date-range-picker-form-group{margin:0 0 20px}:host-context(.sky-theme-modern .sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-theme-modern .sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-theme-modern .sky-responsive-container-lg) .sky-date-range-picker-form-group{margin:0 20px 0 0}\n"] }]
479
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.SkyDateRangeService }, { type: i2.UntypedFormBuilder }, { type: i3.SkyAppLocaleProvider }, { type: i0.NgZone }, { type: i4.SkyThemeService, decorators: [{
480
- type: Optional
481
- }] }]; }, propDecorators: { calculatorIds: [{
482
- type: Input
483
- }], dateFormat: [{
484
- type: Input
485
- }], disabled: [{
486
- type: Input
487
- }], label: [{
488
- type: Input
489
- }], startDateRequired: [{
490
- type: Input
491
- }], endDateRequired: [{
492
- type: Input
493
- }] } });
494
- //# 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 {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  SimpleChanges,\n  forwardRef,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  UntypedFormBuilder,\n  UntypedFormControl,\n  UntypedFormGroup,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\nimport { SkyAppLocaleProvider } from '@skyux/i18n';\nimport { SkyThemeService } from '@skyux/theme';\n\nimport { Subject, combineLatest } from 'rxjs';\nimport { distinctUntilChanged, first, takeUntil } from 'rxjs/operators';\n\nimport { SkyDateFormatter } from '../datepicker/date-formatter';\n\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';\n\nconst SKY_DATE_RANGE_PICKER_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => SkyDateRangePickerComponent),\n  multi: true,\n};\n\nconst SKY_DATE_RANGE_PICKER_VALIDATOR = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => SkyDateRangePickerComponent),\n  multi: true,\n};\n\nlet uniqueId = 0;\n\n/**\n * Acts as a form control with a form model of type `SkyDateRangeCalculation`.\n * @example\n * ```\n * <sky-date-range-picker\n *   formControlName=\"myPicker\"\n * >\n * </sky-date-range-picker>\n * ```\n */\n@Component({\n  selector: 'sky-date-range-picker',\n  templateUrl: './date-range-picker.component.html',\n  styleUrls: ['./date-range-picker.component.scss'],\n  providers: [\n    SKY_DATE_RANGE_PICKER_VALUE_ACCESSOR,\n    SKY_DATE_RANGE_PICKER_VALIDATOR,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyDateRangePickerComponent\n  implements OnInit, OnChanges, OnDestroy, ControlValueAccessor, Validator\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(value: SkyDateRangeCalculatorId[] | undefined) {\n    this.#_calculatorIds = value || [\n      SkyDateRangeCalculatorId.AnyTime,\n      SkyDateRangeCalculatorId.Before,\n      SkyDateRangeCalculatorId.After,\n      SkyDateRangeCalculatorId.SpecificRange,\n      SkyDateRangeCalculatorId.Yesterday,\n      SkyDateRangeCalculatorId.Today,\n      SkyDateRangeCalculatorId.Tomorrow,\n      SkyDateRangeCalculatorId.LastWeek,\n      SkyDateRangeCalculatorId.ThisWeek,\n      SkyDateRangeCalculatorId.NextWeek,\n      SkyDateRangeCalculatorId.LastMonth,\n      SkyDateRangeCalculatorId.ThisMonth,\n      SkyDateRangeCalculatorId.NextMonth,\n      SkyDateRangeCalculatorId.LastQuarter,\n      SkyDateRangeCalculatorId.ThisQuarter,\n      SkyDateRangeCalculatorId.NextQuarter,\n      SkyDateRangeCalculatorId.LastCalendarYear,\n      SkyDateRangeCalculatorId.ThisCalendarYear,\n      SkyDateRangeCalculatorId.NextCalendarYear,\n      SkyDateRangeCalculatorId.LastFiscalYear,\n      SkyDateRangeCalculatorId.ThisFiscalYear,\n      SkyDateRangeCalculatorId.NextFiscalYear,\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 set dateFormat(value: string | undefined) {\n    this.#_dateFormat = value;\n    this.dateFormatOrDefault = value || this.#preferredShortDateFormat;\n  }\n\n  public get dateFormat(): string | undefined {\n    return this.#_dateFormat;\n  }\n\n  /**\n   * Whether to disable the date range picker on template-driven forms. Don't use this input on reactive forms because they may overwrite the input or leave the control out of sync.\n   * To set the disabled state on reactive forms, use the `FormControl` instead.\n   * @default false\n   */\n  @Input()\n  public set disabled(value: boolean | undefined) {\n    this.#_disabled = value;\n\n    if (this.formGroup) {\n      if (this.#_disabled) {\n        this.formGroup.disable();\n      } else {\n        this.formGroup.enable();\n      }\n    }\n\n    this.#changeDetector.markForCheck();\n  }\n\n  public get disabled(): boolean | undefined {\n    return this.#_disabled;\n  }\n\n  /**\n   * The label for the date range picker.\n   * @required\n   */\n  @Input()\n  public label: string | undefined;\n\n  /**\n   * Whether to require users to specify a start date.\n   * @default false\n   */\n  @Input()\n  public startDateRequired: boolean | undefined = false;\n\n  /**\n   * Whether to require users to specify a end date.\n   * @default false\n   */\n  @Input()\n  public endDateRequired: boolean | undefined = false;\n\n  public selectedCalculator: SkyDateRangeCalculator | undefined;\n\n  public readonly dateRangePickerId = `sky-date-range-picker-${uniqueId++}`;\n\n  public calculators: SkyDateRangeCalculator[] = [];\n  public dateFormatOrDefault: string | undefined;\n  public formGroup: UntypedFormGroup | undefined;\n  public isReady = false;\n  public showEndDatePicker = false;\n  public showStartDatePicker = false;\n\n  get #calculatorIdControl(): AbstractControl | undefined | null {\n    return this.formGroup?.get('calculatorId');\n  }\n\n  get #defaultCalculator(): SkyDateRangeCalculator | undefined {\n    return this.calculators[0];\n  }\n\n  get #defaultValue(): SkyDateRangeCalculation | undefined {\n    return this.#defaultCalculator?.getValue();\n  }\n\n  get #endDateControl(): AbstractControl | undefined | null {\n    return this.formGroup?.get('endDate');\n  }\n\n  get #startDateControl(): AbstractControl | undefined | null {\n    return this.formGroup?.get('startDate');\n  }\n\n  #value: SkyDateRangeCalculation | undefined;\n\n  set #valueOrDefault(value: SkyDateRangeCalculation | undefined) {\n    this.#_valueOrDefault = value;\n    this.#updateSelectedCalculator();\n  }\n\n  get #valueOrDefault(): SkyDateRangeCalculation | undefined {\n    return this.#_valueOrDefault;\n  }\n\n  #control: AbstractControl | undefined;\n  #preferredShortDateFormat: string | undefined;\n  #ngUnsubscribe = new Subject<void>();\n\n  #_calculatorIds: SkyDateRangeCalculatorId[] = [\n    SkyDateRangeCalculatorId.AnyTime,\n    SkyDateRangeCalculatorId.Before,\n    SkyDateRangeCalculatorId.After,\n    SkyDateRangeCalculatorId.SpecificRange,\n    SkyDateRangeCalculatorId.Yesterday,\n    SkyDateRangeCalculatorId.Today,\n    SkyDateRangeCalculatorId.Tomorrow,\n    SkyDateRangeCalculatorId.LastWeek,\n    SkyDateRangeCalculatorId.ThisWeek,\n    SkyDateRangeCalculatorId.NextWeek,\n    SkyDateRangeCalculatorId.LastMonth,\n    SkyDateRangeCalculatorId.ThisMonth,\n    SkyDateRangeCalculatorId.NextMonth,\n    SkyDateRangeCalculatorId.LastQuarter,\n    SkyDateRangeCalculatorId.ThisQuarter,\n    SkyDateRangeCalculatorId.NextQuarter,\n    SkyDateRangeCalculatorId.LastCalendarYear,\n    SkyDateRangeCalculatorId.ThisCalendarYear,\n    SkyDateRangeCalculatorId.NextCalendarYear,\n    SkyDateRangeCalculatorId.LastFiscalYear,\n    SkyDateRangeCalculatorId.ThisFiscalYear,\n    SkyDateRangeCalculatorId.NextFiscalYear,\n  ];\n  #_dateFormat: string | undefined;\n  #_disabled: boolean | undefined = false;\n  #_valueOrDefault: SkyDateRangeCalculation | undefined;\n\n  #changeDetector: ChangeDetectorRef;\n  #dateRangeService: SkyDateRangeService;\n  #formBuilder: UntypedFormBuilder;\n  #localeProvider: SkyAppLocaleProvider;\n  #ngZone: NgZone;\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    dateRangeService: SkyDateRangeService,\n    formBuilder: UntypedFormBuilder,\n    localeProvider: SkyAppLocaleProvider,\n    ngZone: NgZone,\n    @Optional() themeSvc?: SkyThemeService\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#dateRangeService = dateRangeService;\n    this.#formBuilder = formBuilder;\n    this.#localeProvider = localeProvider;\n    this.#ngZone = ngZone;\n\n    this.dateFormatOrDefault = this.dateFormat;\n\n    this.#localeProvider\n      .getLocaleInfo()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((localeInfo) => {\n        SkyDateFormatter.setLocale(localeInfo.locale);\n        this.#preferredShortDateFormat =\n          SkyDateFormatter.getPreferredShortDateFormat();\n        this.dateFormatOrDefault =\n          this.dateFormat || this.#preferredShortDateFormat;\n      });\n\n    // Update icons when theme changes.\n    /* istanbul ignore next */\n    themeSvc?.settingsChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#changeDetector.markForCheck();\n      });\n  }\n\n  public ngOnInit(): void {\n    this.#createForm();\n\n    this.#updateCalculators().then(() => {\n      if (!this.#value || !this.#value.calculatorId) {\n        this.#valueOrDefault = this.#defaultValue;\n      }\n\n      this.#addEventListeners();\n\n      this.isReady = true;\n\n      this.#showRelevantFormFields();\n\n      // We need to let Angular be stable and have rendered the components prior to setting the values and form controls. This ensures all initial validation will be ran correctly.\n      this.#ngZone.onStable.pipe(first()).subscribe(() => {\n        // Fill in any unprovided values after the calculators have been initialized.\n        // For example, if the control is initialized with only the `calculatorId`,\n        // allow the calculator to fill in the missing start and end dates.\n        const defaultValue = this.selectedCalculator?.getValue(\n          this.#valueOrDefault?.startDate,\n          this.#valueOrDefault?.endDate\n        );\n        const newValue = Object.assign({}, defaultValue, this.#valueOrDefault);\n\n        this.#setValue(newValue, false);\n\n        this.#resetFormGroupValue();\n\n        // This is needed to address a bug in Angular 4.\n        // When a control value is set initially, its value is not represented on the view.\n        // See: https://github.com/angular/angular/issues/13792\n        /* istanbul ignore else */\n        if (this.#control) {\n          this.#control.setValue(this.#valueOrDefault, {\n            emitEvent: false,\n          });\n        }\n      });\n    });\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (\n      changes['calculatorIds'] &&\n      changes['calculatorIds'].firstChange === false\n    ) {\n      this.#updateCalculators().then(() => {\n        const id = this.#calculatorIdControl?.value;\n\n        // Maintain the currently selected values if the calculators change after\n        // a value has been chosen.\n        const found = this.calculators.find((calculator) => {\n          return calculator.calculatorId === id;\n        });\n\n        /* istanbul ignore else */\n        if (!found) {\n          const newValue = this.#defaultCalculator?.getValue();\n          this.#setValue(newValue);\n          this.#resetFormGroupValue(newValue);\n          this.#showRelevantFormFields();\n        }\n      });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public onFieldBlur(): void {\n    this.#onTouched();\n  }\n\n  public writeValue(value: SkyDateRangeCalculation): void {\n    // Only update the underlying controls when the calculators are ready.\n    const notifyChange = false;\n\n    // (We still need to save the initial value set by the consumer's form, however.)\n    this.#setValue(value, notifyChange);\n\n    if (this.isReady) {\n      // When the control's value is set to `null`,\n      // set it to the default value.\n      if (!value) {\n        this.#onChange(this.#defaultValue);\n      }\n\n      this.#resetFormGroupValue();\n      this.#showRelevantFormFields();\n    }\n  }\n\n  public validate(control: AbstractControl): ValidationErrors | null {\n    if (!this.#control) {\n      this.#control = control;\n    }\n\n    if (!this.isReady) {\n      return null;\n    }\n\n    const value = control.value;\n    const idControl = this.#calculatorIdControl;\n    const result = this.selectedCalculator?.validate(value);\n\n    let errors: ValidationErrors | null = null;\n\n    if (result) {\n      errors = {\n        skyDateRange: {\n          calculatorId: idControl?.value,\n          errors: result,\n        },\n      };\n    } else {\n      let startErrors: ValidationErrors | null = null;\n      let endErrors: ValidationErrors | null = null;\n      if (this.#startDateControl) {\n        startErrors = this.#startDateControl.errors;\n      }\n      if (this.#endDateControl) {\n        endErrors = this.#endDateControl.errors;\n      }\n\n      errors = startErrors || endErrors;\n    }\n\n    if (!errors) {\n      // Clear any errors on the calculator select.\n      idControl?.setErrors(null);\n      return null;\n    }\n\n    idControl?.setErrors(errors);\n    idControl?.markAsTouched();\n    idControl?.markAsDirty();\n\n    // Need to mark the control as touched for the error messages to appear.\n    this.#control.markAsTouched();\n\n    // Notify the view to display any errors.\n    this.#changeDetector.markForCheck();\n\n    return errors;\n  }\n\n  public registerOnChange(\n    fn: (value: SkyDateRangeCalculation | undefined) => SkyDateRangeCalculation\n  ): void {\n    this.#onChange = fn;\n  }\n\n  public registerOnTouched(fn: () => SkyDateRangeCalculation): void {\n    this.#onTouched = fn;\n  }\n\n  public setDisabledState(disabled: boolean): void {\n    this.disabled = disabled;\n  }\n\n  #setValue(\n    value: SkyDateRangeCalculation | undefined,\n    notifyChange = true\n  ): void {\n    const isNewValue = !this.#dateRangesEqual(this.#value, value);\n\n    if (isNewValue) {\n      this.#value = value;\n      if (!value || value.calculatorId === undefined) {\n        this.#valueOrDefault = this.#defaultValue;\n      } else {\n        this.#valueOrDefault = value;\n      }\n\n      if (notifyChange) {\n        this.#onChange(this.#valueOrDefault);\n      }\n    }\n  }\n\n  #patchValue(value: any): void {\n    const newValue = Object.assign({}, this.#valueOrDefault, value);\n\n    this.#setValue(newValue);\n  }\n\n  #createForm(): void {\n    this.formGroup = this.#formBuilder.group({\n      calculatorId: new UntypedFormControl(),\n      startDate: new UntypedFormControl(),\n      endDate: new UntypedFormControl(),\n    });\n\n    if (this.disabled) {\n      this.formGroup.disable();\n    }\n  }\n\n  #showRelevantFormFields(): void {\n    const calculator = this.selectedCalculator;\n\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 = showEndDatePicker;\n    this.showStartDatePicker = showStartDatePicker;\n    this.#changeDetector.markForCheck();\n  }\n\n  #resetFormGroupValue(value?: SkyDateRangeCalculation): void {\n    this.formGroup?.reset(value || this.#valueOrDefault);\n  }\n\n  #addEventListeners(): void {\n    // Watch for selected calculator change.\n    this.#calculatorIdControl?.valueChanges\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((value) => {\n        if (value !== this.#valueOrDefault?.calculatorId) {\n          const id = parseInt(value, 10);\n          // if the component is disabled during form creation, null is passed\n          // as the value of the calculator id control\n          // only handle the value changes if the calculator id is a number\n          /* istanbul ignore else */\n          if (!isNaN(id)) {\n            const calculator = this.#getCalculatorById(id);\n            const newValue = calculator?.getValue();\n\n            this.#setValue(newValue);\n            this.#resetFormGroupValue(newValue);\n            this.#showRelevantFormFields();\n          }\n        }\n      });\n\n    // Watch for start date value changes.\n    this.#startDateControl?.valueChanges\n      .pipe(distinctUntilChanged(), takeUntil(this.#ngUnsubscribe))\n      .subscribe((startDate) => {\n        this.#patchValue({ startDate });\n      });\n\n    // Watch for end date value changes.\n    this.#endDateControl?.valueChanges\n      .pipe(distinctUntilChanged(), takeUntil(this.#ngUnsubscribe))\n      .subscribe((endDate) => {\n        this.#patchValue({ endDate });\n      });\n\n    // Safety check\n    /* istanbul ignore else */\n    if (this.#startDateControl && this.#endDateControl) {\n      // Detect errors from the date inputs and update ng- classes on picker.\n      combineLatest([\n        this.#startDateControl.statusChanges,\n        this.#endDateControl.statusChanges,\n      ])\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          this.#updateBasedOnControls();\n        });\n    } else if (this.#startDateControl) {\n      this.#startDateControl.statusChanges\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          this.#updateBasedOnControls();\n        });\n    } else if (this.#endDateControl) {\n      this.#endDateControl.statusChanges\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe(() => {\n          this.#updateBasedOnControls();\n        });\n    }\n  }\n\n  #updateBasedOnControls(): void {\n    this.#changeDetector.markForCheck();\n\n    // Wait for initial validation to complete.\n    this.#ngZone.onStable.pipe(first()).subscribe(() => {\n      this.#control?.updateValueAndValidity({ emitEvent: false });\n    });\n  }\n\n  #updateCalculators(): Promise<void> {\n    return this.#dateRangeService\n      .getCalculators(this.calculatorIds)\n      .then((calculators) => {\n        this.calculators = calculators;\n        // Ensure that any previously set value is used to determine the selected calculator\n        this.#updateSelectedCalculator();\n        this.#changeDetector.markForCheck();\n      });\n  }\n\n  #getCalculatorById(\n    id: SkyDateRangeCalculatorId\n  ): SkyDateRangeCalculator | undefined {\n    return this.calculators.find((calculator) => {\n      return calculator.calculatorId === id;\n    });\n  }\n\n  #dateRangesEqual(\n    rangeA: SkyDateRangeCalculation | undefined,\n    rangeB: SkyDateRangeCalculation | undefined\n  ): boolean {\n    return (\n      !!rangeA && !!rangeB && JSON.stringify(rangeA) === JSON.stringify(rangeB)\n    );\n  }\n\n  #updateSelectedCalculator(): void {\n    this.selectedCalculator = this.#valueOrDefault\n      ? this.#getCalculatorById(this.#valueOrDefault.calculatorId)\n      : undefined;\n  }\n\n  /* istanbul ignore next */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function, @typescript-eslint/no-unused-vars\n  #onChange = (_: SkyDateRangeCalculation | undefined): void => {};\n  /* istanbul ignore next */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  #onTouched = (): void => {};\n}\n","<div\n  *ngIf=\"isReady && formGroup\"\n  class=\"sky-date-range-picker\"\n  [formGroup]=\"formGroup\"\n>\n  <div class=\"sky-date-range-picker-form-group\">\n    <sky-input-box [disabled]=\"disabled\">\n      <label\n        class=\"sky-control-label\"\n        [attr.for]=\"dateRangePickerId + '-select-calculator'\"\n      >\n        {{ label || 'skyux_date_range_picker_default_label' | skyLibResources }}\n      </label>\n      <select\n        class=\"sky-form-control\"\n        formControlName=\"calculatorId\"\n        [attr.id]=\"dateRangePickerId + '-select-calculator'\"\n        (blur)=\"onFieldBlur()\"\n      >\n        <option\n          *ngFor=\"let calculator of calculators\"\n          [value]=\"calculator.calculatorId\"\n        >\n          {{ calculator.shortDescription }}\n        </option>\n      </select>\n    </sky-input-box>\n  </div>\n\n  <div class=\"sky-date-range-picker-form-group\" [hidden]=\"!showStartDatePicker\">\n    <sky-input-box [disabled]=\"disabled\">\n      <label\n        class=\"sky-control-label\"\n        [attr.for]=\"dateRangePickerId + '-start-date'\"\n        [ngClass]=\"{ 'sky-control-label-required': startDateRequired }\"\n      >\n        {{\n          selectedCalculator?.type\n            | skyDateRangePickerStartDateResourceKey\n            | skyLibResources\n        }}\n      </label>\n\n      <sky-datepicker>\n        <input\n          formControlName=\"startDate\"\n          [attr.aria-label]=\"\n            selectedCalculator?.type\n              | skyDateRangePickerStartDateResourceKey\n              | skyLibResources\n          \"\n          [attr.id]=\"dateRangePickerId + '-start-date'\"\n          [attr.placeholder]=\"dateFormatOrDefault\"\n          [required]=\"!!startDateRequired\"\n          [dateFormat]=\"dateFormatOrDefault\"\n          (blur)=\"onFieldBlur()\"\n          skyDatepickerInput\n        />\n      </sky-datepicker>\n    </sky-input-box>\n  </div>\n\n  <div class=\"sky-date-range-picker-form-group\" [hidden]=\"!showEndDatePicker\">\n    <sky-input-box [disabled]=\"disabled\">\n      <label\n        class=\"sky-control-label\"\n        [attr.for]=\"dateRangePickerId + '-end-date'\"\n        [ngClass]=\"{ 'sky-control-label-required': endDateRequired }\"\n      >\n        {{\n          selectedCalculator?.type\n            | skyDateRangePickerEndDateResourceKey\n            | skyLibResources\n        }}\n      </label>\n\n      <sky-datepicker>\n        <input\n          formControlName=\"endDate\"\n          skyDatepickerInput\n          [attr.aria-label]=\"\n            selectedCalculator?.type\n              | skyDateRangePickerEndDateResourceKey\n              | skyLibResources\n          \"\n          [attr.id]=\"dateRangePickerId + '-end-date'\"\n          [attr.placeholder]=\"dateFormatOrDefault\"\n          [dateFormat]=\"dateFormatOrDefault\"\n          [required]=\"!!endDateRequired\"\n          (blur)=\"onFieldBlur()\"\n        />\n      </sky-datepicker>\n    </sky-input-box>\n  </div>\n</div>\n"]}