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