@skyux/datetime 11.39.0 → 12.0.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/documentation.json +1004 -2555
  2. package/fesm2022/skyux-datetime-testing.mjs +4 -3
  3. package/fesm2022/skyux-datetime-testing.mjs.map +1 -1
  4. package/fesm2022/skyux-datetime.mjs +105 -102
  5. package/fesm2022/skyux-datetime.mjs.map +1 -1
  6. package/package.json +15 -19
  7. package/testing/modules/datepicker/datepicker-calendar-harness.d.ts +3 -2
  8. package/testing/public-api.d.ts +0 -2
  9. package/esm2022/index.mjs +0 -23
  10. package/esm2022/lib/modules/date-pipe/date-pipe.module.mjs +0 -20
  11. package/esm2022/lib/modules/date-pipe/date.pipe.mjs +0 -68
  12. package/esm2022/lib/modules/date-pipe/date.service.mjs +0 -94
  13. package/esm2022/lib/modules/date-pipe/fuzzy-date.pipe.mjs +0 -47
  14. package/esm2022/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +0 -21
  15. package/esm2022/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +0 -21
  16. package/esm2022/lib/modules/date-range-picker/date-range-picker.component.mjs +0 -445
  17. package/esm2022/lib/modules/date-range-picker/date-range-picker.module.mjs +0 -17
  18. package/esm2022/lib/modules/date-range-picker/date-range.service.mjs +0 -95
  19. package/esm2022/lib/modules/date-range-picker/types/date-range-calculation.mjs +0 -2
  20. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-config.mjs +0 -2
  21. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +0 -2
  22. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-id.mjs +0 -118
  23. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-type.mjs +0 -23
  24. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +0 -2
  25. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator.mjs +0 -71
  26. package/esm2022/lib/modules/date-range-picker/types/date-range-default-calculator-config.mjs +0 -2
  27. package/esm2022/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +0 -173
  28. package/esm2022/lib/modules/date-range-picker/types/date-range-relative-value.mjs +0 -249
  29. package/esm2022/lib/modules/date-range-picker/types/date-range.mjs +0 -2
  30. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar-change.mjs +0 -2
  31. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar-inner.component.mjs +0 -383
  32. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar-label.pipe.mjs +0 -39
  33. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar.component.mjs +0 -100
  34. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar.service.mjs +0 -22
  35. package/esm2022/lib/modules/datepicker/calendar/daypicker-button.component.mjs +0 -23
  36. package/esm2022/lib/modules/datepicker/calendar/daypicker-cell.component.mjs +0 -129
  37. package/esm2022/lib/modules/datepicker/calendar/daypicker-context.mjs +0 -2
  38. package/esm2022/lib/modules/datepicker/calendar/daypicker.component.mjs +0 -221
  39. package/esm2022/lib/modules/datepicker/calendar/monthpicker.component.mjs +0 -80
  40. package/esm2022/lib/modules/datepicker/calendar/yearpicker.component.mjs +0 -87
  41. package/esm2022/lib/modules/datepicker/date-formatter.mjs +0 -38
  42. package/esm2022/lib/modules/datepicker/datepicker-config.service.mjs +0 -21
  43. package/esm2022/lib/modules/datepicker/datepicker-custom-date.mjs +0 -2
  44. package/esm2022/lib/modules/datepicker/datepicker-host.service.mjs +0 -61
  45. package/esm2022/lib/modules/datepicker/datepicker-input.directive.mjs +0 -526
  46. package/esm2022/lib/modules/datepicker/datepicker.component.mjs +0 -419
  47. package/esm2022/lib/modules/datepicker/datepicker.module.mjs +0 -62
  48. package/esm2022/lib/modules/datepicker/fuzzy/datepicker-input-fuzzy.directive.mjs +0 -516
  49. package/esm2022/lib/modules/datepicker/fuzzy/fuzzy-date.mjs +0 -2
  50. package/esm2022/lib/modules/datepicker/fuzzy/fuzzy-date.service.mjs +0 -411
  51. package/esm2022/lib/modules/shared/sky-datetime-resources.module.mjs +0 -130
  52. package/esm2022/lib/modules/timepicker/timepicker-time-format-type.mjs +0 -2
  53. package/esm2022/lib/modules/timepicker/timepicker-time-output.mjs +0 -2
  54. package/esm2022/lib/modules/timepicker/timepicker.component.mjs +0 -415
  55. package/esm2022/lib/modules/timepicker/timepicker.directive.mjs +0 -226
  56. package/esm2022/lib/modules/timepicker/timepicker.module.mjs +0 -37
  57. package/esm2022/skyux-datetime.mjs +0 -5
  58. package/esm2022/testing/legacy/datepicker-fixture.mjs +0 -56
  59. package/esm2022/testing/legacy/timepicker-fixture.mjs +0 -52
  60. package/esm2022/testing/modules/date-range-picker/date-range-picker-harness.filters.mjs +0 -2
  61. package/esm2022/testing/modules/date-range-picker/date-range-picker-harness.mjs +0 -193
  62. package/esm2022/testing/modules/datepicker/datepicker-calendar-harness.filters.mjs +0 -2
  63. package/esm2022/testing/modules/datepicker/datepicker-calendar-harness.mjs +0 -87
  64. package/esm2022/testing/modules/datepicker/datepicker-harness.filters.mjs +0 -2
  65. package/esm2022/testing/modules/datepicker/datepicker-harness.mjs +0 -60
  66. package/esm2022/testing/modules/datepicker/datepicker-input-harness.mjs +0 -29
  67. package/esm2022/testing/modules/datepicker/fuzzy-datepicker-input-harness.mjs +0 -29
  68. package/esm2022/testing/public-api.mjs +0 -8
  69. package/esm2022/testing/skyux-datetime-testing.mjs +0 -5
