@skyux/datetime 11.0.0-alpha.8 → 11.0.0-beta.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 (34) hide show
  1. package/documentation.json +1462 -1669
  2. package/esm2022/lib/modules/date-pipe/date-pipe.module.mjs +6 -7
  3. package/esm2022/lib/modules/date-pipe/date.pipe.mjs +3 -3
  4. package/esm2022/lib/modules/date-pipe/date.service.mjs +3 -3
  5. package/esm2022/lib/modules/date-pipe/fuzzy-date.pipe.mjs +3 -3
  6. package/esm2022/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +3 -3
  7. package/esm2022/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +3 -3
  8. package/esm2022/lib/modules/date-range-picker/date-range-picker.component.mjs +30 -55
  9. package/esm2022/lib/modules/date-range-picker/date-range-picker.module.mjs +4 -4
  10. package/esm2022/lib/modules/date-range-picker/date-range.service.mjs +3 -3
  11. package/esm2022/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +5 -5
  12. package/esm2022/lib/modules/datepicker/datepicker-calendar-label.pipe.mjs +3 -3
  13. package/esm2022/lib/modules/datepicker/datepicker-calendar.component.mjs +9 -10
  14. package/esm2022/lib/modules/datepicker/datepicker-config.service.mjs +3 -3
  15. package/esm2022/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +3 -3
  16. package/esm2022/lib/modules/datepicker/datepicker-input.directive.mjs +3 -3
  17. package/esm2022/lib/modules/datepicker/datepicker.component.mjs +5 -5
  18. package/esm2022/lib/modules/datepicker/datepicker.module.mjs +4 -4
  19. package/esm2022/lib/modules/datepicker/datepicker.service.mjs +3 -3
  20. package/esm2022/lib/modules/datepicker/daypicker-button.component.mjs +5 -5
  21. package/esm2022/lib/modules/datepicker/daypicker-cell.component.mjs +5 -5
  22. package/esm2022/lib/modules/datepicker/daypicker.component.mjs +7 -8
  23. package/esm2022/lib/modules/datepicker/fuzzy-date.service.mjs +3 -3
  24. package/esm2022/lib/modules/datepicker/monthpicker.component.mjs +5 -5
  25. package/esm2022/lib/modules/datepicker/yearpicker.component.mjs +5 -5
  26. package/esm2022/lib/modules/shared/sky-datetime-resources.module.mjs +4 -4
  27. package/esm2022/lib/modules/timepicker/timepicker.component.mjs +5 -5
  28. package/esm2022/lib/modules/timepicker/timepicker.directive.mjs +3 -3
  29. package/esm2022/lib/modules/timepicker/timepicker.module.mjs +4 -4
  30. package/fesm2022/skyux-datetime.mjs +135 -160
  31. package/fesm2022/skyux-datetime.mjs.map +1 -1
  32. package/lib/modules/date-pipe/date-pipe.module.d.ts +2 -3
  33. package/lib/modules/date-range-picker/date-range-picker.component.d.ts +6 -20
  34. package/package.json +14 -14
@@ -1,9 +1,9 @@
1
1
  import { CommonModule } from '@angular/common';
2
2
  import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, Injector, Input, booleanAttribute, inject, } from '@angular/core';
3
- import { FormBuilder, FormControl, FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, ReactiveFormsModule, Validators, } from '@angular/forms';
3
+ import { FormBuilder, FormControl, FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, ReactiveFormsModule, TouchedChangeEvent, Validators, } from '@angular/forms';
4
4
  import { SkyLogService } from '@skyux/core';
5
- import { SKY_FORM_ERRORS_ENABLED, SkyFormErrorsModule, SkyFormFieldLabelTextRequiredService, SkyInputBoxModule, } from '@skyux/forms';
6
- import { Subject, distinctUntilChanged, merge, takeUntil } from 'rxjs';
5
+ import { SKY_FORM_ERRORS_ENABLED, SkyFormErrorsModule, SkyInputBoxModule, } from '@skyux/forms';
6
+ import { Subject, distinctUntilChanged, filter, merge, takeUntil } from 'rxjs';
7
7
  import { SkyDatepickerModule } from '../datepicker/datepicker.module';
8
8
  import { SkyDatetimeResourcesModule } from '../shared/sky-datetime-resources.module';
9
9
  import { SkyDateRangePickerEndDateResourceKeyPipe } from './date-range-picker-end-date-resource-key.pipe';
@@ -114,15 +114,8 @@ export class SkyDateRangePickerComponent {
114
114
  #changeDetector;
115
115
  #dateRangeSvc;
116
116
  #injector;
117
- #labelTextRequiredSvc;
118
117
  #logger;
119
118
  constructor() {
120
- /**
121
- * Whether to require users to specify a end date.
122
- * @deprecated Use the `required` directive or Angular's `Validators.required`
123
- * on the form control to mark the date range picker as required.
124
- */
125
- this.endDateRequired = false;
126
119
  /**
127
120
  * Whether the date range picker requires a value.
128
121
  */
@@ -132,24 +125,17 @@ export class SkyDateRangePickerComponent {
132
125
  * vertical spacing is automatically added to the date range picker.
133
126
  */
134
127
  this.stacked = false;
135
- /**
136
- * Whether to require users to specify a start date.
137
- * @deprecated Use the `required` directive or Angular's `Validators.required`
138
- * on the form control to mark the date range picker as required.
139
- */
140
- this.startDateRequired = false;
128
+ this.calculatorIdHasErrors = false;
141
129
  this.calculators = [];
142
- this.hasErrors = false;
130
+ this.endDateHasErrors = false;
143
131
  this.showEndDatePicker = false;
144
132
  this.showStartDatePicker = false;
133
+ this.startDateHasErrors = false;
145
134
  this.#_calculatorIds = SKY_DEFAULT_CALCULATOR_IDS;
146
135
  this.#ngUnsubscribe = new Subject();
147
136
  this.#changeDetector = inject(ChangeDetectorRef);
148
137
  this.#dateRangeSvc = inject(SkyDateRangeService);
149
138
  this.#injector = inject(Injector);
150
- this.#labelTextRequiredSvc = inject(SkyFormFieldLabelTextRequiredService, {
151
- optional: true,
152
- });
153
139
  this.#logger = inject(SkyLogService);
154
140
  this.calculators = this.#dateRangeSvc.calculators;
155
141
  this.selectedCalculator = this.calculators[0];
@@ -161,14 +147,6 @@ export class SkyDateRangePickerComponent {
161
147
  endDate: new FormControl(initialValue.endDate),
162
148
  });
163
149
  }
164
- ngOnInit() {
165
- if (this.#labelTextRequiredSvc) {
166
- this.#labelTextRequiredSvc.validateLabelText(this.labelText || this.label);
167
- if (!this.label && !this.labelText) {
168
- this.display = 'none';
169
- }
170
- }
171
- }
172
150
  ngAfterViewInit() {
173
151
  this.hostControl = this.#injector.get(NgControl, null, {
174
152
  optional: true,
@@ -232,6 +210,11 @@ export class SkyDateRangePickerComponent {
232
210
  });
233
211
  });
234
212
  });
213
+ this.hostControl?.events
214
+ .pipe(filter((event) => event instanceof TouchedChangeEvent), takeUntil(this.#ngUnsubscribe))
215
+ .subscribe(() => {
216
+ this.formGroup.markAllAsTouched();
217
+ });
235
218
  this.#updatePickerVisibility(this.selectedCalculator);
236
219
  }
237
220
  /**
@@ -243,19 +226,20 @@ export class SkyDateRangePickerComponent {
243
226
  */
244
227
  ngDoCheck() {
245
228
  const control = this.hostControl;
246
- const touched = this.formGroup.touched;
247
229
  if (control) {
248
- if (control.touched && !touched) {
249
- this.formGroup.markAllAsTouched();
250
- this.#changeDetector.markForCheck();
251
- }
252
- else if (control.untouched && touched) {
253
- this.formGroup.markAsUntouched();
254
- this.#changeDetector.markForCheck();
255
- }
256
- this.hasErrors = !!control.errors && (control.touched || control.dirty);
230
+ this.startDateHasErrors =
231
+ this.#controlHasErrors(this.#startDateControl) ||
232
+ this.#controlHasErrors(this.#calculatorIdControl);
233
+ this.endDateHasErrors =
234
+ this.#controlHasErrors(this.#endDateControl) ||
235
+ this.#controlHasErrors(this.#calculatorIdControl);
236
+ this.calculatorIdHasErrors = this.#controlHasErrors(this.#calculatorIdControl);
237
+ this.#changeDetector.markForCheck();
257
238
  }
258
239
  }
240
+ #controlHasErrors(control) {
241
+ return !!control.errors && (control.touched || control.dirty);
242
+ }
259
243
  ngOnDestroy() {
260
244
  this.#ngUnsubscribe.next();
261
245
  this.#ngUnsubscribe.complete();
@@ -286,6 +270,8 @@ export class SkyDateRangePickerComponent {
286
270
  },
287
271
  };
288
272
  }
273
+ // Set calculator errors on the select so that they appear beneath it.
274
+ this.#calculatorIdControl.setErrors(errors);
289
275
  if (this.showStartDatePicker && startDateErrors) {
290
276
  errors ||= {};
291
277
  errors = { ...errors, ...startDateErrors };
@@ -294,8 +280,6 @@ export class SkyDateRangePickerComponent {
294
280
  errors ||= {};
295
281
  errors = { ...errors, ...endDateErrors };
296
282
  }
297
- // Set errors on the calculator select so that they appear beneath it.
298
- this.#calculatorIdControl.setErrors(errors);
299
283
  this.#changeDetector.markForCheck();
300
284
  return errors;
301
285
  }
@@ -385,8 +369,8 @@ export class SkyDateRangePickerComponent {
385
369
  this.showStartDatePicker = showStartDatePicker;
386
370
  this.#changeDetector.markForCheck();
387
371
  }
