@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.
- package/documentation.json +1004 -2555
- package/fesm2022/skyux-datetime-testing.mjs +4 -3
- package/fesm2022/skyux-datetime-testing.mjs.map +1 -1
- package/fesm2022/skyux-datetime.mjs +105 -102
- package/fesm2022/skyux-datetime.mjs.map +1 -1
- package/package.json +15 -19
- package/testing/modules/datepicker/datepicker-calendar-harness.d.ts +3 -2
- package/testing/public-api.d.ts +0 -2
- package/esm2022/index.mjs +0 -23
- package/esm2022/lib/modules/date-pipe/date-pipe.module.mjs +0 -20
- package/esm2022/lib/modules/date-pipe/date.pipe.mjs +0 -68
- package/esm2022/lib/modules/date-pipe/date.service.mjs +0 -94
- package/esm2022/lib/modules/date-pipe/fuzzy-date.pipe.mjs +0 -47
- package/esm2022/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +0 -21
- package/esm2022/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +0 -21
- package/esm2022/lib/modules/date-range-picker/date-range-picker.component.mjs +0 -445
- package/esm2022/lib/modules/date-range-picker/date-range-picker.module.mjs +0 -17
- package/esm2022/lib/modules/date-range-picker/date-range.service.mjs +0 -95
- package/esm2022/lib/modules/date-range-picker/types/date-range-calculation.mjs +0 -2
- package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-config.mjs +0 -2
- package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +0 -2
- package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-id.mjs +0 -118
- package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-type.mjs +0 -23
- package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +0 -2
- package/esm2022/lib/modules/date-range-picker/types/date-range-calculator.mjs +0 -71
- package/esm2022/lib/modules/date-range-picker/types/date-range-default-calculator-config.mjs +0 -2
- package/esm2022/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +0 -173
- package/esm2022/lib/modules/date-range-picker/types/date-range-relative-value.mjs +0 -249
- package/esm2022/lib/modules/date-range-picker/types/date-range.mjs +0 -2
- package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar-change.mjs +0 -2
- package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar-inner.component.mjs +0 -383
- package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar-label.pipe.mjs +0 -39
- package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar.component.mjs +0 -100
- package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar.service.mjs +0 -22
- package/esm2022/lib/modules/datepicker/calendar/daypicker-button.component.mjs +0 -23
- package/esm2022/lib/modules/datepicker/calendar/daypicker-cell.component.mjs +0 -129
- package/esm2022/lib/modules/datepicker/calendar/daypicker-context.mjs +0 -2
- package/esm2022/lib/modules/datepicker/calendar/daypicker.component.mjs +0 -221
- package/esm2022/lib/modules/datepicker/calendar/monthpicker.component.mjs +0 -80
- package/esm2022/lib/modules/datepicker/calendar/yearpicker.component.mjs +0 -87
- package/esm2022/lib/modules/datepicker/date-formatter.mjs +0 -38
- package/esm2022/lib/modules/datepicker/datepicker-config.service.mjs +0 -21
- package/esm2022/lib/modules/datepicker/datepicker-custom-date.mjs +0 -2
- package/esm2022/lib/modules/datepicker/datepicker-host.service.mjs +0 -61
- package/esm2022/lib/modules/datepicker/datepicker-input.directive.mjs +0 -526
- package/esm2022/lib/modules/datepicker/datepicker.component.mjs +0 -419
- package/esm2022/lib/modules/datepicker/datepicker.module.mjs +0 -62
- package/esm2022/lib/modules/datepicker/fuzzy/datepicker-input-fuzzy.directive.mjs +0 -516
- package/esm2022/lib/modules/datepicker/fuzzy/fuzzy-date.mjs +0 -2
- package/esm2022/lib/modules/datepicker/fuzzy/fuzzy-date.service.mjs +0 -411
- package/esm2022/lib/modules/shared/sky-datetime-resources.module.mjs +0 -130
- package/esm2022/lib/modules/timepicker/timepicker-time-format-type.mjs +0 -2
- package/esm2022/lib/modules/timepicker/timepicker-time-output.mjs +0 -2
- package/esm2022/lib/modules/timepicker/timepicker.component.mjs +0 -415
- package/esm2022/lib/modules/timepicker/timepicker.directive.mjs +0 -226
- package/esm2022/lib/modules/timepicker/timepicker.module.mjs +0 -37
- package/esm2022/skyux-datetime.mjs +0 -5
- package/esm2022/testing/legacy/datepicker-fixture.mjs +0 -56
- package/esm2022/testing/legacy/timepicker-fixture.mjs +0 -52
- package/esm2022/testing/modules/date-range-picker/date-range-picker-harness.filters.mjs +0 -2
- package/esm2022/testing/modules/date-range-picker/date-range-picker-harness.mjs +0 -193
- package/esm2022/testing/modules/datepicker/datepicker-calendar-harness.filters.mjs +0 -2
- package/esm2022/testing/modules/datepicker/datepicker-calendar-harness.mjs +0 -87
- package/esm2022/testing/modules/datepicker/datepicker-harness.filters.mjs +0 -2
- package/esm2022/testing/modules/datepicker/datepicker-harness.mjs +0 -60
- package/esm2022/testing/modules/datepicker/datepicker-input-harness.mjs +0 -29
- package/esm2022/testing/modules/datepicker/fuzzy-datepicker-input-harness.mjs +0 -29
- package/esm2022/testing/public-api.mjs +0 -8
- 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==
|