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