388
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: SkyDateRangePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
389
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.1.2", type: SkyDateRangePickerComponent, isStandalone: true, selector: "sky-date-range-picker", inputs: { calculatorIds: "calculatorIds", dateFormat: "dateFormat", disabled: ["disabled", "disabled", booleanAttribute], endDateRequired: ["endDateRequired", "endDateRequired", booleanAttribute], helpPopoverContent: "helpPopoverContent", helpPopoverTitle: "helpPopoverTitle", hintText: "hintText", label: "label", labelText: "labelText", required: ["required", "required", booleanAttribute], stacked: ["stacked", "stacked", booleanAttribute], startDateRequired: ["startDateRequired", "startDateRequired", booleanAttribute], helpKey: "helpKey" }, host: { properties: { "class.sky-margin-stacked-lg": "this.stacked", "style.display": "this.display" } }, providers: [
372
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: SkyDateRangePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
373
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: SkyDateRangePickerComponent, isStandalone: true, selector: "sky-date-range-picker", inputs: { calculatorIds: "calculatorIds", dateFormat: "dateFormat", disabled: ["disabled", "disabled", booleanAttribute], helpPopoverContent: "helpPopoverContent", helpPopoverTitle: "helpPopoverTitle", hintText: "hintText", label: "label", labelText: "labelText", required: ["required", "required", booleanAttribute], stacked: ["stacked", "stacked", booleanAttribute], helpKey: "helpKey" }, host: { properties: { "class.sky-margin-stacked-lg": "this.stacked" } }, providers: [
390
374
  {
391
375
  provide: NG_VALIDATORS,
392
376
  useExisting: SkyDateRangePickerComponent,
@@ -398,9 +382,9 @@ export class SkyDateRangePickerComponent {
398
382
  multi: true,
399
383
  },
400
384
  { provide: SKY_FORM_ERRORS_ENABLED, useValue: true },
401
- ], ngImport: i0, template: "<div\n class=\"sky-date-range-picker\"\n [formGroup]=\"formGroup\"\n (focusout)=\"onBlur()\"\n>\n <div\n class=\"sky-date-range-picker-form-group\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n !showStartDatePicker && !showEndDatePicker\n }\"\n >\n <sky-input-box\n [hasErrors]=\"hasErrors\"\n [helpKey]=\"helpKey\"\n [helpPopoverContent]=\"helpPopoverContent\"\n [helpPopoverTitle]=\"helpPopoverTitle\"\n [hintText]=\"hintText\"\n [labelText]=\"\n labelText ||\n label ||\n ('skyux_date_range_picker_default_label' | skyLibResources)\n \"\n >\n <select\n formControlName=\"calculatorId\"\n [required]=\"isRequired()\"\n (blur)=\"onBlur()\"\n >\n <option\n *ngFor=\"let calculator of calculators\"\n [value]=\"calculator.calculatorId\"\n >\n {{\n calculator._shortDescriptionResourceKey\n ? (calculator._shortDescriptionResourceKey | skyLibResources)\n : calculator.shortDescription\n }}\n </option>\n </select>\n </sky-input-box>\n <sky-form-errors\n *ngIf=\"labelText && hostControl?.errors?.['skyDateRange']\"\n [labelText]=\"labelText\"\n >\n <sky-form-error\n *ngIf=\"\n hostControl?.errors?.['skyDateRange']?.errors.endDateBeforeStartDate\n \"\n [errorName]=\"'endDateBeforeStartDate'\"\n [errorText]=\"\n 'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n | skyLibResources\n \"\n />\n <ng-content select=\"sky-form-error\" />\n </sky-form-errors>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper\"\n [hidden]=\"!showStartDatePicker\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n showStartDatePicker && !showEndDatePicker\n }\"\n >\n <sky-input-box\n [errorsScreenReaderOnly]=\"true\"\n [hasErrors]=\"hasErrors\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker>\n <input\n formControlName=\"startDate\"\n name=\"startDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"\n showStartDatePicker && (startDateRequired || isRequired())\n \"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper\"\n [hidden]=\"!showEndDatePicker\"\n [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker }\"\n >\n <sky-input-box\n [errorsScreenReaderOnly]=\"true\"\n [hasErrors]=\"hasErrors\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker>\n <input\n formControlName=\"endDate\"\n name=\"endDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showEndDatePicker && (endDateRequired || isRequired())\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n</div>\n", styles: [":host{display:block}.sky-date-range-picker{display:flex}:host .sky-date-range-picker{flex-direction:column}:host .sky-date-range-picker-form-group{flex-basis:100%}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-margin-stacked-lg)}:host-context(.sky-responsive-container-xs) .sky-date-range-picker,:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:column}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:100%}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-margin-stacked-lg)}@media (min-width: 768px){:host .sky-date-range-picker{flex-direction:initial}:host .sky-date-range-picker-form-group{flex-basis:33.3333333333%}: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 .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0}}: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%}: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-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0}@media (min-width: 768px){:host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}}.sky-responsive-container-sm :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-md :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-lg :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}:host-context(.sky-theme-modern) .sky-date-range-picker-form-group{padding:0}:host-context(.sky-theme-modern) :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}@media (min-width: 768px){:host-context(.sky-theme-modern) :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}}:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}.sky-theme-modern .sky-date-range-picker-form-group{padding:0}.sky-theme-modern :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}.sky-theme-modern :host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}@media (min-width: 768px){.sky-theme-modern :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}}.sky-theme-modern :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: SkyDatepickerModule }, { kind: "component", type: i3.SkyDatepickerComponent, selector: "sky-datepicker", inputs: ["pickerClass"], outputs: ["calendarDateRangeChange", "dateFormatChange", "openChange"] }, { kind: "directive", type: i4.SkyDatepickerInputDirective, selector: "[skyDatepickerInput]", inputs: ["dateFormat", "disabled", "maxDate", "minDate", "startAtDate", "skyDatepickerInput", "skyDatepickerNoValidate", "startingDay", "strict"] }, { kind: "pipe", type: SkyDateRangePickerEndDateResourceKeyPipe, name: "skyDateRangePickerEndDateResourceKey" }, { kind: "pipe", type: SkyDateRangePickerStartDateResourceKeyPipe, name: "skyDateRangePickerStartDateResourceKey" }, { kind: "ngmodule", type: SkyDatetimeResourcesModule }, { kind: "pipe", type: i5.SkyLibResourcesPipe, name: "skyLibResources" }, { kind: "ngmodule", type: SkyInputBoxModule }, { kind: "component", type: i6.λ10, selector: "sky-input-box", inputs: ["hasErrors", "disabled", "labelText", "characterLimit", "stacked", "helpPopoverTitle", "helpPopoverContent", "helpKey", "hintText", "errorsScreenReaderOnly"] }, { kind: "directive", type: i6.λ20, selector: "input:not([skyId]):not(.sky-form-control),select:not([skyId]):not(.sky-form-control),textarea:not([skyId]):not(.sky-form-control)", inputs: ["autocomplete"] }, { kind: "component", type: i6.λ22, selector: "sky-form-error", inputs: ["errorName", "errorText"] }, { kind: "ngmodule", type: SkyFormErrorsModule }, { kind: "component", type: i6.λ21, selector: "sky-form-errors", inputs: ["errors", "labelText", "showErrors"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
385
+ ], ngImport: i0, template: "<div class=\"sky-date-range-picker\" [formGroup]=\"formGroup\">\n <div\n class=\"sky-date-range-picker-form-group\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n !showStartDatePicker && !showEndDatePicker\n }\"\n >\n <sky-input-box\n [hasErrors]=\"calculatorIdHasErrors\"\n [helpKey]=\"helpKey\"\n [helpPopoverContent]=\"helpPopoverContent\"\n [helpPopoverTitle]=\"helpPopoverTitle\"\n [hintText]=\"hintText\"\n [labelText]=\"\n labelText ||\n label ||\n ('skyux_date_range_picker_default_label' | skyLibResources)\n \"\n >\n <select formControlName=\"calculatorId\" (blur)=\"onBlur()\">\n @for (calculator of calculators; track calculator) {\n <option [value]=\"calculator.calculatorId\">\n {{\n calculator._shortDescriptionResourceKey\n ? (calculator._shortDescriptionResourceKey | skyLibResources)\n : calculator.shortDescription\n }}\n </option>\n }\n </select>\n @if (\n hostControl?.errors?.['skyDateRange']?.errors?.[\n 'endDateBeforeStartDate'\n ] && labelText\n ) {\n <sky-form-error\n [errorName]=\"'endDateBeforeStartDate'\"\n [errorText]=\"\n 'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n | skyLibResources\n \"\n />\n }\n <ng-content select=\"sky-form-error\" />\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper\"\n [hidden]=\"!showStartDatePicker\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n showStartDatePicker && !showEndDatePicker\n }\"\n >\n <sky-input-box\n [hasErrors]=\"startDateHasErrors\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker>\n <input\n formControlName=\"startDate\"\n name=\"startDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showStartDatePicker && isRequired()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper\"\n [hidden]=\"!showEndDatePicker\"\n [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker }\"\n >\n <sky-input-box\n [hasErrors]=\"endDateHasErrors\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker>\n <input\n formControlName=\"endDate\"\n name=\"endDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showEndDatePicker && isRequired()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n</div>\n", styles: [":host{display:block}.sky-date-range-picker{display:flex}:host .sky-date-range-picker{flex-direction:column}:host .sky-date-range-picker-form-group{flex-basis:100%}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-margin-stacked-lg)}:host-context(.sky-responsive-container-xs) .sky-date-range-picker,:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:column}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:100%}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-margin-stacked-lg)}@media (min-width: 768px){:host .sky-date-range-picker{flex-direction:initial}:host .sky-date-range-picker-form-group{flex-basis:33.3333333333%}: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 .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0}}: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%}: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-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0}@media (min-width: 768px){:host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}}.sky-responsive-container-sm :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-md :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-lg :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}:host-context(.sky-theme-modern) .sky-date-range-picker-form-group{padding:0}:host-context(.sky-theme-modern) :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}@media (min-width: 768px){:host-context(.sky-theme-modern) :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}}:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}.sky-theme-modern .sky-date-range-picker-form-group{padding:0}.sky-theme-modern :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}.sky-theme-modern :host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}@media (min-width: 768px){.sky-theme-modern :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}}.sky-theme-modern :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: SkyDatepickerModule }, { kind: "component", type: i3.SkyDatepickerComponent, selector: "sky-datepicker", inputs: ["pickerClass"], outputs: ["calendarDateRangeChange", "dateFormatChange", "openChange"] }, { kind: "directive", type: i4.SkyDatepickerInputDirective, selector: "[skyDatepickerInput]", inputs: ["dateFormat", "disabled", "maxDate", "minDate", "startAtDate", "skyDatepickerInput", "skyDatepickerNoValidate", "startingDay", "strict"] }, { kind: "pipe", type: SkyDateRangePickerEndDateResourceKeyPipe, name: "skyDateRangePickerEndDateResourceKey" }, { kind: "pipe", type: SkyDateRangePickerStartDateResourceKeyPipe, name: "skyDateRangePickerStartDateResourceKey" }, { kind: "ngmodule", type: SkyDatetimeResourcesModule }, { kind: "pipe", type: i5.SkyLibResourcesPipe, name: "skyLibResources" }, { kind: "ngmodule", type: SkyInputBoxModule }, { kind: "component", type: i6.λ10, selector: "sky-input-box", inputs: ["hasErrors", "disabled", "labelText", "characterLimit", "stacked", "helpPopoverTitle", "helpPopoverContent", "helpKey", "hintText"] }, { kind: "directive", type: i6.λ20, selector: "input:not([skyId]):not(.sky-form-control),select:not([skyId]):not(.sky-form-control),textarea:not([skyId]):not(.sky-form-control)", inputs: ["autocomplete"] }, { kind: "component", type: i6.λ22, selector: "sky-form-error", inputs: ["errorName", "errorText"] }, { kind: "ngmodule", type: SkyFormErrorsModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
402
386
  }
403
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: SkyDateRangePickerComponent, decorators: [{
387
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: SkyDateRangePickerComponent, decorators: [{
404
388
  type: Component,
405
389
  args: [{ changeDetection: ChangeDetectionStrategy.OnPush, imports: [
406
390
  CommonModule,
@@ -424,7 +408,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
424
408
  multi: true,
425
409
  },
426
410
  { provide: SKY_FORM_ERRORS_ENABLED, useValue: true },
427
- ], selector: 'sky-date-range-picker', standalone: true, template: "<div\n class=\"sky-date-range-picker\"\n [formGroup]=\"formGroup\"\n (focusout)=\"onBlur()\"\n>\n <div\n class=\"sky-date-range-picker-form-group\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n !showStartDatePicker && !showEndDatePicker\n }\"\n >\n <sky-input-box\n [hasErrors]=\"hasErrors\"\n [helpKey]=\"helpKey\"\n [helpPopoverContent]=\"helpPopoverContent\"\n [helpPopoverTitle]=\"helpPopoverTitle\"\n [hintText]=\"hintText\"\n [labelText]=\"\n labelText ||\n label ||\n ('skyux_date_range_picker_default_label' | skyLibResources)\n \"\n >\n <select\n formControlName=\"calculatorId\"\n [required]=\"isRequired()\"\n (blur)=\"onBlur()\"\n >\n <option\n *ngFor=\"let calculator of calculators\"\n [value]=\"calculator.calculatorId\"\n >\n {{\n calculator._shortDescriptionResourceKey\n ? (calculator._shortDescriptionResourceKey | skyLibResources)\n : calculator.shortDescription\n }}\n </option>\n </select>\n </sky-input-box>\n <sky-form-errors\n *ngIf=\"labelText && hostControl?.errors?.['skyDateRange']\"\n [labelText]=\"labelText\"\n >\n <sky-form-error\n *ngIf=\"\n hostControl?.errors?.['skyDateRange']?.errors.endDateBeforeStartDate\n \"\n [errorName]=\"'endDateBeforeStartDate'\"\n [errorText]=\"\n 'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n | skyLibResources\n \"\n />\n <ng-content select=\"sky-form-error\" />\n </sky-form-errors>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper\"\n [hidden]=\"!showStartDatePicker\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n showStartDatePicker && !showEndDatePicker\n }\"\n >\n <sky-input-box\n [errorsScreenReaderOnly]=\"true\"\n [hasErrors]=\"hasErrors\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker>\n <input\n formControlName=\"startDate\"\n name=\"startDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"\n showStartDatePicker && (startDateRequired || isRequired())\n \"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper\"\n [hidden]=\"!showEndDatePicker\"\n [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker }\"\n >\n <sky-input-box\n [errorsScreenReaderOnly]=\"true\"\n [hasErrors]=\"hasErrors\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker>\n <input\n formControlName=\"endDate\"\n name=\"endDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showEndDatePicker && (endDateRequired || isRequired())\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n</div>\n", styles: [":host{display:block}.sky-date-range-picker{display:flex}:host .sky-date-range-picker{flex-direction:column}:host .sky-date-range-picker-form-group{flex-basis:100%}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-margin-stacked-lg)}:host-context(.sky-responsive-container-xs) .sky-date-range-picker,:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:column}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:100%}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-margin-stacked-lg)}@media (min-width: 768px){:host .sky-date-range-picker{flex-direction:initial}:host .sky-date-range-picker-form-group{flex-basis:33.3333333333%}: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 .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0}}: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%}: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-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0}@media (min-width: 768px){:host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}}.sky-responsive-container-sm :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-md :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-lg :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}:host-context(.sky-theme-modern) .sky-date-range-picker-form-group{padding:0}:host-context(.sky-theme-modern) :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}@media (min-width: 768px){:host-context(.sky-theme-modern) :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}}:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}.sky-theme-modern .sky-date-range-picker-form-group{padding:0}.sky-theme-modern :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}.sky-theme-modern :host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}@media (min-width: 768px){.sky-theme-modern :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}}.sky-theme-modern :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}\n"] }]
411
+ ], selector: 'sky-date-range-picker', standalone: true, template: "<div class=\"sky-date-range-picker\" [formGroup]=\"formGroup\">\n <div\n class=\"sky-date-range-picker-form-group\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n !showStartDatePicker && !showEndDatePicker\n }\"\n >\n <sky-input-box\n [hasErrors]=\"calculatorIdHasErrors\"\n [helpKey]=\"helpKey\"\n [helpPopoverContent]=\"helpPopoverContent\"\n [helpPopoverTitle]=\"helpPopoverTitle\"\n [hintText]=\"hintText\"\n [labelText]=\"\n labelText ||\n label ||\n ('skyux_date_range_picker_default_label' | skyLibResources)\n \"\n >\n <select formControlName=\"calculatorId\" (blur)=\"onBlur()\">\n @for (calculator of calculators; track calculator) {\n <option [value]=\"calculator.calculatorId\">\n {{\n calculator._shortDescriptionResourceKey\n ? (calculator._shortDescriptionResourceKey | skyLibResources)\n : calculator.shortDescription\n }}\n </option>\n }\n </select>\n @if (\n hostControl?.errors?.['skyDateRange']?.errors?.[\n 'endDateBeforeStartDate'\n ] && labelText\n ) {\n <sky-form-error\n [errorName]=\"'endDateBeforeStartDate'\"\n [errorText]=\"\n 'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n | skyLibResources\n \"\n />\n }\n <ng-content select=\"sky-form-error\" />\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper\"\n [hidden]=\"!showStartDatePicker\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n showStartDatePicker && !showEndDatePicker\n }\"\n >\n <sky-input-box\n [hasErrors]=\"startDateHasErrors\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker>\n <input\n formControlName=\"startDate\"\n name=\"startDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showStartDatePicker && isRequired()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper\"\n [hidden]=\"!showEndDatePicker\"\n [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker }\"\n >\n <sky-input-box\n [hasErrors]=\"endDateHasErrors\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker>\n <input\n formControlName=\"endDate\"\n name=\"endDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showEndDatePicker && isRequired()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n</div>\n", styles: [":host{display:block}.sky-date-range-picker{display:flex}:host .sky-date-range-picker{flex-direction:column}:host .sky-date-range-picker-form-group{flex-basis:100%}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-margin-stacked-lg)}:host-context(.sky-responsive-container-xs) .sky-date-range-picker,:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:column}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:100%}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-margin-stacked-lg)}@media (min-width: 768px){:host .sky-date-range-picker{flex-direction:initial}:host .sky-date-range-picker-form-group{flex-basis:33.3333333333%}: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 .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0}}: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%}: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-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0}@media (min-width: 768px){:host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}}.sky-responsive-container-sm :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-md :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-lg :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}:host-context(.sky-theme-modern) .sky-date-range-picker-form-group{padding:0}:host-context(.sky-theme-modern) :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}@media (min-width: 768px){:host-context(.sky-theme-modern) :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}}:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-theme-modern) :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}.sky-theme-modern .sky-date-range-picker-form-group{padding:0}.sky-theme-modern :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}.sky-theme-modern :host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:0}@media (min-width: 768px){.sky-theme-modern :host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}}.sky-theme-modern :host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),.sky-theme-modern :host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-right:20px}\n"] }]
428
412
  }], ctorParameters: () => [], propDecorators: { calculatorIds: [{
429
413
  type: Input
430
414
  }], dateFormat: [{
@@ -432,9 +416,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
432
416
  }], disabled: [{
433
417
  type: Input,
434
418
  args: [{ transform: booleanAttribute }]
435
- }], endDateRequired: [{
436
- type: Input,
437
- args: [{ transform: booleanAttribute }]
438
419
  }], helpPopoverContent: [{
439
420
  type: Input
440
421
  }], helpPopoverTitle: [{
@@ -454,13 +435,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
454
435
  }, {
455
436
  type: HostBinding,
456
437
  args: ['class.sky-margin-stacked-lg']
457
- }], startDateRequired: [{
458
- type: Input,
459
- args: [{ transform: booleanAttribute }]
460
438
  }], helpKey: [{
461
439
  type: Input
462
- }], display: [{
463
- type: HostBinding,
464
- args: ['style.display']
465
440
  }] } });
