@skyux/datetime 7.0.0-beta.8 → 7.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (64) hide show
  1. package/documentation.json +1630 -985
  2. package/esm2020/lib/modules/date-pipe/date-pipe.module.mjs +5 -5
  3. package/esm2020/lib/modules/date-pipe/date.pipe.mjs +4 -5
  4. package/esm2020/lib/modules/date-pipe/fuzzy-date.pipe.mjs +4 -5
  5. package/esm2020/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +20 -0
  6. package/esm2020/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +20 -0
  7. package/esm2020/lib/modules/date-range-picker/date-range-picker.component.mjs +267 -212
  8. package/esm2020/lib/modules/date-range-picker/date-range-picker.module.mjs +14 -6
  9. package/esm2020/lib/modules/date-range-picker/date-range.service.mjs +45 -42
  10. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +1 -1
  11. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +1 -1
  12. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator.mjs +15 -15
  13. package/esm2020/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +4 -2
  14. package/esm2020/lib/modules/date-range-picker/types/date-range.mjs +1 -1
  15. package/esm2020/lib/modules/datepicker/date-formatter.mjs +2 -2
  16. package/esm2020/lib/modules/datepicker/datepicker-adapter.service.mjs +11 -18
  17. package/esm2020/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +46 -23
  18. package/esm2020/lib/modules/datepicker/datepicker-calendar.component.mjs +29 -37
  19. package/esm2020/lib/modules/datepicker/datepicker-config.service.mjs +4 -4
  20. package/esm2020/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +227 -217
  21. package/esm2020/lib/modules/datepicker/datepicker-input.directive.mjs +216 -227
  22. package/esm2020/lib/modules/datepicker/datepicker.component.mjs +122 -145
  23. package/esm2020/lib/modules/datepicker/datepicker.module.mjs +5 -5
  24. package/esm2020/lib/modules/datepicker/datepicker.service.mjs +4 -4
  25. package/esm2020/lib/modules/datepicker/daypicker-button.component.mjs +5 -6
  26. package/esm2020/lib/modules/datepicker/daypicker-cell.component.mjs +63 -63
  27. package/esm2020/lib/modules/datepicker/daypicker.component.mjs +146 -141
  28. package/esm2020/lib/modules/datepicker/fuzzy-date.service.mjs +126 -136
  29. package/esm2020/lib/modules/datepicker/monthpicker.component.mjs +53 -52
  30. package/esm2020/lib/modules/datepicker/yearpicker.component.mjs +55 -54
  31. package/esm2020/lib/modules/shared/sky-datetime-resources.module.mjs +5 -5
  32. package/esm2020/lib/modules/timepicker/timepicker.component.mjs +109 -95
  33. package/esm2020/lib/modules/timepicker/timepicker.directive.mjs +109 -103
  34. package/esm2020/lib/modules/timepicker/timepicker.module.mjs +5 -5
  35. package/fesm2015/skyux-datetime.mjs +1716 -1590
  36. package/fesm2015/skyux-datetime.mjs.map +1 -1
  37. package/fesm2020/skyux-datetime.mjs +1694 -1586
  38. package/fesm2020/skyux-datetime.mjs.map +1 -1
  39. package/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.d.ts +8 -0
  40. package/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.d.ts +8 -0
  41. package/lib/modules/date-range-picker/date-range-picker.component.d.ts +14 -43
  42. package/lib/modules/date-range-picker/date-range-picker.module.d.ts +9 -7
  43. package/lib/modules/date-range-picker/date-range.service.d.ts +1 -5
  44. package/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.d.ts +1 -1
  45. package/lib/modules/date-range-picker/types/date-range-calculator-validate-function.d.ts +1 -1
  46. package/lib/modules/date-range-picker/types/date-range-calculator.d.ts +3 -8
  47. package/lib/modules/date-range-picker/types/date-range.d.ts +2 -2
  48. package/lib/modules/datepicker/date-formatter.d.ts +3 -3
  49. package/lib/modules/datepicker/datepicker-adapter.service.d.ts +1 -5
  50. package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +18 -19
  51. package/lib/modules/datepicker/datepicker-calendar.component.d.ts +14 -25
  52. package/lib/modules/datepicker/datepicker-config.service.d.ts +3 -3
  53. package/lib/modules/datepicker/datepicker-input-fuzzy.directive.d.ts +17 -53
  54. package/lib/modules/datepicker/datepicker-input.directive.d.ts +13 -68
  55. package/lib/modules/datepicker/datepicker.component.d.ts +21 -58
  56. package/lib/modules/datepicker/daypicker-button.component.d.ts +1 -1
  57. package/lib/modules/datepicker/daypicker-cell.component.d.ts +3 -10
  58. package/lib/modules/datepicker/daypicker.component.d.ts +4 -16
  59. package/lib/modules/datepicker/fuzzy-date.service.d.ts +6 -30
  60. package/lib/modules/datepicker/monthpicker.component.d.ts +1 -4
  61. package/lib/modules/datepicker/yearpicker.component.d.ts +1 -3
  62. package/lib/modules/timepicker/timepicker.component.d.ts +14 -32
  63. package/lib/modules/timepicker/timepicker.directive.d.ts +9 -27
  64. package/package.json +12 -12
@@ -1,7 +1,7 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Optional, Output, TemplateRef, ViewChild, } from '@angular/core';
2
- import { SkyAffixAutoFitContext, SkyAffixService, SkyCoreAdapterService, SkyOverlayService, } from '@skyux/core';
3
- import { SkyInputBoxHostService } from '@skyux/forms';
4
- import { SkyThemeService } from '@skyux/theme';
1
+ var _SkyDatepickerComponent_instances, _SkyDatepickerComponent_affixer, _SkyDatepickerComponent_calendarUnsubscribe, _SkyDatepickerComponent_customDatesSubscription, _SkyDatepickerComponent_ngUnsubscribe, _SkyDatepickerComponent_overlay, _SkyDatepickerComponent_overlayKeydownListner, _SkyDatepickerComponent__calendarRef, _SkyDatepickerComponent__disabled, _SkyDatepickerComponent__selectedDate, _SkyDatepickerComponent_affixService, _SkyDatepickerComponent_changeDetector, _SkyDatepickerComponent_coreAdapter, _SkyDatepickerComponent_overlayService, _SkyDatepickerComponent_closePicker, _SkyDatepickerComponent_openPicker, _SkyDatepickerComponent_createAffixer, _SkyDatepickerComponent_destroyAffixer, _SkyDatepickerComponent_createOverlay, _SkyDatepickerComponent_destroyOverlay, _SkyDatepickerComponent_addKeydownListener, _SkyDatepickerComponent_removePickerEventListeners, _SkyDatepickerComponent_cancelCustomDatesSubscription;
2
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
+ import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Input, Optional, Output, TemplateRef, ViewChild, } from '@angular/core';
4
+ import { SkyAffixAutoFitContext, } from '@skyux/core';
5
5
  import { Subject, fromEvent } from 'rxjs';
6
6
  import { debounceTime, takeUntil } from 'rxjs/operators';
7
7
  import { SkyDatepickerCalendarComponent } from './datepicker-calendar.component';
@@ -20,11 +20,8 @@ let nextId = 0;
20
20
  */
21
21
  export class SkyDatepickerComponent {
22
22
  constructor(affixService, changeDetector, coreAdapter, overlayService, inputBoxHostService, themeSvc) {
23
- this.affixService = affixService;
24
- this.changeDetector = changeDetector;
25
- this.coreAdapter = coreAdapter;
26
- this.overlayService = overlayService;
27
23
  this.inputBoxHostService = inputBoxHostService;
24
+ _SkyDatepickerComponent_instances.add(this);
28
25
  /**
29
26
  * Adds a class to the datepicker.
30
27
  * @default ""
@@ -40,86 +37,74 @@ export class SkyDatepickerComponent {
40
37
  this.isDaypickerWaiting = false;
41
38
  this.isOpen = false;
42
39
  this.isVisible = false;
43
- this.ngUnsubscribe = new Subject();
44
- this._disabled = false;
40
+ _SkyDatepickerComponent_affixer.set(this, void 0);
41
+ _SkyDatepickerComponent_calendarUnsubscribe.set(this, new Subject());
42
+ _SkyDatepickerComponent_customDatesSubscription.set(this, void 0);
43
+ _SkyDatepickerComponent_ngUnsubscribe.set(this, new Subject());
44
+ _SkyDatepickerComponent_overlay.set(this, void 0);
45
+ _SkyDatepickerComponent_overlayKeydownListner.set(this, void 0);
46
+ _SkyDatepickerComponent__calendarRef.set(this, void 0);
47
+ _SkyDatepickerComponent__disabled.set(this, false);
48
+ _SkyDatepickerComponent__selectedDate.set(this, void 0);
49
+ _SkyDatepickerComponent_affixService.set(this, void 0);
50
+ _SkyDatepickerComponent_changeDetector.set(this, void 0);
51
+ _SkyDatepickerComponent_coreAdapter.set(this, void 0);
52
+ _SkyDatepickerComponent_overlayService.set(this, void 0);
53
+ __classPrivateFieldSet(this, _SkyDatepickerComponent_affixService, affixService, "f");
54
+ __classPrivateFieldSet(this, _SkyDatepickerComponent_changeDetector, changeDetector, "f");
55
+ __classPrivateFieldSet(this, _SkyDatepickerComponent_coreAdapter, coreAdapter, "f");
56
+ __classPrivateFieldSet(this, _SkyDatepickerComponent_overlayService, overlayService, "f");
45
57
  const uniqueId = nextId++;
46
58
  this.calendarId = `sky-datepicker-calendar-${uniqueId}`;
47
59
  this.triggerButtonId = `sky-datepicker-button-${uniqueId}`;
48
60
  // Update icons when theme changes.
49
61
  themeSvc?.settingsChange
50
- .pipe(takeUntil(this.ngUnsubscribe))
62
+ .pipe(takeUntil(__classPrivateFieldGet(this, _SkyDatepickerComponent_ngUnsubscribe, "f")))
51
63
  .subscribe(() => {
52
- this.changeDetector.markForCheck();
64
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_changeDetector, "f").markForCheck();
53
65
  });
54
66
  }
55
- /**
56
- * @internal
57
- * Indicates if the calendar button element or any of its children have focus.
58
- * @deprecated This property will be removed in the next major version release.
59
- */
60
- get buttonIsFocused() {
61
- /* sanity check */
62
- /* istanbul ignore if */
63
- if (!this.triggerButtonRef) {
64
- return false;
65
- }
66
- const activeEl = document.activeElement;
67
- return this.triggerButtonRef.nativeElement === activeEl;
68
- }
69
- /**
70
- * @internal
71
- * Indicates if the calendar element or any of its children have focus.
72
- * @deprecated This property will be removed in the next major version release.
73
- */
74
- get calendarIsFocused() {
75
- if (!this.calendarRef) {
76
- return false;
77
- }
78
- const focusedEl = document.activeElement;
79
- return this.calendarRef.nativeElement.contains(focusedEl);
80
- }
81
- /**
82
- * @internal
83
- * Indicates if the calendar element's visiblity property is 'visible'.
84
- * @deprecated This property will be removed in the next major version release.
85
- */
86
- get calendarIsVisible() {
87
- return this.calendar ? this.calendar.isVisible : false;
88
- }
89
67
  get disabled() {
90
- return this._disabled;
68
+ return __classPrivateFieldGet(this, _SkyDatepickerComponent__disabled, "f");
91
69
  }
92
70
  set disabled(value) {
93
- this._disabled = value;
94
- this.changeDetector.markForCheck();
71
+ __classPrivateFieldSet(this, _SkyDatepickerComponent__disabled, value, "f");
72
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_changeDetector, "f").markForCheck();
95
73
  }
96
74
  set selectedDate(value) {
97
- this._selectedDate = value;
75
+ __classPrivateFieldSet(this, _SkyDatepickerComponent__selectedDate, value, "f");
98
76
  if (this.calendar) {
99
- this.calendar.writeValue(this._selectedDate);
77
+ this.calendar.writeValue(value);
100
78
  }
101
79
  }
80
+ get selectedDate() {
81
+ return __classPrivateFieldGet(this, _SkyDatepickerComponent__selectedDate, "f");
82
+ }
102
83
  set calendarRef(value) {
103
84
  if (value) {
104
- this._calendarRef = value;
85
+ __classPrivateFieldSet(this, _SkyDatepickerComponent__calendarRef, value, "f");
105
86
  // Wait for the calendar component to render before gauging dimensions.
106
87
  setTimeout(() => {
107
- this.calendar.writeValue(this._selectedDate);
108
- this.destroyAffixer();
109
- this.createAffixer();
110
- setTimeout(() => {
111
- this.coreAdapter.getFocusableChildrenAndApplyFocus(this.calendarRef, '.sky-datepicker-calendar-inner', false);
112
- this.isVisible = true;
113
- this.changeDetector.markForCheck();
114
- });
88
+ if (this.calendarRef) {
89
+ this.calendar?.writeValue(this.selectedDate);
90
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_destroyAffixer).call(this);
91
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_createAffixer).call(this);
92
+ setTimeout(() => {
93
+ if (this.calendarRef) {
94
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_coreAdapter, "f").getFocusableChildrenAndApplyFocus(this.calendarRef, '.sky-datepicker-calendar-inner', false);
95
+ this.isVisible = true;
96
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_changeDetector, "f").markForCheck();
97
+ }
98
+ });
99
+ }
115
100
  });
