@skyux/datetime 8.7.0 → 9.0.0-alpha.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 (95) hide show
  1. package/esm2022/lib/modules/date-pipe/date-format-utility.mjs +45 -0
  2. package/{esm2020 → esm2022}/lib/modules/date-pipe/date-pipe.module.mjs +5 -5
  3. package/esm2022/lib/modules/date-pipe/date.pipe.mjs +67 -0
  4. package/esm2022/lib/modules/date-pipe/fuzzy-date.pipe.mjs +47 -0
  5. package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +4 -4
  6. package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +4 -4
  7. package/esm2022/lib/modules/date-range-picker/date-range-picker.component.mjs +518 -0
  8. package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker.module.mjs +19 -19
  9. package/esm2022/lib/modules/date-range-picker/date-range.service.mjs +97 -0
  10. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator.mjs +54 -0
  11. package/esm2022/lib/modules/datepicker/date-formatter.mjs +38 -0
  12. package/esm2022/lib/modules/datepicker/datepicker-adapter.service.mjs +23 -0
  13. package/esm2022/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +332 -0
  14. package/esm2022/lib/modules/datepicker/datepicker-calendar.component.mjs +95 -0
  15. package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-config.service.mjs +4 -4
  16. package/esm2022/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +487 -0
  17. package/esm2022/lib/modules/datepicker/datepicker-input.directive.mjs +534 -0
  18. package/esm2022/lib/modules/datepicker/datepicker.component.mjs +327 -0
  19. package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker.module.mjs +35 -35
  20. package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker.service.mjs +4 -4
  21. package/{esm2020 → esm2022}/lib/modules/datepicker/daypicker-button.component.mjs +4 -4
  22. package/esm2022/lib/modules/datepicker/daypicker-cell.component.mjs +128 -0
  23. package/esm2022/lib/modules/datepicker/daypicker.component.mjs +224 -0
  24. package/esm2022/lib/modules/datepicker/fuzzy-date.service.mjs +412 -0
  25. package/esm2022/lib/modules/datepicker/monthpicker.component.mjs +80 -0
  26. package/{esm2020 → esm2022}/lib/modules/datepicker/yearpicker.component.mjs +53 -54
  27. package/{esm2020 → esm2022}/lib/modules/shared/sky-datetime-resources.module.mjs +11 -11
  28. package/esm2022/lib/modules/timepicker/timepicker.component.mjs +396 -0
  29. package/esm2022/lib/modules/timepicker/timepicker.directive.mjs +237 -0
  30. package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker.module.mjs +17 -17
  31. package/esm2022/testing/datepicker-fixture.mjs +55 -0
  32. package/esm2022/testing/timepicker-fixture.mjs +52 -0
  33. package/fesm2022/skyux-datetime-testing.mjs +112 -0
  34. package/{fesm2020 → fesm2022}/skyux-datetime-testing.mjs.map +1 -1
  35. package/fesm2022/skyux-datetime.mjs +5030 -0
  36. package/fesm2022/skyux-datetime.mjs.map +1 -0
  37. package/lib/modules/date-range-picker/date-range-picker.component.d.ts +1 -1
  38. package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +1 -1
  39. package/lib/modules/datepicker/datepicker-calendar.component.d.ts +1 -1
  40. package/lib/modules/datepicker/datepicker-input-fuzzy.directive.d.ts +1 -1
  41. package/lib/modules/datepicker/datepicker-input.directive.d.ts +1 -1
  42. package/lib/modules/datepicker/datepicker.component.d.ts +1 -1
  43. package/lib/modules/datepicker/daypicker-button.component.d.ts +1 -1
  44. package/lib/modules/datepicker/daypicker-cell.component.d.ts +1 -1
  45. package/lib/modules/datepicker/daypicker.component.d.ts +1 -1
  46. package/lib/modules/timepicker/timepicker.directive.d.ts +1 -1
  47. package/package.json +19 -27
  48. package/esm2020/lib/modules/date-pipe/date-format-utility.mjs +0 -45
  49. package/esm2020/lib/modules/date-pipe/date.pipe.mjs +0 -70
  50. package/esm2020/lib/modules/date-pipe/fuzzy-date.pipe.mjs +0 -50
  51. package/esm2020/lib/modules/date-range-picker/date-range-picker.component.mjs +0 -494
  52. package/esm2020/lib/modules/date-range-picker/date-range.service.mjs +0 -100
  53. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator.mjs +0 -53
  54. package/esm2020/lib/modules/datepicker/date-formatter.mjs +0 -38
  55. package/esm2020/lib/modules/datepicker/datepicker-adapter.service.mjs +0 -26
  56. package/esm2020/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +0 -333
  57. package/esm2020/lib/modules/datepicker/datepicker-calendar.component.mjs +0 -96
  58. package/esm2020/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +0 -462
  59. package/esm2020/lib/modules/datepicker/datepicker-input.directive.mjs +0 -496
  60. package/esm2020/lib/modules/datepicker/datepicker.component.mjs +0 -319
  61. package/esm2020/lib/modules/datepicker/daypicker-cell.component.mjs +0 -126
  62. package/esm2020/lib/modules/datepicker/daypicker.component.mjs +0 -216
  63. package/esm2020/lib/modules/datepicker/fuzzy-date.service.mjs +0 -392
  64. package/esm2020/lib/modules/datepicker/monthpicker.component.mjs +0 -81
  65. package/esm2020/lib/modules/timepicker/timepicker.component.mjs +0 -389
  66. package/esm2020/lib/modules/timepicker/timepicker.directive.mjs +0 -236
  67. package/esm2020/testing/datepicker-fixture.mjs +0 -58
  68. package/esm2020/testing/timepicker-fixture.mjs +0 -55
  69. package/fesm2015/skyux-datetime-testing.mjs +0 -117
  70. package/fesm2015/skyux-datetime-testing.mjs.map +0 -1
  71. package/fesm2015/skyux-datetime.mjs +0 -4925
  72. package/fesm2015/skyux-datetime.mjs.map +0 -1
  73. package/fesm2020/skyux-datetime-testing.mjs +0 -117
  74. package/fesm2020/skyux-datetime.mjs +0 -4895
  75. package/fesm2020/skyux-datetime.mjs.map +0 -1
  76. /package/{esm2020 → esm2022}/index.mjs +0 -0
  77. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculation.mjs +0 -0
  78. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-config.mjs +0 -0
  79. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +0 -0
  80. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-id.mjs +0 -0
  81. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-type.mjs +0 -0
  82. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +0 -0
  83. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-default-calculator-config.mjs +0 -0
  84. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +0 -0
  85. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-relative-value.mjs +0 -0
  86. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range.mjs +0 -0
  87. /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-calendar-change.mjs +0 -0
  88. /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-custom-date.mjs +0 -0
  89. /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-date.mjs +0 -0
  90. /package/{esm2020 → esm2022}/lib/modules/datepicker/fuzzy-date.mjs +0 -0
  91. /package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker-time-format-type.mjs +0 -0
  92. /package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker-time-output.mjs +0 -0
  93. /package/{esm2020 → esm2022}/skyux-datetime.mjs +0 -0
  94. /package/{esm2020 → esm2022}/testing/public-api.mjs +0 -0
  95. /package/{esm2020 → esm2022}/testing/skyux-datetime-testing.mjs +0 -0