466
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-picker.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/date-range-picker/date-range-picker.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/date-range-picker/date-range-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  HostBinding,\n  Injector,\n  Input,\n  OnDestroy,\n  OnInit,\n  TemplateRef,\n  booleanAttribute,\n  inject,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormBuilder,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  NgControl,\n  ReactiveFormsModule,\n  ValidationErrors,\n  Validator,\n  Validators,\n} from '@angular/forms';\nimport { SkyLogService } from '@skyux/core';\nimport {\n  SKY_FORM_ERRORS_ENABLED,\n  SkyFormErrorsModule,\n  SkyFormFieldLabelTextRequiredService,\n  SkyInputBoxModule,\n} from '@skyux/forms';\n\nimport { Subject, distinctUntilChanged, merge, takeUntil } from 'rxjs';\n\nimport { SkyDatepickerModule } from '../datepicker/datepicker.module';\nimport { SkyDatetimeResourcesModule } from '../shared/sky-datetime-resources.module';\n\nimport { SkyDateRangePickerEndDateResourceKeyPipe } from './date-range-picker-end-date-resource-key.pipe';\nimport { SkyDateRangePickerStartDateResourceKeyPipe } from './date-range-picker-start-date-resource-key.pipe';\nimport { SkyDateRangeService } from './date-range.service';\nimport { SkyDateRangeCalculation } from './types/date-range-calculation';\nimport { SkyDateRangeCalculator } from './types/date-range-calculator';\nimport { SkyDateRangeCalculatorId } from './types/date-range-calculator-id';\nimport { SkyDateRangeCalculatorType } from './types/date-range-calculator-type';\nimport { SKY_DEFAULT_CALCULATOR_IDS } from './types/date-range-default-calculator-configs';\n\ntype DateValue = Date | string | null | undefined;\n\nfunction areDateRangesEqual(\n  rangeA: SkyDateRangeCalculation | undefined,\n  rangeB: SkyDateRangeCalculation | undefined,\n): boolean {\n  return (\n    !!rangeA &&\n    !!rangeB &&\n    rangeA.calculatorId === rangeB.calculatorId &&\n    areDatesEqual(rangeA.startDate, rangeB.startDate) &&\n    areDatesEqual(rangeA.endDate, rangeB.endDate)\n  );\n}\n\nfunction areDatesEqual(a: DateValue, b: DateValue): boolean {\n  if (typeof a !== typeof b) {\n    return false;\n  }\n\n  if (!a && !b) {\n    return true;\n  }\n\n  if (typeof a === 'string' && a === b) {\n    return true;\n  }\n\n  return a instanceof Date && b instanceof Date && a.getTime() === b.getTime();\n}\n\nfunction isNullOrUndefined(value: unknown): value is undefined | null {\n  return value === undefined || value === null;\n}\n\nfunction isPartialValue(\n  value: Partial<SkyDateRangeCalculation> | null | undefined,\n): value is Partial<SkyDateRangeCalculation> | null | undefined {\n  return (\n    isNullOrUndefined(value) ||\n    isNullOrUndefined(value.calculatorId) ||\n    !('endDate' in value) ||\n    !('startDate' in value)\n  );\n}\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    SkyDatepickerModule,\n    SkyDateRangePickerEndDateResourceKeyPipe,\n    SkyDateRangePickerStartDateResourceKeyPipe,\n    SkyDatetimeResourcesModule,\n    SkyInputBoxModule,\n    SkyFormErrorsModule,\n  ],\n  providers: [\n    {\n      provide: NG_VALIDATORS,\n      useExisting: SkyDateRangePickerComponent,\n      multi: true,\n    },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: SkyDateRangePickerComponent,\n      multi: true,\n    },\n    { provide: SKY_FORM_ERRORS_ENABLED, useValue: true },\n  ],\n  selector: 'sky-date-range-picker',\n  standalone: true,\n  styleUrl: './date-range-picker.component.scss',\n  templateUrl: './date-range-picker.component.html',\n})\nexport class SkyDateRangePickerComponent\n  implements\n    AfterViewInit,\n    ControlValueAccessor,\n    DoCheck,\n    OnDestroy,\n    OnInit,\n    Validator\n{\n  /**\n   * IDs for the date range options to include in the picker's dropdown.\n   * The options specify calculator objects that return two `Date` objects to represent date ranges.\n   * By default, this property includes all `SkyDateRangeCalculatorId` values.\n   */\n  @Input()\n  public set calculatorIds(\n    calculatorIds: SkyDateRangeCalculatorId[] | undefined,\n  ) {\n    const currentCalculatorId = this.#getValue().calculatorId;\n\n    this.#_calculatorIds = calculatorIds ?? SKY_DEFAULT_CALCULATOR_IDS;\n    this.calculators = this.#dateRangeSvc.filterCalculators(\n      this.#_calculatorIds,\n    );\n\n    // If the currently selected calculator isn't available anymore,\n    // select the first calculator in the new array.\n    if (!this.#_calculatorIds.includes(currentCalculatorId)) {\n      this.#setValue(\n        { calculatorId: this.calculatorIds[0] },\n        { emitEvent: true },\n      );\n    }\n  }\n\n  public get calculatorIds(): SkyDateRangeCalculatorId[] {\n    return this.#_calculatorIds;\n  }\n\n  /**\n   * The date format for\n   * [the `sky-datepicker` components](https://developer.blackbaud.com/skyux/components/datepicker)\n   * that make up the date range picker. The text input is a composite component of\n   * up to two `sky-datepicker` components.\n   * @default \"MM/DD/YYYY\"\n   */\n  @Input()\n  public dateFormat: string | undefined;\n\n  /**\n   * Whether to disable the date range picker on template-driven forms. Don't use\n   * this input on reactive forms because they may overwrite the input or leave\n   * the control out of sync. To set the disabled state on reactive forms,\n   * use the `FormControl` instead.\n   * @default false\n   */\n  @Input({ transform: booleanAttribute })\n  public set disabled(value: boolean) {\n    if (value) {\n      this.formGroup.disable();\n    } else {\n      this.formGroup.enable();\n    }\n  }\n\n  /**\n   * Whether to require users to specify a end date.\n   * @deprecated Use the `required` directive or Angular's `Validators.required`\n   * on the form control to mark the date range picker as required.\n   */\n  @Input({ transform: booleanAttribute })\n  public endDateRequired = false;\n\n  /**\n   * The content of the help popover. When specified along with `labelText`, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is added to date range picker. The help inline button displays a [popover](https://developer.blackbaud.com/skyux/components/popover)\n   * when clicked using the specified content and optional title.\n   */\n  @Input()\n  public helpPopoverContent: string | TemplateRef<unknown> | undefined;\n\n  /**\n   * The title of the help popover. This property only applies when `helpPopoverContent` is\n   * also specified.\n   */\n  @Input()\n  public helpPopoverTitle: string | undefined;\n\n  /**\n   * [Persistent inline help text](https://developer.blackbaud.com/skyux/design/guidelines/user-assistance#inline-help) that provides\n   * additional context to the user.\n   */\n  @Input()\n  public hintText: string | undefined;\n\n  /**\n   * The label for the date range picker.\n   * @deprecated Use the `labelText` input instead.\n   */\n  @Input()\n  public set label(value: string | undefined) {\n    this.#_label = value;\n\n    if (value) {\n      this.#logger.deprecated('SkyDateRangePickerComponent.label', {\n        deprecationMajorVersion: 10,\n        replacementRecommendation: 'Use the `labelText` input instead.',\n      });\n    }\n  }\n\n  public get label(): string | undefined {\n    return this.#_label;\n  }\n\n  /**\n   * The text to display as the date range picker's label.\n   */\n  @Input()\n  public labelText: string | undefined;\n\n  /**\n   * Whether the date range picker requires a value.\n   */\n  @Input({ transform: booleanAttribute })\n  public required = false;\n\n  /**\n   * Whether the date range picker is stacked on another form component. When specified, the appropriate\n   * vertical spacing is automatically added to the date range picker.\n   */\n  @Input({ transform: booleanAttribute })\n  @HostBinding('class.sky-margin-stacked-lg')\n  public stacked = false;\n\n  /**\n   * Whether to require users to specify a start date.\n   * @deprecated Use the `required` directive or Angular's `Validators.required`\n   * on the form control to mark the date range picker as required.\n   */\n  @Input({ transform: booleanAttribute })\n  public startDateRequired = false;\n\n  /**\n   * A help key that identifies the global help content to display. When specified, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is placed beside the date range picker label. Clicking the button invokes [global help](https://developer.blackbaud.com/skyux/learn/develop/global-help)\n   * as configured by the application.\n   */\n  @Input()\n  public helpKey: string | undefined;\n\n  @HostBinding('style.display')\n  protected display: string | undefined;\n\n  protected calculators: SkyDateRangeCalculator[] = [];\n  protected formGroup: FormGroup;\n  protected hasErrors = false;\n  protected hostControl: AbstractControl | null | undefined;\n  protected selectedCalculator: SkyDateRangeCalculator;\n  protected showEndDatePicker = false;\n  protected showStartDatePicker = false;\n\n  get #calculatorIdControl(): AbstractControl<SkyDateRangeCalculatorId> {\n    return this.formGroup.get(\n      'calculatorId',\n    ) as AbstractControl<SkyDateRangeCalculatorId>;\n  }\n\n  get #endDateControl(): AbstractControl<DateValue> {\n    return this.formGroup.get('endDate') as AbstractControl<DateValue>;\n  }\n\n  get #startDateControl(): AbstractControl<DateValue> {\n    return this.formGroup.get('startDate') as AbstractControl<DateValue>;\n  }\n\n  #_calculatorIds = SKY_DEFAULT_CALCULATOR_IDS;\n  #_label: string | undefined;\n  #_value: SkyDateRangeCalculation;\n  #ngUnsubscribe = new Subject<void>();\n  #notifyChange: ((_: SkyDateRangeCalculation) => void) | undefined;\n  #notifyTouched: (() => void) | undefined;\n\n  readonly #changeDetector = inject(ChangeDetectorRef);\n  readonly #dateRangeSvc = inject(SkyDateRangeService);\n  readonly #injector = inject(Injector);\n  readonly #labelTextRequiredSvc = inject(\n    SkyFormFieldLabelTextRequiredService,\n    {\n      optional: true,\n    },\n  );\n  readonly #logger = inject(SkyLogService);\n\n  constructor() {\n    this.calculators = this.#dateRangeSvc.calculators;\n    this.selectedCalculator = this.calculators[0];\n\n    const initialValue = this.#getDefaultValue(this.selectedCalculator);\n    this.#_value = initialValue;\n\n    this.formGroup = inject(FormBuilder).group({\n      calculatorId: new FormControl<number>(initialValue.calculatorId),\n      startDate: new FormControl<DateValue>(initialValue.startDate),\n      endDate: new FormControl<DateValue>(initialValue.endDate),\n    });\n  }\n\n  public ngOnInit(): void {\n    if (this.#labelTextRequiredSvc) {\n      this.#labelTextRequiredSvc.validateLabelText(\n        this.labelText || this.label,\n      );\n\n      if (!this.label && !this.labelText) {\n        this.display = 'none';\n      }\n    }\n  }\n\n  public ngAfterViewInit(): void {\n    this.hostControl = this.#injector.get(NgControl, null, {\n      optional: true,\n      self: true,\n    })?.control;\n\n    // Set a default value on the control if it's undefined on init.\n    // We need to use setTimeout to avoid interfering with the first\n    // validation cycle.\n    if (isPartialValue(this.hostControl?.value)) {\n      setTimeout(() => {\n        this.hostControl?.setValue(this.#getValue(), {\n          emitEvent: false,\n          onlySelf: true,\n        });\n      });\n    }\n\n    // Update the view when \"required\" or \"disabled\" states are changed on the\n    // host control.\n    this.hostControl?.statusChanges\n      .pipe(distinctUntilChanged(), takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#changeDetector.markForCheck();\n      });\n\n    // Start listening for changes after the first change detection cycle.\n    setTimeout(() => {\n      this.formGroup.valueChanges\n        .pipe(\n          distinctUntilChanged(areDateRangesEqual),\n          takeUntil(this.#ngUnsubscribe),\n        )\n        .subscribe((value) => {\n          if (!isNullOrUndefined(value?.calculatorId)) {\n            // The select element sets the calculator ID to a string, but we\n            // need it to be a number.\n            value.calculatorId = +value.calculatorId;\n\n            // If the calculator ID is changed, we need to reset the start and\n            // end date values and wait until the next valueChanges event to\n            // notify the host control.\n            if (value.calculatorId !== this.#getValue().calculatorId) {\n              this.#setValue(\n                { calculatorId: value.calculatorId },\n                { emitEvent: true },\n              );\n\n              return;\n            }\n          }\n\n          this.#setValue(value, { emitEvent: false });\n          const newValue = this.#getValue();\n\n          // Update the host control if the value is different.\n          if (!areDateRangesEqual(this.hostControl?.value, newValue)) {\n            this.#notifyChange?.(newValue);\n          }\n        });\n    });\n\n    // If the datepickers' statuses change, we want to retrigger the host\n    // control's validation so that their errors are reflected back to the host.\n    merge(\n      this.#startDateControl.statusChanges,\n      this.#endDateControl.statusChanges,\n    )\n      .pipe(distinctUntilChanged(), takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        // Use a setTimeout to avoid an ExpressionChangedAfterChecked error,\n        // since multiple calls to updateValueAndValidity in the same\n        // cycle may collide with one another.\n        setTimeout(() => {\n          this.hostControl?.updateValueAndValidity({\n            emitEvent: false,\n            onlySelf: true,\n          });\n        });\n      });\n\n    this.#updatePickerVisibility(this.selectedCalculator);\n  }\n\n  /**\n   * Check for touched status in ngDoCheck since Angular does not (currently)\n   * have an API to respond to touched status changes from the host control.\n   * @see https://github.com/angular/angular/issues/17736#issuecomment-310812368\n   * TODO: Angular 18 introduces a new API to respond to these statuses.\n   * @see https://github.com/angular/angular/issues/10887#issuecomment-2035267400\n   */\n  public ngDoCheck(): void {\n    const control = this.hostControl;\n    const touched = this.formGroup.touched;\n\n    if (control) {\n      if (control.touched && !touched) {\n        this.formGroup.markAllAsTouched();\n        this.#changeDetector.markForCheck();\n      } else if (control.untouched && touched) {\n        this.formGroup.markAsUntouched();\n        this.#changeDetector.markForCheck();\n      }\n\n      this.hasErrors = !!control.errors && (control.touched || control.dirty);\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public registerOnChange(fn: (_: unknown) => void): void {\n    this.#notifyChange = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public registerOnTouched(fn: () => void): void {\n    this.#notifyTouched = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  // Implemented as part of Validator.\n  public validate(control: AbstractControl): ValidationErrors | null {\n    let errors: ValidationErrors | null = null;\n\n    const calculatorErrors = this.selectedCalculator.validate(control.value);\n    const startDateErrors = this.#startDateControl.errors;\n    const endDateErrors = this.#endDateControl.errors;\n\n    if (calculatorErrors) {\n      errors = {\n        skyDateRange: {\n          calculatorId: this.#getValue().calculatorId,\n          errors: calculatorErrors,\n        },\n      };\n    }\n\n    if (this.showStartDatePicker && startDateErrors) {\n      errors ||= {};\n      errors = { ...errors, ...startDateErrors };\n    }\n\n    if (this.showEndDatePicker && endDateErrors) {\n      errors ||= {};\n      errors = { ...errors, ...endDateErrors };\n    }\n\n    // Set errors on the calculator select so that they appear beneath it.\n    this.#calculatorIdControl.setErrors(errors);\n    this.#changeDetector.markForCheck();\n\n    return errors;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  // The date range picker always has a value, so if the consumer passes in a\n  // partial value (via `patchValue`) or null, we need to update the host control's\n  // value with the complete value after it's been modified.\n  public writeValue(value: Partial<SkyDateRangeCalculation> | undefined): void {\n    this.#patchValue(value);\n\n    // Update the host control if it is set to a partial or null value.\n    if (isPartialValue(value)) {\n      this.hostControl?.setValue(this.#getValue(), {\n        emitEvent: false,\n        onlySelf: true,\n      });\n    }\n  }\n\n  protected isRequired(): boolean {\n    return !!(\n      this.required || this.hostControl?.hasValidator(Validators.required)\n    );\n  }\n\n  protected onBlur(): void {\n    this.#notifyTouched?.();\n  }\n\n  #getCalculator(calculatorId: number): SkyDateRangeCalculator {\n    const found = this.calculators.find((c) => c.calculatorId === calculatorId);\n\n    /*safety check: should not happen*/\n    /*istanbul ignore if*/\n    if (!found) {\n      throw new Error(\n        `A date range calculator with ID (${calculatorId}) could not be found.`,\n      );\n    }\n\n    return found;\n  }\n\n  #getDefaultValue(\n    calculator: SkyDateRangeCalculator,\n  ): SkyDateRangeCalculation {\n    return calculator.getValue();\n  }\n\n  #getValue(): SkyDateRangeCalculation {\n    return this.#_value;\n  }\n\n  #patchValue(\n    partialValue: Partial<SkyDateRangeCalculation> | null | undefined,\n  ): void {\n    this.#setValue(\n      isNullOrUndefined(partialValue)\n        ? null\n        : { ...this.#getValue(), ...partialValue },\n      { emitEvent: true },\n    );\n  }\n\n  /**\n   * Sets the value to be used by the date range picker form control.\n   */\n  #setValue(\n    value: SkyDateRangeCalculation | null | undefined,\n    options: { emitEvent: boolean },\n  ): void {\n    const oldValue = this.#getValue();\n\n    const valueOrDefault =\n      !value || isNullOrUndefined(value.calculatorId)\n        ? this.#getDefaultValue(this.calculators[0])\n        : {\n            ...this.#getDefaultValue(this.#getCalculator(value.calculatorId)),\n            ...value,\n          };\n\n    // Ensure falsy values are set to null.\n    valueOrDefault.endDate = valueOrDefault.endDate || null;\n    valueOrDefault.startDate = valueOrDefault.startDate || null;\n\n    if (!areDateRangesEqual(oldValue, valueOrDefault)) {\n      this.#_value = valueOrDefault;\n\n      this.selectedCalculator = this.#getCalculator(\n        valueOrDefault.calculatorId,\n      );\n\n      if (oldValue.calculatorId !== valueOrDefault.calculatorId) {\n        this.#updatePickerVisibility(this.selectedCalculator);\n      }\n\n      if (options?.emitEvent) {\n        this.formGroup.patchValue(valueOrDefault);\n      }\n    }\n  }\n\n  #updatePickerVisibility(calculator: SkyDateRangeCalculator): void {\n    let showEndDatePicker = false;\n    let showStartDatePicker = false;\n\n    switch (calculator.type) {\n      case SkyDateRangeCalculatorType.Before:\n        showEndDatePicker = true;\n        break;\n\n      case SkyDateRangeCalculatorType.After:\n        showStartDatePicker = true;\n        break;\n\n      case SkyDateRangeCalculatorType.Range:\n        showEndDatePicker = true;\n        showStartDatePicker = true;\n        break;\n\n      default:\n        break;\n    }\n\n    this.showEndDatePicker = showEndDatePicker;\n    this.showStartDatePicker = showStartDatePicker;\n    this.#changeDetector.markForCheck();\n  }\n}\n","<div\n  class=\"sky-date-range-picker\"\n  [formGroup]=\"formGroup\"\n  (focusout)=\"onBlur()\"\n>\n  <div\n    class=\"sky-date-range-picker-form-group\"\n    [ngClass]=\"{\n      'sky-date-range-picker-last-input':\n        !showStartDatePicker && !showEndDatePicker\n    }\"\n  >\n    <sky-input-box\n      [hasErrors]=\"hasErrors\"\n      [helpKey]=\"helpKey\"\n      [helpPopoverContent]=\"helpPopoverContent\"\n      [helpPopoverTitle]=\"helpPopoverTitle\"\n      [hintText]=\"hintText\"\n      [labelText]=\"\n        labelText ||\n        label ||\n        ('skyux_date_range_picker_default_label' | skyLibResources)\n      \"\n    >\n      <select\n        formControlName=\"calculatorId\"\n        [required]=\"isRequired()\"\n        (blur)=\"onBlur()\"\n      >\n        <option\n          *ngFor=\"let calculator of calculators\"\n          [value]=\"calculator.calculatorId\"\n        >\n          {{\n            calculator._shortDescriptionResourceKey\n              ? (calculator._shortDescriptionResourceKey | skyLibResources)\n              : calculator.shortDescription\n          }}\n        </option>\n      </select>\n    </sky-input-box>\n    <sky-form-errors\n      *ngIf=\"labelText && hostControl?.errors?.['skyDateRange']\"\n      [labelText]=\"labelText\"\n    >\n      <sky-form-error\n        *ngIf=\"\n          hostControl?.errors?.['skyDateRange']?.errors.endDateBeforeStartDate\n        \"\n        [errorName]=\"'endDateBeforeStartDate'\"\n        [errorText]=\"\n          'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n            | skyLibResources\n        \"\n      />\n      <ng-content select=\"sky-form-error\" />\n    </sky-form-errors>\n  </div>\n  <div\n    class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper\"\n    [hidden]=\"!showStartDatePicker\"\n    [ngClass]=\"{\n      'sky-date-range-picker-last-input':\n        showStartDatePicker && !showEndDatePicker\n    }\"\n  >\n    <sky-input-box\n      [errorsScreenReaderOnly]=\"true\"\n      [hasErrors]=\"hasErrors\"\n      [labelText]=\"\n        selectedCalculator.type\n          | skyDateRangePickerStartDateResourceKey\n          | skyLibResources\n      \"\n    >\n      <sky-datepicker>\n        <input\n          formControlName=\"startDate\"\n          name=\"startDate\"\n          skyDatepickerInput\n          type=\"text\"\n          [attr.aria-label]=\"\n            labelText || label\n              ? ('skyux_date_range_picker_default_aria_label'\n                | skyLibResources\n                  : (selectedCalculator.type\n                      | skyDateRangePickerStartDateResourceKey\n                      | skyLibResources)\n                  : (labelText ? labelText : label))\n              : (selectedCalculator.type\n                | skyDateRangePickerStartDateResourceKey\n                | skyLibResources)\n          \"\n          [dateFormat]=\"dateFormat\"\n          [required]=\"\n            showStartDatePicker && (startDateRequired || isRequired())\n          \"\n        />\n      </sky-datepicker>\n    </sky-input-box>\n  </div>\n  <div\n    class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper\"\n    [hidden]=\"!showEndDatePicker\"\n    [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker }\"\n  >\n    <sky-input-box\n      [errorsScreenReaderOnly]=\"true\"\n      [hasErrors]=\"hasErrors\"\n      [labelText]=\"\n        selectedCalculator.type\n          | skyDateRangePickerEndDateResourceKey\n          | skyLibResources\n      \"\n    >\n      <sky-datepicker>\n        <input\n          formControlName=\"endDate\"\n          name=\"endDate\"\n          skyDatepickerInput\n          type=\"text\"\n          [attr.aria-label]=\"\n            labelText || label\n              ? ('skyux_date_range_picker_default_aria_label'\n                | skyLibResources\n                  : (selectedCalculator.type\n                      | skyDateRangePickerEndDateResourceKey\n                      | skyLibResources)\n                  : (labelText ? labelText : label))\n              : (selectedCalculator.type\n                | skyDateRangePickerEndDateResourceKey\n                | skyLibResources)\n          \"\n          [dateFormat]=\"dateFormat\"\n          [required]=\"showEndDatePicker && (endDateRequired || isRequired())\"\n        />\n      </sky-datepicker>\n    </sky-input-box>\n  </div>\n</div>\n"]}
441
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-picker.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/date-range-picker/date-range-picker.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/date-range-picker/date-range-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  HostBinding,\n  Injector,\n  Input,\n  OnDestroy,\n  TemplateRef,\n  booleanAttribute,\n  inject,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormBuilder,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  NgControl,\n  ReactiveFormsModule,\n  TouchedChangeEvent,\n  ValidationErrors,\n  Validator,\n  Validators,\n} from '@angular/forms';\nimport { SkyLogService } from '@skyux/core';\nimport {\n  SKY_FORM_ERRORS_ENABLED,\n  SkyFormErrorsModule,\n  SkyInputBoxModule,\n} from '@skyux/forms';\n\nimport { Subject, distinctUntilChanged, filter, merge, takeUntil } from 'rxjs';\n\nimport { SkyDatepickerModule } from '../datepicker/datepicker.module';\nimport { SkyDatetimeResourcesModule } from '../shared/sky-datetime-resources.module';\n\nimport { SkyDateRangePickerEndDateResourceKeyPipe } from './date-range-picker-end-date-resource-key.pipe';\nimport { SkyDateRangePickerStartDateResourceKeyPipe } from './date-range-picker-start-date-resource-key.pipe';\nimport { SkyDateRangeService } from './date-range.service';\nimport { SkyDateRangeCalculation } from './types/date-range-calculation';\nimport { SkyDateRangeCalculator } from './types/date-range-calculator';\nimport { SkyDateRangeCalculatorId } from './types/date-range-calculator-id';\nimport { SkyDateRangeCalculatorType } from './types/date-range-calculator-type';\nimport { SKY_DEFAULT_CALCULATOR_IDS } from './types/date-range-default-calculator-configs';\n\ntype DateValue = Date | string | null | undefined;\n\nfunction areDateRangesEqual(\n  rangeA: SkyDateRangeCalculation | undefined,\n  rangeB: SkyDateRangeCalculation | undefined,\n): boolean {\n  return (\n    !!rangeA &&\n    !!rangeB &&\n    rangeA.calculatorId === rangeB.calculatorId &&\n    areDatesEqual(rangeA.startDate, rangeB.startDate) &&\n    areDatesEqual(rangeA.endDate, rangeB.endDate)\n  );\n}\n\nfunction areDatesEqual(a: DateValue, b: DateValue): boolean {\n  if (typeof a !== typeof b) {\n    return false;\n  }\n\n  if (!a && !b) {\n    return true;\n  }\n\n  if (typeof a === 'string' && a === b) {\n    return true;\n  }\n\n  return a instanceof Date && b instanceof Date && a.getTime() === b.getTime();\n}\n\nfunction isNullOrUndefined(value: unknown): value is undefined | null {\n  return value === undefined || value === null;\n}\n\nfunction isPartialValue(\n  value: Partial<SkyDateRangeCalculation> | null | undefined,\n): value is Partial<SkyDateRangeCalculation> | null | undefined {\n  return (\n    isNullOrUndefined(value) ||\n    isNullOrUndefined(value.calculatorId) ||\n    !('endDate' in value) ||\n    !('startDate' in value)\n  );\n}\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    SkyDatepickerModule,\n    SkyDateRangePickerEndDateResourceKeyPipe,\n    SkyDateRangePickerStartDateResourceKeyPipe,\n    SkyDatetimeResourcesModule,\n    SkyInputBoxModule,\n    SkyFormErrorsModule,\n  ],\n  providers: [\n    {\n      provide: NG_VALIDATORS,\n      useExisting: SkyDateRangePickerComponent,\n      multi: true,\n    },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: SkyDateRangePickerComponent,\n      multi: true,\n    },\n    { provide: SKY_FORM_ERRORS_ENABLED, useValue: true },\n  ],\n  selector: 'sky-date-range-picker',\n  standalone: true,\n  styleUrl: './date-range-picker.component.scss',\n  templateUrl: './date-range-picker.component.html',\n})\nexport class SkyDateRangePickerComponent\n  implements AfterViewInit, ControlValueAccessor, DoCheck, OnDestroy, Validator\n{\n  /**\n   * IDs for the date range options to include in the picker's dropdown.\n   * The options specify calculator objects that return two `Date` objects to represent date ranges.\n   * By default, this property includes all `SkyDateRangeCalculatorId` values.\n   */\n  @Input()\n  public set calculatorIds(\n    calculatorIds: SkyDateRangeCalculatorId[] | undefined,\n  ) {\n    const currentCalculatorId = this.#getValue().calculatorId;\n\n    this.#_calculatorIds = calculatorIds ?? SKY_DEFAULT_CALCULATOR_IDS;\n    this.calculators = this.#dateRangeSvc.filterCalculators(\n      this.#_calculatorIds,\n    );\n\n    // If the currently selected calculator isn't available anymore,\n    // select the first calculator in the new array.\n    if (!this.#_calculatorIds.includes(currentCalculatorId)) {\n      this.#setValue(\n        { calculatorId: this.calculatorIds[0] },\n        { emitEvent: true },\n      );\n    }\n  }\n\n  public get calculatorIds(): SkyDateRangeCalculatorId[] {\n    return this.#_calculatorIds;\n  }\n\n  /**\n   * The date format for\n   * [the `sky-datepicker` components](https://developer.blackbaud.com/skyux/components/datepicker)\n   * that make up the date range picker. The text input is a composite component of\n   * up to two `sky-datepicker` components.\n   * @default \"MM/DD/YYYY\"\n   */\n  @Input()\n  public dateFormat: string | undefined;\n\n  /**\n   * Whether to disable the date range picker on template-driven forms. Don't use\n   * this input on reactive forms because they may overwrite the input or leave\n   * the control out of sync. To set the disabled state on reactive forms,\n   * use the `FormControl` instead.\n   * @default false\n   */\n  @Input({ transform: booleanAttribute })\n  public set disabled(value: boolean) {\n    if (value) {\n      this.formGroup.disable();\n    } else {\n      this.formGroup.enable();\n    }\n  }\n\n  /**\n   * The content of the help popover. When specified along with `labelText`, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is added to date range picker. The help inline button displays a [popover](https://developer.blackbaud.com/skyux/components/popover)\n   * when clicked using the specified content and optional title.\n   */\n  @Input()\n  public helpPopoverContent: string | TemplateRef<unknown> | undefined;\n\n  /**\n   * The title of the help popover. This property only applies when `helpPopoverContent` is\n   * also specified.\n   */\n  @Input()\n  public helpPopoverTitle: string | undefined;\n\n  /**\n   * [Persistent inline help text](https://developer.blackbaud.com/skyux/design/guidelines/user-assistance#inline-help) that provides\n   * additional context to the user.\n   */\n  @Input()\n  public hintText: string | undefined;\n\n  /**\n   * The label for the date range picker.\n   * @deprecated Use the `labelText` input instead.\n   */\n  @Input()\n  public set label(value: string | undefined) {\n    this.#_label = value;\n\n    if (value) {\n      this.#logger.deprecated('SkyDateRangePickerComponent.label', {\n        deprecationMajorVersion: 10,\n        replacementRecommendation: 'Use the `labelText` input instead.',\n      });\n    }\n  }\n\n  public get label(): string | undefined {\n    return this.#_label;\n  }\n\n  /**\n   * The text to display as the date range picker's label.\n   */\n  @Input()\n  public labelText: string | undefined;\n\n  /**\n   * Whether the date range picker requires a value.\n   */\n  @Input({ transform: booleanAttribute })\n  public required = false;\n\n  /**\n   * Whether the date range picker is stacked on another form component. When specified, the appropriate\n   * vertical spacing is automatically added to the date range picker.\n   */\n  @Input({ transform: booleanAttribute })\n  @HostBinding('class.sky-margin-stacked-lg')\n  public stacked = false;\n\n  /**\n   * A help key that identifies the global help content to display. When specified, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is placed beside the date range picker label. Clicking the button invokes [global help](https://developer.blackbaud.com/skyux/learn/develop/global-help)\n   * as configured by the application.\n   */\n  @Input()\n  public helpKey: string | undefined;\n\n  protected calculatorIdHasErrors = false;\n  protected calculators: SkyDateRangeCalculator[] = [];\n  protected endDateHasErrors = false;\n  protected formGroup: FormGroup;\n  protected hostControl: AbstractControl | null | undefined;\n  protected selectedCalculator: SkyDateRangeCalculator;\n  protected showEndDatePicker = false;\n  protected showStartDatePicker = false;\n  protected startDateHasErrors = false;\n\n  get #calculatorIdControl(): AbstractControl<SkyDateRangeCalculatorId> {\n    return this.formGroup.get(\n      'calculatorId',\n    ) as AbstractControl<SkyDateRangeCalculatorId>;\n  }\n\n  get #endDateControl(): AbstractControl<DateValue> {\n    return this.formGroup.get('endDate') as AbstractControl<DateValue>;\n  }\n\n  get #startDateControl(): AbstractControl<DateValue> {\n    return this.formGroup.get('startDate') as AbstractControl<DateValue>;\n  }\n\n  #_calculatorIds = SKY_DEFAULT_CALCULATOR_IDS;\n  #_label: string | undefined;\n  #_value: SkyDateRangeCalculation;\n  #ngUnsubscribe = new Subject<void>();\n  #notifyChange: ((_: SkyDateRangeCalculation) => void) | undefined;\n  #notifyTouched: (() => void) | undefined;\n\n  readonly #changeDetector = inject(ChangeDetectorRef);\n  readonly #dateRangeSvc = inject(SkyDateRangeService);\n  readonly #injector = inject(Injector);\n  readonly #logger = inject(SkyLogService);\n\n  constructor() {\n    this.calculators = this.#dateRangeSvc.calculators;\n    this.selectedCalculator = this.calculators[0];\n\n    const initialValue = this.#getDefaultValue(this.selectedCalculator);\n    this.#_value = initialValue;\n\n    this.formGroup = inject(FormBuilder).group({\n      calculatorId: new FormControl<number>(initialValue.calculatorId),\n      startDate: new FormControl<DateValue>(initialValue.startDate),\n      endDate: new FormControl<DateValue>(initialValue.endDate),\n    });\n  }\n\n  public ngAfterViewInit(): void {\n    this.hostControl = this.#injector.get(NgControl, null, {\n      optional: true,\n      self: true,\n    })?.control;\n\n    // Set a default value on the control if it's undefined on init.\n    // We need to use setTimeout to avoid interfering with the first\n    // validation cycle.\n    if (isPartialValue(this.hostControl?.value)) {\n      setTimeout(() => {\n        this.hostControl?.setValue(this.#getValue(), {\n          emitEvent: false,\n          onlySelf: true,\n        });\n      });\n    }\n\n    // Update the view when \"required\" or \"disabled\" states are changed on the\n    // host control.\n    this.hostControl?.statusChanges\n      .pipe(distinctUntilChanged(), takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#changeDetector.markForCheck();\n      });\n\n    // Start listening for changes after the first change detection cycle.\n    setTimeout(() => {\n      this.formGroup.valueChanges\n        .pipe(\n          distinctUntilChanged(areDateRangesEqual),\n          takeUntil(this.#ngUnsubscribe),\n        )\n        .subscribe((value) => {\n          if (!isNullOrUndefined(value?.calculatorId)) {\n            // The select element sets the calculator ID to a string, but we\n            // need it to be a number.\n            value.calculatorId = +value.calculatorId;\n\n            // If the calculator ID is changed, we need to reset the start and\n            // end date values and wait until the next valueChanges event to\n            // notify the host control.\n            if (value.calculatorId !== this.#getValue().calculatorId) {\n              this.#setValue(\n                { calculatorId: value.calculatorId },\n                { emitEvent: true },\n              );\n\n              return;\n            }\n          }\n\n          this.#setValue(value, { emitEvent: false });\n          const newValue = this.#getValue();\n\n          // Update the host control if the value is different.\n          if (!areDateRangesEqual(this.hostControl?.value, newValue)) {\n            this.#notifyChange?.(newValue);\n          }\n        });\n    });\n\n    // If the datepickers' statuses change, we want to retrigger the host\n    // control's validation so that their errors are reflected back to the host.\n    merge(\n      this.#startDateControl.statusChanges,\n      this.#endDateControl.statusChanges,\n    )\n      .pipe(distinctUntilChanged(), takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        // Use a setTimeout to avoid an ExpressionChangedAfterChecked error,\n        // since multiple calls to updateValueAndValidity in the same\n        // cycle may collide with one another.\n        setTimeout(() => {\n          this.hostControl?.updateValueAndValidity({\n            emitEvent: false,\n            onlySelf: true,\n          });\n        });\n      });\n\n    this.hostControl?.events\n      .pipe(\n        filter((event) => event instanceof TouchedChangeEvent),\n        takeUntil(this.#ngUnsubscribe),\n      )\n      .subscribe(() => {\n        this.formGroup.markAllAsTouched();\n      });\n\n    this.#updatePickerVisibility(this.selectedCalculator);\n  }\n\n  /**\n   * Check for touched status in ngDoCheck since Angular does not (currently)\n   * have an API to respond to touched status changes from the host control.\n   * @see https://github.com/angular/angular/issues/17736#issuecomment-310812368\n   * TODO: Angular 18 introduces a new API to respond to these statuses.\n   * @see https://github.com/angular/angular/issues/10887#issuecomment-2035267400\n   */\n  public ngDoCheck(): void {\n    const control = this.hostControl;\n\n    if (control) {\n      this.startDateHasErrors =\n        this.#controlHasErrors(this.#startDateControl) ||\n        this.#controlHasErrors(this.#calculatorIdControl);\n      this.endDateHasErrors =\n        this.#controlHasErrors(this.#endDateControl) ||\n        this.#controlHasErrors(this.#calculatorIdControl);\n      this.calculatorIdHasErrors = this.#controlHasErrors(\n        this.#calculatorIdControl,\n      );\n      this.#changeDetector.markForCheck();\n    }\n  }\n\n  #controlHasErrors(control: AbstractControl): boolean {\n    return !!control.errors && (control.touched || control.dirty);\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public registerOnChange(fn: (_: unknown) => void): void {\n    this.#notifyChange = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public registerOnTouched(fn: () => void): void {\n    this.#notifyTouched = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  // Implemented as part of Validator.\n  public validate(control: AbstractControl): ValidationErrors | null {\n    let errors: ValidationErrors | null = null;\n\n    const calculatorErrors = this.selectedCalculator.validate(control.value);\n    const startDateErrors = this.#startDateControl.errors;\n    const endDateErrors = this.#endDateControl.errors;\n\n    if (calculatorErrors) {\n      errors = {\n        skyDateRange: {\n          calculatorId: this.#getValue().calculatorId,\n          errors: calculatorErrors,\n        },\n      };\n    }\n\n    // Set calculator errors on the select so that they appear beneath it.\n    this.#calculatorIdControl.setErrors(errors);\n\n    if (this.showStartDatePicker && startDateErrors) {\n      errors ||= {};\n      errors = { ...errors, ...startDateErrors };\n    }\n\n    if (this.showEndDatePicker && endDateErrors) {\n      errors ||= {};\n      errors = { ...errors, ...endDateErrors };\n    }\n\n    this.#changeDetector.markForCheck();\n\n    return errors;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  // The date range picker always has a value, so if the consumer passes in a\n  // partial value (via `patchValue`) or null, we need to update the host control's\n  // value with the complete value after it's been modified.\n  public writeValue(value: Partial<SkyDateRangeCalculation> | undefined): void {\n    this.#patchValue(value);\n\n    // Update the host control if it is set to a partial or null value.\n    if (isPartialValue(value)) {\n      this.hostControl?.setValue(this.#getValue(), {\n        emitEvent: false,\n        onlySelf: true,\n      });\n    }\n  }\n\n  protected isRequired(): boolean {\n    return !!(\n      this.required || this.hostControl?.hasValidator(Validators.required)\n    );\n  }\n\n  protected onBlur(): void {\n    this.#notifyTouched?.();\n  }\n\n  #getCalculator(calculatorId: number): SkyDateRangeCalculator {\n    const found = this.calculators.find((c) => c.calculatorId === calculatorId);\n\n    /*safety check: should not happen*/\n    /*istanbul ignore if*/\n    if (!found) {\n      throw new Error(\n        `A date range calculator with ID (${calculatorId}) could not be found.`,\n      );\n    }\n\n    return found;\n  }\n\n  #getDefaultValue(\n    calculator: SkyDateRangeCalculator,\n  ): SkyDateRangeCalculation {\n    return calculator.getValue();\n  }\n\n  #getValue(): SkyDateRangeCalculation {\n    return this.#_value;\n  }\n\n  #patchValue(\n    partialValue: Partial<SkyDateRangeCalculation> | null | undefined,\n  ): void {\n    this.#setValue(\n      isNullOrUndefined(partialValue)\n        ? null\n        : { ...this.#getValue(), ...partialValue },\n      { emitEvent: true },\n    );\n  }\n\n  /**\n   * Sets the value to be used by the date range picker form control.\n   */\n  #setValue(\n    value: SkyDateRangeCalculation | null | undefined,\n    options: { emitEvent: boolean },\n  ): void {\n    const oldValue = this.#getValue();\n\n    const valueOrDefault =\n      !value || isNullOrUndefined(value.calculatorId)\n        ? this.#getDefaultValue(this.calculators[0])\n        : {\n            ...this.#getDefaultValue(this.#getCalculator(value.calculatorId)),\n            ...value,\n          };\n\n    // Ensure falsy values are set to null.\n    valueOrDefault.endDate = valueOrDefault.endDate || null;\n    valueOrDefault.startDate = valueOrDefault.startDate || null;\n\n    if (!areDateRangesEqual(oldValue, valueOrDefault)) {\n      this.#_value = valueOrDefault;\n\n      this.selectedCalculator = this.#getCalculator(\n        valueOrDefault.calculatorId,\n      );\n\n      if (oldValue.calculatorId !== valueOrDefault.calculatorId) {\n        this.#updatePickerVisibility(this.selectedCalculator);\n      }\n\n      if (options?.emitEvent) {\n        this.formGroup.patchValue(valueOrDefault);\n      }\n    }\n  }\n\n  #updatePickerVisibility(calculator: SkyDateRangeCalculator): void {\n    let showEndDatePicker = false;\n    let showStartDatePicker = false;\n\n    switch (calculator.type) {\n      case SkyDateRangeCalculatorType.Before:\n        showEndDatePicker = true;\n        break;\n\n      case SkyDateRangeCalculatorType.After:\n        showStartDatePicker = true;\n        break;\n\n      case SkyDateRangeCalculatorType.Range:\n        showEndDatePicker = true;\n        showStartDatePicker = true;\n        break;\n\n      default:\n        break;\n    }\n\n    this.showEndDatePicker = showEndDatePicker;\n    this.showStartDatePicker = showStartDatePicker;\n    this.#changeDetector.markForCheck();\n  }\n}\n","<div class=\"sky-date-range-picker\" [formGroup]=\"formGroup\">\n  <div\n    class=\"sky-date-range-picker-form-group\"\n    [ngClass]=\"{\n      'sky-date-range-picker-last-input':\n        !showStartDatePicker && !showEndDatePicker\n    }\"\n  >\n    <sky-input-box\n      [hasErrors]=\"calculatorIdHasErrors\"\n      [helpKey]=\"helpKey\"\n      [helpPopoverContent]=\"helpPopoverContent\"\n      [helpPopoverTitle]=\"helpPopoverTitle\"\n      [hintText]=\"hintText\"\n      [labelText]=\"\n        labelText ||\n        label ||\n        ('skyux_date_range_picker_default_label' | skyLibResources)\n      \"\n    >\n      <select formControlName=\"calculatorId\" (blur)=\"onBlur()\">\n        @for (calculator of calculators; track calculator) {\n          <option [value]=\"calculator.calculatorId\">\n            {{\n              calculator._shortDescriptionResourceKey\n                ? (calculator._shortDescriptionResourceKey | skyLibResources)\n                : calculator.shortDescription\n            }}\n          </option>\n        }\n      </select>\n      @if (\n        hostControl?.errors?.['skyDateRange']?.errors?.[\n          'endDateBeforeStartDate'\n        ] && labelText\n      ) {\n        <sky-form-error\n          [errorName]=\"'endDateBeforeStartDate'\"\n          [errorText]=\"\n            'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n              | skyLibResources\n          \"\n        />\n      }\n      <ng-content select=\"sky-form-error\" />\n    </sky-input-box>\n  </div>\n  <div\n    class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper\"\n    [hidden]=\"!showStartDatePicker\"\n    [ngClass]=\"{\n      'sky-date-range-picker-last-input':\n        showStartDatePicker && !showEndDatePicker\n    }\"\n  >\n    <sky-input-box\n      [hasErrors]=\"startDateHasErrors\"\n      [labelText]=\"\n        selectedCalculator.type\n          | skyDateRangePickerStartDateResourceKey\n          | skyLibResources\n      \"\n    >\n      <sky-datepicker>\n        <input\n          formControlName=\"startDate\"\n          name=\"startDate\"\n          skyDatepickerInput\n          type=\"text\"\n          [attr.aria-label]=\"\n            labelText || label\n              ? ('skyux_date_range_picker_default_aria_label'\n                | skyLibResources\n                  : (selectedCalculator.type\n                      | skyDateRangePickerStartDateResourceKey\n                      | skyLibResources)\n                  : (labelText ? labelText : label))\n              : (selectedCalculator.type\n                | skyDateRangePickerStartDateResourceKey\n                | skyLibResources)\n          \"\n          [dateFormat]=\"dateFormat\"\n          [required]=\"showStartDatePicker && isRequired()\"\n        />\n      </sky-datepicker>\n    </sky-input-box>\n  </div>\n  <div\n    class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper\"\n    [hidden]=\"!showEndDatePicker\"\n    [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker }\"\n  >\n    <sky-input-box\n      [hasErrors]=\"endDateHasErrors\"\n      [labelText]=\"\n        selectedCalculator.type\n          | skyDateRangePickerEndDateResourceKey\n          | skyLibResources\n      \"\n    >\n      <sky-datepicker>\n        <input\n          formControlName=\"endDate\"\n          name=\"endDate\"\n          skyDatepickerInput\n          type=\"text\"\n          [attr.aria-label]=\"\n            labelText || label\n              ? ('skyux_date_range_picker_default_aria_label'\n                | skyLibResources\n                  : (selectedCalculator.type\n                      | skyDateRangePickerEndDateResourceKey\n                      | skyLibResources)\n                  : (labelText ? labelText : label))\n              : (selectedCalculator.type\n                | skyDateRangePickerEndDateResourceKey\n                | skyLibResources)\n          \"\n          [dateFormat]=\"dateFormat\"\n          [required]=\"showEndDatePicker && isRequired()\"\n        />\n      </sky-datepicker>\n    </sky-input-box>\n  </div>\n</div>\n"]}
@@ -3,11 +3,11 @@ import { SkyFormErrorModule } from '@skyux/forms';
3
3
  import { SkyDateRangePickerComponent } from './date-range-picker.component';
4
4
  import * as i0 from "@angular/core";
5
5
  export class SkyDateRangePickerModule {
6
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: SkyDateRangePickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.1.2", ngImport: i0, type: SkyDateRangePickerModule, imports: [SkyDateRangePickerComponent], exports: [SkyDateRangePickerComponent, SkyFormErrorModule] }); }
8
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: SkyDateRangePickerModule, imports: [SkyDateRangePickerComponent, SkyFormErrorModule] }); }
6
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: SkyDateRangePickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.3", ngImport: i0, type: SkyDateRangePickerModule, imports: [SkyDateRangePickerComponent], exports: [SkyDateRangePickerComponent, SkyFormErrorModule] }); }
8
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: SkyDateRangePickerModule, imports: [SkyDateRangePickerComponent, SkyFormErrorModule] }); }
9
9
  }
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: SkyDateRangePickerModule, decorators: [{
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: SkyDateRangePickerModule, decorators: [{
11
11
  type: NgModule,
12
12
  args: [{
13
13
  exports: [SkyDateRangePickerComponent, SkyFormErrorModule],
@@ -85,10 +85,10 @@ export class SkyDateRangeService {
85
85
  }
86
86
  return calculators;
87
87
  }
88
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: SkyDateRangeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
89
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: SkyDateRangeService, providedIn: 'root' }); }
88
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: SkyDateRangeService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
89
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: SkyDateRangeService, providedIn: 'root' }); }
90
90
  }
91
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: SkyDateRangeService, decorators: [{
91
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: SkyDateRangeService, decorators: [{
92
92
  type: Injectable,
93
93
  args: [{
94
94
  providedIn: 'root',