116
101
  }
117
102
  }
118
103
  get calendarRef() {
119
- return this._calendarRef;
104
+ return __classPrivateFieldGet(this, _SkyDatepickerComponent__calendarRef, "f");
120
105
  }
121
106
  ngOnInit() {
122
- if (this.inputBoxHostService) {
107
+ if (this.inputBoxHostService && this.inputTemplateRef) {
123
108
  this.inputBoxHostService.populate({
124
109
  inputTemplate: this.inputTemplateRef,
125
110
  buttonsTemplate: this.triggerButtonTemplateRef,
@@ -128,34 +113,34 @@ export class SkyDatepickerComponent {
128
113
  }
129
114
  ngOnDestroy() {
130
115
  this.dateChange.complete();
131
- this.ngUnsubscribe.next();
132
- this.ngUnsubscribe.complete();
133
- this.removePickerEventListeners();
134
- this.destroyAffixer();
135
- this.destroyOverlay();
116
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_ngUnsubscribe, "f").next();
117
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_ngUnsubscribe, "f").complete();
118
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_removePickerEventListeners).call(this);
119
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_destroyAffixer).call(this);
120
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_destroyOverlay).call(this);
136
121
  }
137
122
  onCalendarModeChange() {
138
123
  // Let the calendar populate in the DOM before recalculating placement.
139
124
  setTimeout(() => {
140
- this.affixer.reaffix();
125
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_affixer, "f")?.reaffix();
141
126
  });
142
127
  }
143
128
  onSelectedDateChange(value) {
144
129
  this.dateChange.emit(value);
145
- this.closePicker();
130
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_closePicker).call(this);
146
131
  }
147
132
  onTriggerButtonClick() {
148
133
  if (this.isOpen) {
149
- this.closePicker();
134
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_closePicker).call(this);
150
135
  }
151
136
  else {
152
- this.openPicker();
137
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_openPicker).call(this);
153
138
  }
154
139
  }
155
140
  onCalendarDateRangeChange(event) {
156
141
  /* istanbul ignore else */
157
142
  if (event) {
158
- this.cancelCustomDatesSubscription();
143
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_cancelCustomDatesSubscription).call(this);
159
144
  const args = {
160
145
  startDate: event.startDate,
161
146
  endDate: event.endDate,
@@ -167,15 +152,15 @@ export class SkyDatepickerComponent {
167
152
  if (args.customDates) {
168
153
  this.isDaypickerWaiting = true;
169
154
  // Avoid an ExpressionChangedAfterItHasBeenCheckedError.
170
- this.changeDetector.detectChanges();
171
- this.customDatesSubscription = args.customDates
155
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_changeDetector, "f").detectChanges();
156
+ __classPrivateFieldSet(this, _SkyDatepickerComponent_customDatesSubscription, args.customDates
172
157
  .pipe(debounceTime(250))
173
158
  .subscribe((result) => {
174
159
  this.customDates = result;
175
160
  this.isDaypickerWaiting = false;
176
161
  // Trigger change detection in child components to show changes in the calendar.
177
- this.changeDetector.markForCheck();
178
- });
162
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_changeDetector, "f").markForCheck();
163
+ }), "f");
179
164
  }
180
165
  else {
181
166
  // If consumer returns an undefined value after custom dates have
@@ -183,36 +168,35 @@ export class SkyDatepickerComponent {
183
168
  if (this.customDates) {
184
169
  this.customDates = undefined;
185
170
  // Avoid an ExpressionChangedAfterItHasBeenCheckedError.
186
- this.changeDetector.detectChanges();
171
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_changeDetector, "f").detectChanges();
187
172
  }
188
173
  }
189
174
  }
190
175
  }