@@ -1,445 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, DestroyRef, ElementRef, HostBinding, Injector, Input, booleanAttribute, computed, inject, runInInjectionContext, signal, viewChildren, } from '@angular/core';
3
- import { takeUntilDestroyed, toSignal } from '@angular/core/rxjs-interop';
4
- import { FormBuilder, FormControl, FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, ReactiveFormsModule, StatusChangeEvent, TouchedChangeEvent, } from '@angular/forms';
5
- import { SkyLogService } from '@skyux/core';
6
- import { SKY_FORM_ERRORS_ENABLED, SkyFormErrorsModule, SkyInputBoxModule, } from '@skyux/forms';
7
- import { distinctUntilChanged, filter, map } from 'rxjs';
8
- import { SkyDatepickerComponent } from '../datepicker/datepicker.component';
9
- import { SkyDatepickerModule } from '../datepicker/datepicker.module';
10
- import { SkyDatetimeResourcesModule } from '../shared/sky-datetime-resources.module';
11
- import { SkyDateRangePickerEndDateResourceKeyPipe } from './date-range-picker-end-date-resource-key.pipe';
12
- import { SkyDateRangePickerStartDateResourceKeyPipe } from './date-range-picker-start-date-resource-key.pipe';
13
- import { SkyDateRangeService } from './date-range.service';
14
- import { SkyDateRangeCalculatorType } from './types/date-range-calculator-type';
15
- import { SKY_DEFAULT_CALCULATOR_IDS } from './types/date-range-default-calculator-configs';
16
- import * as i0 from "@angular/core";
17
- import * as i1 from "@angular/common";
18
- import * as i2 from "@angular/forms";
19
- import * as i3 from "../datepicker/datepicker.component";
20
- import * as i4 from "../datepicker/datepicker-input.directive";
21
- import * as i5 from "@skyux/i18n";
22
- import * as i6 from "@skyux/forms";
23
- function areDateRangesEqual(rangeA, rangeB) {
24
- return (!!rangeA &&
25
- !!rangeB &&
26
- rangeA.calculatorId === rangeB.calculatorId &&
27
- areDatesEqual(rangeA.startDate, rangeB.startDate) &&
28
- areDatesEqual(rangeA.endDate, rangeB.endDate));
29
- }
30
- function areDatesEqual(a, b) {
31
- if (typeof a !== typeof b) {
32
- return false;
33
- }
34
- if (!a && !b) {
35
- return true;
36
- }
37
- if (typeof a === 'string' && a === b) {
38
- return true;
39
- }
40
- return a instanceof Date && b instanceof Date && a.getTime() === b.getTime();
41
- }
42
- function isNullOrUndefined(value) {
43
- return value === undefined || value === null;
44
- }
45
- function isPartialValue(value) {
46
- return (isNullOrUndefined(value) ||
47
- isNullOrUndefined(value.calculatorId) ||
48
- !('endDate' in value) ||
49
- !('startDate' in value));
50
- }
51
- export class SkyDateRangePickerComponent {
52
- constructor() {
53
- this.#dateRangeSvc = inject(SkyDateRangeService);
54
- this.#destroyRef = inject(DestroyRef);
55
- this.#elementRef = inject(ElementRef);
56
- this.#injector = inject(Injector);
57
- this.#logger = inject(SkyLogService);
58
- /**
59
- * Whether the date range picker is stacked on another form component. When specified, the appropriate
60
- * vertical spacing is automatically added to the date range picker.
61
- */
62
- this.stacked = false;
63
- this.calculators = this.#dateRangeSvc.calculators;
64
- this.datepickers = viewChildren(SkyDatepickerComponent);
65
- this.selectedCalculator = this.calculators[0];
66
- this.showEndDatePicker = signal(false);
67
- this.showStartDatePicker = signal(false);
68
- this.#_calculatorIds = SKY_DEFAULT_CALCULATOR_IDS;
69
- this.#_value = this.selectedCalculator.getValue();
70
- this.#calculatorIdControl = new FormControl(this.#getValue().calculatorId, { nonNullable: true });
71
- this.#calculatorIdInvalid = this.#createStatusChangeSignal(this.#calculatorIdControl);
72
- this.#calculatorIdTouched = this.#createTouchedChangeSignal(this.#calculatorIdControl);
73
- this.#endDateControl = new FormControl(this.#getValue().endDate);
74
- this.#endDateInvalid = this.#createStatusChangeSignal(this.#endDateControl);
75
- this.#endDateTouched = this.#createTouchedChangeSignal(this.#endDateControl);
76
- this.#startDateControl = new FormControl(this.#getValue().startDate);
77
- this.#startDateInvalid = this.#createStatusChangeSignal(this.#startDateControl);
78
- this.#startDateTouched = this.#createTouchedChangeSignal(this.#startDateControl);
79
- this.formGroup = inject(FormBuilder).group({
80
- calculatorId: this.#calculatorIdControl,
81
- startDate: this.#startDateControl,
82
- endDate: this.#endDateControl,
83
- });
84
- this.calculatorIdHasErrors = computed(() => {
85
- const touched = this.#calculatorIdTouched();
86
- const invalid = this.#calculatorIdInvalid() || this.#hostHasCustomError?.();
87
- return touched && invalid;
88
- });
89
- this.endDateHasErrors = computed(() => {
90
- const calculatorIdHasErrors = this.calculatorIdHasErrors();
91
- const touched = this.#endDateTouched();
92
- const invalid = this.#endDateInvalid();
93
- return calculatorIdHasErrors || (touched && invalid);
94
- });
95
- this.startDateHasErrors = computed(() => {
96
- const calculatorIdHasErrors = this.calculatorIdHasErrors();
97
- const touched = this.#startDateTouched();
98
- const invalid = this.#startDateInvalid();
99
- return calculatorIdHasErrors || (touched && invalid);
100
- });
101
- }
102
- #dateRangeSvc;
103
- #destroyRef;
104
- #elementRef;
105
- #injector;
106
- #logger;
107
- /**
108
- * IDs for the date range options to include in the picker's dropdown.
109
- * The options specify calculator objects that return two `Date` objects to represent date ranges.
110
- * By default, this property includes all `SkyDateRangeCalculatorId` values.
111
- */
112
- set calculatorIds(calculatorIds) {
113
- const currentCalculatorId = this.#getValue().calculatorId;
114
- this.#_calculatorIds = calculatorIds ?? SKY_DEFAULT_CALCULATOR_IDS;
115
- this.calculators = this.#dateRangeSvc.filterCalculators(this.#_calculatorIds);
116
- // If the currently selected calculator isn't available anymore,
117
- // select the first calculator in the new array.
118
- if (!this.#_calculatorIds.includes(currentCalculatorId)) {
119
- this.#setValue({ calculatorId: this.calculatorIds[0] });
120
- }
121
- }
122
- get calculatorIds() {
123
- return this.#_calculatorIds;
124
- }
125
- /**
126
- * Whether to disable the date range picker on template-driven forms. Don't use
127
- * this input on reactive forms because they may overwrite the input or leave
128
- * the control out of sync. To set the disabled state on reactive forms,
129
- * use the `FormControl` instead.
130
- * @default false
131
- */
132
- set disabled(value) {
133
- if (value) {
134
- this.formGroup.disable();
135
- }
136
- else {
137
- this.formGroup.enable();
138
- }
139
- }
140
- /**
141
- * The label for the date range picker.
142
- * @deprecated Use the `labelText` input instead.
143
- */
144
- set label(value) {
145
- this.#_label = value;
146
- if (value) {
147
- this.#logger.deprecated('SkyDateRangePickerComponent.label', {
148
- deprecationMajorVersion: 10,
149
- replacementRecommendation: 'Use the `labelText` input instead.',
150
- });
151
- }
152
- }
153
- get label() {
154
- return this.#_label;
155
- }
156
- #_calculatorIds;
157
- #_label;
158
- #_value;
159
- #hostHasCustomError;
160
- #notifyChange;
161
- #notifyTouched;
162
- #calculatorIdControl;
163
- #calculatorIdInvalid;
164
- #calculatorIdTouched;
165
- #endDateControl;
166
- #endDateInvalid;
167
- #endDateTouched;
168
- #startDateControl;
169
- #startDateInvalid;
170
- #startDateTouched;
171
- ngAfterViewInit() {
172
- this.hostControl = this.#injector.get(NgControl, null, {
173
- optional: true,
174
- self: true,
175
- })?.control;
176
- runInInjectionContext(this.#injector, () => {
177
- if (this.hostControl) {
178
- this.#hostHasCustomError = this.#createHostCustomErrorChangeSignal(this.hostControl);
179
- }
180
- });
181
- // Set a default value on the control if it's undefined on init.
182
- // We need to use setTimeout to avoid interfering with the first
183
- // validation cycle.
184
- if (isPartialValue(this.hostControl?.value)) {
185
- setTimeout(() => {
186
- this.hostControl?.setValue(this.#getValue(), {
187
- emitEvent: false,
188
- });
189
- });
190
- }
191
- // If the datepickers' statuses change, we want to retrigger the host
192
- // control's validation so that their errors are reflected back to the host.
193
- this.formGroup.events
194
- .pipe(filter((evt) => evt instanceof StatusChangeEvent), map((evt) => evt.status), distinctUntilChanged(), takeUntilDestroyed(this.#destroyRef))
195
- .subscribe(() => {
196
- this.hostControl?.updateValueAndValidity({
197
- emitEvent: false,
198
- onlySelf: true,
199
- });
200
- });
201
- // Mark all fields as touched if the host control is touched.
202
- this.hostControl?.events
203
- .pipe(filter((evt) => evt instanceof TouchedChangeEvent), map((evt) => evt.touched), distinctUntilChanged(), takeUntilDestroyed(this.#destroyRef))
204
- .subscribe(() => {
205
- this.formGroup.markAllAsTouched();
206
- });
207
- }
208
- // Implemented as part of ControlValueAccessor.
209
- registerOnChange(fn) {
210
- this.#notifyChange = fn;
211
- }
212
- // Implemented as part of ControlValueAccessor.
213
- registerOnTouched(fn) {
214
- this.#notifyTouched = fn;
215
- }
216
- // Implemented as part of ControlValueAccessor.
217
- setDisabledState(isDisabled) {
218
- this.disabled = isDisabled;
219
- }
220
- // Implemented as part of Validator.
221
- validate(control) {
222
- let errors = null;
223
- const calculatorErrors = this.selectedCalculator.validate(control.value);
224
- const startDateErrors = this.#startDateControl.errors;
225
- const endDateErrors = this.#endDateControl.errors;
226
- if (calculatorErrors) {
227
- errors = {
228
- skyDateRange: {
229
- calculatorId: this.#getValue().calculatorId,
230
- errors: calculatorErrors,
231
- },
232
- };
233
- }
234
- // Set calculator errors on the select so that they appear beneath it.
235
- this.#calculatorIdControl.setErrors(errors);
236
- if (this.showStartDatePicker() && startDateErrors) {
237
- errors ||= {};
238
- errors = { ...errors, ...startDateErrors };
239
- }
240
- if (this.showEndDatePicker() && endDateErrors) {
241
- errors ||= {};
242
- errors = { ...errors, ...endDateErrors };
243
- }
244
- return errors;
245
- }
246
- // Implemented as part of ControlValueAccessor.
247
- // The date range picker always has a value, so if the consumer passes in a
248
- // partial value (via `patchValue`) or null, we need to update the host control's
249
- // value with the complete value after it's been modified.
250
- writeValue(value) {
251
- this.#patchValue(value);
252
- // Update the host control if it is set to a partial or null value.
253
- if (isPartialValue(value)) {
254
- this.hostControl?.setValue(this.#getValue(), {
255
- emitEvent: false,
256
- onlySelf: true,
257
- });
258
- }
259
- }
260
- /**
261
- * Fires when a user changes the selected calculator ID.
262
- */
263
- onCalculatorIdChange() {
264
- // Reset the value when the calculator ID changes.
265
- this.#setValue({ calculatorId: +this.#calculatorIdControl.value });
266
- this.onDateChange();
267
- }
268
- /**
269
- * Fires when a user interacts with a date range picker.
270
- */
271
- onDateChange() {
272
- // Wait until the form control is updated before retrieving its value.
273
- setTimeout(() => {
274
- this.#notifyChange?.(this.formGroup.getRawValue());
275
- });
276
- }
277
- /**
278
- * Fires when the date range picker loses focus.
279
- */
280
- onFocusout({ relatedTarget }) {
281
- if (relatedTarget &&
282
- !this.#elementRef.nativeElement.contains(relatedTarget) &&
283
- !this.datepickers().some((picker) => picker.containsTarget(relatedTarget))) {
284
- this.#notifyTouched?.();
285
- }
286
- }
287
- #getCalculator(calculatorId) {
288
- const found = this.calculators.find((c) => c.calculatorId === calculatorId);
289
- /*istanbul ignore if: safety check*/
290
- if (!found) {
291
- throw new Error(`A date range calculator with ID (${calculatorId}) could not be found.`);
292
- }
293
- return found;
294
- }
295
- #getValue() {
296
- // Important! Return a clone to avoid changing the properties by reference.
297
- return { ...this.#_value };
298
- }
299
- #patchValue(partialValue) {
300
- if (isNullOrUndefined(partialValue)) {
301
- this.#setValue(null);
302
- return;
303
- }
304
- const oldValue = this.#getValue();
305
- // If the new ID is distinct, erase the old start and end dates because
306
- // they're no longer applicable.
307
- if (!isNullOrUndefined(partialValue.calculatorId) &&
308
- oldValue.calculatorId !== partialValue.calculatorId) {
309
- delete oldValue.endDate;
310
- delete oldValue.startDate;
311
- }
312
- const value = {
313
- ...oldValue,
314
- ...partialValue,
315
- };
316
- this.#setValue(value);
317
- }
318
- /**
319
- * Sets the value to be used by the date range picker form control.
320
- */
321
- #setValue(value) {
322
- const oldValue = this.#getValue();
323
- const isValueEmpty = !value || isNullOrUndefined(value.calculatorId);
324
- const valueOrDefault = isValueEmpty
325
- ? this.calculators[0].getValue()
326
- : {
327
- ...this.#getCalculator(value.calculatorId).getValue(),
328
- ...value,
329
- };
330
- // Ensure falsy values are set to null.
331
- valueOrDefault.endDate = valueOrDefault.endDate || null;
332
- valueOrDefault.startDate = valueOrDefault.startDate || null;
333
- if (!areDateRangesEqual(oldValue, valueOrDefault)) {
334
- this.#_value = valueOrDefault;
335
- if (oldValue.calculatorId !== valueOrDefault.calculatorId) {
336
- this.selectedCalculator = this.#getCalculator(valueOrDefault.calculatorId);
337
- this.#updatePickerVisibility(this.selectedCalculator);
338
- }
339
- this.formGroup.patchValue(valueOrDefault);
340
- }
341
- }
342
- #updatePickerVisibility(calculator) {
343
- let showEndDatePicker = false;
344
- let showStartDatePicker = false;
345
- switch (calculator.type) {
346
- case SkyDateRangeCalculatorType.Before:
347
- showEndDatePicker = true;
348
- break;
349
- case SkyDateRangeCalculatorType.After:
350
- showStartDatePicker = true;
351
- break;
352
- case SkyDateRangeCalculatorType.Range:
353
- showEndDatePicker = true;
354
- showStartDatePicker = true;
355
- break;
356
- default:
357
- break;
358
- }
359
- this.showEndDatePicker.set(showEndDatePicker);
360
- this.showStartDatePicker.set(showStartDatePicker);
361
- }
362
- #createHostCustomErrorChangeSignal(control) {
363
- return toSignal(control.events.pipe(filter((evt) => evt instanceof StatusChangeEvent), map((evt) => {
364
- const errors = evt.source.errors ?? [];
365
- const knownErrors = ['required', 'skyDate'];
366
- return Object.keys(errors).some((error) => {
367
- return !knownErrors.includes(error);
368
- });
369
- })));
370
- }
371
- #createStatusChangeSignal(control) {
372
- return toSignal(control.events.pipe(filter((evt) => evt instanceof StatusChangeEvent), map((evt) => evt.status === 'INVALID'), takeUntilDestroyed(this.#destroyRef)));
373
- }
374
- #createTouchedChangeSignal(control) {
375
- return toSignal(control.events.pipe(filter((evt) => evt instanceof TouchedChangeEvent), map((evt) => evt.touched), takeUntilDestroyed(this.#destroyRef)));
376
- }
377
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDateRangePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
378
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: SkyDateRangePickerComponent, isStandalone: true, selector: "sky-date-range-picker", inputs: { calculatorIds: "calculatorIds", dateFormat: "dateFormat", disabled: ["disabled", "disabled", booleanAttribute], helpPopoverContent: "helpPopoverContent", helpPopoverTitle: "helpPopoverTitle", hintText: "hintText", label: "label", labelText: "labelText", stacked: ["stacked", "stacked", booleanAttribute], helpKey: "helpKey" }, host: { listeners: { "focusout": "onFocusout($event)" }, properties: { "class.sky-form-field-stacked": "this.stacked" } }, providers: [
379
- {
380
- provide: NG_VALIDATORS,
381
- useExisting: SkyDateRangePickerComponent,
382
- multi: true,
383
- },
384
- {
385
- provide: NG_VALUE_ACCESSOR,
386
- useExisting: SkyDateRangePickerComponent,
387
- multi: true,
388
- },
389
- { provide: SKY_FORM_ERRORS_ENABLED, useValue: true },
390
- ], viewQueries: [{ propertyName: "datepickers", predicate: SkyDatepickerComponent, descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"sky-date-range-picker\" [formGroup]=\"formGroup\">\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-picker-select-calculator\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n !showStartDatePicker() && !showEndDatePicker()\n }\"\n >\n <sky-input-box\n [hasErrors]=\"calculatorIdHasErrors()\"\n [helpKey]=\"helpKey\"\n [helpPopoverContent]=\"helpPopoverContent\"\n [helpPopoverTitle]=\"helpPopoverTitle\"\n [hintText]=\"hintText\"\n [labelText]=\"\n labelText ||\n label ||\n ('skyux_date_range_picker_default_label' | skyLibResources)\n \"\n >\n <select formControlName=\"calculatorId\" (change)=\"onCalculatorIdChange()\">\n @for (calculator of calculators; track calculator.calculatorId) {\n <option [value]=\"calculator.calculatorId\">\n {{ calculator.shortDescription$ | async }}\n </option>\n }\n </select>\n @if (\n hostControl?.errors?.['skyDateRange']?.errors?.[\n 'endDateBeforeStartDate'\n ] && labelText\n ) {\n <sky-form-error\n errorName=\"endDateBeforeStartDate\"\n [errorText]=\"\n 'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n | skyLibResources\n \"\n />\n }\n <span class=\"sky-input-box-descendent-form-error\">\n <ng-content select=\"sky-form-error\" />\n </span>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-start-date\"\n [hidden]=\"!showStartDatePicker()\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n showStartDatePicker() && !showEndDatePicker()\n }\"\n >\n <sky-input-box\n [hasErrors]=\"startDateHasErrors()\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n <input\n formControlName=\"startDate\"\n name=\"startDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showStartDatePicker()\"\n (change)=\"onDateChange()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-end-date\"\n [hidden]=\"!showEndDatePicker()\"\n [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker() }\"\n >\n <sky-input-box\n [hasErrors]=\"endDateHasErrors()\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n <input\n formControlName=\"endDate\"\n name=\"endDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showEndDatePicker()\"\n (change)=\"onDateChange()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n</div>\n", styles: [".sky-date-range-picker:not(.sky-theme-modern *){--sky-override-date-range-picker-margin-right: 0;--sky-override-date-range-picker-padding-left: 5px;--sky-override-date-range-picker-padding-right: 5px;--sky-override-date-range-picker-responsive-bottom-margin: var( --sky-margin-stacked-lg )}:host{display:block}.sky-date-range-picker{display:flex}:host .sky-date-range-picker{flex-direction:column}:host .sky-date-range-picker-form-group{flex-basis:100%}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-override-date-range-picker-responsive-bottom-margin, var(--sky-space-gap-form-l));margin-right:0}:host-context(.sky-responsive-container-xs) .sky-date-range-picker,:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:column}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:100%}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-override-date-range-picker-responsive-bottom-margin, var(--sky-space-gap-form-l));margin-right:0}@media (min-width: 768px){:host .sky-date-range-picker{flex-direction:initial}:host .sky-date-range-picker-form-group{flex-basis:33.3333333333%;padding:0}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:var(--sky-override-date-range-picker-padding-left, 0)}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:var(--sky-override-date-range-picker-padding-right, 0)}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0;margin-right:var(--sky-override-date-range-picker-margin-right, var(--sky-space-gap-form-l))}}:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:initial}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:33.3333333333%;padding:0}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:var(--sky-override-date-range-picker-padding-left, 0)}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:var(--sky-override-date-range-picker-padding-right, 0)}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0;margin-right:var(--sky-override-date-range-picker-margin-right, var(--sky-space-gap-form-l))}@media (min-width: 768px){:host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}}.sky-responsive-container-sm :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-md :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-lg :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: SkyDatepickerModule }, { kind: "component", type: i3.SkyDatepickerComponent, selector: "sky-datepicker", inputs: ["pickerClass"], outputs: ["calendarDateRangeChange", "dateFormatChange", "openChange", "calendarDateChange"] }, { kind: "directive", type: i4.SkyDatepickerInputDirective, selector: "[skyDatepickerInput]", inputs: ["dateFormat", "disabled", "maxDate", "minDate", "startAtDate", "skyDatepickerInput", "skyDatepickerNoValidate", "startingDay", "strict"] }, { kind: "pipe", type: SkyDateRangePickerEndDateResourceKeyPipe, name: "skyDateRangePickerEndDateResourceKey" }, { kind: "pipe", type: SkyDateRangePickerStartDateResourceKeyPipe, name: "skyDateRangePickerStartDateResourceKey" }, { kind: "ngmodule", type: SkyDatetimeResourcesModule }, { kind: "pipe", type: i5.SkyLibResourcesPipe, name: "skyLibResources" }, { kind: "ngmodule", type: SkyInputBoxModule }, { kind: "component", type: i6.λ10, selector: "sky-input-box", inputs: ["hasErrors", "disabled", "labelText", "characterLimit", "stacked", "helpPopoverTitle", "helpPopoverContent", "helpKey", "hintText"] }, { kind: "directive", type: i6.λ20, selector: "input:not([skyId]):not(.sky-form-control),select:not([skyId]):not(.sky-form-control),textarea:not([skyId]):not(.sky-form-control)", inputs: ["autocomplete"] }, { kind: "component", type: i6.λ22, selector: "sky-form-error", inputs: ["errorName", "errorText"] }, { kind: "ngmodule", type: SkyFormErrorsModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
391
- }
392
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDateRangePickerComponent, decorators: [{
393
- type: Component,
394
- args: [{ changeDetection: ChangeDetectionStrategy.OnPush, host: {
395
- '(focusout)': 'onFocusout($event)',
396
- }, imports: [
397
- CommonModule,
398
- FormsModule,
399
- ReactiveFormsModule,
400
- SkyDatepickerModule,
401
- SkyDateRangePickerEndDateResourceKeyPipe,
402
- SkyDateRangePickerStartDateResourceKeyPipe,
403
- SkyDatetimeResourcesModule,
404
- SkyInputBoxModule,
405
- SkyFormErrorsModule,
406
- ], providers: [
407
- {
408
- provide: NG_VALIDATORS,
409
- useExisting: SkyDateRangePickerComponent,
410
- multi: true,
411
- },
412
- {
413
- provide: NG_VALUE_ACCESSOR,
414
- useExisting: SkyDateRangePickerComponent,
415
- multi: true,
416
- },
417
- { provide: SKY_FORM_ERRORS_ENABLED, useValue: true },
418
- ], selector: 'sky-date-range-picker', standalone: true, template: "<div class=\"sky-date-range-picker\" [formGroup]=\"formGroup\">\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-picker-select-calculator\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n !showStartDatePicker() && !showEndDatePicker()\n }\"\n >\n <sky-input-box\n [hasErrors]=\"calculatorIdHasErrors()\"\n [helpKey]=\"helpKey\"\n [helpPopoverContent]=\"helpPopoverContent\"\n [helpPopoverTitle]=\"helpPopoverTitle\"\n [hintText]=\"hintText\"\n [labelText]=\"\n labelText ||\n label ||\n ('skyux_date_range_picker_default_label' | skyLibResources)\n \"\n >\n <select formControlName=\"calculatorId\" (change)=\"onCalculatorIdChange()\">\n @for (calculator of calculators; track calculator.calculatorId) {\n <option [value]=\"calculator.calculatorId\">\n {{ calculator.shortDescription$ | async }}\n </option>\n }\n </select>\n @if (\n hostControl?.errors?.['skyDateRange']?.errors?.[\n 'endDateBeforeStartDate'\n ] && labelText\n ) {\n <sky-form-error\n errorName=\"endDateBeforeStartDate\"\n [errorText]=\"\n 'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n | skyLibResources\n \"\n />\n }\n <span class=\"sky-input-box-descendent-form-error\">\n <ng-content select=\"sky-form-error\" />\n </span>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-start-date\"\n [hidden]=\"!showStartDatePicker()\"\n [ngClass]=\"{\n 'sky-date-range-picker-last-input':\n showStartDatePicker() && !showEndDatePicker()\n }\"\n >\n <sky-input-box\n [hasErrors]=\"startDateHasErrors()\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n <input\n formControlName=\"startDate\"\n name=\"startDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerStartDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showStartDatePicker()\"\n (change)=\"onDateChange()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n <div\n class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-end-date\"\n [hidden]=\"!showEndDatePicker()\"\n [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker() }\"\n >\n <sky-input-box\n [hasErrors]=\"endDateHasErrors()\"\n [labelText]=\"\n selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources\n \"\n >\n <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n <input\n formControlName=\"endDate\"\n name=\"endDate\"\n skyDatepickerInput\n type=\"text\"\n [attr.aria-label]=\"\n labelText || label\n ? ('skyux_date_range_picker_default_aria_label'\n | skyLibResources\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n : (labelText ? labelText : label))\n : (selectedCalculator.type\n | skyDateRangePickerEndDateResourceKey\n | skyLibResources)\n \"\n [dateFormat]=\"dateFormat\"\n [required]=\"showEndDatePicker()\"\n (change)=\"onDateChange()\"\n />\n </sky-datepicker>\n </sky-input-box>\n </div>\n</div>\n", styles: [".sky-date-range-picker:not(.sky-theme-modern *){--sky-override-date-range-picker-margin-right: 0;--sky-override-date-range-picker-padding-left: 5px;--sky-override-date-range-picker-padding-right: 5px;--sky-override-date-range-picker-responsive-bottom-margin: var( --sky-margin-stacked-lg )}:host{display:block}.sky-date-range-picker{display:flex}:host .sky-date-range-picker{flex-direction:column}:host .sky-date-range-picker-form-group{flex-basis:100%}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-override-date-range-picker-responsive-bottom-margin, var(--sky-space-gap-form-l));margin-right:0}:host-context(.sky-responsive-container-xs) .sky-date-range-picker,:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:column}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:100%}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:initial}:host-context(.sky-responsive-container-xs) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:var(--sky-override-date-range-picker-responsive-bottom-margin, var(--sky-space-gap-form-l));margin-right:0}@media (min-width: 768px){:host .sky-date-range-picker{flex-direction:initial}:host .sky-date-range-picker-form-group{flex-basis:33.3333333333%;padding:0}:host .sky-date-range-picker-form-group:not(:first-of-type){padding-left:var(--sky-override-date-range-picker-padding-left, 0)}:host .sky-date-range-picker-form-group:not(:last-of-type){padding-right:var(--sky-override-date-range-picker-padding-right, 0)}:host .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0;margin-right:var(--sky-override-date-range-picker-margin-right, var(--sky-space-gap-form-l))}}:host-context(.sky-responsive-container-sm) .sky-date-range-picker,:host-context(.sky-responsive-container-md) .sky-date-range-picker,:host-context(.sky-responsive-container-lg) .sky-date-range-picker{flex-direction:initial}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group,:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group{flex-basis:33.3333333333%;padding:0}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:first-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:first-of-type){padding-left:var(--sky-override-date-range-picker-padding-left, 0)}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(:last-of-type),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(:last-of-type){padding-right:var(--sky-override-date-range-picker-padding-right, 0)}:host-context(.sky-responsive-container-sm) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-md) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input),:host-context(.sky-responsive-container-lg) .sky-date-range-picker-form-group:not(.sky-date-range-picker-last-input){margin-bottom:0;margin-right:var(--sky-override-date-range-picker-margin-right, var(--sky-space-gap-form-l))}@media (min-width: 768px){:host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}}.sky-responsive-container-sm :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-md :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group,.sky-responsive-container-lg :host-context(sky-filter-inline-item) .sky-date-range-picker-form-group{flex-basis:100%}\n"] }]
419
- }], propDecorators: { calculatorIds: [{
420
- type: Input
421
- }], dateFormat: [{
422
- type: Input
423
- }], disabled: [{
424
- type: Input,
425
- args: [{ transform: booleanAttribute }]
426
- }], helpPopoverContent: [{
427
- type: Input
428
- }], helpPopoverTitle: [{
429
- type: Input
430
- }], hintText: [{
431
- type: Input
432
- }], label: [{
433
- type: Input
434
- }], labelText: [{
435
- type: Input
436
- }], stacked: [{
437
- type: Input,
438
- args: [{ transform: booleanAttribute }]
439
- }, {
440
- type: HostBinding,
441
- args: ['class.sky-form-field-stacked']
442
- }], helpKey: [{
443
- type: Input
444
- }] } });
445
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-picker.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/date-range-picker/date-range-picker.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/date-range-picker/date-range-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  ElementRef,\n  HostBinding,\n  Injector,\n  Input,\n  Signal,\n  TemplateRef,\n  booleanAttribute,\n  computed,\n  inject,\n  runInInjectionContext,\n  signal,\n  viewChildren,\n} from '@angular/core';\nimport { takeUntilDestroyed, toSignal } from '@angular/core/rxjs-interop';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormBuilder,\n  FormControl,\n  FormsModule,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  NgControl,\n  ReactiveFormsModule,\n  StatusChangeEvent,\n  TouchedChangeEvent,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\nimport { SkyLogService } from '@skyux/core';\nimport {\n  SKY_FORM_ERRORS_ENABLED,\n  SkyFormErrorsModule,\n  SkyInputBoxModule,\n} from '@skyux/forms';\n\nimport { distinctUntilChanged, filter, map } from 'rxjs';\n\nimport { SkyDatepickerComponent } from '../datepicker/datepicker.component';\nimport { SkyDatepickerModule } from '../datepicker/datepicker.module';\nimport { SkyDatetimeResourcesModule } from '../shared/sky-datetime-resources.module';\n\nimport { SkyDateRangePickerEndDateResourceKeyPipe } from './date-range-picker-end-date-resource-key.pipe';\nimport { SkyDateRangePickerStartDateResourceKeyPipe } from './date-range-picker-start-date-resource-key.pipe';\nimport { SkyDateRangeService } from './date-range.service';\nimport { SkyDateRangeCalculation } from './types/date-range-calculation';\nimport { SkyDateRangeCalculator } from './types/date-range-calculator';\nimport { SkyDateRangeCalculatorId } from './types/date-range-calculator-id';\nimport { SkyDateRangeCalculatorType } from './types/date-range-calculator-type';\nimport { SKY_DEFAULT_CALCULATOR_IDS } from './types/date-range-default-calculator-configs';\n\ntype DateValue = Date | string | null | undefined;\n\nfunction areDateRangesEqual(\n  rangeA: SkyDateRangeCalculation | undefined,\n  rangeB: SkyDateRangeCalculation | undefined,\n): boolean {\n  return (\n    !!rangeA &&\n    !!rangeB &&\n    rangeA.calculatorId === rangeB.calculatorId &&\n    areDatesEqual(rangeA.startDate, rangeB.startDate) &&\n    areDatesEqual(rangeA.endDate, rangeB.endDate)\n  );\n}\n\nfunction areDatesEqual(a: DateValue, b: DateValue): boolean {\n  if (typeof a !== typeof b) {\n    return false;\n  }\n\n  if (!a && !b) {\n    return true;\n  }\n\n  if (typeof a === 'string' && a === b) {\n    return true;\n  }\n\n  return a instanceof Date && b instanceof Date && a.getTime() === b.getTime();\n}\n\nfunction isNullOrUndefined(value: unknown): value is undefined | null {\n  return value === undefined || value === null;\n}\n\nfunction isPartialValue(\n  value: Partial<SkyDateRangeCalculation> | null | undefined,\n): value is Partial<SkyDateRangeCalculation> | null | undefined {\n  return (\n    isNullOrUndefined(value) ||\n    isNullOrUndefined(value.calculatorId) ||\n    !('endDate' in value) ||\n    !('startDate' in value)\n  );\n}\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    '(focusout)': 'onFocusout($event)',\n  },\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    SkyDatepickerModule,\n    SkyDateRangePickerEndDateResourceKeyPipe,\n    SkyDateRangePickerStartDateResourceKeyPipe,\n    SkyDatetimeResourcesModule,\n    SkyInputBoxModule,\n    SkyFormErrorsModule,\n  ],\n  providers: [\n    {\n      provide: NG_VALIDATORS,\n      useExisting: SkyDateRangePickerComponent,\n      multi: true,\n    },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: SkyDateRangePickerComponent,\n      multi: true,\n    },\n    { provide: SKY_FORM_ERRORS_ENABLED, useValue: true },\n  ],\n  selector: 'sky-date-range-picker',\n  standalone: true,\n  styleUrl: './date-range-picker.component.scss',\n  templateUrl: './date-range-picker.component.html',\n})\nexport class SkyDateRangePickerComponent\n  implements AfterViewInit, ControlValueAccessor, Validator\n{\n  readonly #dateRangeSvc = inject(SkyDateRangeService);\n  readonly #destroyRef = inject(DestroyRef);\n  readonly #elementRef = inject(ElementRef);\n  readonly #injector = inject(Injector);\n  readonly #logger = inject(SkyLogService);\n\n  /**\n   * IDs for the date range options to include in the picker's dropdown.\n   * The options specify calculator objects that return two `Date` objects to represent date ranges.\n   * By default, this property includes all `SkyDateRangeCalculatorId` values.\n   */\n  @Input()\n  public set calculatorIds(\n    calculatorIds: SkyDateRangeCalculatorId[] | undefined,\n  ) {\n    const currentCalculatorId = this.#getValue().calculatorId;\n\n    this.#_calculatorIds = calculatorIds ?? SKY_DEFAULT_CALCULATOR_IDS;\n    this.calculators = this.#dateRangeSvc.filterCalculators(\n      this.#_calculatorIds,\n    );\n\n    // If the currently selected calculator isn't available anymore,\n    // select the first calculator in the new array.\n    if (!this.#_calculatorIds.includes(currentCalculatorId)) {\n      this.#setValue({ calculatorId: this.calculatorIds[0] });\n    }\n  }\n\n  public get calculatorIds(): SkyDateRangeCalculatorId[] {\n    return this.#_calculatorIds;\n  }\n\n  /**\n   * The date format for\n   * [the `sky-datepicker` components](https://developer.blackbaud.com/skyux/components/datepicker)\n   * that make up the date range picker. The text input is a composite component of\n   * up to two `sky-datepicker` components.\n   * @default \"MM/DD/YYYY\"\n   */\n  @Input()\n  public dateFormat: string | undefined;\n\n  /**\n   * Whether to disable the date range picker on template-driven forms. Don't use\n   * this input on reactive forms because they may overwrite the input or leave\n   * the control out of sync. To set the disabled state on reactive forms,\n   * use the `FormControl` instead.\n   * @default false\n   */\n  @Input({ transform: booleanAttribute })\n  public set disabled(value: boolean) {\n    if (value) {\n      this.formGroup.disable();\n    } else {\n      this.formGroup.enable();\n    }\n  }\n\n  /**\n   * The content of the help popover. When specified along with `labelText`, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is added to date range picker. The help inline button displays a [popover](https://developer.blackbaud.com/skyux/components/popover)\n   * when clicked using the specified content and optional title. This property only applies when `labelText` is also specified.\n   */\n  @Input()\n  public helpPopoverContent: string | TemplateRef<unknown> | undefined;\n\n  /**\n   * The title of the help popover. This property only applies when `helpPopoverContent` is\n   * also specified.\n   */\n  @Input()\n  public helpPopoverTitle: string | undefined;\n\n  /**\n   * [Persistent inline help text](https://developer.blackbaud.com/skyux/design/guidelines/user-assistance#inline-help) that provides\n   * additional context to the user.\n   */\n  @Input()\n  public hintText: string | undefined;\n\n  /**\n   * The label for the date range picker.\n   * @deprecated Use the `labelText` input instead.\n   */\n  @Input()\n  public set label(value: string | undefined) {\n    this.#_label = value;\n\n    if (value) {\n      this.#logger.deprecated('SkyDateRangePickerComponent.label', {\n        deprecationMajorVersion: 10,\n        replacementRecommendation: 'Use the `labelText` input instead.',\n      });\n    }\n  }\n\n  public get label(): string | undefined {\n    return this.#_label;\n  }\n\n  /**\n   * The text to display as the date range picker's label.\n   */\n  @Input()\n  public labelText: string | undefined;\n\n  /**\n   * Whether the date range picker is stacked on another form component. When specified, the appropriate\n   * vertical spacing is automatically added to the date range picker.\n   */\n  @Input({ transform: booleanAttribute })\n  @HostBinding('class.sky-form-field-stacked')\n  public stacked = false;\n\n  /**\n   * A help key that identifies the global help content to display. When specified along with `labelText`, a [help inline](https://developer.blackbaud.com/skyux/components/help-inline)\n   * button is placed beside the date range picker label. Clicking the button invokes [global help](https://developer.blackbaud.com/skyux/learn/develop/global-help)\n   * as configured by the application. This property only applies when `labelText` is also specified.\n   */\n  @Input()\n  public helpKey: string | undefined;\n\n  protected calculators = this.#dateRangeSvc.calculators;\n  protected datepickers = viewChildren(SkyDatepickerComponent);\n  protected hostControl: AbstractControl | null | undefined;\n  protected selectedCalculator = this.calculators[0];\n  protected showEndDatePicker = signal<boolean>(false);\n  protected showStartDatePicker = signal<boolean>(false);\n\n  #_calculatorIds = SKY_DEFAULT_CALCULATOR_IDS;\n  #_label: string | undefined;\n  #_value = this.selectedCalculator.getValue();\n\n  #hostHasCustomError: Signal<boolean | undefined> | undefined;\n  #notifyChange: ((_: SkyDateRangeCalculation) => void) | undefined;\n  #notifyTouched: (() => void) | undefined;\n\n  #calculatorIdControl = new FormControl<number>(\n    this.#getValue().calculatorId,\n    { nonNullable: true },\n  );\n  #calculatorIdInvalid = this.#createStatusChangeSignal(\n    this.#calculatorIdControl,\n  );\n  #calculatorIdTouched = this.#createTouchedChangeSignal(\n    this.#calculatorIdControl,\n  );\n\n  #endDateControl = new FormControl<DateValue>(this.#getValue().endDate);\n  #endDateInvalid = this.#createStatusChangeSignal(this.#endDateControl);\n  #endDateTouched = this.#createTouchedChangeSignal(this.#endDateControl);\n\n  #startDateControl = new FormControl<DateValue>(this.#getValue().startDate);\n  #startDateInvalid = this.#createStatusChangeSignal(this.#startDateControl);\n  #startDateTouched = this.#createTouchedChangeSignal(this.#startDateControl);\n\n  protected formGroup = inject(FormBuilder).group({\n    calculatorId: this.#calculatorIdControl,\n    startDate: this.#startDateControl,\n    endDate: this.#endDateControl,\n  });\n\n  protected readonly calculatorIdHasErrors = computed(() => {\n    const touched = this.#calculatorIdTouched();\n    const invalid = this.#calculatorIdInvalid() || this.#hostHasCustomError?.();\n    return touched && invalid;\n  });\n\n  protected readonly endDateHasErrors = computed(() => {\n    const calculatorIdHasErrors = this.calculatorIdHasErrors();\n    const touched = this.#endDateTouched();\n    const invalid = this.#endDateInvalid();\n\n    return calculatorIdHasErrors || (touched && invalid);\n  });\n\n  protected readonly startDateHasErrors = computed(() => {\n    const calculatorIdHasErrors = this.calculatorIdHasErrors();\n    const touched = this.#startDateTouched();\n    const invalid = this.#startDateInvalid();\n\n    return calculatorIdHasErrors || (touched && invalid);\n  });\n\n  public ngAfterViewInit(): void {\n    this.hostControl = this.#injector.get(NgControl, null, {\n      optional: true,\n      self: true,\n    })?.control;\n\n    runInInjectionContext(this.#injector, () => {\n      if (this.hostControl) {\n        this.#hostHasCustomError = this.#createHostCustomErrorChangeSignal(\n          this.hostControl,\n        );\n      }\n    });\n\n    // Set a default value on the control if it's undefined on init.\n    // We need to use setTimeout to avoid interfering with the first\n    // validation cycle.\n    if (isPartialValue(this.hostControl?.value)) {\n      setTimeout(() => {\n        this.hostControl?.setValue(this.#getValue(), {\n          emitEvent: false,\n        });\n      });\n    }\n\n    // If the datepickers' statuses change, we want to retrigger the host\n    // control's validation so that their errors are reflected back to the host.\n    this.formGroup.events\n      .pipe(\n        filter((evt) => evt instanceof StatusChangeEvent),\n        map((evt: StatusChangeEvent) => evt.status),\n        distinctUntilChanged(),\n        takeUntilDestroyed(this.#destroyRef),\n      )\n      .subscribe(() => {\n        this.hostControl?.updateValueAndValidity({\n          emitEvent: false,\n          onlySelf: true,\n        });\n      });\n\n    // Mark all fields as touched if the host control is touched.\n    this.hostControl?.events\n      .pipe(\n        filter((evt) => evt instanceof TouchedChangeEvent),\n        map((evt: TouchedChangeEvent) => evt.touched),\n        distinctUntilChanged(),\n        takeUntilDestroyed(this.#destroyRef),\n      )\n      .subscribe(() => {\n        this.formGroup.markAllAsTouched();\n      });\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public registerOnChange(fn: (_: unknown) => void): void {\n    this.#notifyChange = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public registerOnTouched(fn: () => void): void {\n    this.#notifyTouched = fn;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  // Implemented as part of Validator.\n  public validate(control: AbstractControl): ValidationErrors | null {\n    let errors: ValidationErrors | null = null;\n\n    const calculatorErrors = this.selectedCalculator.validate(control.value);\n    const startDateErrors = this.#startDateControl.errors;\n    const endDateErrors = this.#endDateControl.errors;\n\n    if (calculatorErrors) {\n      errors = {\n        skyDateRange: {\n          calculatorId: this.#getValue().calculatorId,\n          errors: calculatorErrors,\n        },\n      };\n    }\n\n    // Set calculator errors on the select so that they appear beneath it.\n    this.#calculatorIdControl.setErrors(errors);\n\n    if (this.showStartDatePicker() && startDateErrors) {\n      errors ||= {};\n      errors = { ...errors, ...startDateErrors };\n    }\n\n    if (this.showEndDatePicker() && endDateErrors) {\n      errors ||= {};\n      errors = { ...errors, ...endDateErrors };\n    }\n\n    return errors;\n  }\n\n  // Implemented as part of ControlValueAccessor.\n  // The date range picker always has a value, so if the consumer passes in a\n  // partial value (via `patchValue`) or null, we need to update the host control's\n  // value with the complete value after it's been modified.\n  public writeValue(value: Partial<SkyDateRangeCalculation> | undefined): void {\n    this.#patchValue(value);\n\n    // Update the host control if it is set to a partial or null value.\n    if (isPartialValue(value)) {\n      this.hostControl?.setValue(this.#getValue(), {\n        emitEvent: false,\n        onlySelf: true,\n      });\n    }\n  }\n\n  /**\n   * Fires when a user changes the selected calculator ID.\n   */\n  protected onCalculatorIdChange(): void {\n    // Reset the value when the calculator ID changes.\n    this.#setValue({ calculatorId: +this.#calculatorIdControl.value });\n    this.onDateChange();\n  }\n\n  /**\n   * Fires when a user interacts with a date range picker.\n   */\n  protected onDateChange(): void {\n    // Wait until the form control is updated before retrieving its value.\n    setTimeout(() => {\n      this.#notifyChange?.(\n        this.formGroup.getRawValue() as SkyDateRangeCalculation,\n      );\n    });\n  }\n\n  /**\n   * Fires when the date range picker loses focus.\n   */\n  protected onFocusout({ relatedTarget }: FocusEvent): void {\n    if (\n      relatedTarget &&\n      !this.#elementRef.nativeElement.contains(relatedTarget) &&\n      !this.datepickers().some((picker) => picker.containsTarget(relatedTarget))\n    ) {\n      this.#notifyTouched?.();\n    }\n  }\n\n  #getCalculator(calculatorId: number): SkyDateRangeCalculator {\n    const found = this.calculators.find((c) => c.calculatorId === calculatorId);\n\n    /*istanbul ignore if: safety check*/\n    if (!found) {\n      throw new Error(\n        `A date range calculator with ID (${calculatorId}) could not be found.`,\n      );\n    }\n\n    return found;\n  }\n\n  #getValue(): SkyDateRangeCalculation {\n    // Important! Return a clone to avoid changing the properties by reference.\n    return { ...this.#_value };\n  }\n\n  #patchValue(\n    partialValue: Partial<SkyDateRangeCalculation> | null | undefined,\n  ): void {\n    if (isNullOrUndefined(partialValue)) {\n      this.#setValue(null);\n      return;\n    }\n\n    const oldValue = this.#getValue();\n\n    // If the new ID is distinct, erase the old start and end dates because\n    // they're no longer applicable.\n    if (\n      !isNullOrUndefined(partialValue.calculatorId) &&\n      oldValue.calculatorId !== partialValue.calculatorId\n    ) {\n      delete oldValue.endDate;\n      delete oldValue.startDate;\n    }\n\n    const value = {\n      ...oldValue,\n      ...partialValue,\n    };\n\n    this.#setValue(value);\n  }\n\n  /**\n   * Sets the value to be used by the date range picker form control.\n   */\n  #setValue(value: SkyDateRangeCalculation | null | undefined): void {\n    const oldValue = this.#getValue();\n\n    const isValueEmpty = !value || isNullOrUndefined(value.calculatorId);\n    const valueOrDefault = isValueEmpty\n      ? this.calculators[0].getValue()\n      : {\n          ...this.#getCalculator(value.calculatorId).getValue(),\n          ...value,\n        };\n\n    // Ensure falsy values are set to null.\n    valueOrDefault.endDate = valueOrDefault.endDate || null;\n    valueOrDefault.startDate = valueOrDefault.startDate || null;\n\n    if (!areDateRangesEqual(oldValue, valueOrDefault)) {\n      this.#_value = valueOrDefault;\n\n      if (oldValue.calculatorId !== valueOrDefault.calculatorId) {\n        this.selectedCalculator = this.#getCalculator(\n          valueOrDefault.calculatorId,\n        );\n\n        this.#updatePickerVisibility(this.selectedCalculator);\n      }\n\n      this.formGroup.patchValue(valueOrDefault);\n    }\n  }\n\n  #updatePickerVisibility(calculator: SkyDateRangeCalculator): void {\n    let showEndDatePicker = false;\n    let showStartDatePicker = false;\n\n    switch (calculator.type) {\n      case SkyDateRangeCalculatorType.Before:\n        showEndDatePicker = true;\n        break;\n\n      case SkyDateRangeCalculatorType.After:\n        showStartDatePicker = true;\n        break;\n\n      case SkyDateRangeCalculatorType.Range:\n        showEndDatePicker = true;\n        showStartDatePicker = true;\n        break;\n\n      default:\n        break;\n    }\n\n    this.showEndDatePicker.set(showEndDatePicker);\n    this.showStartDatePicker.set(showStartDatePicker);\n  }\n\n  #createHostCustomErrorChangeSignal(\n    control: AbstractControl,\n  ): Signal<boolean | undefined> {\n    return toSignal(\n      control.events.pipe(\n        filter((evt) => evt instanceof StatusChangeEvent),\n        map((evt: StatusChangeEvent) => {\n          const errors = evt.source.errors ?? [];\n          const knownErrors = ['required', 'skyDate'];\n\n          return Object.keys(errors).some((error) => {\n            return !knownErrors.includes(error);\n          });\n        }),\n      ),\n    );\n  }\n\n  #createStatusChangeSignal(control: FormControl): Signal<boolean | undefined> {\n    return toSignal(\n      control.events.pipe(\n        filter((evt) => evt instanceof StatusChangeEvent),\n        map((evt: StatusChangeEvent) => evt.status === 'INVALID'),\n        takeUntilDestroyed(this.#destroyRef),\n      ),\n    );\n  }\n\n  #createTouchedChangeSignal(\n    control: FormControl,\n  ): Signal<boolean | undefined> {\n    return toSignal(\n      control.events.pipe(\n        filter((evt) => evt instanceof TouchedChangeEvent),\n        map((evt: TouchedChangeEvent) => evt.touched),\n        takeUntilDestroyed(this.#destroyRef),\n      ),\n    );\n  }\n}\n","<div class=\"sky-date-range-picker\" [formGroup]=\"formGroup\">\n  <div\n    class=\"sky-date-range-picker-form-group sky-date-range-picker-select-calculator\"\n    [ngClass]=\"{\n      'sky-date-range-picker-last-input':\n        !showStartDatePicker() && !showEndDatePicker()\n    }\"\n  >\n    <sky-input-box\n      [hasErrors]=\"calculatorIdHasErrors()\"\n      [helpKey]=\"helpKey\"\n      [helpPopoverContent]=\"helpPopoverContent\"\n      [helpPopoverTitle]=\"helpPopoverTitle\"\n      [hintText]=\"hintText\"\n      [labelText]=\"\n        labelText ||\n        label ||\n        ('skyux_date_range_picker_default_label' | skyLibResources)\n      \"\n    >\n      <select formControlName=\"calculatorId\" (change)=\"onCalculatorIdChange()\">\n        @for (calculator of calculators; track calculator.calculatorId) {\n          <option [value]=\"calculator.calculatorId\">\n            {{ calculator.shortDescription$ | async }}\n          </option>\n        }\n      </select>\n      @if (\n        hostControl?.errors?.['skyDateRange']?.errors?.[\n          'endDateBeforeStartDate'\n        ] && labelText\n      ) {\n        <sky-form-error\n          errorName=\"endDateBeforeStartDate\"\n          [errorText]=\"\n            'skyux_date_range_picker_end_date_before_start_date_error_label_text'\n              | skyLibResources\n          \"\n        />\n      }\n      <span class=\"sky-input-box-descendent-form-error\">\n        <ng-content select=\"sky-form-error\" />\n      </span>\n    </sky-input-box>\n  </div>\n  <div\n    class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-start-date\"\n    [hidden]=\"!showStartDatePicker()\"\n    [ngClass]=\"{\n      'sky-date-range-picker-last-input':\n        showStartDatePicker() && !showEndDatePicker()\n    }\"\n  >\n    <sky-input-box\n      [hasErrors]=\"startDateHasErrors()\"\n      [labelText]=\"\n        selectedCalculator.type\n          | skyDateRangePickerStartDateResourceKey\n          | skyLibResources\n      \"\n    >\n      <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n        <input\n          formControlName=\"startDate\"\n          name=\"startDate\"\n          skyDatepickerInput\n          type=\"text\"\n          [attr.aria-label]=\"\n            labelText || label\n              ? ('skyux_date_range_picker_default_aria_label'\n                | skyLibResources\n                  : (selectedCalculator.type\n                      | skyDateRangePickerStartDateResourceKey\n                      | skyLibResources)\n                  : (labelText ? labelText : label))\n              : (selectedCalculator.type\n                | skyDateRangePickerStartDateResourceKey\n                | skyLibResources)\n          \"\n          [dateFormat]=\"dateFormat\"\n          [required]=\"showStartDatePicker()\"\n          (change)=\"onDateChange()\"\n        />\n      </sky-datepicker>\n    </sky-input-box>\n  </div>\n  <div\n    class=\"sky-date-range-picker-form-group sky-date-range-datepicker-wrapper sky-date-range-picker-end-date\"\n    [hidden]=\"!showEndDatePicker()\"\n    [ngClass]=\"{ 'sky-date-range-picker-last-input': showEndDatePicker() }\"\n  >\n    <sky-input-box\n      [hasErrors]=\"endDateHasErrors()\"\n      [labelText]=\"\n        selectedCalculator.type\n          | skyDateRangePickerEndDateResourceKey\n          | skyLibResources\n      \"\n    >\n      <sky-datepicker (calendarDateChange)=\"onDateChange()\">\n        <input\n          formControlName=\"endDate\"\n          name=\"endDate\"\n          skyDatepickerInput\n          type=\"text\"\n          [attr.aria-label]=\"\n            labelText || label\n              ? ('skyux_date_range_picker_default_aria_label'\n                | skyLibResources\n                  : (selectedCalculator.type\n                      | skyDateRangePickerEndDateResourceKey\n                      | skyLibResources)\n                  : (labelText ? labelText : label))\n              : (selectedCalculator.type\n                | skyDateRangePickerEndDateResourceKey\n                | skyLibResources)\n          \"\n          [dateFormat]=\"dateFormat\"\n          [required]=\"showEndDatePicker()\"\n          (change)=\"onDateChange()\"\n        />\n      </sky-datepicker>\n    </sky-input-box>\n  </div>\n</div>\n"]}
@@ -1,17 +0,0 @@
1
- import { NgModule } from '@angular/core';
2
- import { SkyFormErrorModule } from '@skyux/forms';
3
- import { SkyDateRangePickerComponent } from './date-range-picker.component';
4
- import * as i0 from "@angular/core";
5
- export class SkyDateRangePickerModule {
6
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDateRangePickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: SkyDateRangePickerModule, imports: [SkyDateRangePickerComponent], exports: [SkyDateRangePickerComponent, SkyFormErrorModule] }); }
8
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDateRangePickerModule, imports: [SkyDateRangePickerComponent, SkyFormErrorModule] }); }
9
- }
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDateRangePickerModule, decorators: [{
11
- type: NgModule,
12
- args: [{
13
- exports: [SkyDateRangePickerComponent, SkyFormErrorModule],
14
- imports: [SkyDateRangePickerComponent],
15
- }]
16
- }] });
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1yYW5nZS1waWNrZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2RhdGV0aW1lL3NyYy9saWIvbW9kdWxlcy9kYXRlLXJhbmdlLXBpY2tlci9kYXRlLXJhbmdlLXBpY2tlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFbEQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sK0JBQStCLENBQUM7O0FBTTVFLE1BQU0sT0FBTyx3QkFBd0I7K0dBQXhCLHdCQUF3QjtnSEFBeEIsd0JBQXdCLFlBRnpCLDJCQUEyQixhQUQzQiwyQkFBMkIsRUFBRSxrQkFBa0I7Z0hBRzlDLHdCQUF3QixZQUZ6QiwyQkFBMkIsRUFERSxrQkFBa0I7OzRGQUc5Qyx3QkFBd0I7a0JBSnBDLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsMkJBQTJCLEVBQUUsa0JBQWtCLENBQUM7b0JBQzFELE9BQU8sRUFBRSxDQUFDLDJCQUEyQixDQUFDO2lCQUN2QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTa3lGb3JtRXJyb3JNb2R1bGUgfSBmcm9tICdAc2t5dXgvZm9ybXMnO1xuXG5pbXBvcnQgeyBTa3lEYXRlUmFuZ2VQaWNrZXJDb21wb25lbnQgfSBmcm9tICcuL2RhdGUtcmFuZ2UtcGlja2VyLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGV4cG9ydHM6IFtTa3lEYXRlUmFuZ2VQaWNrZXJDb21wb25lbnQsIFNreUZvcm1FcnJvck1vZHVsZV0sXG4gIGltcG9ydHM6IFtTa3lEYXRlUmFuZ2VQaWNrZXJDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lEYXRlUmFuZ2VQaWNrZXJNb2R1bGUge31cbiJdfQ==