@@ -0,0 +1,487 @@
1
+ import { Directive, HostListener, Input, Optional, forwardRef, } from '@angular/core';
2
+ import { NG_VALIDATORS, NG_VALUE_ACCESSOR, } from '@angular/forms';
3
+ import { Subject } from 'rxjs';
4
+ import { distinctUntilChanged, takeUntil } from 'rxjs/operators';
5
+ import { SkyDateFormatter } from './date-formatter';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "./datepicker-config.service";
8
+ import * as i2 from "./fuzzy-date.service";
9
+ import * as i3 from "@skyux/i18n";
10
+ import * as i4 from "./datepicker.component";
11
+ const SKY_FUZZY_DATEPICKER_VALUE_ACCESSOR = {
12
+ provide: NG_VALUE_ACCESSOR,
13
+ useExisting: forwardRef(() => SkyFuzzyDatepickerInputDirective),
14
+ multi: true,
15
+ };
16
+ const SKY_FUZZY_DATEPICKER_VALIDATOR = {
17
+ provide: NG_VALIDATORS,
18
+ useExisting: forwardRef(() => SkyFuzzyDatepickerInputDirective),
19
+ multi: true,
20
+ };
21
+ export class SkyFuzzyDatepickerInputDirective {
22
+ /**
23
+ * The date format for the input. Place this attribute on the `input` element
24
+ * to override the default in `SkyDatepickerConfigService`.
25
+ * @default "MM/DD/YYYY"
26
+ */
27
+ set dateFormat(value) {
28
+ this.#_dateFormat = value;
29
+ if (this.#value) {
30
+ const formattedDate = this.#fuzzyDateService.format(this.#value, this.dateFormat, this.#locale);
31
+ this.#setInputElementValue(formattedDate);
32
+ this.#changeDetector.markForCheck();
33
+ }
34
+ }
35
+ // TODO: Refactor to not have getter logic
36
+ get dateFormat() {
37
+ return (this.#_dateFormat ||
38
+ this.#configService.dateFormat ||
39
+ this.#preferredShortDateFormat);
40
+ }
41
+ /**
42
+ * Whether to disable the datepicker on template-driven forms. Don't use this input on reactive forms because they may overwrite the input or leave the control out of sync.
43
+ * To set the disabled state on reactive forms, use the `FormControl` instead.
44
+ * @default false
45
+ */
46
+ set disabled(value) {
47
+ this.#_disabled = value;
48
+ this.#datepickerComponent.disabled = value;
49
+ this.#renderer.setProperty(this.#elementRef.nativeElement, 'disabled', value);
50
+ }
51
+ get disabled() {
52
+ return this.#_disabled;
53
+ }
54
+ /**
55
+ * Whether to prevent users from specifying dates that are in the future.
56
+ * Place this attribute on the `input` element.
57
+ * @default false
58
+ */
59
+ set futureDisabled(value) {
60
+ this.#_futureDisabled = value;
61
+ this.#onValidatorChange();
62
+ }
63
+ get futureDisabled() {
64
+ return this.#_futureDisabled;
65
+ }
66
+ /**
67
+ * The latest fuzzy date allowed. Place this attribute on the `input` element
68
+ * to prevent fuzzy dates after a specified date. This property accepts
69
+ * a `SkyFuzzyDate` value that includes numeric month, day, and year values.
70
+ * For example: `{ month: 1, day: 1, year: 2027 }`.
71
+ */
72
+ set maxDate(value) {
73
+ this.#_maxDate = value;
74
+ this.#datepickerComponent.maxDate = this.#getMaxDate();
75
+ this.#onValidatorChange();
76
+ }
77
+ get maxDate() {
78
+ return this.#_maxDate;
79
+ }
80
+ /**
81
+ * The earliest fuzzy date allowed. Place this attribute on the `input` element
82
+ * to prevent fuzzy dates before a specified date. This property accepts a `SkyFuzzyDate` value
83
+ * that includes numeric month, day, and year values.
84
+ * For example: `{ month: 1, day: 1, year: 2007 }`.
85
+ */
86
+ set minDate(value) {
87
+ this.#_minDate = value;
88
+ this.#datepickerComponent.minDate = this.#getMinDate();
89
+ this.#onValidatorChange();
90
+ }
91
+ get minDate() {
92
+ return this.#_minDate;
93
+ }
94
+ /**
95
+ * The starting day of the week in the calendar, where `0` sets the starting day
96
+ * to Sunday. Place this attribute on the `input` element to override the default
97
+ * in `SkyDatepickerConfigService`.
98
+ * @default 0
99
+ */
100
+ set startingDay(value) {
101
+ this.#_startingDay = value;
102
+ this.#datepickerComponent.startingDay = this.startingDay;
103
+ this.#onValidatorChange();
104
+ }
105
+ // TODO: Refactor to not have getter logic
106
+ get startingDay() {
107
+ return this.#_startingDay || this.#configService.startingDay;
108
+ }
109
+ /**
110
+ * Whether to require the year in fuzzy dates.
111
+ * @default false
112
+ */
113
+ set yearRequired(value) {
114
+ this.#_yearRequired = value;
115
+ this.#onValidatorChange();
116
+ }
117
+ get yearRequired() {
118
+ return this.#_yearRequired;
119
+ }
120
+ get #value() {
121
+ return this.#_value;
122
+ }
123
+ set #value(value) {
124
+ this.#updateValue(value);
125
+ }
126
+ #control;
127
+ #dateFormatter;
128
+ #locale;
129
+ #preferredShortDateFormat;
130
+ #ngUnsubscribe;
131
+ #_futureDisabled;
132
+ #_dateFormat;
133
+ #_disabled;
134
+ #_maxDate;
135
+ #_minDate;
136
+ #_startingDay;
137
+ #_value;
138
+ #_yearRequired;
139
+ #changeDetector;
140
+ #configService;
141
+ #elementRef;
142
+ #fuzzyDateService;
143
+ #renderer;
144
+ #resourcesService;
145
+ #datepickerComponent;
146
+ constructor(changeDetector, configService, elementRef, fuzzyDateService, localeProvider, renderer, resourcesService, datepickerComponent) {
147
+ /**
148
+ * Whether to disable date validation on the fuzzy datepicker input.
149
+ * @default false
150
+ */
151
+ this.skyDatepickerNoValidate = false;
152
+ this.#dateFormatter = new SkyDateFormatter();
153
+ this.#ngUnsubscribe = new Subject();
154
+ this.#_futureDisabled = false;
155
+ this.#_disabled = false;
156
+ this.#_yearRequired = false;
157
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
158
+ // istanbul ignore next
159
+ this.#onChange = (_) => { };
160
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
161
+ // istanbul ignore next
162
+ this.#onTouched = () => { };
163
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
164
+ // istanbul ignore next
165
+ this.#onValidatorChange = () => { };
166
+ if (!datepickerComponent) {
167
+ throw new Error('You must wrap the `skyFuzzyDatepickerInput` directive within a ' +
168
+ '`<sky-datepicker>` component!');
169
+ }
170
+ this.#changeDetector = changeDetector;
171
+ this.#configService = configService;
172
+ this.#elementRef = elementRef;
173
+ this.#fuzzyDateService = fuzzyDateService;
174
+ this.#renderer = renderer;
175
+ this.#resourcesService = resourcesService;
176
+ this.#datepickerComponent = datepickerComponent;
177
+ this.#locale = localeProvider.defaultLocale;
178
+ localeProvider
179
+ .getLocaleInfo()
180
+ .pipe(takeUntil(this.#ngUnsubscribe))
181
+ .subscribe((localeInfo) => {
182
+ this.#locale = localeInfo.locale;
183
+ SkyDateFormatter.setLocale(this.#locale);
184
+ this.#preferredShortDateFormat =
185
+ SkyDateFormatter.getPreferredShortDateFormat();
186
+ });
187
+ }
188
+ ngOnInit() {
189
+ if (this.yearRequired) {
190
+ if (this.dateFormat?.toLowerCase().indexOf('y') === -1) {
191
+ throw new Error('You have configured conflicting settings. Year is required and dateFormat does not include year.');
192
+ }
193
+ }
194
+ const element = this.#elementRef.nativeElement;
195
+ this.#renderer.addClass(element, 'sky-form-control');
196
+ const hasAriaLabel = element.getAttribute('aria-label');
197
+ /* istanbul ignore else */
198
+ if (!hasAriaLabel) {
199
+ this.#resourcesService
200
+ .getString('skyux_date_field_default_label')
201
+ .pipe(takeUntil(this.#ngUnsubscribe))
202
+ .subscribe((value) => {
203
+ this.#renderer.setAttribute(element, 'aria-label', value);
204
+ });
205
+ }
206
+ }
207
+ ngAfterContentInit() {
208
+ this.#datepickerComponent.dateChange
209
+ .pipe(distinctUntilChanged(), takeUntil(this.#ngUnsubscribe))
210
+ .subscribe((value) => {
211
+ this.#value = value;
212
+ this.#onTouched();
213
+ });
214
+ }
215
+ ngAfterViewInit() {
216
+ // This is needed to address a bug in Angular 4.
217
+ // When a control value is set initially, its value is not represented on the view.
218
+ // See: https://github.com/angular/angular/issues/13792
219
+ // Of note is the parent check which allows us to determine if the form is reactive.
220
+ // Without this check there is a changed before checked error
221
+ /* istanbul ignore else */
222
+ if (this.#control && this.#control.parent) {
223
+ setTimeout(() => {
224
+ this.#control?.setValue(this.#value, {
225
+ emitEvent: false,
226
+ });
227
+ this.#changeDetector.markForCheck();
228
+ });
229
+ }
230
+ }
231
+ ngOnDestroy() {
232
+ this.#ngUnsubscribe.next();
233
+ this.#ngUnsubscribe.complete();
234
+ }
235
+ onInputChange(event) {
236
+ this.#onValueChange(event.target.value);
237
+ }
238
+ onInputBlur() {
239
+ this.#onTouched();
240
+ const formattedDate = this.#fuzzyDateService.format(this.#value, this.dateFormat, this.#locale);
241
+ if (this.#control?.valid) {
242
+ this.#setInputElementValue(formattedDate);
243
+ }
244
+ }
245
+ onInput() {
246
+ this.#control?.markAsDirty();
247
+ }
248
+ writeValue(value) {
249
+ this.#updateValue(value, false);
250
+ }
251
+ validate(control) {
252
+ if (!this.#control) {
253
+ this.#control = control;
254
+ }
255
+ if (this.skyDatepickerNoValidate) {
256
+ return null;
257
+ }
258
+ if (!this.#control.value) {
259
+ return null;
260
+ }
261
+ const value = control.value;
262
+ let fuzzyDate;
263
+ let validationError = null;
264
+ if (typeof value === 'string') {
265
+ fuzzyDate = this.#fuzzyDateService.getFuzzyDateFromString(value, this.dateFormat);
266
+ }
267
+ else {
268
+ fuzzyDate = value;
269
+ }
270
+ if (!fuzzyDate) {
271
+ validationError = {
272
+ skyFuzzyDate: {
273
+ invalid: value,
274
+ },
275
+ };
276
+ }
277
+ else {
278
+ if (!fuzzyDate.year && this.yearRequired) {
279
+ validationError = {
280
+ skyFuzzyDate: {
281
+ yearRequired: value,
282
+ },
283
+ };
284
+ }
285
+ if (!validationError && fuzzyDate.year) {
286
+ let fuzzyDateRange;
287
+ if (this.maxDate) {
288
+ fuzzyDateRange = this.#fuzzyDateService.getFuzzyDateRange(fuzzyDate, this.maxDate);
289
+ if (!fuzzyDateRange.valid) {
290
+ validationError = {
291
+ skyFuzzyDate: {
292
+ maxDate: value,
293
+ },
294
+ };
295
+ }
296
+ }
297
+ if (!validationError && this.minDate) {
298
+ fuzzyDateRange = this.#fuzzyDateService.getFuzzyDateRange(this.minDate, fuzzyDate);
299
+ if (!fuzzyDateRange.valid) {
300
+ validationError = {
301
+ skyFuzzyDate: {
302
+ minDate: value,
303
+ },
304
+ };
305
+ }
306
+ }
307
+ if (!validationError && this.futureDisabled) {
308
+ fuzzyDateRange = this.#fuzzyDateService.getFuzzyDateRange(fuzzyDate, this.#fuzzyDateService.getCurrentFuzzyDate());
309
+ if (!fuzzyDateRange.valid) {
310
+ validationError = {
311
+ skyFuzzyDate: {
312
+ futureDisabled: value,
313
+ },
314
+ };
315
+ }
316
+ }
317
+ }
318
+ }
319
+ if (validationError) {
320
+ // Mark the invalid control as touched so that the input's invalid CSS styles appear.
321
+ // (This is only required when the invalid value is set by the FormControl constructor.)
322
+ this.#control.markAsTouched();
323
+ }
324
+ return validationError;
325
+ }
326
+ registerOnChange(fn) {
327
+ this.#onChange = fn;
328
+ }
329
+ registerOnTouched(fn) {
330
+ this.#onTouched = fn;
331
+ }
332
+ registerOnValidatorChange(fn) {
333
+ this.#onValidatorChange = fn;
334
+ }
335
+ setDisabledState(disabled) {
336
+ this.disabled = disabled;
337
+ this.#datepickerComponent.disabled = disabled;
338
+ }
339
+ /**
340
+ * Detects changes to the underlying input element's value and updates the ngModel accordingly.
341
+ * This is useful if you need to update the ngModel value before the input element loses focus.
342
+ */
343
+ detectInputValueChange() {
344
+ this.#onValueChange(this.#elementRef.nativeElement.value);
345
+ }
346
+ #onValueChange(newValue) {
347
+ this.#value = newValue;
348
+ }
349
+ #setInputElementValue(value) {
350
+ this.#renderer.setProperty(this.#elementRef.nativeElement, 'value', value);
351
+ }
352
+ #getMaxDate() {
353
+ if (this.maxDate) {
354
+ const maxDate = this.#fuzzyDateService.getMomentFromFuzzyDate(this.maxDate);
355
+ if (maxDate.isValid()) {
356
+ return maxDate.toDate();
357
+ }
358
+ }
359
+ else if (this.futureDisabled) {
360
+ return new Date();
361
+ }
362
+ return this.#configService.maxDate;
363
+ }
364
+ #getMinDate() {
365
+ if (this.minDate) {
366
+ const minDate = this.#fuzzyDateService.getMomentFromFuzzyDate(this.minDate);
367
+ if (minDate.isValid()) {
368
+ return minDate.toDate();
369
+ }
370
+ }
371
+ return this.#configService.minDate;
372
+ }
373
+ /* istanbul ignore next */
374
+ #fuzzyDatesEqual(dateA, dateB) {
375
+ return (dateA !== undefined &&
376
+ dateB !== undefined &&
377
+ ((!dateA.day && !dateB.day) || dateA.day === dateB.day) &&
378
+ ((!dateA.month && !dateB.month) || dateA.month === dateB.month) &&
379
+ ((!dateA.year && !dateB.year) || dateA.year === dateB.year));
380
+ }
381
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
382
+ // istanbul ignore next
383
+ #onChange;
384
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
385
+ // istanbul ignore next
386
+ #onTouched;
387
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
388
+ // istanbul ignore next
389
+ #onValidatorChange;
390
+ /**
391
+ * Update the value of the form control and input element
392
+ * @param emitEvent Denotes if we emit an event to the consumer's form control. We do not want to do this if the value is being updated via a `setValue` call or a `patchValue` call as this is already handled by Angular.
393
+ * In these cases we do not want to fire `onChange` as it will cause extra `valueChange` and `statusChange` events and the status of the form should not be affected by these changes.
394
+ */
395
+ #updateValue(value, emitEvent = true) {
396
+ if (this.#_value === value ||
397
+ (this.#_value === undefined && value === null)) {
398
+ return;
399
+ }
400
+ let fuzzyDate;
401
+ let fuzzyMoment;
402
+ let dateValue;
403
+ let formattedDate;
404
+ if (value instanceof Date) {
405
+ dateValue = value;
406
+ formattedDate = this.#dateFormatter.format(value, this.dateFormat);
407
+ fuzzyDate = this.#fuzzyDateService.getFuzzyDateFromSelectedDate(value, this.dateFormat);
408
+ }
409
+ else if (typeof value === 'string') {
410
+ fuzzyDate = this.#fuzzyDateService.getFuzzyDateFromString(value, this.dateFormat);
411
+ if (fuzzyDate) {
412
+ formattedDate = this.#fuzzyDateService.format(fuzzyDate, this.dateFormat, this.#locale);
413
+ }
414
+ if (!formattedDate) {
415
+ formattedDate = value;
416
+ }
417
+ fuzzyMoment = this.#fuzzyDateService.getMomentFromFuzzyDate(fuzzyDate);
418
+ if (fuzzyMoment) {
419
+ dateValue = fuzzyMoment.toDate();
420
+ }
421
+ }
422
+ else {
423
+ fuzzyDate = value;
424
+ formattedDate = this.#fuzzyDateService.format(fuzzyDate, this.dateFormat, this.#locale);
425
+ fuzzyMoment = this.#fuzzyDateService.getMomentFromFuzzyDate(fuzzyDate);
426
+ if (fuzzyMoment) {
427
+ dateValue = fuzzyMoment.toDate();
428
+ }
429
+ }
430
+ const areFuzzyDatesEqual = this.#fuzzyDatesEqual(this.#_value, fuzzyDate);
431
+ const isNewValue = fuzzyDate !== this.#_value || !areFuzzyDatesEqual;
432
+ this.#_value = fuzzyDate || value;
433
+ if (isNewValue) {
434
+ if (emitEvent) {
435
+ this.#onChange(this.#_value);
436
+ }
437
+ else {
438
+ this.#control?.setValue(this.#_value, { emitEvent: false });
439
+ }
440
+ this.#datepickerComponent.selectedDate = dateValue;
441
+ }
442
+ this.#setInputElementValue(formattedDate || '');
443
+ }
444
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyFuzzyDatepickerInputDirective, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.SkyDatepickerConfigService }, { token: i0.ElementRef }, { token: i2.SkyFuzzyDateService }, { token: i3.SkyAppLocaleProvider }, { token: i0.Renderer2 }, { token: i3.SkyLibResourcesService }, { token: i4.SkyDatepickerComponent, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
445
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.7", type: SkyFuzzyDatepickerInputDirective, selector: "[skyFuzzyDatepickerInput]", inputs: { dateFormat: "dateFormat", disabled: "disabled", futureDisabled: "futureDisabled", maxDate: "maxDate", minDate: "minDate", skyDatepickerNoValidate: "skyDatepickerNoValidate", startingDay: "startingDay", yearRequired: "yearRequired" }, host: { listeners: { "change": "onInputChange($event)", "blur": "onInputBlur()", "input": "onInput()" } }, providers: [
446
+ SKY_FUZZY_DATEPICKER_VALUE_ACCESSOR,
447
+ SKY_FUZZY_DATEPICKER_VALIDATOR,
448
+ ], ngImport: i0 }); }
449
+ }
450
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyFuzzyDatepickerInputDirective, decorators: [{
451
+ type: Directive,
452
+ args: [{
453
+ selector: '[skyFuzzyDatepickerInput]',
454
+ providers: [
455
+ SKY_FUZZY_DATEPICKER_VALUE_ACCESSOR,
456
+ SKY_FUZZY_DATEPICKER_VALIDATOR,
457
+ ],
458
+ }]
459
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.SkyDatepickerConfigService }, { type: i0.ElementRef }, { type: i2.SkyFuzzyDateService }, { type: i3.SkyAppLocaleProvider }, { type: i0.Renderer2 }, { type: i3.SkyLibResourcesService }, { type: i4.SkyDatepickerComponent, decorators: [{
460
+ type: Optional
461
+ }] }]; }, propDecorators: { dateFormat: [{
462
+ type: Input
463
+ }], disabled: [{
464
+ type: Input
465
+ }], futureDisabled: [{
466
+ type: Input
467
+ }], maxDate: [{
468
+ type: Input
469
+ }], minDate: [{
470
+ type: Input
471
+ }], skyDatepickerNoValidate: [{
472
+ type: Input
473
+ }], startingDay: [{
474
+ type: Input
475
+ }], yearRequired: [{
476
+ type: Input
477
+ }], onInputChange: [{
478
+ type: HostListener,
479
+ args: ['change', ['$event']]
480
+ }], onInputBlur: [{
481
+ type: HostListener,
482
+ args: ['blur']
483
+ }], onInput: [{
484
+ type: HostListener,
485
+ args: ['input']
486
+ }] } });
487
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-input-fuzzy.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-input-fuzzy.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Renderer2,\n  forwardRef,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\nimport { SkyAppLocaleProvider, SkyLibResourcesService } from '@skyux/i18n';\n\nimport { Subject } from 'rxjs';\nimport { distinctUntilChanged, takeUntil } from 'rxjs/operators';\n\nimport { SkyDateFormatter } from './date-formatter';\nimport { SkyDatepickerConfigService } from './datepicker-config.service';\nimport { SkyDatepickerComponent } from './datepicker.component';\nimport { SkyFuzzyDate } from './fuzzy-date';\nimport { SkyFuzzyDateService } from './fuzzy-date.service';\n\nconst SKY_FUZZY_DATEPICKER_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => SkyFuzzyDatepickerInputDirective),\n  multi: true,\n};\n\nconst SKY_FUZZY_DATEPICKER_VALIDATOR = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => SkyFuzzyDatepickerInputDirective),\n  multi: true,\n};\n\n@Directive({\n  selector: '[skyFuzzyDatepickerInput]',\n  providers: [\n    SKY_FUZZY_DATEPICKER_VALUE_ACCESSOR,\n    SKY_FUZZY_DATEPICKER_VALIDATOR,\n  ],\n})\nexport class SkyFuzzyDatepickerInputDirective\n  implements\n    OnInit,\n    OnDestroy,\n    AfterViewInit,\n    AfterContentInit,\n    ControlValueAccessor,\n    Validator\n{\n  /**\n   * The date format for the input. Place this attribute on the `input` element\n   * to override the default in `SkyDatepickerConfigService`.\n   * @default \"MM/DD/YYYY\"\n   */\n  @Input()\n  public set dateFormat(value: string | undefined) {\n    this.#_dateFormat = value;\n\n    if (this.#value) {\n      const formattedDate = this.#fuzzyDateService.format(\n        this.#value,\n        this.dateFormat,\n        this.#locale\n      );\n      this.#setInputElementValue(formattedDate);\n      this.#changeDetector.markForCheck();\n    }\n  }\n\n  // TODO: Refactor to not have getter logic\n  public get dateFormat(): string | undefined {\n    return (\n      this.#_dateFormat ||\n      this.#configService.dateFormat ||\n      this.#preferredShortDateFormat\n    );\n  }\n\n  /**\n   * Whether to disable the datepicker on template-driven forms. Don't use this input on reactive forms because they may overwrite the input or leave the control out of sync.\n   * To set the disabled state on reactive forms, use the `FormControl` instead.\n   * @default false\n   */\n  @Input()\n  public set disabled(value: boolean | undefined) {\n    this.#_disabled = value;\n    this.#datepickerComponent.disabled = value;\n\n    this.#renderer.setProperty(\n      this.#elementRef.nativeElement,\n      'disabled',\n      value\n    );\n  }\n\n  public get disabled(): boolean | undefined {\n    return this.#_disabled;\n  }\n\n  /**\n   * Whether to prevent users from specifying dates that are in the future.\n   * Place this attribute on the `input` element.\n   * @default false\n   */\n  @Input()\n  public set futureDisabled(value: boolean | undefined) {\n    this.#_futureDisabled = value;\n    this.#onValidatorChange();\n  }\n\n  public get futureDisabled(): boolean | undefined {\n    return this.#_futureDisabled;\n  }\n\n  /**\n   * The latest fuzzy date allowed. Place this attribute on the `input` element\n   * to prevent fuzzy dates after a specified date. This property accepts\n   * a `SkyFuzzyDate` value that includes numeric month, day, and year values.\n   * For example: `{ month: 1, day: 1, year: 2027 }`.\n   */\n  @Input()\n  public set maxDate(value: SkyFuzzyDate | undefined) {\n    this.#_maxDate = value;\n    this.#datepickerComponent.maxDate = this.#getMaxDate();\n    this.#onValidatorChange();\n  }\n\n  public get maxDate(): SkyFuzzyDate | undefined {\n    return this.#_maxDate;\n  }\n\n  /**\n   * The earliest fuzzy date allowed. Place this attribute on the `input` element\n   * to prevent fuzzy dates before a specified date. This property accepts a `SkyFuzzyDate` value\n   * that includes numeric month, day, and year values.\n   * For example: `{ month: 1, day: 1, year: 2007 }`.\n   */\n  @Input()\n  public set minDate(value: SkyFuzzyDate | undefined) {\n    this.#_minDate = value;\n    this.#datepickerComponent.minDate = this.#getMinDate();\n    this.#onValidatorChange();\n  }\n\n  public get minDate(): SkyFuzzyDate | undefined {\n    return this.#_minDate;\n  }\n\n  /**\n   * Whether to disable date validation on the fuzzy datepicker input.\n   * @default false\n   */\n  @Input()\n  public skyDatepickerNoValidate: boolean | undefined = false;\n\n  /**\n   * The starting day of the week in the calendar, where `0` sets the starting day\n   * to Sunday. Place this attribute on the `input` element to override the default\n   * in `SkyDatepickerConfigService`.\n   * @default 0\n   */\n  @Input()\n  public set startingDay(value: number | undefined) {\n    this.#_startingDay = value;\n    this.#datepickerComponent.startingDay = this.startingDay;\n\n    this.#onValidatorChange();\n  }\n\n  // TODO: Refactor to not have getter logic\n  public get startingDay(): number {\n    return this.#_startingDay || this.#configService.startingDay;\n  }\n\n  /**\n   * Whether to require the year in fuzzy dates.\n   * @default false\n   */\n  @Input()\n  public set yearRequired(value: boolean | undefined) {\n    this.#_yearRequired = value;\n    this.#onValidatorChange();\n  }\n\n  public get yearRequired(): boolean | undefined {\n    return this.#_yearRequired;\n  }\n\n  get #value(): any {\n    return this.#_value;\n  }\n\n  set #value(value: any) {\n    this.#updateValue(value);\n  }\n\n  #control: AbstractControl | undefined;\n\n  #dateFormatter = new SkyDateFormatter();\n\n  #locale: string;\n\n  #preferredShortDateFormat: string | undefined;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #_futureDisabled: boolean | undefined = false;\n\n  #_dateFormat: string | undefined;\n\n  #_disabled: boolean | undefined = false;\n\n  #_maxDate: SkyFuzzyDate | undefined;\n\n  #_minDate: SkyFuzzyDate | undefined;\n\n  #_startingDay: number | undefined;\n\n  #_value: any;\n\n  #_yearRequired: boolean | undefined = false;\n\n  #changeDetector: ChangeDetectorRef;\n  #configService: SkyDatepickerConfigService;\n  #elementRef: ElementRef;\n  #fuzzyDateService: SkyFuzzyDateService;\n  #renderer: Renderer2;\n  #resourcesService: SkyLibResourcesService;\n  #datepickerComponent: SkyDatepickerComponent;\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    configService: SkyDatepickerConfigService,\n    elementRef: ElementRef,\n    fuzzyDateService: SkyFuzzyDateService,\n    localeProvider: SkyAppLocaleProvider,\n    renderer: Renderer2,\n    resourcesService: SkyLibResourcesService,\n    @Optional() datepickerComponent?: SkyDatepickerComponent\n  ) {\n    if (!datepickerComponent) {\n      throw new Error(\n        'You must wrap the `skyFuzzyDatepickerInput` directive within a ' +\n          '`<sky-datepicker>` component!'\n      );\n    }\n\n    this.#changeDetector = changeDetector;\n    this.#configService = configService;\n    this.#elementRef = elementRef;\n    this.#fuzzyDateService = fuzzyDateService;\n    this.#renderer = renderer;\n    this.#resourcesService = resourcesService;\n    this.#datepickerComponent = datepickerComponent;\n\n    this.#locale = localeProvider.defaultLocale;\n    localeProvider\n      .getLocaleInfo()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((localeInfo) => {\n        this.#locale = localeInfo.locale;\n        SkyDateFormatter.setLocale(this.#locale);\n        this.#preferredShortDateFormat =\n          SkyDateFormatter.getPreferredShortDateFormat();\n      });\n  }\n\n  public ngOnInit(): void {\n    if (this.yearRequired) {\n      if (this.dateFormat?.toLowerCase().indexOf('y') === -1) {\n        throw new Error(\n          'You have configured conflicting settings. Year is required and dateFormat does not include year.'\n        );\n      }\n    }\n\n    const element = this.#elementRef.nativeElement;\n\n    this.#renderer.addClass(element, 'sky-form-control');\n\n    const hasAriaLabel = element.getAttribute('aria-label');\n\n    /* istanbul ignore else */\n    if (!hasAriaLabel) {\n      this.#resourcesService\n        .getString('skyux_date_field_default_label')\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((value: string) => {\n          this.#renderer.setAttribute(element, 'aria-label', value);\n        });\n    }\n  }\n\n  public ngAfterContentInit(): void {\n    this.#datepickerComponent.dateChange\n      .pipe(distinctUntilChanged(), takeUntil(this.#ngUnsubscribe))\n      .subscribe((value: Date) => {\n        this.#value = value;\n        this.#onTouched();\n      });\n  }\n\n  public ngAfterViewInit(): void {\n    // This is needed to address a bug in Angular 4.\n    // When a control value is set initially, its value is not represented on the view.\n    // See: https://github.com/angular/angular/issues/13792\n    // Of note is the parent check which allows us to determine if the form is reactive.\n    // Without this check there is a changed before checked error\n    /* istanbul ignore else */\n\n    if (this.#control && this.#control.parent) {\n      setTimeout(() => {\n        this.#control?.setValue(this.#value, {\n          emitEvent: false,\n        });\n\n        this.#changeDetector.markForCheck();\n      });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  @HostListener('change', ['$event'])\n  public onInputChange(event: any) {\n    this.#onValueChange(event.target.value);\n  }\n\n  @HostListener('blur')\n  public onInputBlur(): void {\n    this.#onTouched();\n\n    const formattedDate = this.#fuzzyDateService.format(\n      this.#value,\n      this.dateFormat,\n      this.#locale\n    );\n\n    if (this.#control?.valid) {\n      this.#setInputElementValue(formattedDate);\n    }\n  }\n\n  @HostListener('input')\n  public onInput(): void {\n    this.#control?.markAsDirty();\n  }\n\n  public writeValue(value: any): void {\n    this.#updateValue(value, false);\n  }\n\n  public validate(control: AbstractControl): ValidationErrors | null {\n    if (!this.#control) {\n      this.#control = control;\n    }\n\n    if (this.skyDatepickerNoValidate) {\n      return null;\n    }\n\n    if (!this.#control.value) {\n      return null;\n    }\n\n    const value: any = control.value;\n\n    let fuzzyDate: SkyFuzzyDate | undefined;\n    let validationError: ValidationErrors | null = null;\n\n    if (typeof value === 'string') {\n      fuzzyDate = this.#fuzzyDateService.getFuzzyDateFromString(\n        value,\n        this.dateFormat\n      );\n    } else {\n      fuzzyDate = value;\n    }\n\n    if (!fuzzyDate) {\n      validationError = {\n        skyFuzzyDate: {\n          invalid: value,\n        },\n      };\n    } else {\n      if (!fuzzyDate.year && this.yearRequired) {\n        validationError = {\n          skyFuzzyDate: {\n            yearRequired: value,\n          },\n        };\n      }\n\n      if (!validationError && fuzzyDate.year) {\n        let fuzzyDateRange;\n\n        if (this.maxDate) {\n          fuzzyDateRange = this.#fuzzyDateService.getFuzzyDateRange(\n            fuzzyDate,\n            this.maxDate\n          );\n\n          if (!fuzzyDateRange.valid) {\n            validationError = {\n              skyFuzzyDate: {\n                maxDate: value,\n              },\n            };\n          }\n        }\n\n        if (!validationError && this.minDate) {\n          fuzzyDateRange = this.#fuzzyDateService.getFuzzyDateRange(\n            this.minDate,\n            fuzzyDate\n          );\n          if (!fuzzyDateRange.valid) {\n            validationError = {\n              skyFuzzyDate: {\n                minDate: value,\n              },\n            };\n          }\n        }\n\n        if (!validationError && this.futureDisabled) {\n          fuzzyDateRange = this.#fuzzyDateService.getFuzzyDateRange(\n            fuzzyDate,\n            this.#fuzzyDateService.getCurrentFuzzyDate()\n          );\n          if (!fuzzyDateRange.valid) {\n            validationError = {\n              skyFuzzyDate: {\n                futureDisabled: value,\n              },\n            };\n          }\n        }\n      }\n    }\n\n    if (validationError) {\n      // Mark the invalid control as touched so that the input's invalid CSS styles appear.\n      // (This is only required when the invalid value is set by the FormControl constructor.)\n      this.#control.markAsTouched();\n    }\n\n    return validationError;\n  }\n\n  public registerOnChange(fn: (value: any) => void): void {\n    this.#onChange = fn;\n  }\n\n  public registerOnTouched(fn: () => void): void {\n    this.#onTouched = fn;\n  }\n\n  public registerOnValidatorChange(fn: () => void): void {\n    this.#onValidatorChange = fn;\n  }\n\n  public setDisabledState(disabled: boolean): void {\n    this.disabled = disabled;\n    this.#datepickerComponent.disabled = disabled;\n  }\n\n  /**\n   * Detects changes to the underlying input element's value and updates the ngModel accordingly.\n   * This is useful if you need to update the ngModel value before the input element loses focus.\n   */\n  public detectInputValueChange(): void {\n    this.#onValueChange(this.#elementRef.nativeElement.value);\n  }\n\n  #onValueChange(newValue: string): void {\n    this.#value = newValue;\n  }\n\n  #setInputElementValue(value: string): void {\n    this.#renderer.setProperty(this.#elementRef.nativeElement, 'value', value);\n  }\n\n  #getMaxDate(): Date | undefined {\n    if (this.maxDate) {\n      const maxDate = this.#fuzzyDateService.getMomentFromFuzzyDate(\n        this.maxDate\n      );\n      if (maxDate.isValid()) {\n        return maxDate.toDate();\n      }\n    } else if (this.futureDisabled) {\n      return new Date();\n    }\n    return this.#configService.maxDate;\n  }\n\n  #getMinDate(): Date | undefined {\n    if (this.minDate) {\n      const minDate = this.#fuzzyDateService.getMomentFromFuzzyDate(\n        this.minDate\n      );\n      if (minDate.isValid()) {\n        return minDate.toDate();\n      }\n    }\n    return this.#configService.minDate;\n  }\n\n  /* istanbul ignore next */\n  #fuzzyDatesEqual(dateA?: SkyFuzzyDate, dateB?: SkyFuzzyDate): boolean {\n    return (\n      dateA !== undefined &&\n      dateB !== undefined &&\n      ((!dateA.day && !dateB.day) || dateA.day === dateB.day) &&\n      ((!dateA.month && !dateB.month) || dateA.month === dateB.month) &&\n      ((!dateA.year && !dateB.year) || dateA.year === dateB.year)\n    );\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  // istanbul ignore next\n  #onChange = (_: any) => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  // istanbul ignore next\n  #onTouched = () => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  // istanbul ignore next\n  #onValidatorChange = () => {};\n\n  /**\n   * Update the value of the form control and input element\n   * @param emitEvent Denotes if we emit an event to the consumer's form control. We do not want to do this if the value is being updated via a `setValue` call or a `patchValue` call as this is already handled by Angular.\n   * In these cases we do not want to fire `onChange` as it will cause extra `valueChange` and `statusChange` events and the status of the form should not be affected by these changes.\n   */\n  #updateValue(value: any, emitEvent = true): void {\n    if (\n      this.#_value === value ||\n      (this.#_value === undefined && value === null)\n    ) {\n      return;\n    }\n\n    let fuzzyDate: SkyFuzzyDate | undefined;\n    let fuzzyMoment: any;\n    let dateValue: Date | undefined;\n    let formattedDate: string | undefined;\n\n    if (value instanceof Date) {\n      dateValue = value;\n      formattedDate = this.#dateFormatter.format(value, this.dateFormat);\n      fuzzyDate = this.#fuzzyDateService.getFuzzyDateFromSelectedDate(\n        value,\n        this.dateFormat\n      );\n    } else if (typeof value === 'string') {\n      fuzzyDate = this.#fuzzyDateService.getFuzzyDateFromString(\n        value,\n        this.dateFormat\n      );\n      if (fuzzyDate) {\n        formattedDate = this.#fuzzyDateService.format(\n          fuzzyDate,\n          this.dateFormat,\n          this.#locale\n        );\n      }\n\n      if (!formattedDate) {\n        formattedDate = value;\n      }\n\n      fuzzyMoment = this.#fuzzyDateService.getMomentFromFuzzyDate(fuzzyDate);\n\n      if (fuzzyMoment) {\n        dateValue = fuzzyMoment.toDate();\n      }\n    } else {\n      fuzzyDate = value as SkyFuzzyDate;\n      formattedDate = this.#fuzzyDateService.format(\n        fuzzyDate,\n        this.dateFormat,\n        this.#locale\n      );\n      fuzzyMoment = this.#fuzzyDateService.getMomentFromFuzzyDate(fuzzyDate);\n\n      if (fuzzyMoment) {\n        dateValue = fuzzyMoment.toDate();\n      }\n    }\n\n    const areFuzzyDatesEqual = this.#fuzzyDatesEqual(this.#_value, fuzzyDate);\n    const isNewValue = fuzzyDate !== this.#_value || !areFuzzyDatesEqual;\n\n    this.#_value = fuzzyDate || value;\n\n    if (isNewValue) {\n      if (emitEvent) {\n        this.#onChange(this.#_value);\n      } else {\n        this.#control?.setValue(this.#_value, { emitEvent: false });\n      }\n\n      this.#datepickerComponent.selectedDate = dateValue;\n    }\n\n    this.#setInputElementValue(formattedDate || '');\n  }\n}\n"]}