191
- closePicker() {
192
- this.destroyAffixer();
193
- this.destroyOverlay();
194
- this.removePickerEventListeners();
195
- this.triggerButtonRef.nativeElement.focus();
196
- this.isOpen = false;
197
- }
198
- openPicker() {
199
- this.isVisible = false;
200
- this.changeDetector.markForCheck();
201
- this.removePickerEventListeners();
202
- this.calendarUnsubscribe = new Subject();
203
- this.destroyOverlay();
204
- this.createOverlay();
205
- this.isOpen = true;
206
- this.changeDetector.markForCheck();
207
- }
208
- createAffixer() {
209
- const affixer = this.affixService.createAffixer(this.calendarRef);
176
+ }
177
+ _SkyDatepickerComponent_affixer = new WeakMap(), _SkyDatepickerComponent_calendarUnsubscribe = new WeakMap(), _SkyDatepickerComponent_customDatesSubscription = new WeakMap(), _SkyDatepickerComponent_ngUnsubscribe = new WeakMap(), _SkyDatepickerComponent_overlay = new WeakMap(), _SkyDatepickerComponent_overlayKeydownListner = new WeakMap(), _SkyDatepickerComponent__calendarRef = new WeakMap(), _SkyDatepickerComponent__disabled = new WeakMap(), _SkyDatepickerComponent__selectedDate = new WeakMap(), _SkyDatepickerComponent_affixService = new WeakMap(), _SkyDatepickerComponent_changeDetector = new WeakMap(), _SkyDatepickerComponent_coreAdapter = new WeakMap(), _SkyDatepickerComponent_overlayService = new WeakMap(), _SkyDatepickerComponent_instances = new WeakSet(), _SkyDatepickerComponent_closePicker = function _SkyDatepickerComponent_closePicker() {
178
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_destroyAffixer).call(this);
179
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_destroyOverlay).call(this);
180
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_removePickerEventListeners).call(this);
181
+ this.triggerButtonRef?.nativeElement.focus();
182
+ this.isOpen = false;
183
+ }, _SkyDatepickerComponent_openPicker = function _SkyDatepickerComponent_openPicker() {
184
+ this.isVisible = false;
185
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_changeDetector, "f").markForCheck();
186
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_removePickerEventListeners).call(this);
187
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_destroyOverlay).call(this);
188
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_createOverlay).call(this);
189
+ this.isOpen = true;
190
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_changeDetector, "f").markForCheck();
191
+ }, _SkyDatepickerComponent_createAffixer = function _SkyDatepickerComponent_createAffixer() {
192
+ if (this.calendarRef && this.triggerButtonRef) {
193
+ const affixer = __classPrivateFieldGet(this, _SkyDatepickerComponent_affixService, "f").createAffixer(this.calendarRef);
210
194
  // Hide calendar when trigger button is scrolled off screen.
211
195
  affixer.placementChange
212
- .pipe(takeUntil(this.calendarUnsubscribe))
196
+ .pipe(takeUntil(__classPrivateFieldGet(this, _SkyDatepickerComponent_calendarUnsubscribe, "f")))
213
197
  .subscribe((change) => {
214
198
  this.isVisible = change.placement !== null;
215
- this.changeDetector.markForCheck();
199
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_changeDetector, "f").markForCheck();
216
200
  });
217
201
  affixer.affixTo(this.triggerButtonRef.nativeElement, {
218
202
  autoFitContext: SkyAffixAutoFitContext.Viewport,
@@ -221,69 +205,62 @@ export class SkyDatepickerComponent {
221
205
  isSticky: true,
222
206
  placement: 'below',
223
207
  });
224
- this.affixer = affixer;
208
+ __classPrivateFieldSet(this, _SkyDatepickerComponent_affixer, affixer, "f");
225
209
  }
226
- destroyAffixer() {
227
- /*istanbul ignore else*/
228
- if (this.affixer) {
229
- this.affixer.destroy();
230
- this.affixer = undefined;
231
- }
210
+ }, _SkyDatepickerComponent_destroyAffixer = function _SkyDatepickerComponent_destroyAffixer() {
211
+ /*istanbul ignore else*/
212
+ if (__classPrivateFieldGet(this, _SkyDatepickerComponent_affixer, "f")) {
213
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_affixer, "f").destroy();
214
+ __classPrivateFieldSet(this, _SkyDatepickerComponent_affixer, undefined, "f");
232
215
  }
233
- createOverlay() {
234
- const overlay = this.overlayService.create({
216
+ }, _SkyDatepickerComponent_createOverlay = function _SkyDatepickerComponent_createOverlay() {
217
+ if (this.calendarTemplateRef) {
218
+ const overlay = __classPrivateFieldGet(this, _SkyDatepickerComponent_overlayService, "f").create({
235
219
  wrapperClass: this.pickerClass,
236
220
  enableClose: false,
237
221
  enablePointerEvents: false,
238
222
  });
239
223
  overlay.backdropClick
240
- .pipe(takeUntil(this.calendarUnsubscribe))
224
+ .pipe(takeUntil(__classPrivateFieldGet(this, _SkyDatepickerComponent_calendarUnsubscribe, "f")))
241
225
  .subscribe(() => {
242
226
  /* istanbul ignore else */
243
227
  if (this.isOpen) {
244
- this.closePicker();
228
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_closePicker).call(this);
245
229
  }
246
230
  });
247
- this.addKeydownListner();
231
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_addKeydownListener).call(this);
248
232
  overlay.attachTemplate(this.calendarTemplateRef);
249
- this.overlay = overlay;
250
- }
251
- destroyOverlay() {
252
- /*istanbul ignore else*/
253
- if (this.overlay) {
254
- this.overlayService.close(this.overlay);
255
- this.overlay = undefined;
256
- }
257
- }
258
- addKeydownListner() {
259
- this.overlayKeydownListner = fromEvent(window.document, 'keydown')
260
- .pipe(takeUntil(this.ngUnsubscribe))
261
- .subscribe((event) => {
262
- const key = event.key?.toLowerCase();
263
- if (key === 'escape' && this.isOpen) {
264
- this.closePicker();
265
- }
266
- });
233
+ __classPrivateFieldSet(this, _SkyDatepickerComponent_overlay, overlay, "f");
267
234
  }
268
- removePickerEventListeners() {
269
- /* istanbul ignore else */
270
- if (this.calendarUnsubscribe) {
271
- this.calendarUnsubscribe.next();
272
- this.calendarUnsubscribe.complete();
273
- this.calendarUnsubscribe = undefined;
274
- }
275
- this.overlayKeydownListner?.unsubscribe();
235
+ }, _SkyDatepickerComponent_destroyOverlay = function _SkyDatepickerComponent_destroyOverlay() {
236
+ /*istanbul ignore else*/
237
+ if (__classPrivateFieldGet(this, _SkyDatepickerComponent_overlay, "f")) {
238
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_overlayService, "f").close(__classPrivateFieldGet(this, _SkyDatepickerComponent_overlay, "f"));
239
+ __classPrivateFieldSet(this, _SkyDatepickerComponent_overlay, undefined, "f");
276
240
  }
277
- cancelCustomDatesSubscription() {
278
- if (this.customDatesSubscription) {
279
- this.customDatesSubscription.unsubscribe();
280
- this.customDatesSubscription = undefined;
241
+ }, _SkyDatepickerComponent_addKeydownListener = function _SkyDatepickerComponent_addKeydownListener() {
242
+ __classPrivateFieldSet(this, _SkyDatepickerComponent_overlayKeydownListner, fromEvent(window.document, 'keydown')
243
+ .pipe(takeUntil(__classPrivateFieldGet(this, _SkyDatepickerComponent_ngUnsubscribe, "f")))
244
+ .subscribe((event) => {
245
+ const key = event.key?.toLowerCase();
246
+ if (key === 'escape' && this.isOpen) {
247
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_instances, "m", _SkyDatepickerComponent_closePicker).call(this);
281
248
  }
249
+ }), "f");
250
+ }, _SkyDatepickerComponent_removePickerEventListeners = function _SkyDatepickerComponent_removePickerEventListeners() {
251
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_calendarUnsubscribe, "f").next();
252
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_calendarUnsubscribe, "f").complete();
253
+ __classPrivateFieldSet(this, _SkyDatepickerComponent_calendarUnsubscribe, new Subject(), "f");
254
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_overlayKeydownListner, "f")?.unsubscribe();
255
+ }, _SkyDatepickerComponent_cancelCustomDatesSubscription = function _SkyDatepickerComponent_cancelCustomDatesSubscription() {
256
+ if (__classPrivateFieldGet(this, _SkyDatepickerComponent_customDatesSubscription, "f")) {
257
+ __classPrivateFieldGet(this, _SkyDatepickerComponent_customDatesSubscription, "f").unsubscribe();
258
+ __classPrivateFieldSet(this, _SkyDatepickerComponent_customDatesSubscription, undefined, "f");
282
259
  }
283
- }
284
- SkyDatepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDatepickerComponent, deps: [{ token: i1.SkyAffixService }, { token: i0.ChangeDetectorRef }, { token: i1.SkyCoreAdapterService }, { token: i1.SkyOverlayService }, { token: i2.SkyInputBoxHostService, optional: true }, { token: i3.SkyThemeService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
285
- SkyDatepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyDatepickerComponent, selector: "sky-datepicker", inputs: { pickerClass: "pickerClass" }, outputs: { calendarDateRangeChange: "calendarDateRangeChange" }, viewQueries: [{ propertyName: "calendar", first: true, predicate: SkyDatepickerCalendarComponent, descendants: true }, { propertyName: "calendarRef", first: true, predicate: ["calendarRef"], descendants: true, read: ElementRef }, { propertyName: "calendarTemplateRef", first: true, predicate: ["calendarTemplateRef"], descendants: true, read: TemplateRef }, { propertyName: "triggerButtonRef", first: true, predicate: ["triggerButtonRef"], descendants: true, read: ElementRef }, { propertyName: "inputTemplateRef", first: true, predicate: ["inputTemplateRef"], descendants: true, read: TemplateRef, static: true }, { propertyName: "triggerButtonTemplateRef", first: true, predicate: ["triggerButtonTemplateRef"], descendants: true, read: TemplateRef, static: true }], ngImport: i0, template: "<div class=\"sky-datepicker\">\n <ng-container *ngIf=\"!inputBoxHostService\">\n <div class=\"sky-input-group\">\n <ng-container *ngTemplateOutlet=\"inputTemplateRef\"></ng-container>\n <ng-container *ngTemplateOutlet=\"triggerButtonTemplateRef\"></ng-container>\n </div>\n </ng-container>\n</div>\n\n<ng-template #inputTemplateRef>\n <ng-content></ng-content>\n</ng-template>\n\n<ng-template #triggerButtonTemplateRef>\n <div class=\"sky-input-group-btn\">\n <button\n aria-haspopup=\"dialog\"\n class=\"sky-btn sky-btn-default sky-input-group-datepicker-btn\"\n type=\"button\"\n [attr.aria-controls]=\"isOpen ? calendarId : null\"\n [attr.aria-expanded]=\"isOpen\"\n [attr.aria-label]=\"\n 'skyux_datepicker_trigger_button_label' | skyLibResources\n \"\n [attr.id]=\"triggerButtonId\"\n [attr.title]=\"'skyux_datepicker_trigger_button_label' | skyLibResources\"\n [disabled]=\"disabled\"\n (click)=\"onTriggerButtonClick()\"\n #triggerButtonRef\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"calendar\" size=\"lg\"></sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n icon=\"calendar\"\n size=\"lg\"\n iconType=\"skyux\"\n ></sky-icon>\n </button>\n </div>\n</ng-template>\n\n<ng-template #calendarTemplateRef>\n <div\n class=\"sky-datepicker-calendar-container sky-shadow sky-elevation-4\"\n role=\"dialog\"\n [attr.aria-labelledby]=\"triggerButtonId\"\n [attr.id]=\"calendarId\"\n [class.sky-datepicker-hidden]=\"!isVisible\"\n #calendarRef\n >\n <sky-datepicker-calendar\n [customDates]=\"customDates\"\n [isDaypickerWaiting]=\"isDaypickerWaiting\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [startingDay]=\"startingDay\"\n (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n (calendarModeChange)=\"onCalendarModeChange()\"\n (selectedDateChange)=\"onSelectedDateChange($event)\"\n >\n </sky-datepicker-calendar>\n </div>\n</ng-template>\n", styles: [".sky-datepicker-calendar-container{position:fixed;border-radius:5px}.sky-datepicker-hidden{visibility:hidden}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "directive", type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { kind: "component", type: i6.SkyDatepickerCalendarComponent, selector: "sky-datepicker-calendar", inputs: ["customDates", "isDaypickerWaiting", "minDate", "maxDate", "selectedDate", "startingDay"], outputs: ["calendarDateRangeChange", "calendarModeChange", "selectedDateChange"] }, { kind: "pipe", type: i7.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
286
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDatepickerComponent, decorators: [{
260
+ };
261
+ SkyDatepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDatepickerComponent, deps: [{ token: i1.SkyAffixService }, { token: i0.ChangeDetectorRef }, { token: i1.SkyCoreAdapterService }, { token: i1.SkyOverlayService }, { token: i2.SkyInputBoxHostService, optional: true }, { token: i3.SkyThemeService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
262
+ SkyDatepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.11", type: SkyDatepickerComponent, selector: "sky-datepicker", inputs: { pickerClass: "pickerClass" }, outputs: { calendarDateRangeChange: "calendarDateRangeChange" }, viewQueries: [{ propertyName: "calendar", first: true, predicate: SkyDatepickerCalendarComponent, descendants: true }, { propertyName: "calendarRef", first: true, predicate: ["calendarRef"], descendants: true, read: ElementRef }, { propertyName: "calendarTemplateRef", first: true, predicate: ["calendarTemplateRef"], descendants: true, read: TemplateRef }, { propertyName: "triggerButtonRef", first: true, predicate: ["triggerButtonRef"], descendants: true, read: ElementRef }, { propertyName: "inputTemplateRef", first: true, predicate: ["inputTemplateRef"], descendants: true, read: TemplateRef, static: true }, { propertyName: "triggerButtonTemplateRef", first: true, predicate: ["triggerButtonTemplateRef"], descendants: true, read: TemplateRef, static: true }], ngImport: i0, template: "<div class=\"sky-datepicker\">\n <ng-container *ngIf=\"!inputBoxHostService\">\n <div class=\"sky-input-group\">\n <ng-container *ngTemplateOutlet=\"inputTemplateRef\"></ng-container>\n <ng-container *ngTemplateOutlet=\"triggerButtonTemplateRef\"></ng-container>\n </div>\n </ng-container>\n</div>\n\n<ng-template #inputTemplateRef>\n <ng-content></ng-content>\n</ng-template>\n\n<ng-template #triggerButtonTemplateRef>\n <div class=\"sky-input-group-btn\">\n <button\n aria-haspopup=\"dialog\"\n class=\"sky-btn sky-btn-default sky-input-group-datepicker-btn\"\n type=\"button\"\n [attr.aria-controls]=\"isOpen ? calendarId : null\"\n [attr.aria-expanded]=\"isOpen\"\n [attr.aria-label]=\"\n 'skyux_datepicker_trigger_button_label' | skyLibResources\n \"\n [attr.id]=\"triggerButtonId\"\n [attr.title]=\"'skyux_datepicker_trigger_button_label' | skyLibResources\"\n [disabled]=\"disabled\"\n (click)=\"onTriggerButtonClick()\"\n #triggerButtonRef\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"calendar\" size=\"lg\"></sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n icon=\"calendar\"\n size=\"lg\"\n iconType=\"skyux\"\n ></sky-icon>\n </button>\n </div>\n</ng-template>\n\n<ng-template #calendarTemplateRef>\n <div\n class=\"sky-datepicker-calendar-container sky-shadow sky-elevation-4\"\n role=\"dialog\"\n [attr.aria-labelledby]=\"triggerButtonId\"\n [attr.id]=\"calendarId\"\n [class.sky-datepicker-hidden]=\"!isVisible\"\n #calendarRef\n >\n <sky-datepicker-calendar\n [customDates]=\"customDates\"\n [isDaypickerWaiting]=\"isDaypickerWaiting\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [startingDay]=\"startingDay\"\n (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n (calendarModeChange)=\"onCalendarModeChange()\"\n (selectedDateChange)=\"onSelectedDateChange($event)\"\n >\n </sky-datepicker-calendar>\n </div>\n</ng-template>\n", styles: [".sky-datepicker-calendar-container{position:fixed;border-radius:5px}.sky-datepicker-hidden{visibility:hidden}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "directive", type: i3.λ3, selector: "[skyThemeIf]", inputs: ["skyThemeIf"] }, { kind: "component", type: i6.SkyDatepickerCalendarComponent, selector: "sky-datepicker-calendar", inputs: ["customDates", "isDaypickerWaiting", "minDate", "maxDate", "selectedDate", "startingDay"], outputs: ["calendarDateRangeChange", "calendarModeChange", "selectedDateChange"] }, { kind: "pipe", type: i7.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
263
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDatepickerComponent, decorators: [{
287
264
  type: Component,
288
265
  args: [{ selector: 'sky-datepicker', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"sky-datepicker\">\n <ng-container *ngIf=\"!inputBoxHostService\">\n <div class=\"sky-input-group\">\n <ng-container *ngTemplateOutlet=\"inputTemplateRef\"></ng-container>\n <ng-container *ngTemplateOutlet=\"triggerButtonTemplateRef\"></ng-container>\n </div>\n </ng-container>\n</div>\n\n<ng-template #inputTemplateRef>\n <ng-content></ng-content>\n</ng-template>\n\n<ng-template #triggerButtonTemplateRef>\n <div class=\"sky-input-group-btn\">\n <button\n aria-haspopup=\"dialog\"\n class=\"sky-btn sky-btn-default sky-input-group-datepicker-btn\"\n type=\"button\"\n [attr.aria-controls]=\"isOpen ? calendarId : null\"\n [attr.aria-expanded]=\"isOpen\"\n [attr.aria-label]=\"\n 'skyux_datepicker_trigger_button_label' | skyLibResources\n \"\n [attr.id]=\"triggerButtonId\"\n [attr.title]=\"'skyux_datepicker_trigger_button_label' | skyLibResources\"\n [disabled]=\"disabled\"\n (click)=\"onTriggerButtonClick()\"\n #triggerButtonRef\n >\n <sky-icon *skyThemeIf=\"'default'\" icon=\"calendar\" size=\"lg\"></sky-icon>\n <sky-icon\n *skyThemeIf=\"'modern'\"\n icon=\"calendar\"\n size=\"lg\"\n iconType=\"skyux\"\n ></sky-icon>\n </button>\n </div>\n</ng-template>\n\n<ng-template #calendarTemplateRef>\n <div\n class=\"sky-datepicker-calendar-container sky-shadow sky-elevation-4\"\n role=\"dialog\"\n [attr.aria-labelledby]=\"triggerButtonId\"\n [attr.id]=\"calendarId\"\n [class.sky-datepicker-hidden]=\"!isVisible\"\n #calendarRef\n >\n <sky-datepicker-calendar\n [customDates]=\"customDates\"\n [isDaypickerWaiting]=\"isDaypickerWaiting\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [startingDay]=\"startingDay\"\n (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n (calendarModeChange)=\"onCalendarModeChange()\"\n (selectedDateChange)=\"onSelectedDateChange($event)\"\n >\n </sky-datepicker-calendar>\n </div>\n</ng-template>\n", styles: [".sky-datepicker-calendar-container{position:fixed;border-radius:5px}.sky-datepicker-hidden{visibility:hidden}\n"] }]
289
266
  }], ctorParameters: function () { return [{ type: i1.SkyAffixService }, { type: i0.ChangeDetectorRef }, { type: i1.SkyCoreAdapterService }, { type: i1.SkyOverlayService }, { type: i2.SkyInputBoxHostService, decorators: [{
@@ -325,4 +302,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
325
302
  static: true,
326
303
  }]
327
304
  }] } });
328
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport {\n  SkyAffixAutoFitContext,\n  SkyAffixService,\n  SkyAffixer,\n  SkyCoreAdapterService,\n  SkyOverlayInstance,\n  SkyOverlayService,\n} from '@skyux/core';\nimport { SkyInputBoxHostService } from '@skyux/forms';\nimport { SkyThemeService } from '@skyux/theme';\n\nimport { Subject, Subscription, fromEvent } from 'rxjs';\nimport { debounceTime, takeUntil } from 'rxjs/operators';\n\nimport { SkyDatepickerCalendarChange } from './datepicker-calendar-change';\nimport { SkyDatepickerCalendarComponent } from './datepicker-calendar.component';\nimport { SkyDatepickerCustomDate } from './datepicker-custom-date';\n\nlet nextId = 0;\n\n/**\n * Creates the datepicker button and calendar.\n * You must wrap this component around an input with the `skyDatepickerInput` directive.\n */\n@Component({\n  selector: 'sky-datepicker',\n  templateUrl: './datepicker.component.html',\n  styleUrls: ['./datepicker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyDatepickerComponent implements OnDestroy, OnInit {\n  /**\n   * Adds a class to the datepicker.\n   * @default \"\"\n   */\n  @Input()\n  public pickerClass = '';\n\n  /**\n   * @internal\n   * Indicates if the calendar button element or any of its children have focus.\n   * @deprecated This property will be removed in the next major version release.\n   */\n  public get buttonIsFocused(): boolean {\n    /* sanity check */\n    /* istanbul ignore if */\n    if (!this.triggerButtonRef) {\n      return false;\n    }\n    const activeEl = document.activeElement;\n    return this.triggerButtonRef.nativeElement === activeEl;\n  }\n\n  /**\n   * @internal\n   * Indicates if the calendar element or any of its children have focus.\n   * @deprecated This property will be removed in the next major version release.\n   */\n  public get calendarIsFocused(): boolean {\n    if (!this.calendarRef) {\n      return false;\n    }\n\n    const focusedEl = document.activeElement;\n    return this.calendarRef.nativeElement.contains(focusedEl);\n  }\n\n  /**\n   * @internal\n   * Indicates if the calendar element's visiblity property is 'visible'.\n   * @deprecated This property will be removed in the next major version release.\n   */\n  public get calendarIsVisible(): boolean {\n    return this.calendar ? this.calendar.isVisible : false;\n  }\n\n  public get disabled(): boolean {\n    return this._disabled;\n  }\n\n  public set disabled(value: boolean) {\n    this._disabled = value;\n    this.changeDetector.markForCheck();\n  }\n\n  public set selectedDate(value: Date) {\n    this._selectedDate = value;\n    if (this.calendar) {\n      this.calendar.writeValue(this._selectedDate);\n    }\n  }\n\n  /**\n   * Fires when the range of displayed dates in the calendar changes. Provides the\n   * current range of displayed dates and a mutable `customDate` property consumers can use\n   * to modify individual dates on the calendar.\n   */\n  @Output()\n  public calendarDateRangeChange = new EventEmitter<SkyDatepickerCalendarChange>();\n\n  public calendarId: string;\n\n  public customDates: SkyDatepickerCustomDate[] | undefined;\n\n  public dateChange = new EventEmitter<Date>();\n\n  public isDaypickerWaiting = false;\n\n  public isOpen = false;\n\n  public isVisible = false;\n\n  public maxDate: Date;\n\n  public minDate: Date;\n\n  public startingDay: number;\n\n  public triggerButtonId: string;\n\n  @ViewChild(SkyDatepickerCalendarComponent)\n  private calendar: SkyDatepickerCalendarComponent;\n\n  @ViewChild('calendarRef', {\n    read: ElementRef,\n  })\n  private set calendarRef(value: ElementRef) {\n    if (value) {\n      this._calendarRef = value;\n\n      // Wait for the calendar component to render before gauging dimensions.\n      setTimeout(() => {\n        this.calendar.writeValue(this._selectedDate);\n\n        this.destroyAffixer();\n        this.createAffixer();\n\n        setTimeout(() => {\n          this.coreAdapter.getFocusableChildrenAndApplyFocus(\n            this.calendarRef,\n            '.sky-datepicker-calendar-inner',\n            false\n          );\n\n          this.isVisible = true;\n          this.changeDetector.markForCheck();\n        });\n      });\n    }\n  }\n\n  private get calendarRef(): ElementRef {\n    return this._calendarRef;\n  }\n\n  @ViewChild('calendarTemplateRef', {\n    read: TemplateRef,\n  })\n  private calendarTemplateRef: TemplateRef<unknown>;\n\n  @ViewChild('triggerButtonRef', {\n    read: ElementRef,\n  })\n  private triggerButtonRef: ElementRef;\n\n  @ViewChild('inputTemplateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  private inputTemplateRef: TemplateRef<unknown>;\n\n  @ViewChild('triggerButtonTemplateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  private triggerButtonTemplateRef: TemplateRef<unknown>;\n\n  private affixer: SkyAffixer;\n\n  private calendarUnsubscribe: Subject<void>;\n\n  private customDatesSubscription: Subscription;\n\n  private ngUnsubscribe = new Subject<void>();\n\n  private overlay: SkyOverlayInstance;\n\n  private overlayKeydownListner: Subscription;\n\n  private _calendarRef: ElementRef;\n\n  private _disabled = false;\n\n  private _selectedDate: Date;\n\n  constructor(\n    private affixService: SkyAffixService,\n    private changeDetector: ChangeDetectorRef,\n    private coreAdapter: SkyCoreAdapterService,\n    private overlayService: SkyOverlayService,\n    @Optional() public inputBoxHostService?: SkyInputBoxHostService,\n    @Optional() themeSvc?: SkyThemeService\n  ) {\n    const uniqueId = nextId++;\n    this.calendarId = `sky-datepicker-calendar-${uniqueId}`;\n    this.triggerButtonId = `sky-datepicker-button-${uniqueId}`;\n\n    // Update icons when theme changes.\n    themeSvc?.settingsChange\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe(() => {\n        this.changeDetector.markForCheck();\n      });\n  }\n\n  public ngOnInit(): void {\n    if (this.inputBoxHostService) {\n      this.inputBoxHostService.populate({\n        inputTemplate: this.inputTemplateRef,\n        buttonsTemplate: this.triggerButtonTemplateRef,\n      });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.dateChange.complete();\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n    this.removePickerEventListeners();\n    this.destroyAffixer();\n    this.destroyOverlay();\n  }\n\n  public onCalendarModeChange(): void {\n    // Let the calendar populate in the DOM before recalculating placement.\n    setTimeout(() => {\n      this.affixer.reaffix();\n    });\n  }\n\n  public onSelectedDateChange(value: Date): void {\n    this.dateChange.emit(value);\n    this.closePicker();\n  }\n\n  public onTriggerButtonClick(): void {\n    if (this.isOpen) {\n      this.closePicker();\n    } else {\n      this.openPicker();\n    }\n  }\n\n  public onCalendarDateRangeChange(event: SkyDatepickerCalendarChange): void {\n    /* istanbul ignore else */\n    if (event) {\n      this.cancelCustomDatesSubscription();\n\n      const args: SkyDatepickerCalendarChange = {\n        startDate: event.startDate,\n        endDate: event.endDate,\n        customDates: undefined,\n      };\n      this.calendarDateRangeChange.emit(args);\n      // If consumer has added an observable to the args, watch for incoming custom dates.\n      /* istanbul ignore else */\n      if (args.customDates) {\n        this.isDaypickerWaiting = true;\n        // Avoid an ExpressionChangedAfterItHasBeenCheckedError.\n        this.changeDetector.detectChanges();\n\n        this.customDatesSubscription = args.customDates\n          .pipe(debounceTime(250))\n          .subscribe((result) => {\n            this.customDates = result;\n            this.isDaypickerWaiting = false;\n\n            // Trigger change detection in child components to show changes in the calendar.\n            this.changeDetector.markForCheck();\n          });\n      } else {\n        // If consumer returns an undefined value after custom dates have\n        // already ben established, remove custom dates.\n        if (this.customDates) {\n          this.customDates = undefined;\n          // Avoid an ExpressionChangedAfterItHasBeenCheckedError.\n          this.changeDetector.detectChanges();\n        }\n      }\n    }\n  }\n\n  private closePicker() {\n    this.destroyAffixer();\n    this.destroyOverlay();\n    this.removePickerEventListeners();\n    this.triggerButtonRef.nativeElement.focus();\n    this.isOpen = false;\n  }\n\n  private openPicker(): void {\n    this.isVisible = false;\n    this.changeDetector.markForCheck();\n\n    this.removePickerEventListeners();\n    this.calendarUnsubscribe = new Subject<void>();\n    this.destroyOverlay();\n    this.createOverlay();\n\n    this.isOpen = true;\n    this.changeDetector.markForCheck();\n  }\n\n  private createAffixer(): void {\n    const affixer = this.affixService.createAffixer(this.calendarRef);\n\n    // Hide calendar when trigger button is scrolled off screen.\n    affixer.placementChange\n      .pipe(takeUntil(this.calendarUnsubscribe))\n      .subscribe((change) => {\n        this.isVisible = change.placement !== null;\n        this.changeDetector.markForCheck();\n      });\n\n    affixer.affixTo(this.triggerButtonRef.nativeElement, {\n      autoFitContext: SkyAffixAutoFitContext.Viewport,\n      enableAutoFit: true,\n      horizontalAlignment: 'right',\n      isSticky: true,\n      placement: 'below',\n    });\n\n    this.affixer = affixer;\n  }\n\n  private destroyAffixer(): void {\n    /*istanbul ignore else*/\n    if (this.affixer) {\n      this.affixer.destroy();\n      this.affixer = undefined;\n    }\n  }\n\n  private createOverlay(): void {\n    const overlay = this.overlayService.create({\n      wrapperClass: this.pickerClass,\n      enableClose: false,\n      enablePointerEvents: false,\n    });\n\n    overlay.backdropClick\n      .pipe(takeUntil(this.calendarUnsubscribe))\n      .subscribe(() => {\n        /* istanbul ignore else */\n        if (this.isOpen) {\n          this.closePicker();\n        }\n      });\n\n    this.addKeydownListner();\n\n    overlay.attachTemplate(this.calendarTemplateRef);\n\n    this.overlay = overlay;\n  }\n\n  private destroyOverlay(): void {\n    /*istanbul ignore else*/\n    if (this.overlay) {\n      this.overlayService.close(this.overlay);\n      this.overlay = undefined;\n    }\n  }\n\n  private addKeydownListner(): void {\n    this.overlayKeydownListner = fromEvent(window.document, 'keydown')\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe((event: KeyboardEvent) => {\n        const key = event.key?.toLowerCase();\n        if (key === 'escape' && this.isOpen) {\n          this.closePicker();\n        }\n      });\n  }\n\n  private removePickerEventListeners(): void {\n    /* istanbul ignore else */\n    if (this.calendarUnsubscribe) {\n      this.calendarUnsubscribe.next();\n      this.calendarUnsubscribe.complete();\n      this.calendarUnsubscribe = undefined;\n    }\n    this.overlayKeydownListner?.unsubscribe();\n  }\n\n  private cancelCustomDatesSubscription(): void {\n    if (this.customDatesSubscription) {\n      this.customDatesSubscription.unsubscribe();\n      this.customDatesSubscription = undefined;\n    }\n  }\n}\n","<div class=\"sky-datepicker\">\n  <ng-container *ngIf=\"!inputBoxHostService\">\n    <div class=\"sky-input-group\">\n      <ng-container *ngTemplateOutlet=\"inputTemplateRef\"></ng-container>\n      <ng-container *ngTemplateOutlet=\"triggerButtonTemplateRef\"></ng-container>\n    </div>\n  </ng-container>\n</div>\n\n<ng-template #inputTemplateRef>\n  <ng-content></ng-content>\n</ng-template>\n\n<ng-template #triggerButtonTemplateRef>\n  <div class=\"sky-input-group-btn\">\n    <button\n      aria-haspopup=\"dialog\"\n      class=\"sky-btn sky-btn-default sky-input-group-datepicker-btn\"\n      type=\"button\"\n      [attr.aria-controls]=\"isOpen ? calendarId : null\"\n      [attr.aria-expanded]=\"isOpen\"\n      [attr.aria-label]=\"\n        'skyux_datepicker_trigger_button_label' | skyLibResources\n      \"\n      [attr.id]=\"triggerButtonId\"\n      [attr.title]=\"'skyux_datepicker_trigger_button_label' | skyLibResources\"\n      [disabled]=\"disabled\"\n      (click)=\"onTriggerButtonClick()\"\n      #triggerButtonRef\n    >\n      <sky-icon *skyThemeIf=\"'default'\" icon=\"calendar\" size=\"lg\"></sky-icon>\n      <sky-icon\n        *skyThemeIf=\"'modern'\"\n        icon=\"calendar\"\n        size=\"lg\"\n        iconType=\"skyux\"\n      ></sky-icon>\n    </button>\n  </div>\n</ng-template>\n\n<ng-template #calendarTemplateRef>\n  <div\n    class=\"sky-datepicker-calendar-container sky-shadow sky-elevation-4\"\n    role=\"dialog\"\n    [attr.aria-labelledby]=\"triggerButtonId\"\n    [attr.id]=\"calendarId\"\n    [class.sky-datepicker-hidden]=\"!isVisible\"\n    #calendarRef\n  >\n    <sky-datepicker-calendar\n      [customDates]=\"customDates\"\n      [isDaypickerWaiting]=\"isDaypickerWaiting\"\n      [maxDate]=\"maxDate\"\n      [minDate]=\"minDate\"\n      [startingDay]=\"startingDay\"\n      (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n      (calendarModeChange)=\"onCalendarModeChange()\"\n      (selectedDateChange)=\"onSelectedDateChange($event)\"\n    >\n    </sky-datepicker-calendar>\n  </div>\n</ng-template>\n"]}
305
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport {\n  SkyAffixAutoFitContext,\n  SkyAffixService,\n  SkyAffixer,\n  SkyCoreAdapterService,\n  SkyOverlayInstance,\n  SkyOverlayService,\n} from '@skyux/core';\nimport { SkyInputBoxHostService } from '@skyux/forms';\nimport { SkyThemeService } from '@skyux/theme';\n\nimport { Subject, Subscription, fromEvent } from 'rxjs';\nimport { debounceTime, takeUntil } from 'rxjs/operators';\n\nimport { SkyDatepickerCalendarChange } from './datepicker-calendar-change';\nimport { SkyDatepickerCalendarComponent } from './datepicker-calendar.component';\nimport { SkyDatepickerCustomDate } from './datepicker-custom-date';\n\nlet nextId = 0;\n\n/**\n * Creates the datepicker button and calendar.\n * You must wrap this component around an input with the `skyDatepickerInput` directive.\n */\n@Component({\n  selector: 'sky-datepicker',\n  templateUrl: './datepicker.component.html',\n  styleUrls: ['./datepicker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyDatepickerComponent implements OnDestroy, OnInit {\n  /**\n   * Adds a class to the datepicker.\n   * @default \"\"\n   */\n  @Input()\n  public pickerClass: string | undefined = '';\n\n  public get disabled(): boolean | undefined {\n    return this.#_disabled;\n  }\n\n  public set disabled(value: boolean | undefined) {\n    this.#_disabled = value;\n    this.#changeDetector.markForCheck();\n  }\n\n  public set selectedDate(value: Date | undefined) {\n    this.#_selectedDate = value;\n    if (this.calendar) {\n      this.calendar.writeValue(value);\n    }\n  }\n\n  public get selectedDate(): Date | undefined {\n    return this.#_selectedDate;\n  }\n\n  /**\n   * Fires when the range of displayed dates in the calendar changes. Provides the\n   * current range of displayed dates and a mutable `customDate` property consumers can use\n   * to modify individual dates on the calendar.\n   */\n  @Output()\n  public calendarDateRangeChange = new EventEmitter<SkyDatepickerCalendarChange>();\n\n  public calendarId: string;\n\n  public customDates: SkyDatepickerCustomDate[] | undefined;\n\n  public dateChange = new EventEmitter<Date>();\n\n  public isDaypickerWaiting = false;\n\n  public isOpen = false;\n\n  public isVisible = false;\n\n  public maxDate: Date | undefined;\n\n  public minDate: Date | undefined;\n\n  public startingDay: number | undefined;\n\n  public triggerButtonId: string;\n\n  @ViewChild(SkyDatepickerCalendarComponent)\n  public calendar: SkyDatepickerCalendarComponent | undefined;\n\n  @ViewChild('calendarRef', {\n    read: ElementRef,\n  })\n  public set calendarRef(value: ElementRef | undefined) {\n    if (value) {\n      this.#_calendarRef = value;\n\n      // Wait for the calendar component to render before gauging dimensions.\n      setTimeout(() => {\n        if (this.calendarRef) {\n          this.calendar?.writeValue(this.selectedDate);\n\n          this.#destroyAffixer();\n          this.#createAffixer();\n\n          setTimeout(() => {\n            if (this.calendarRef) {\n              this.#coreAdapter.getFocusableChildrenAndApplyFocus(\n                this.calendarRef,\n                '.sky-datepicker-calendar-inner',\n                false\n              );\n\n              this.isVisible = true;\n              this.#changeDetector.markForCheck();\n            }\n          });\n        }\n      });\n    }\n  }\n\n  public get calendarRef(): ElementRef | undefined {\n    return this.#_calendarRef;\n  }\n\n  @ViewChild('calendarTemplateRef', {\n    read: TemplateRef,\n  })\n  public calendarTemplateRef: TemplateRef<unknown> | undefined;\n\n  @ViewChild('triggerButtonRef', {\n    read: ElementRef,\n  })\n  public triggerButtonRef: ElementRef | undefined;\n\n  @ViewChild('inputTemplateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  public inputTemplateRef: TemplateRef<unknown> | undefined;\n\n  @ViewChild('triggerButtonTemplateRef', {\n    read: TemplateRef,\n    static: true,\n  })\n  public triggerButtonTemplateRef: TemplateRef<unknown> | undefined;\n\n  #affixer: SkyAffixer | undefined;\n\n  #calendarUnsubscribe: Subject<void> = new Subject<void>();\n\n  #customDatesSubscription: Subscription | undefined;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #overlay: SkyOverlayInstance | undefined;\n\n  #overlayKeydownListner: Subscription | undefined;\n\n  #_calendarRef: ElementRef | undefined;\n\n  #_disabled: boolean | undefined = false;\n\n  #_selectedDate: Date | undefined;\n\n  #affixService: SkyAffixService;\n  #changeDetector: ChangeDetectorRef;\n  #coreAdapter: SkyCoreAdapterService;\n  #overlayService: SkyOverlayService;\n\n  constructor(\n    affixService: SkyAffixService,\n    changeDetector: ChangeDetectorRef,\n    coreAdapter: SkyCoreAdapterService,\n    overlayService: SkyOverlayService,\n    @Optional() public inputBoxHostService?: SkyInputBoxHostService,\n    @Optional() themeSvc?: SkyThemeService\n  ) {\n    this.#affixService = affixService;\n    this.#changeDetector = changeDetector;\n    this.#coreAdapter = coreAdapter;\n    this.#overlayService = overlayService;\n    const uniqueId = nextId++;\n    this.calendarId = `sky-datepicker-calendar-${uniqueId}`;\n    this.triggerButtonId = `sky-datepicker-button-${uniqueId}`;\n\n    // Update icons when theme changes.\n    themeSvc?.settingsChange\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        this.#changeDetector.markForCheck();\n      });\n  }\n\n  public ngOnInit(): void {\n    if (this.inputBoxHostService && this.inputTemplateRef) {\n      this.inputBoxHostService.populate({\n        inputTemplate: this.inputTemplateRef,\n        buttonsTemplate: this.triggerButtonTemplateRef,\n      });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.dateChange.complete();\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n    this.#removePickerEventListeners();\n    this.#destroyAffixer();\n    this.#destroyOverlay();\n  }\n\n  public onCalendarModeChange(): void {\n    // Let the calendar populate in the DOM before recalculating placement.\n    setTimeout(() => {\n      this.#affixer?.reaffix();\n    });\n  }\n\n  public onSelectedDateChange(value: Date): void {\n    this.dateChange.emit(value);\n    this.#closePicker();\n  }\n\n  public onTriggerButtonClick(): void {\n    if (this.isOpen) {\n      this.#closePicker();\n    } else {\n      this.#openPicker();\n    }\n  }\n\n  public onCalendarDateRangeChange(event?: SkyDatepickerCalendarChange): void {\n    /* istanbul ignore else */\n    if (event) {\n      this.#cancelCustomDatesSubscription();\n\n      const args: SkyDatepickerCalendarChange = {\n        startDate: event.startDate,\n        endDate: event.endDate,\n        customDates: undefined,\n      };\n      this.calendarDateRangeChange.emit(args);\n      // If consumer has added an observable to the args, watch for incoming custom dates.\n      /* istanbul ignore else */\n      if (args.customDates) {\n        this.isDaypickerWaiting = true;\n        // Avoid an ExpressionChangedAfterItHasBeenCheckedError.\n        this.#changeDetector.detectChanges();\n\n        this.#customDatesSubscription = args.customDates\n          .pipe(debounceTime(250))\n          .subscribe((result) => {\n            this.customDates = result;\n            this.isDaypickerWaiting = false;\n\n            // Trigger change detection in child components to show changes in the calendar.\n            this.#changeDetector.markForCheck();\n          });\n      } else {\n        // If consumer returns an undefined value after custom dates have\n        // already ben established, remove custom dates.\n        if (this.customDates) {\n          this.customDates = undefined;\n          // Avoid an ExpressionChangedAfterItHasBeenCheckedError.\n          this.#changeDetector.detectChanges();\n        }\n      }\n    }\n  }\n\n  #closePicker() {\n    this.#destroyAffixer();\n    this.#destroyOverlay();\n    this.#removePickerEventListeners();\n    this.triggerButtonRef?.nativeElement.focus();\n    this.isOpen = false;\n  }\n\n  #openPicker(): void {\n    this.isVisible = false;\n    this.#changeDetector.markForCheck();\n\n    this.#removePickerEventListeners();\n    this.#destroyOverlay();\n    this.#createOverlay();\n\n    this.isOpen = true;\n    this.#changeDetector.markForCheck();\n  }\n\n  #createAffixer(): void {\n    if (this.calendarRef && this.triggerButtonRef) {\n      const affixer = this.#affixService.createAffixer(this.calendarRef);\n\n      // Hide calendar when trigger button is scrolled off screen.\n      affixer.placementChange\n        .pipe(takeUntil(this.#calendarUnsubscribe))\n        .subscribe((change) => {\n          this.isVisible = change.placement !== null;\n          this.#changeDetector.markForCheck();\n        });\n\n      affixer.affixTo(this.triggerButtonRef.nativeElement, {\n        autoFitContext: SkyAffixAutoFitContext.Viewport,\n        enableAutoFit: true,\n        horizontalAlignment: 'right',\n        isSticky: true,\n        placement: 'below',\n      });\n\n      this.#affixer = affixer;\n    }\n  }\n\n  #destroyAffixer(): void {\n    /*istanbul ignore else*/\n    if (this.#affixer) {\n      this.#affixer.destroy();\n      this.#affixer = undefined;\n    }\n  }\n\n  #createOverlay(): void {\n    if (this.calendarTemplateRef) {\n      const overlay = this.#overlayService.create({\n        wrapperClass: this.pickerClass,\n        enableClose: false,\n        enablePointerEvents: false,\n      });\n\n      overlay.backdropClick\n        .pipe(takeUntil(this.#calendarUnsubscribe))\n        .subscribe(() => {\n          /* istanbul ignore else */\n          if (this.isOpen) {\n            this.#closePicker();\n          }\n        });\n\n      this.#addKeydownListener();\n\n      overlay.attachTemplate(this.calendarTemplateRef);\n\n      this.#overlay = overlay;\n    }\n  }\n\n  #destroyOverlay(): void {\n    /*istanbul ignore else*/\n    if (this.#overlay) {\n      this.#overlayService.close(this.#overlay);\n      this.#overlay = undefined;\n    }\n  }\n\n  #addKeydownListener(): void {\n    this.#overlayKeydownListner = fromEvent<KeyboardEvent>(\n      window.document,\n      'keydown'\n    )\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((event) => {\n        const key = event.key?.toLowerCase();\n        if (key === 'escape' && this.isOpen) {\n          this.#closePicker();\n        }\n      });\n  }\n\n  #removePickerEventListeners(): void {\n    this.#calendarUnsubscribe.next();\n    this.#calendarUnsubscribe.complete();\n    this.#calendarUnsubscribe = new Subject<void>();\n    this.#overlayKeydownListner?.unsubscribe();\n  }\n\n  #cancelCustomDatesSubscription(): void {\n    if (this.#customDatesSubscription) {\n      this.#customDatesSubscription.unsubscribe();\n      this.#customDatesSubscription = undefined;\n    }\n  }\n}\n","<div class=\"sky-datepicker\">\n  <ng-container *ngIf=\"!inputBoxHostService\">\n    <div class=\"sky-input-group\">\n      <ng-container *ngTemplateOutlet=\"inputTemplateRef\"></ng-container>\n      <ng-container *ngTemplateOutlet=\"triggerButtonTemplateRef\"></ng-container>\n    </div>\n  </ng-container>\n</div>\n\n<ng-template #inputTemplateRef>\n  <ng-content></ng-content>\n</ng-template>\n\n<ng-template #triggerButtonTemplateRef>\n  <div class=\"sky-input-group-btn\">\n    <button\n      aria-haspopup=\"dialog\"\n      class=\"sky-btn sky-btn-default sky-input-group-datepicker-btn\"\n      type=\"button\"\n      [attr.aria-controls]=\"isOpen ? calendarId : null\"\n      [attr.aria-expanded]=\"isOpen\"\n      [attr.aria-label]=\"\n        'skyux_datepicker_trigger_button_label' | skyLibResources\n      \"\n      [attr.id]=\"triggerButtonId\"\n      [attr.title]=\"'skyux_datepicker_trigger_button_label' | skyLibResources\"\n      [disabled]=\"disabled\"\n      (click)=\"onTriggerButtonClick()\"\n      #triggerButtonRef\n    >\n      <sky-icon *skyThemeIf=\"'default'\" icon=\"calendar\" size=\"lg\"></sky-icon>\n      <sky-icon\n        *skyThemeIf=\"'modern'\"\n        icon=\"calendar\"\n        size=\"lg\"\n        iconType=\"skyux\"\n      ></sky-icon>\n    </button>\n  </div>\n</ng-template>\n\n<ng-template #calendarTemplateRef>\n  <div\n    class=\"sky-datepicker-calendar-container sky-shadow sky-elevation-4\"\n    role=\"dialog\"\n    [attr.aria-labelledby]=\"triggerButtonId\"\n    [attr.id]=\"calendarId\"\n    [class.sky-datepicker-hidden]=\"!isVisible\"\n    #calendarRef\n  >\n    <sky-datepicker-calendar\n      [customDates]=\"customDates\"\n      [isDaypickerWaiting]=\"isDaypickerWaiting\"\n      [maxDate]=\"maxDate\"\n      [minDate]=\"minDate\"\n      [startingDay]=\"startingDay\"\n      (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n      (calendarModeChange)=\"onCalendarModeChange()\"\n      (selectedDateChange)=\"onSelectedDateChange($event)\"\n    >\n    </sky-datepicker-calendar>\n  </div>\n</ng-template>\n"]}
@@ -21,8 +21,8 @@ import { SkyYearPickerComponent } from './yearpicker.component';
21
21
  import * as i0 from "@angular/core";
22
22
  export class SkyDatepickerModule {
23
23
  }
24
- SkyDatepickerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDatepickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
25
- SkyDatepickerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.0", ngImport: i0, type: SkyDatepickerModule, declarations: [SkyDatepickerCalendarComponent,
24
+ SkyDatepickerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDatepickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
25
+ SkyDatepickerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.11", ngImport: i0, type: SkyDatepickerModule, declarations: [SkyDatepickerCalendarComponent,
26
26
  SkyDatepickerCalendarInnerComponent,
27
27
  SkyDayPickerComponent,
28
28
  SkyMonthPickerComponent,
@@ -44,7 +44,7 @@ SkyDatepickerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", ver
44
44
  SkyDatepickerComponent,
45
45
  SkyDatepickerInputDirective,
46
46
  SkyFuzzyDatepickerInputDirective] });
47
- SkyDatepickerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDatepickerModule, providers: [SkyDatepickerService], imports: [CommonModule,
47
+ SkyDatepickerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDatepickerModule, providers: [SkyDatepickerService], imports: [CommonModule,
48
48
  SkyI18nModule,
49
49
  FormsModule,
50
50
  SkyIconModule,
@@ -54,7 +54,7 @@ SkyDatepickerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", ver
54
54
  SkyThemeModule,
55
55
  SkyPopoverModule,
56
56
  SkyWaitModule] });
57
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDatepickerModule, decorators: [{
57
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.11", ngImport: i0, type: SkyDatepickerModule, decorators: [{
58
58
  type: NgModule,
59
59
  args: [{
60
60
  declarations: [
@@ -90,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
90
90
  providers: [SkyDatepickerService],
91
91
  }]
92
92
  }] });
93
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZGF0ZXRpbWUvc3JjL2xpYi9tb2R1bGVzL2RhdGVwaWNrZXIvZGF0ZXBpY2tlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxjQUFjLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDL0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUM1QyxPQUFPLEVBQUUsYUFBYSxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFOUMsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFFckYsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDNUYsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDakYsT0FBTyxFQUFFLGdDQUFnQyxFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDdEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDM0UsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDaEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDNUQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDM0UsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDdkUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDOUQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDbEUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7O0FBbUNoRSxNQUFNLE9BQU8sbUJBQW1COztnSEFBbkIsbUJBQW1CO2lIQUFuQixtQkFBbUIsaUJBL0I1Qiw4QkFBOEI7UUFDOUIsbUNBQW1DO1FBQ25DLHFCQUFxQjtRQUNyQix1QkFBdUI7UUFDdkIsc0JBQXNCO1FBQ3RCLHNCQUFzQjtRQUN0QiwyQkFBMkI7UUFDM0IsZ0NBQWdDO1FBQ2hDLHlCQUF5QjtRQUN6QiwyQkFBMkIsYUFHM0IsWUFBWTtRQUNaLGFBQWE7UUFDYixXQUFXO1FBQ1gsYUFBYTtRQUNiLDBCQUEwQjtRQUMxQixjQUFjO1FBQ2QsZ0JBQWdCO1FBQ2hCLGNBQWM7UUFDZCxnQkFBZ0I7UUFDaEIsYUFBYSxhQUdiLDhCQUE4QjtRQUM5QixzQkFBc0I7UUFDdEIsMkJBQTJCO1FBQzNCLGdDQUFnQztpSEFJdkIsbUJBQW1CLGFBRm5CLENBQUMsb0JBQW9CLENBQUMsWUFqQi9CLFlBQVk7UUFDWixhQUFhO1FBQ2IsV0FBVztRQUNYLGFBQWE7UUFDYiwwQkFBMEI7UUFDMUIsY0FBYztRQUNkLGdCQUFnQjtRQUNoQixjQUFjO1FBQ2QsZ0JBQWdCO1FBQ2hCLGFBQWE7MkZBVUosbUJBQW1CO2tCQWpDL0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osOEJBQThCO3dCQUM5QixtQ0FBbUM7d0JBQ25DLHFCQUFxQjt3QkFDckIsdUJBQXVCO3dCQUN2QixzQkFBc0I7d0JBQ3RCLHNCQUFzQjt3QkFDdEIsMkJBQTJCO3dCQUMzQixnQ0FBZ0M7d0JBQ2hDLHlCQUF5Qjt3QkFDekIsMkJBQTJCO3FCQUM1QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixhQUFhO3dCQUNiLFdBQVc7d0JBQ1gsYUFBYTt3QkFDYiwwQkFBMEI7d0JBQzFCLGNBQWM7d0JBQ2QsZ0JBQWdCO3dCQUNoQixjQUFjO3dCQUNkLGdCQUFnQjt3QkFDaEIsYUFBYTtxQkFDZDtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsOEJBQThCO3dCQUM5QixzQkFBc0I7d0JBQ3RCLDJCQUEyQjt3QkFDM0IsZ0NBQWdDO3FCQUNqQztvQkFDRCxTQUFTLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztpQkFDbEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgU2t5QWZmaXhNb2R1bGUsIFNreU92ZXJsYXlNb2R1bGUgfSBmcm9tICdAc2t5dXgvY29yZSc7XG5pbXBvcnQgeyBTa3lJMThuTW9kdWxlIH0gZnJvbSAnQHNreXV4L2kxOG4nO1xuaW1wb3J0IHsgU2t5SWNvbk1vZHVsZSwgU2t5V2FpdE1vZHVsZSB9IGZyb20gJ0Bza3l1eC9pbmRpY2F0b3JzJztcbmltcG9ydCB7IFNreVBvcG92ZXJNb2R1bGUgfSBmcm9tICdAc2t5dXgvcG9wb3ZlcnMnO1xuaW1wb3J0IHsgU2t5VGhlbWVNb2R1bGUgfSBmcm9tICdAc2t5dXgvdGhlbWUnO1xuXG5pbXBvcnQgeyBTa3lEYXRldGltZVJlc291cmNlc01vZHVsZSB9IGZyb20gJy4uL3NoYXJlZC9za3ktZGF0ZXRpbWUtcmVzb3VyY2VzLm1vZHVsZSc7XG5cbmltcG9ydCB7IFNreURhdGVwaWNrZXJDYWxlbmRhcklubmVyQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRlcGlja2VyLWNhbGVuZGFyLWlubmVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTa3lEYXRlcGlja2VyQ2FsZW5kYXJDb21wb25lbnQgfSBmcm9tICcuL2RhdGVwaWNrZXItY2FsZW5kYXIuY29tcG9uZW50JztcbmltcG9ydCB7IFNreUZ1enp5RGF0ZXBpY2tlcklucHV0RGlyZWN0aXZlIH0gZnJvbSAnLi9kYXRlcGlja2VyLWlucHV0LWZ1enp5LmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBTa3lEYXRlcGlja2VySW5wdXREaXJlY3RpdmUgfSBmcm9tICcuL2RhdGVwaWNrZXItaW5wdXQuZGlyZWN0aXZlJztcbmltcG9ydCB7IFNreURhdGVwaWNrZXJDb21wb25lbnQgfSBmcm9tICcuL2RhdGVwaWNrZXIuY29tcG9uZW50JztcbmltcG9ydCB7IFNreURhdGVwaWNrZXJTZXJ2aWNlIH0gZnJvbSAnLi9kYXRlcGlja2VyLnNlcnZpY2UnO1xuaW1wb3J0IHsgU2t5RGF5UGlja2VyQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi9kYXlwaWNrZXItYnV0dG9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTa3lEYXlQaWNrZXJDZWxsQ29tcG9uZW50IH0gZnJvbSAnLi9kYXlwaWNrZXItY2VsbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2t5RGF5UGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi9kYXlwaWNrZXIuY29tcG9uZW50JztcbmltcG9ydCB7IFNreU1vbnRoUGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi9tb250aHBpY2tlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2t5WWVhclBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4veWVhcnBpY2tlci5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBTa3lEYXRlcGlja2VyQ2FsZW5kYXJDb21wb25lbnQsXG4gICAgU2t5RGF0ZXBpY2tlckNhbGVuZGFySW5uZXJDb21wb25lbnQsXG4gICAgU2t5RGF5UGlja2VyQ29tcG9uZW50LFxuICAgIFNreU1vbnRoUGlja2VyQ29tcG9uZW50LFxuICAgIFNreVllYXJQaWNrZXJDb21wb25lbnQsXG4gICAgU2t5RGF0ZXBpY2tlckNvbXBvbmVudCxcbiAgICBTa3lEYXRlcGlja2VySW5wdXREaXJlY3RpdmUsXG4gICAgU2t5RnV6enlEYXRlcGlja2VySW5wdXREaXJlY3RpdmUsXG4gICAgU2t5RGF5UGlja2VyQ2VsbENvbXBvbmVudCxcbiAgICBTa3lEYXlQaWNrZXJCdXR0b25Db21wb25lbnQsXG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgU2t5STE4bk1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBTa3lJY29uTW9kdWxlLFxuICAgIFNreURhdGV0aW1lUmVzb3VyY2VzTW9kdWxlLFxuICAgIFNreUFmZml4TW9kdWxlLFxuICAgIFNreU92ZXJsYXlNb2R1bGUsXG4gICAgU2t5VGhlbWVNb2R1bGUsXG4gICAgU2t5UG9wb3Zlck1vZHVsZSxcbiAgICBTa3lXYWl0TW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgU2t5RGF0ZXBpY2tlckNhbGVuZGFyQ29tcG9uZW50LFxuICAgIFNreURhdGVwaWNrZXJDb21wb25lbnQsXG4gICAgU2t5RGF0ZXBpY2tlcklucHV0RGlyZWN0aXZlLFxuICAgIFNreUZ1enp5RGF0ZXBpY2tlcklucHV0RGlyZWN0aXZlLFxuICBdLFxuICBwcm92aWRlcnM6IFtTa3lEYXRlcGlja2VyU2VydmljZV0sXG59KVxuZXhwb3J0IGNsYXNzIFNreURhdGVwaWNrZXJNb2R1bGUge31cbiJdfQ==
93
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZGF0ZXRpbWUvc3JjL2xpYi9tb2R1bGVzL2RhdGVwaWNrZXIvZGF0ZXBpY2tlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxjQUFjLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDL0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUM1QyxPQUFPLEVBQUUsYUFBYSxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFFOUMsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFFckYsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDNUYsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDakYsT0FBTyxFQUFFLGdDQUFnQyxFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDdEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDM0UsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDaEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDNUQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDM0UsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDdkUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDOUQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDbEUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7O0FBbUNoRSxNQUFNLE9BQU8sbUJBQW1COztpSEFBbkIsbUJBQW1CO2tIQUFuQixtQkFBbUIsaUJBL0I1Qiw4QkFBOEI7UUFDOUIsbUNBQW1DO1FBQ25DLHFCQUFxQjtRQUNyQix1QkFBdUI7UUFDdkIsc0JBQXNCO1FBQ3RCLHNCQUFzQjtRQUN0QiwyQkFBMkI7UUFDM0IsZ0NBQWdDO1FBQ2hDLHlCQUF5QjtRQUN6QiwyQkFBMkIsYUFHM0IsWUFBWTtRQUNaLGFBQWE7UUFDYixXQUFXO1FBQ1gsYUFBYTtRQUNiLDBCQUEwQjtRQUMxQixjQUFjO1FBQ2QsZ0JBQWdCO1FBQ2hCLGNBQWM7UUFDZCxnQkFBZ0I7UUFDaEIsYUFBYSxhQUdiLDhCQUE4QjtRQUM5QixzQkFBc0I7UUFDdEIsMkJBQTJCO1FBQzNCLGdDQUFnQztrSEFJdkIsbUJBQW1CLGFBRm5CLENBQUMsb0JBQW9CLENBQUMsWUFqQi9CLFlBQVk7UUFDWixhQUFhO1FBQ2IsV0FBVztRQUNYLGFBQWE7UUFDYiwwQkFBMEI7UUFDMUIsY0FBYztRQUNkLGdCQUFnQjtRQUNoQixjQUFjO1FBQ2QsZ0JBQWdCO1FBQ2hCLGFBQWE7NEZBVUosbUJBQW1CO2tCQWpDL0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osOEJBQThCO3dCQUM5QixtQ0FBbUM7d0JBQ25DLHFCQUFxQjt3QkFDckIsdUJBQXVCO3dCQUN2QixzQkFBc0I7d0JBQ3RCLHNCQUFzQjt3QkFDdEIsMkJBQTJCO3dCQUMzQixnQ0FBZ0M7d0JBQ2hDLHlCQUF5Qjt3QkFDekIsMkJBQTJCO3FCQUM1QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixhQUFhO3dCQUNiLFdBQVc7d0JBQ1gsYUFBYTt3QkFDYiwwQkFBMEI7d0JBQzFCLGNBQWM7d0JBQ2QsZ0JBQWdCO3dCQUNoQixjQUFjO3dCQUNkLGdCQUFnQjt3QkFDaEIsYUFBYTtxQkFDZDtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsOEJBQThCO3dCQUM5QixzQkFBc0I7d0JBQ3RCLDJCQUEyQjt3QkFDM0IsZ0NBQWdDO3FCQUNqQztvQkFDRCxTQUFTLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztpQkFDbEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgU2t5QWZmaXhNb2R1bGUsIFNreU92ZXJsYXlNb2R1bGUgfSBmcm9tICdAc2t5dXgvY29yZSc7XG5pbXBvcnQgeyBTa3lJMThuTW9kdWxlIH0gZnJvbSAnQHNreXV4L2kxOG4nO1xuaW1wb3J0IHsgU2t5SWNvbk1vZHVsZSwgU2t5V2FpdE1vZHVsZSB9IGZyb20gJ0Bza3l1eC9pbmRpY2F0b3JzJztcbmltcG9ydCB7IFNreVBvcG92ZXJNb2R1bGUgfSBmcm9tICdAc2t5dXgvcG9wb3ZlcnMnO1xuaW1wb3J0IHsgU2t5VGhlbWVNb2R1bGUgfSBmcm9tICdAc2t5dXgvdGhlbWUnO1xuXG5pbXBvcnQgeyBTa3lEYXRldGltZVJlc291cmNlc01vZHVsZSB9IGZyb20gJy4uL3NoYXJlZC9za3ktZGF0ZXRpbWUtcmVzb3VyY2VzLm1vZHVsZSc7XG5cbmltcG9ydCB7IFNreURhdGVwaWNrZXJDYWxlbmRhcklubmVyQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRlcGlja2VyLWNhbGVuZGFyLWlubmVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTa3lEYXRlcGlja2VyQ2FsZW5kYXJDb21wb25lbnQgfSBmcm9tICcuL2RhdGVwaWNrZXItY2FsZW5kYXIuY29tcG9uZW50JztcbmltcG9ydCB7IFNreUZ1enp5RGF0ZXBpY2tlcklucHV0RGlyZWN0aXZlIH0gZnJvbSAnLi9kYXRlcGlja2VyLWlucHV0LWZ1enp5LmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBTa3lEYXRlcGlja2VySW5wdXREaXJlY3RpdmUgfSBmcm9tICcuL2RhdGVwaWNrZXItaW5wdXQuZGlyZWN0aXZlJztcbmltcG9ydCB7IFNreURhdGVwaWNrZXJDb21wb25lbnQgfSBmcm9tICcuL2RhdGVwaWNrZXIuY29tcG9uZW50JztcbmltcG9ydCB7IFNreURhdGVwaWNrZXJTZXJ2aWNlIH0gZnJvbSAnLi9kYXRlcGlja2VyLnNlcnZpY2UnO1xuaW1wb3J0IHsgU2t5RGF5UGlja2VyQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi9kYXlwaWNrZXItYnV0dG9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTa3lEYXlQaWNrZXJDZWxsQ29tcG9uZW50IH0gZnJvbSAnLi9kYXlwaWNrZXItY2VsbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2t5RGF5UGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi9kYXlwaWNrZXIuY29tcG9uZW50JztcbmltcG9ydCB7IFNreU1vbnRoUGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi9tb250aHBpY2tlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2t5WWVhclBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4veWVhcnBpY2tlci5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBTa3lEYXRlcGlja2VyQ2FsZW5kYXJDb21wb25lbnQsXG4gICAgU2t5RGF0ZXBpY2tlckNhbGVuZGFySW5uZXJDb21wb25lbnQsXG4gICAgU2t5RGF5UGlja2VyQ29tcG9uZW50LFxuICAgIFNreU1vbnRoUGlja2VyQ29tcG9uZW50LFxuICAgIFNreVllYXJQaWNrZXJDb21wb25lbnQsXG4gICAgU2t5RGF0ZXBpY2tlckNvbXBvbmVudCxcbiAgICBTa3lEYXRlcGlja2VySW5wdXREaXJlY3RpdmUsXG4gICAgU2t5RnV6enlEYXRlcGlja2VySW5wdXREaXJlY3RpdmUsXG4gICAgU2t5RGF5UGlja2VyQ2VsbENvbXBvbmVudCxcbiAgICBTa3lEYXlQaWNrZXJCdXR0b25Db21wb25lbnQsXG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgU2t5STE4bk1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBTa3lJY29uTW9kdWxlLFxuICAgIFNreURhdGV0aW1lUmVzb3VyY2VzTW9kdWxlLFxuICAgIFNreUFmZml4TW9kdWxlLFxuICAgIFNreU92ZXJsYXlNb2R1bGUsXG4gICAgU2t5VGhlbWVNb2R1bGUsXG4gICAgU2t5UG9wb3Zlck1vZHVsZSxcbiAgICBTa3lXYWl0TW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgU2t5RGF0ZXBpY2tlckNhbGVuZGFyQ29tcG9uZW50LFxuICAgIFNreURhdGVwaWNrZXJDb21wb25lbnQsXG4gICAgU2t5RGF0ZXBpY2tlcklucHV0RGlyZWN0aXZlLFxuICAgIFNreUZ1enp5RGF0ZXBpY2tlcklucHV0RGlyZWN0aXZlLFxuICBdLFxuICBwcm92aWRlcnM6IFtTa3lEYXRlcGlja2VyU2VydmljZV0sXG59KVxuZXhwb3J0IGNsYXNzIFNreURhdGVwaWNrZXJNb2R1bGUge31cbiJdfQ==