@skyux/datetime 10.0.0-alpha.2 → 10.0.0-alpha.3

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 (26) hide show
  1. package/documentation.json +1242 -1170
  2. package/esm2022/lib/modules/date-range-picker/date-range-picker.component.mjs +1 -1
  3. package/esm2022/lib/modules/date-range-picker/date-range-picker.module.mjs +2 -4
  4. package/esm2022/lib/modules/date-range-picker/date-range.service.mjs +6 -3
  5. package/esm2022/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +12 -2
  6. package/esm2022/lib/modules/datepicker/datepicker-calendar-label.pipe.mjs +39 -0
  7. package/esm2022/lib/modules/datepicker/datepicker-calendar.component.mjs +3 -4
  8. package/esm2022/lib/modules/datepicker/datepicker-input.directive.mjs +11 -30
  9. package/esm2022/lib/modules/datepicker/datepicker.component.mjs +45 -4
  10. package/esm2022/lib/modules/datepicker/datepicker.module.mjs +4 -1
  11. package/esm2022/lib/modules/datepicker/daypicker-button.component.mjs +4 -3
  12. package/esm2022/lib/modules/datepicker/daypicker.component.mjs +2 -1
  13. package/esm2022/lib/modules/datepicker/monthpicker.component.mjs +5 -3
  14. package/esm2022/lib/modules/datepicker/yearpicker.component.mjs +5 -3
  15. package/esm2022/lib/modules/shared/sky-datetime-resources.module.mjs +2 -1
  16. package/esm2022/lib/modules/timepicker/timepicker.component.mjs +3 -3
  17. package/fesm2022/skyux-datetime.mjs +113 -58
  18. package/fesm2022/skyux-datetime.mjs.map +1 -1
  19. package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +4 -0
  20. package/lib/modules/datepicker/datepicker-calendar-label.pipe.d.ts +23 -0
  21. package/lib/modules/datepicker/datepicker-input.directive.d.ts +2 -3
  22. package/lib/modules/datepicker/datepicker.component.d.ts +7 -1
  23. package/lib/modules/datepicker/datepicker.module.d.ts +6 -5
  24. package/package.json +8 -8
  25. package/esm2022/lib/modules/datepicker/datepicker-adapter.service.mjs +0 -23
  26. package/lib/modules/datepicker/datepicker-adapter.service.d.ts +0 -13
@@ -4,12 +4,10 @@ import moment from 'moment';
4
4
  import { Subject } from 'rxjs';
5
5
  import { distinctUntilChanged, takeUntil } from 'rxjs/operators';
6
6
  import { SkyDateFormatter } from './date-formatter';
7
- import { SkyDatepickerAdapterService } from './datepicker-adapter.service';
8
7
  import * as i0 from "@angular/core";
9
- import * as i1 from "./datepicker-adapter.service";
10
- import * as i2 from "./datepicker-config.service";
11
- import * as i3 from "@skyux/i18n";
12
- import * as i4 from "./datepicker.component";
8
+ import * as i1 from "./datepicker-config.service";
9
+ import * as i2 from "@skyux/i18n";
10
+ import * as i3 from "./datepicker.component";
13
11
  const SKY_DATEPICKER_VALUE_ACCESSOR = {
14
12
  provide: NG_VALUE_ACCESSOR,
15
13
  useExisting: forwardRef(() => SkyDatepickerInputDirective),
@@ -130,7 +128,6 @@ export class SkyDatepickerInputDirective {
130
128
  }
131
129
  #control;
132
130
  #dateFormatter;
133
- #initialPlaceholder;
134
131
  #preferredShortDateFormat;
135
132
  #ngUnsubscribe;
136
133
  #_dateFormat;
@@ -140,14 +137,13 @@ export class SkyDatepickerInputDirective {
140
137
  #_startingDay;
141
138
  #_strict;
142
139
  #_value;
143
- #adapter;
144
140
  #changeDetector;
145
141
  #configService;
146
142
  #elementRef;
147
143
  #localeProvider;
148
144
  #renderer;
149
145
  #datepickerComponent;
150
- constructor(adapter, changeDetector, configService, elementRef, localeProvider, renderer, datepickerComponent) {
146
+ constructor(changeDetector, configService, elementRef, localeProvider, renderer, datepickerComponent) {
151
147
  /**
152
148
  * Whether to disable date validation on the datepicker input.
153
149
  * @default false
@@ -170,15 +166,12 @@ export class SkyDatepickerInputDirective {
170
166
  throw new Error('You must wrap the `skyDatepickerInput` directive within a ' +
171
167
  '`<sky-datepicker>` component!');
172
168
  }
173
- this.#adapter = adapter;
174
169
  this.#changeDetector = changeDetector;
175
170
  this.#configService = configService;
176
171
  this.#elementRef = elementRef;
177
172
  this.#localeProvider = localeProvider;
178
173
  this.#renderer = renderer;
179
174
  this.#datepickerComponent = datepickerComponent;
180
- this.#initialPlaceholder = this.#adapter.getPlaceholder(this.#elementRef);
181
- this.#updatePlaceholder();
182
175
  this.#localeProvider
183
176
  .getLocaleInfo()
184
177
  .pipe(takeUntil(this.#ngUnsubscribe))
@@ -194,6 +187,7 @@ export class SkyDatepickerInputDirective {
194
187
  this.#renderer.addClass(element, 'sky-form-control');
195
188
  }
196
189
  ngAfterContentInit() {
190
+ this.#datepickerComponent.dateFormat = this.dateFormat;
197
191
  this.#datepickerComponent.dateChange
198
192
  .pipe(distinctUntilChanged())
199
193
  .pipe(takeUntil(this.#ngUnsubscribe))
@@ -331,7 +325,7 @@ export class SkyDatepickerInputDirective {
331
325
  this.#onValueChange(this.#elementRef.nativeElement.value);
332
326
  }
333
327
  #applyDateFormat() {
334
- this.#updatePlaceholder();
328
+ this.#datepickerComponent.dateFormat = this.dateFormat;
335
329
  if (this.#value) {
336
330
  const formattedDate = this.#dateFormatter.format(this.#value, this.dateFormat);
337
331
  this.#setInputElementValue(formattedDate);
@@ -421,11 +415,6 @@ export class SkyDatepickerInputDirective {
421
415
  // eslint-disable-next-line @typescript-eslint/no-empty-function
422
416
  // istanbul ignore next
423
417
  #onValidatorChange;
424
- #updatePlaceholder() {
425
- if (!this.#initialPlaceholder && this.dateFormat) {
426
- this.#adapter.setPlaceholder(this.#elementRef, this.dateFormat);
427
- }
428
- }
429
418
  /**
430
419
  * Update the value of the form control and input element
431
420
  * @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.
@@ -475,24 +464,16 @@ export class SkyDatepickerInputDirective {
475
464
  }
476
465
  }
477
466
  }
478
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerInputDirective, deps: [{ token: i1.SkyDatepickerAdapterService }, { token: i0.ChangeDetectorRef }, { token: i2.SkyDatepickerConfigService }, { token: i0.ElementRef }, { token: i3.SkyAppLocaleProvider }, { token: i0.Renderer2 }, { token: i4.SkyDatepickerComponent, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
479
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.1", type: SkyDatepickerInputDirective, selector: "[skyDatepickerInput]", inputs: { dateFormat: "dateFormat", disabled: "disabled", maxDate: "maxDate", minDate: "minDate", skyDatepickerInput: "skyDatepickerInput", skyDatepickerNoValidate: "skyDatepickerNoValidate", startingDay: "startingDay", strict: "strict" }, host: { listeners: { "change": "onInputChange($event)", "blur": "onInputBlur()", "input": "onInput()" } }, providers: [
480
- SKY_DATEPICKER_VALUE_ACCESSOR,
481
- SKY_DATEPICKER_VALIDATOR,
482
- SkyDatepickerAdapterService,
483
- ], ngImport: i0 }); }
467
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerInputDirective, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.SkyDatepickerConfigService }, { token: i0.ElementRef }, { token: i2.SkyAppLocaleProvider }, { token: i0.Renderer2 }, { token: i3.SkyDatepickerComponent, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
468
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.1", type: SkyDatepickerInputDirective, selector: "[skyDatepickerInput]", inputs: { dateFormat: "dateFormat", disabled: "disabled", maxDate: "maxDate", minDate: "minDate", skyDatepickerInput: "skyDatepickerInput", skyDatepickerNoValidate: "skyDatepickerNoValidate", startingDay: "startingDay", strict: "strict" }, host: { listeners: { "change": "onInputChange($event)", "blur": "onInputBlur()", "input": "onInput()" } }, providers: [SKY_DATEPICKER_VALUE_ACCESSOR, SKY_DATEPICKER_VALIDATOR], ngImport: i0 }); }
484
469
  }
485
470
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerInputDirective, decorators: [{
486
471
  type: Directive,
487
472
  args: [{
488
473
  selector: '[skyDatepickerInput]',
489
- providers: [
490
- SKY_DATEPICKER_VALUE_ACCESSOR,
491
- SKY_DATEPICKER_VALIDATOR,
492
- SkyDatepickerAdapterService,
493
- ],
474
+ providers: [SKY_DATEPICKER_VALUE_ACCESSOR, SKY_DATEPICKER_VALIDATOR],
494
475
  }]
495
- }], ctorParameters: () => [{ type: i1.SkyDatepickerAdapterService }, { type: i0.ChangeDetectorRef }, { type: i2.SkyDatepickerConfigService }, { type: i0.ElementRef }, { type: i3.SkyAppLocaleProvider }, { type: i0.Renderer2 }, { type: i4.SkyDatepickerComponent, decorators: [{
476
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.SkyDatepickerConfigService }, { type: i0.ElementRef }, { type: i2.SkyAppLocaleProvider }, { type: i0.Renderer2 }, { type: i3.SkyDatepickerComponent, decorators: [{
496
477
  type: Optional
497
478
  }] }], propDecorators: { dateFormat: [{
498
479
  type: Input
@@ -520,4 +501,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImpor
520
501
  type: HostListener,
521
502
  args: ['input']
522
503
  }] } });
523
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-input.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-input.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAIL,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,QAAQ,EAER,UAAU,GACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAGL,aAAa,EACb,iBAAiB,GAGlB,MAAM,gBAAgB,CAAC;AAGxB,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,oBAAoB,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAE,2BAA2B,EAAE,MAAM,8BAA8B,CAAC;;;;;;AAI3E,MAAM,6BAA6B,GAAG;IACpC,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,2BAA2B,CAAC;IAC1D,KAAK,EAAE,IAAI;CACZ,CAAC;AAEF,MAAM,wBAAwB,GAAG;IAC/B,OAAO,EAAE,aAAa;IACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,2BAA2B,CAAC;IAC1D,KAAK,EAAE,IAAI;CACZ,CAAC;AAUF,MAAM,OAAO,2BAA2B;IAStC;;;;OAIG;IACH,IACW,UAAU,CAAC,KAAyB;QAC7C,0BAA0B;QAC1B,IAAI,KAAK,KAAK,IAAI,CAAC,YAAY,EAAE,CAAC;YAChC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;YAC1B,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC;IACH,CAAC;IAED,0CAA0C;IAC1C,IAAW,UAAU;QACnB,OAAO,CACL,IAAI,CAAC,YAAY;YACjB,IAAI,CAAC,cAAc,CAAC,UAAU;YAC9B,IAAI,CAAC,yBAAyB,CAC/B,CAAC;IACJ,CAAC;IAED;;;;OAIG;IACH,IACW,QAAQ,CAAC,KAA0B;QAC5C,IAAI,CAAC,UAAU,GAAG,KAAK,IAAI,KAAK,CAAC;QACjC,IAAI,CAAC,oBAAoB,CAAC,QAAQ,GAAG,KAAK,CAAC;QAC3C,IAAI,CAAC,SAAS,CAAC,WAAW,CACxB,IAAI,CAAC,WAAW,CAAC,aAAa,EAC9B,UAAU,EACV,KAAK,CACN,CAAC;IACJ,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED;;;OAGG;IACH,IACW,OAAO,CAAC,KAAuB;QACxC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,oBAAoB,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAEjD,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,0CAA0C;IAC1C,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;IACvD,CAAC;IAED;;;OAGG;IACH,IACW,OAAO,CAAC,KAAuB;QACxC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,oBAAoB,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAEjD,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,0CAA0C;IAC1C,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;IACvD,CAAC;IAED;;;;;OAKG;IACH,IACW,kBAAkB,CAC3B,KAA8C;QAE9C,IAAI,KAAK,EAAE,CAAC;YACV,OAAO,CAAC,IAAI,CACV,oFAAoF;gBAClF,oFAAoF;gBACpF,2BAA2B;gBAC3B,oBAAoB;gBACpB,qEAAqE,CACxE,CAAC;QACJ,CAAC;IACH,CAAC;IASD;;;;;OAKG;IACH,IACW,WAAW,CAAC,KAAyB;QAC9C,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,oBAAoB,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QAEzD,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,0CAA0C;IAC1C,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC;IAC/D,CAAC;IAED;;;;;;;OAOG;IACH,IACW,MAAM,CAAC,KAA0B;QAC1C,IAAI,CAAC,QAAQ,GAAG,KAAK,IAAI,KAAK,CAAC;IACjC,CAAC;IAED,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED,IAAI,MAAM,CAAC,KAAU;QACnB,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED,QAAQ,CAA8B;IACtC,cAAc,CAA0B;IACxC,mBAAmB,CAAS;IAC5B,yBAAyB,CAAqB;IAC9C,cAAc,CAAuB;IAErC,YAAY,CAAqB;IACjC,UAAU,CAAS;IACnB,SAAS,CAAmB;IAC5B,SAAS,CAAmB;IAC5B,aAAa,CAAqB;IAClC,QAAQ,CAAS;IACjB,OAAO,CAAM;IAEb,QAAQ,CAA8B;IACtC,eAAe,CAAoB;IACnC,cAAc,CAA6B;IAC3C,WAAW,CAAa;IACxB,eAAe,CAAuB;IACtC,SAAS,CAAY;IACrB,oBAAoB,CAAyB;IAE7C,YACE,OAAoC,EACpC,cAAiC,EACjC,aAAyC,EACzC,UAAsB,EACtB,cAAoC,EACpC,QAAmB,EACP,mBAA4C;QAhF1D;;;WAGG;QAEI,4BAAuB,GAAwB,KAAK,CAAC;QA+C5D,mBAAc,GAAG,IAAI,gBAAgB,EAAE,CAAC;QAGxC,mBAAc,GAAG,IAAI,OAAO,EAAQ,CAAC;QAGrC,eAAU,GAAG,KAAK,CAAC;QAInB,aAAQ,GAAG,KAAK,CAAC;QAuUjB,gEAAgE;QAChE,uBAAuB;QACvB,cAAS,GAAG,CAAC,CAAM,EAAE,EAAE,GAAE,CAAC,CAAC;QAC3B,gEAAgE;QAChE,uBAAuB;QACvB,eAAU,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QACtB,gEAAgE;QAChE,uBAAuB;QACvB,uBAAkB,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QA3T5B,IAAI,CAAC,mBAAmB,EAAE,CAAC;YACzB,MAAM,IAAI,KAAK,CACb,4DAA4D;gBAC1D,+BAA+B,CAClC,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QACxB,IAAI,CAAC,eAAe,GAAG,cAAc,CAAC;QACtC,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC;QACpC,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;QAC9B,IAAI,CAAC,eAAe,GAAG,cAAc,CAAC;QACtC,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,oBAAoB,GAAG,mBAAmB,CAAC;QAChD,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1E,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAE1B,IAAI,CAAC,eAAe;aACjB,aAAa,EAAE;aACf,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;aACpC,SAAS,CAAC,CAAC,UAAU,EAAE,EAAE;YACxB,gBAAgB,CAAC,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;YAC9C,IAAI,CAAC,yBAAyB;gBAC5B,gBAAgB,CAAC,2BAA2B,EAAE,CAAC;YACjD,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,QAAQ;QACb,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;QAE/C,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,kBAAkB,CAAC,CAAC;IACvD,CAAC;IAEM,kBAAkB;QACvB,IAAI,CAAC,oBAAoB,CAAC,UAAU;aACjC,IAAI,CAAC,oBAAoB,EAAE,CAAC;aAC5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;aACpC,SAAS,CAAC,CAAC,KAAW,EAAE,EAAE;YACzB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACpB,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,eAAe;QACpB,gDAAgD;QAChD,mFAAmF;QACnF,uDAAuD;QACvD,oFAAoF;QACpF,6DAA6D;QAC7D,0BAA0B;QAC1B,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;YAC1C,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE;oBACnC,SAAS,EAAE,KAAK;iBACjB,CAAC,CAAC;gBAEH,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;YACtC,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;QAC3B,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC;IAGM,aAAa,CAAC,KAAU;QAC7B,MAAM,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QAEjC,IAAI,IAAI,CAAC,uBAAuB,EAAE,CAAC;YACjC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YAC3B,OAAO;QACT,CAAC;QAED,4EAA4E;QAC5E,IAAI,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,EAAE,CAAC;YACnC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YAC3B,OAAO;QACT,CAAC;QAED,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAEtB,IAAI,CAAC,QAAQ,EAAE,SAAS,CAAC;YACvB,OAAO,EAAE;gBACP,OAAO,EAAE,IAAI;aACd;SACF,CAAC,CAAC;IACL,CAAC;IAGM,WAAW;QAChB,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAGM,OAAO;QACZ,IAAI,CAAC,QAAQ,EAAE,WAAW,EAAE,CAAC;IAC/B,CAAC;IAEM,UAAU,CAAC,KAAU;QAC1B,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IAClC,CAAC;IAEM,QAAQ,CAAC,OAAwB;QACtC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;YACxB,8EAA8E;YAC9E,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,KAAK,IAAI,CAAC,MAAM,EAAE,CAAC;gBACxC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;YAC9D,CAAC;QACH,CAAC;QAED,IAAI,IAAI,CAAC,uBAAuB,EAAE,CAAC;YACjC,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,KAAK,GAAY,OAAO,CAAC,KAAK,CAAC;QAErC,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,KAAK,YAAY,IAAI,EAAE,CAAC;YAC1B,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YAE3D,IAAI,CAAC,WAAW,EAAE,CAAC;gBACjB,qFAAqF;gBACrF,wFAAwF;gBACxF,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC;gBAE9B,OAAO;oBACL,OAAO,EAAE;wBACP,OAAO,EAAE,KAAK;qBACf;iBACF,CAAC;YACJ,CAAC;YAED,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;YAE7B,IACE,OAAO;gBACP,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,OAAO,CAAC;gBACxC,KAAK,GAAG,OAAO,EACf,CAAC;gBACD,OAAO;oBACL,OAAO,EAAE;wBACP,OAAO;qBACR;iBACF,CAAC;YACJ,CAAC;YAED,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;YAE7B,IACE,OAAO;gBACP,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,OAAO,CAAC;gBACxC,KAAK,GAAG,OAAO,EACf,CAAC;gBACD,OAAO;oBACL,OAAO,EAAE;wBACP,OAAO;qBACR;iBACF,CAAC;YACJ,CAAC;QACH,CAAC;aAAM,CAAC;YACN,qFAAqF;YACrF,wFAAwF;YACxF,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC;YAE9B,OAAO;gBACL,OAAO,EAAE;oBACP,OAAO,EAAE,KAAK;iBACf;aACF,CAAC;QACJ,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAEM,gBAAgB,CAAC,EAAwB;QAC9C,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAEM,iBAAiB,CAAC,EAAc;QACrC,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IAEM,yBAAyB,CAAC,EAAc;QAC7C,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC;IAC/B,CAAC;IAEM,gBAAgB,CAAC,QAAiB;QACvC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,oBAAoB,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAChD,CAAC;IAED;;;OAGG;IACI,sBAAsB;QAC3B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC5D,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,MAAM,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAC9C,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,UAAU,CAChB,CAAC;YACF,IAAI,CAAC,qBAAqB,CAAC,aAAa,CAAC,CAAC;YAC1C,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;QACtC,CAAC;IACH,CAAC;IAED,cAAc,CAAC,QAAgB;QAC7B,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC;IACzB,CAAC;IAED,qBAAqB,CAAC,KAAa;QACjC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;IAC7E,CAAC;IAED;;;;OAIG;IACH,aAAa,CAAC,KAAc;QAC1B,IAAI,KAAK,YAAY,IAAI,EAAE,CAAC;YAC1B,OAAO,KAAK,CAAC;QACf,CAAC;aAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YACrC,OAAO,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;QAC7C,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;;;OAIG;IACH,uBAAuB,CAAC,KAAa;QACnC,MAAM,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1B,yJAAyJ;YACzJ,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvB,MAAM,KAAK,GAAG,IAAI,MAAM,CAAC,uCAAuC,EAAE,GAAG,CAAC,CAAC;gBACvE,MAAM,gBAAgB,GAAG,IAAI,CAAC,UAAU;oBACtC,EAAE,KAAK,CAAC,KAAK,CAAC;oBACd,EAAE,IAAI,CAAC,EAAE,CAAC;qBACT,OAAO,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,CAAC;gBAErC,IAAI,gBAAgB,IAAI,gBAAgB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;oBACtD,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAChD,KAAK,EACL,gBAAgB,EAChB,IAAI,CACL,CAAC;oBACF,IAAI,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC;wBAC1C,OAAO,IAAI,CAAC;oBACd,CAAC;gBACH,CAAC;YACH,CAAC;YACD,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,MAAM,YAAY,GAAG,IAAI,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,QAAQ,EAAE,EAAE,GAAG,CAAC,CAAC;YACtE,MAAM,WAAW,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC;YAC3C,IAAI,GAAG,GAAG,CAAC,IAAI,GAAG,IAAI,WAAW,EAAE,CAAC;gBAClC,OAAO,YAAY,CAAC;YACtB,CAAC;QACH,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAChD,KAAK,EACL,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,MAAM,CACZ,CAAC;YACF,IAAI,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC1C,OAAO,IAAI,CAAC;YACd,CAAC;QACH,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;OAEG;IACH,kBAAkB,CAAC,KAAa;QAC9B,IAAI,CAAC,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YACxC,OAAO,IAAI,CAAC;QACd,CAAC;QAED,0DAA0D;QAC1D,MAAM,MAAM,GAAG,WAAW,CAAC;QAC3B,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEnC,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,IAAI,CAAC;QACd,CAAC;QAED,sDAAsD;QACtD,MAAM,UAAU,GAAG,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,EAAE,CAAC;QAE5D,OAAO,UAAU,CAAC;IACpB,CAAC;IAED,gEAAgE;IAChE,uBAAuB;IACvB,SAAS,CAAkB;IAC3B,gEAAgE;IAChE,uBAAuB;IACvB,UAAU,CAAY;IACtB,gEAAgE;IAChE,uBAAuB;IACvB,kBAAkB,CAAY;IAE9B,kBAAkB;QAChB,IAAI,CAAC,IAAI,CAAC,mBAAmB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACjD,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QAClE,CAAC;IACH,CAAC;IAED;;;;OAIG;IACH,YAAY,CAAC,KAAU,EAAE,SAAS,GAAG,IAAI;QACvC,IAAI,IAAI,CAAC,OAAO,KAAK,KAAK,EAAE,CAAC;YAC3B,OAAO;QACT,CAAC;QAED,MAAM,iBAAiB,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAEzD,0FAA0F;QAC1F,wHAAwH;QACxH,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACvB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,SAAS,EAAE,CAAC;gBACd,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC/B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;YAC9D,CAAC;YAED,IAAI,CAAC,oBAAoB,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC;YAEtD,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC;aAAM,CAAC;YACN,kEAAkE;YAClE,gEAAgE;YAChE,MAAM,SAAS,GAAqB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAE9D,MAAM,aAAa,GACjB,IAAI,CAAC,OAAO,YAAY,IAAI;gBAC5B,SAAS;gBACT,SAAS,CAAC,OAAO,EAAE,KAAK,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;YAEjD,IAAI,SAAS,KAAK,IAAI,CAAC,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC;gBACjD,IAAI,CAAC,OAAO,GAAG,SAAS,IAAI,KAAK,CAAC;gBAClC,IAAI,SAAS,EAAE,CAAC;oBACd,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBAC/B,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;gBAC9D,CAAC;gBAED,IAAI,CAAC,oBAAoB,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC;YACxD,CAAC;YAED,IAAI,SAAS,EAAE,CAAC;gBACd,MAAM,mBAAmB,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CACpD,SAAS,EACT,IAAI,CAAC,UAAU,CAChB,CAAC;gBACF,IAAI,CAAC,qBAAqB,CAAC,mBAAmB,CAAC,CAAC;YAClD,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,qBAAqB,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC;YAC1C,CAAC;QACH,CAAC;IACH,CAAC;8GAxjBU,2BAA2B;kGAA3B,2BAA2B,0YAN3B;YACT,6BAA6B;YAC7B,wBAAwB;YACxB,2BAA2B;SAC5B;;2FAEU,2BAA2B;kBARvC,SAAS;mBAAC;oBACT,QAAQ,EAAE,sBAAsB;oBAChC,SAAS,EAAE;wBACT,6BAA6B;wBAC7B,wBAAwB;wBACxB,2BAA2B;qBAC5B;iBACF;;0BA4LI,QAAQ;yCA5KA,UAAU;sBADpB,KAAK;gBAwBK,QAAQ;sBADlB,KAAK;gBAoBK,OAAO;sBADjB,KAAK;gBAkBK,OAAO;sBADjB,KAAK;gBAoBK,kBAAkB;sBAD5B,KAAK;gBAoBC,uBAAuB;sBAD7B,KAAK;gBAUK,WAAW;sBADrB,KAAK;gBAsBK,MAAM;sBADhB,KAAK;gBAmHC,aAAa;sBADnB,YAAY;uBAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC;gBA0B3B,WAAW;sBADjB,YAAY;uBAAC,MAAM;gBAMb,OAAO;sBADb,YAAY;uBAAC,OAAO","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 } from '@skyux/i18n';\n\nimport moment from 'moment';\nimport { Subject } from 'rxjs';\nimport { distinctUntilChanged, takeUntil } from 'rxjs/operators';\n\nimport { SkyDateFormatter } from './date-formatter';\nimport { SkyDatepickerAdapterService } from './datepicker-adapter.service';\nimport { SkyDatepickerConfigService } from './datepicker-config.service';\nimport { SkyDatepickerComponent } from './datepicker.component';\n\nconst SKY_DATEPICKER_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => SkyDatepickerInputDirective),\n  multi: true,\n};\n\nconst SKY_DATEPICKER_VALIDATOR = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => SkyDatepickerInputDirective),\n  multi: true,\n};\n\n@Directive({\n  selector: '[skyDatepickerInput]',\n  providers: [\n    SKY_DATEPICKER_VALUE_ACCESSOR,\n    SKY_DATEPICKER_VALIDATOR,\n    SkyDatepickerAdapterService,\n  ],\n})\nexport class SkyDatepickerInputDirective\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 the `SkyDatepickerConfigService`.\n   * @default \"MM/DD/YYYY\"\n   */\n  @Input()\n  public set dateFormat(value: string | undefined) {\n    /* istanbul ignore else */\n    if (value !== this.#_dateFormat) {\n      this.#_dateFormat = value;\n      this.#applyDateFormat();\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 || false;\n    this.#datepickerComponent.disabled = value;\n    this.#renderer.setProperty(\n      this.#elementRef.nativeElement,\n      'disabled',\n      value,\n    );\n  }\n\n  public get disabled(): boolean {\n    return this.#_disabled;\n  }\n\n  /**\n   * The latest date that is available in the calendar. Place this attribute on\n   * the `input` element to override the default in `SkyDatepickerConfigService`.\n   */\n  @Input()\n  public set maxDate(value: Date | undefined) {\n    this.#_maxDate = value;\n    this.#datepickerComponent.maxDate = this.maxDate;\n\n    this.#onValidatorChange();\n  }\n\n  // TODO: Refactor to not have getter logic\n  public get maxDate(): Date | undefined {\n    return this.#_maxDate || this.#configService.maxDate;\n  }\n\n  /**\n   * The earliest date that is available in the calendar. Place this attribute on\n   * the `input` element to override the default in `SkyDatepickerConfigService`. To avoid validation errors, the time associated with the minimum date must be midnight. This is necessary because the datepicker automatically sets the time on the `Date` object for selected dates to midnight in the current user's time zone.\n   */\n  @Input()\n  public set minDate(value: Date | undefined) {\n    this.#_minDate = value;\n    this.#datepickerComponent.minDate = this.minDate;\n\n    this.#onValidatorChange();\n  }\n\n  // TODO: Refactor to not have getter logic\n  public get minDate(): Date | undefined {\n    return this.#_minDate || this.#configService.minDate;\n  }\n\n  /**\n   * Creates the datepicker input and calendar. Place this directive on an `input` element,\n   * and wrap the input in a `sky-datepicker` component. The value that users select is driven\n   * through the `ngModel` attribute specified on the `input` element.\n   * @required\n   */\n  @Input()\n  public set skyDatepickerInput(\n    value: SkyDatepickerComponent | undefined | '',\n  ) {\n    if (value) {\n      console.warn(\n        '[Deprecation warning] You no longer need to provide a template reference variable ' +\n          'to the `skyDatepickerInput` attribute (this will be a breaking change in the next ' +\n          'major version release).\\n' +\n          'Do this instead:\\n' +\n          '<sky-datepicker>\\n  <input skyDatepickerInput />\\n</sky-datepicker>',\n      );\n    }\n  }\n\n  /**\n   * Whether to disable date validation on the 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 the format of the date value must match the format from the `dateFormat` value.\n   * If this property is `true` and the datepicker input directive cannot find an exact match, then\n   * the input is marked as invalid.\n   * If this property is `false` and the datepicker input directive cannot find an exact match, then\n   * it attempts to format the string based on the [ISO 8601 standard format](https://www.iso.org/iso-8601-date-and-time-format.html).\n   * @default false\n   */\n  @Input()\n  public set strict(value: boolean | undefined) {\n    this.#_strict = value || false;\n  }\n\n  public get strict(): boolean {\n    return this.#_strict;\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  #dateFormatter = new SkyDateFormatter();\n  #initialPlaceholder: string;\n  #preferredShortDateFormat: string | undefined;\n  #ngUnsubscribe = new Subject<void>();\n\n  #_dateFormat: string | undefined;\n  #_disabled = false;\n  #_maxDate: Date | undefined;\n  #_minDate: Date | undefined;\n  #_startingDay: number | undefined;\n  #_strict = false;\n  #_value: any;\n\n  #adapter: SkyDatepickerAdapterService;\n  #changeDetector: ChangeDetectorRef;\n  #configService: SkyDatepickerConfigService;\n  #elementRef: ElementRef;\n  #localeProvider: SkyAppLocaleProvider;\n  #renderer: Renderer2;\n  #datepickerComponent: SkyDatepickerComponent;\n\n  constructor(\n    adapter: SkyDatepickerAdapterService,\n    changeDetector: ChangeDetectorRef,\n    configService: SkyDatepickerConfigService,\n    elementRef: ElementRef,\n    localeProvider: SkyAppLocaleProvider,\n    renderer: Renderer2,\n    @Optional() datepickerComponent?: SkyDatepickerComponent,\n  ) {\n    if (!datepickerComponent) {\n      throw new Error(\n        'You must wrap the `skyDatepickerInput` directive within a ' +\n          '`<sky-datepicker>` component!',\n      );\n    }\n    this.#adapter = adapter;\n    this.#changeDetector = changeDetector;\n    this.#configService = configService;\n    this.#elementRef = elementRef;\n    this.#localeProvider = localeProvider;\n    this.#renderer = renderer;\n    this.#datepickerComponent = datepickerComponent;\n    this.#initialPlaceholder = this.#adapter.getPlaceholder(this.#elementRef);\n    this.#updatePlaceholder();\n\n    this.#localeProvider\n      .getLocaleInfo()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((localeInfo) => {\n        SkyDateFormatter.setLocale(localeInfo.locale);\n        this.#preferredShortDateFormat =\n          SkyDateFormatter.getPreferredShortDateFormat();\n        this.#applyDateFormat();\n      });\n  }\n\n  public ngOnInit(): void {\n    const element = this.#elementRef.nativeElement;\n\n    this.#renderer.addClass(element, 'sky-form-control');\n  }\n\n  public ngAfterContentInit(): void {\n    this.#datepickerComponent.dateChange\n      .pipe(distinctUntilChanged())\n      .pipe(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    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    const value = event.target.value;\n\n    if (this.skyDatepickerNoValidate) {\n      this.#onValueChange(value);\n      return;\n    }\n\n    // Don't try to parse the string value into a Date value if it is malformed.\n    if (this.#isDateStringValid(value)) {\n      this.#onValueChange(value);\n      return;\n    }\n\n    this.#_value = value;\n    this.#onChange(value);\n\n    this.#control?.setErrors({\n      skyDate: {\n        invalid: true,\n      },\n    });\n  }\n\n  @HostListener('blur')\n  public onInputBlur(): void {\n    this.#onTouched();\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      // Account for any date conversion that may have occurred prior to validation.\n      if (this.#control.value !== this.#value) {\n        this.#control.patchValue(this.#value, { emitEvent: false });\n      }\n    }\n\n    if (this.skyDatepickerNoValidate) {\n      return null;\n    }\n\n    const value: unknown = control.value;\n\n    if (!value) {\n      return null;\n    }\n\n    if (value instanceof Date) {\n      const isDateValid = this.#dateFormatter.dateIsValid(value);\n\n      if (!isDateValid) {\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        return {\n          skyDate: {\n            invalid: value,\n          },\n        };\n      }\n\n      const minDate = this.minDate;\n\n      if (\n        minDate &&\n        this.#dateFormatter.dateIsValid(minDate) &&\n        value < minDate\n      ) {\n        return {\n          skyDate: {\n            minDate,\n          },\n        };\n      }\n\n      const maxDate = this.maxDate;\n\n      if (\n        maxDate &&\n        this.#dateFormatter.dateIsValid(maxDate) &&\n        value > maxDate\n      ) {\n        return {\n          skyDate: {\n            maxDate,\n          },\n        };\n      }\n    } else {\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      return {\n        skyDate: {\n          invalid: value,\n        },\n      };\n    }\n    return null;\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  #applyDateFormat(): void {\n    this.#updatePlaceholder();\n    if (this.#value) {\n      const formattedDate = this.#dateFormatter.format(\n        this.#value,\n        this.dateFormat,\n      );\n      this.#setInputElementValue(formattedDate);\n      this.#changeDetector.markForCheck();\n    }\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  /**\n   * Gets the date value from a value - if possible.\n   * Will not convert unconvertible dates or numbers outside of the current month's number of days.\n   * Returns `undefined` if the value can not be converted.\n   */\n  #getDateValue(value: unknown): Date | undefined {\n    if (value instanceof Date) {\n      return value;\n    } else if (typeof value === 'string') {\n      return this.#getShortcutOrDateValue(value);\n    }\n    return undefined;\n  }\n\n  /**\n   * Converts a string to a date object if the string is a valid date string.\n   * It will also convert numeric input to a date if that number is within the current month's number of days.\n   * If the string can not be converted, `undefined` be returned.\n   */\n  #getShortcutOrDateValue(value: string): Date | undefined {\n    const num = Number(value);\n    if (Number.isInteger(num)) {\n      // We require 8 digits in order to know that we have all information needed to determine what part of the number is the month (2), day (2), and year (4).\n      if (value.length === 8) {\n        const regex = new RegExp(/\\b(MM)\\b|\\b(DD)\\b|\\b(YY)\\b|\\b(YYYY)\\b/, 'g');\n        const formatTokensOnly = this.dateFormat\n          ?.match(regex)\n          ?.join('')\n          .replace(new RegExp(/Y+/), 'YYYY');\n\n        if (formatTokensOnly && formatTokensOnly.length === 8) {\n          const date = this.#dateFormatter.getDateFromString(\n            value,\n            formatTokensOnly,\n            true,\n          );\n          if (this.#dateFormatter.dateIsValid(date)) {\n            return date;\n          }\n        }\n      }\n      const now = new Date();\n      const shortcutDate = new Date(now.getFullYear(), now.getMonth(), num);\n      const daysInMonth = shortcutDate.getDate();\n      if (num > 0 && num <= daysInMonth) {\n        return shortcutDate;\n      }\n    } else {\n      const date = this.#dateFormatter.getDateFromString(\n        value,\n        this.dateFormat,\n        this.strict,\n      );\n      if (this.#dateFormatter.dateIsValid(date)) {\n        return date;\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * Validates the input value to ensure it is formatted correctly.\n   */\n  #isDateStringValid(value: string): boolean {\n    if (!value || typeof value !== 'string') {\n      return true;\n    }\n\n    // Does the value only include digits, dashes, or slashes?\n    const regexp = /^[\\d/-]+$/;\n    const isValid = regexp.test(value);\n\n    if (isValid) {\n      return true;\n    }\n\n    // If not, does it conform to the standard ISO format?\n    const isValidIso = moment(value, moment.ISO_8601).isValid();\n\n    return isValidIso;\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  #updatePlaceholder(): void {\n    if (!this.#initialPlaceholder && this.dateFormat) {\n      this.#adapter.setPlaceholder(this.#elementRef, this.dateFormat);\n    }\n  }\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 (this.#_value === value) {\n      return;\n    }\n\n    const isValidDateString = this.#isDateStringValid(value);\n\n    // If the string value supplied is malformed, do not set the value to its Date equivalent.\n    // (JavaScript's Date parser will convert poorly formatted dates to Date objects, such as \"abc 123\", which isn't ideal.)\n    if (!isValidDateString) {\n      this.#_value = value;\n      if (emitEvent) {\n        this.#onChange(this.#_value);\n      } else {\n        this.#control?.setValue(this.#_value, { emitEvent: false });\n      }\n\n      this.#datepickerComponent.selectedDate = this.#_value;\n\n      this.#setInputElementValue(value);\n    } else {\n      // This value represents the date value for the input if possible.\n      // This value will take into account all shortcut functionality.\n      const dateValue: Date | undefined = this.#getDateValue(value);\n\n      const areDatesEqual =\n        this.#_value instanceof Date &&\n        dateValue &&\n        dateValue.getTime() === this.#_value.getTime();\n\n      if (dateValue !== this.#_value || !areDatesEqual) {\n        this.#_value = dateValue || value;\n        if (emitEvent) {\n          this.#onChange(this.#_value);\n        } else {\n          this.#control?.setValue(this.#_value, { emitEvent: false });\n        }\n\n        this.#datepickerComponent.selectedDate = this.#_value;\n      }\n\n      if (dateValue) {\n        const formattedDateString = this.#dateFormatter.format(\n          dateValue,\n          this.dateFormat,\n        );\n        this.#setInputElementValue(formattedDateString);\n      } else {\n        this.#setInputElementValue(value || '');\n      }\n    }\n  }\n}\n"]}
504
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-input.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-input.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 } from '@skyux/i18n';\n\nimport moment from 'moment';\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';\n\nconst SKY_DATEPICKER_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => SkyDatepickerInputDirective),\n  multi: true,\n};\n\nconst SKY_DATEPICKER_VALIDATOR = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => SkyDatepickerInputDirective),\n  multi: true,\n};\n\n@Directive({\n  selector: '[skyDatepickerInput]',\n  providers: [SKY_DATEPICKER_VALUE_ACCESSOR, SKY_DATEPICKER_VALIDATOR],\n})\nexport class SkyDatepickerInputDirective\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 the `SkyDatepickerConfigService`.\n   * @default \"MM/DD/YYYY\"\n   */\n  @Input()\n  public set dateFormat(value: string | undefined) {\n    /* istanbul ignore else */\n    if (value !== this.#_dateFormat) {\n      this.#_dateFormat = value;\n      this.#applyDateFormat();\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 || false;\n    this.#datepickerComponent.disabled = value;\n    this.#renderer.setProperty(\n      this.#elementRef.nativeElement,\n      'disabled',\n      value,\n    );\n  }\n\n  public get disabled(): boolean {\n    return this.#_disabled;\n  }\n\n  /**\n   * The latest date that is available in the calendar. Place this attribute on\n   * the `input` element to override the default in `SkyDatepickerConfigService`.\n   */\n  @Input()\n  public set maxDate(value: Date | undefined) {\n    this.#_maxDate = value;\n    this.#datepickerComponent.maxDate = this.maxDate;\n\n    this.#onValidatorChange();\n  }\n\n  // TODO: Refactor to not have getter logic\n  public get maxDate(): Date | undefined {\n    return this.#_maxDate || this.#configService.maxDate;\n  }\n\n  /**\n   * The earliest date that is available in the calendar. Place this attribute on\n   * the `input` element to override the default in `SkyDatepickerConfigService`. To avoid validation errors, the time associated with the minimum date must be midnight. This is necessary because the datepicker automatically sets the time on the `Date` object for selected dates to midnight in the current user's time zone.\n   */\n  @Input()\n  public set minDate(value: Date | undefined) {\n    this.#_minDate = value;\n    this.#datepickerComponent.minDate = this.minDate;\n\n    this.#onValidatorChange();\n  }\n\n  // TODO: Refactor to not have getter logic\n  public get minDate(): Date | undefined {\n    return this.#_minDate || this.#configService.minDate;\n  }\n\n  /**\n   * Creates the datepicker input and calendar. Place this directive on an `input` element,\n   * and wrap the input in a `sky-datepicker` component. The value that users select is driven\n   * through the `ngModel` attribute specified on the `input` element.\n   * @required\n   */\n  @Input()\n  public set skyDatepickerInput(\n    value: SkyDatepickerComponent | undefined | '',\n  ) {\n    if (value) {\n      console.warn(\n        '[Deprecation warning] You no longer need to provide a template reference variable ' +\n          'to the `skyDatepickerInput` attribute (this will be a breaking change in the next ' +\n          'major version release).\\n' +\n          'Do this instead:\\n' +\n          '<sky-datepicker>\\n  <input skyDatepickerInput />\\n</sky-datepicker>',\n      );\n    }\n  }\n\n  /**\n   * Whether to disable date validation on the 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 the format of the date value must match the format from the `dateFormat` value.\n   * If this property is `true` and the datepicker input directive cannot find an exact match, then\n   * the input is marked as invalid.\n   * If this property is `false` and the datepicker input directive cannot find an exact match, then\n   * it attempts to format the string based on the [ISO 8601 standard format](https://www.iso.org/iso-8601-date-and-time-format.html).\n   * @default false\n   */\n  @Input()\n  public set strict(value: boolean | undefined) {\n    this.#_strict = value || false;\n  }\n\n  public get strict(): boolean {\n    return this.#_strict;\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  #dateFormatter = new SkyDateFormatter();\n  #preferredShortDateFormat: string | undefined;\n  #ngUnsubscribe = new Subject<void>();\n\n  #_dateFormat: string | undefined;\n  #_disabled = false;\n  #_maxDate: Date | undefined;\n  #_minDate: Date | undefined;\n  #_startingDay: number | undefined;\n  #_strict = false;\n  #_value: any;\n\n  #changeDetector: ChangeDetectorRef;\n  #configService: SkyDatepickerConfigService;\n  #elementRef: ElementRef;\n  #localeProvider: SkyAppLocaleProvider;\n  #renderer: Renderer2;\n  #datepickerComponent: SkyDatepickerComponent;\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    configService: SkyDatepickerConfigService,\n    elementRef: ElementRef,\n    localeProvider: SkyAppLocaleProvider,\n    renderer: Renderer2,\n    @Optional() datepickerComponent?: SkyDatepickerComponent,\n  ) {\n    if (!datepickerComponent) {\n      throw new Error(\n        'You must wrap the `skyDatepickerInput` directive within a ' +\n          '`<sky-datepicker>` component!',\n      );\n    }\n    this.#changeDetector = changeDetector;\n    this.#configService = configService;\n    this.#elementRef = elementRef;\n    this.#localeProvider = localeProvider;\n    this.#renderer = renderer;\n    this.#datepickerComponent = datepickerComponent;\n\n    this.#localeProvider\n      .getLocaleInfo()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((localeInfo) => {\n        SkyDateFormatter.setLocale(localeInfo.locale);\n        this.#preferredShortDateFormat =\n          SkyDateFormatter.getPreferredShortDateFormat();\n        this.#applyDateFormat();\n      });\n  }\n\n  public ngOnInit(): void {\n    const element = this.#elementRef.nativeElement;\n\n    this.#renderer.addClass(element, 'sky-form-control');\n  }\n\n  public ngAfterContentInit(): void {\n    this.#datepickerComponent.dateFormat = this.dateFormat;\n    this.#datepickerComponent.dateChange\n      .pipe(distinctUntilChanged())\n      .pipe(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    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    const value = event.target.value;\n\n    if (this.skyDatepickerNoValidate) {\n      this.#onValueChange(value);\n      return;\n    }\n\n    // Don't try to parse the string value into a Date value if it is malformed.\n    if (this.#isDateStringValid(value)) {\n      this.#onValueChange(value);\n      return;\n    }\n\n    this.#_value = value;\n    this.#onChange(value);\n\n    this.#control?.setErrors({\n      skyDate: {\n        invalid: true,\n      },\n    });\n  }\n\n  @HostListener('blur')\n  public onInputBlur(): void {\n    this.#onTouched();\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      // Account for any date conversion that may have occurred prior to validation.\n      if (this.#control.value !== this.#value) {\n        this.#control.patchValue(this.#value, { emitEvent: false });\n      }\n    }\n\n    if (this.skyDatepickerNoValidate) {\n      return null;\n    }\n\n    const value: unknown = control.value;\n\n    if (!value) {\n      return null;\n    }\n\n    if (value instanceof Date) {\n      const isDateValid = this.#dateFormatter.dateIsValid(value);\n\n      if (!isDateValid) {\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        return {\n          skyDate: {\n            invalid: value,\n          },\n        };\n      }\n\n      const minDate = this.minDate;\n\n      if (\n        minDate &&\n        this.#dateFormatter.dateIsValid(minDate) &&\n        value < minDate\n      ) {\n        return {\n          skyDate: {\n            minDate,\n          },\n        };\n      }\n\n      const maxDate = this.maxDate;\n\n      if (\n        maxDate &&\n        this.#dateFormatter.dateIsValid(maxDate) &&\n        value > maxDate\n      ) {\n        return {\n          skyDate: {\n            maxDate,\n          },\n        };\n      }\n    } else {\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      return {\n        skyDate: {\n          invalid: value,\n        },\n      };\n    }\n    return null;\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  #applyDateFormat(): void {\n    this.#datepickerComponent.dateFormat = this.dateFormat;\n    if (this.#value) {\n      const formattedDate = this.#dateFormatter.format(\n        this.#value,\n        this.dateFormat,\n      );\n      this.#setInputElementValue(formattedDate);\n      this.#changeDetector.markForCheck();\n    }\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  /**\n   * Gets the date value from a value - if possible.\n   * Will not convert unconvertible dates or numbers outside of the current month's number of days.\n   * Returns `undefined` if the value can not be converted.\n   */\n  #getDateValue(value: unknown): Date | undefined {\n    if (value instanceof Date) {\n      return value;\n    } else if (typeof value === 'string') {\n      return this.#getShortcutOrDateValue(value);\n    }\n    return undefined;\n  }\n\n  /**\n   * Converts a string to a date object if the string is a valid date string.\n   * It will also convert numeric input to a date if that number is within the current month's number of days.\n   * If the string can not be converted, `undefined` be returned.\n   */\n  #getShortcutOrDateValue(value: string): Date | undefined {\n    const num = Number(value);\n    if (Number.isInteger(num)) {\n      // We require 8 digits in order to know that we have all information needed to determine what part of the number is the month (2), day (2), and year (4).\n      if (value.length === 8) {\n        const regex = new RegExp(/\\b(MM)\\b|\\b(DD)\\b|\\b(YY)\\b|\\b(YYYY)\\b/, 'g');\n        const formatTokensOnly = this.dateFormat\n          ?.match(regex)\n          ?.join('')\n          .replace(new RegExp(/Y+/), 'YYYY');\n\n        if (formatTokensOnly && formatTokensOnly.length === 8) {\n          const date = this.#dateFormatter.getDateFromString(\n            value,\n            formatTokensOnly,\n            true,\n          );\n          if (this.#dateFormatter.dateIsValid(date)) {\n            return date;\n          }\n        }\n      }\n      const now = new Date();\n      const shortcutDate = new Date(now.getFullYear(), now.getMonth(), num);\n      const daysInMonth = shortcutDate.getDate();\n      if (num > 0 && num <= daysInMonth) {\n        return shortcutDate;\n      }\n    } else {\n      const date = this.#dateFormatter.getDateFromString(\n        value,\n        this.dateFormat,\n        this.strict,\n      );\n      if (this.#dateFormatter.dateIsValid(date)) {\n        return date;\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * Validates the input value to ensure it is formatted correctly.\n   */\n  #isDateStringValid(value: string): boolean {\n    if (!value || typeof value !== 'string') {\n      return true;\n    }\n\n    // Does the value only include digits, dashes, or slashes?\n    const regexp = /^[\\d/-]+$/;\n    const isValid = regexp.test(value);\n\n    if (isValid) {\n      return true;\n    }\n\n    // If not, does it conform to the standard ISO format?\n    const isValidIso = moment(value, moment.ISO_8601).isValid();\n\n    return isValidIso;\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 (this.#_value === value) {\n      return;\n    }\n\n    const isValidDateString = this.#isDateStringValid(value);\n\n    // If the string value supplied is malformed, do not set the value to its Date equivalent.\n    // (JavaScript's Date parser will convert poorly formatted dates to Date objects, such as \"abc 123\", which isn't ideal.)\n    if (!isValidDateString) {\n      this.#_value = value;\n      if (emitEvent) {\n        this.#onChange(this.#_value);\n      } else {\n        this.#control?.setValue(this.#_value, { emitEvent: false });\n      }\n\n      this.#datepickerComponent.selectedDate = this.#_value;\n\n      this.#setInputElementValue(value);\n    } else {\n      // This value represents the date value for the input if possible.\n      // This value will take into account all shortcut functionality.\n      const dateValue: Date | undefined = this.#getDateValue(value);\n\n      const areDatesEqual =\n        this.#_value instanceof Date &&\n        dateValue &&\n        dateValue.getTime() === this.#_value.getTime();\n\n      if (dateValue !== this.#_value || !areDatesEqual) {\n        this.#_value = dateValue || value;\n        if (emitEvent) {\n          this.#onChange(this.#_value);\n        } else {\n          this.#control?.setValue(this.#_value, { emitEvent: false });\n        }\n\n        this.#datepickerComponent.selectedDate = this.#_value;\n      }\n\n      if (dateValue) {\n        const formattedDateString = this.#dateFormatter.format(\n          dateValue,\n          this.dateFormat,\n        );\n        this.#setInputElementValue(formattedDateString);\n      } else {\n        this.#setInputElementValue(value || '');\n      }\n    }\n  }\n}\n"]}
@@ -1,5 +1,6 @@
1
1
  import { ChangeDetectionStrategy, Component, ElementRef, EnvironmentInjector, EventEmitter, Inject, Input, Optional, Output, TemplateRef, ViewChild, inject, } from '@angular/core';
2
- import { SKY_STACKING_CONTEXT, SkyAffixAutoFitContext, } from '@skyux/core';
2
+ import { SKY_STACKING_CONTEXT, SkyAffixAutoFitContext, SkyAppFormat, } from '@skyux/core';
3
+ import { SkyLibResourcesService } from '@skyux/i18n';
3
4
  import { Subject, fromEvent } from 'rxjs';
4
5
  import { debounceTime, takeUntil } from 'rxjs/operators';
5
6
  import { SkyDatepickerCalendarComponent } from './datepicker-calendar.component';
@@ -18,6 +19,14 @@ let nextId = 0;
18
19
  * You must wrap this component around an input with the `skyDatepickerInput` directive.
19
20
  */
20
21
  export class SkyDatepickerComponent {
22
+ set dateFormat(value) {
23
+ this.#_dateFormat = value;
24
+ this.dateFormatChange.emit(value);
25
+ this.#populateInputBoxHelpText();
26
+ }
27
+ get dateFormat() {
28
+ return this.#_dateFormat;
29
+ }
21
30
  get disabled() {
22
31
  return this.#_disabled;
23
32
  }
@@ -65,12 +74,16 @@ export class SkyDatepickerComponent {
65
74
  #overlay;
66
75
  #overlayKeyupListener;
67
76
  #_calendarRef;
77
+ #_dateFormat;
68
78
  #_disabled;
69
79
  #_selectedDate;
70
80
  #affixService;
81
+ #appFormatter;
71
82
  #changeDetector;
72
83
  #coreAdapter;
84
+ #dateFormatHintTextTemplateString;
73
85
  #environmentInjector;
86
+ #resourceSvc;
74
87
  #overlayService;
75
88
  #zIndex;
76
89
  constructor(affixService, changeDetector, coreAdapter, overlayService, inputBoxHostService, themeSvc, stackingContext) {
@@ -86,6 +99,10 @@ export class SkyDatepickerComponent {
86
99
  * to modify individual dates on the calendar.
87
100
  */
88
101
  this.calendarDateRangeChange = new EventEmitter();
102
+ /**
103
+ * @internal
104
+ */
105
+ this.dateFormatChange = new EventEmitter();
89
106
  /**
90
107
  * @internal
91
108
  */
@@ -97,7 +114,10 @@ export class SkyDatepickerComponent {
97
114
  this.#calendarUnsubscribe = new Subject();
98
115
  this.#ngUnsubscribe = new Subject();
99
116
  this.#_disabled = false;
117
+ this.#appFormatter = inject(SkyAppFormat);
118
+ this.#dateFormatHintTextTemplateString = '';
100
119
  this.#environmentInjector = inject(EnvironmentInjector);
120
+ this.#resourceSvc = inject(SkyLibResourcesService);
101
121
  this.#affixService = affixService;
102
122
  this.#changeDetector = changeDetector;
103
123
  this.#coreAdapter = coreAdapter;
@@ -119,6 +139,13 @@ export class SkyDatepickerComponent {
119
139
  inputTemplate: this.inputTemplateRef,
120
140
  buttonsTemplate: this.triggerButtonTemplateRef,
121
141
  });
142
+ this.#resourceSvc
143
+ .getString('skyux_datepicker_format_hint_text')
144
+ .pipe(takeUntil(this.#ngUnsubscribe))
145
+ .subscribe((templateString) => {
146
+ this.#dateFormatHintTextTemplateString = templateString;
147
+ this.#populateInputBoxHelpText();
148
+ });
122
149
  }
123
150
  }
124
151
  ngOnDestroy() {
@@ -288,12 +315,24 @@ export class SkyDatepickerComponent {
288
315
  this.#customDatesSubscription = undefined;
289
316
  }
290
317
  }
318
+ #populateInputBoxHelpText() {
319
+ if (this.inputBoxHostService && this.inputTemplateRef) {
320
+ /* safety check */
321
+ /* istanbul ignore else */
322
+ if (this.dateFormat) {
323
+ this.inputBoxHostService?.setHintText(this.#appFormatter.formatText(this.#dateFormatHintTextTemplateString, this.dateFormat));
324
+ }
325
+ else {
326
+ this.inputBoxHostService?.setHintText('');
327
+ }
328
+ }
329
+ }
291
330
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.1", 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 }, { token: SKY_STACKING_CONTEXT, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
292
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.1", type: SkyDatepickerComponent, selector: "sky-datepicker", inputs: { pickerClass: "pickerClass" }, outputs: { calendarDateRangeChange: "calendarDateRangeChange", openChange: "openChange" }, 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 />\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 inputBoxHostService?.labelText\n ? ('skyux_datepicker_trigger_button_label_context'\n | skyLibResources : inputBoxHostService?.labelText)\n : ('skyux_datepicker_trigger_button_label' | skyLibResources)\n \"\n [attr.id]=\"triggerButtonId\"\n [attr.title]=\"\n inputBoxHostService?.labelText\n ? ('skyux_datepicker_trigger_button_label_context'\n | skyLibResources : inputBoxHostService?.labelText)\n : ('skyux_datepicker_trigger_button_label' | skyLibResources)\n \"\n [disabled]=\"disabled\"\n (click)=\"onTriggerButtonClick()\"\n #triggerButtonRef\n >\n <sky-icon icon=\"calendar\" size=\"lg\" />\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 cdkTrapFocus\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.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i6.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "component", type: i7.SkyDatepickerCalendarComponent, selector: "sky-datepicker-calendar", inputs: ["customDates", "isDaypickerWaiting", "minDate", "maxDate", "selectedDate", "startingDay"], outputs: ["calendarDateRangeChange", "calendarModeChange", "selectedDateChange"] }, { kind: "pipe", type: i8.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
331
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.1", type: SkyDatepickerComponent, selector: "sky-datepicker", inputs: { pickerClass: "pickerClass" }, outputs: { calendarDateRangeChange: "calendarDateRangeChange", dateFormatChange: "dateFormatChange", openChange: "openChange" }, 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 />\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 inputBoxHostService?.labelText\n ? ('skyux_datepicker_trigger_button_label_context'\n | skyLibResources: inputBoxHostService?.labelText)\n : ('skyux_datepicker_trigger_button_label' | skyLibResources)\n \"\n [attr.id]=\"triggerButtonId\"\n [attr.title]=\"\n inputBoxHostService?.labelText\n ? ('skyux_datepicker_trigger_button_label_context'\n | skyLibResources: inputBoxHostService?.labelText)\n : ('skyux_datepicker_trigger_button_label' | skyLibResources)\n \"\n [disabled]=\"disabled\"\n (click)=\"onTriggerButtonClick()\"\n #triggerButtonRef\n >\n <sky-icon icon=\"calendar\" size=\"lg\" />\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 cdkTrapFocus\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.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i6.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "component", type: i7.SkyDatepickerCalendarComponent, selector: "sky-datepicker-calendar", inputs: ["customDates", "isDaypickerWaiting", "minDate", "maxDate", "selectedDate", "startingDay"], outputs: ["calendarDateRangeChange", "calendarModeChange", "selectedDateChange"] }, { kind: "pipe", type: i8.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
293
332
  }
294
333
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerComponent, decorators: [{
295
334
  type: Component,
296
- 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 />\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 inputBoxHostService?.labelText\n ? ('skyux_datepicker_trigger_button_label_context'\n | skyLibResources : inputBoxHostService?.labelText)\n : ('skyux_datepicker_trigger_button_label' | skyLibResources)\n \"\n [attr.id]=\"triggerButtonId\"\n [attr.title]=\"\n inputBoxHostService?.labelText\n ? ('skyux_datepicker_trigger_button_label_context'\n | skyLibResources : inputBoxHostService?.labelText)\n : ('skyux_datepicker_trigger_button_label' | skyLibResources)\n \"\n [disabled]=\"disabled\"\n (click)=\"onTriggerButtonClick()\"\n #triggerButtonRef\n >\n <sky-icon icon=\"calendar\" size=\"lg\" />\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 cdkTrapFocus\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"] }]
335
+ 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 />\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 inputBoxHostService?.labelText\n ? ('skyux_datepicker_trigger_button_label_context'\n | skyLibResources: inputBoxHostService?.labelText)\n : ('skyux_datepicker_trigger_button_label' | skyLibResources)\n \"\n [attr.id]=\"triggerButtonId\"\n [attr.title]=\"\n inputBoxHostService?.labelText\n ? ('skyux_datepicker_trigger_button_label_context'\n | skyLibResources: inputBoxHostService?.labelText)\n : ('skyux_datepicker_trigger_button_label' | skyLibResources)\n \"\n [disabled]=\"disabled\"\n (click)=\"onTriggerButtonClick()\"\n #triggerButtonRef\n >\n <sky-icon icon=\"calendar\" size=\"lg\" />\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 cdkTrapFocus\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"] }]
297
336
  }], ctorParameters: () => [{ type: i1.SkyAffixService }, { type: i0.ChangeDetectorRef }, { type: i1.SkyCoreAdapterService }, { type: i1.SkyOverlayService }, { type: i2.SkyInputBoxHostService, decorators: [{
298
337
  type: Optional
299
338
  }] }, { type: i3.SkyThemeService, decorators: [{
@@ -307,6 +346,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImpor
307
346
  type: Input
308
347
  }], calendarDateRangeChange: [{
309
348
  type: Output
349
+ }], dateFormatChange: [{
350
+ type: Output
310
351
  }], openChange: [{
311
352
  type: Output
312
353
  }], calendar: [{
@@ -340,4 +381,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImpor
340
381
  static: true,
341
382
  }]
342
383
  }] } });
343
- //# 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  EnvironmentInjector,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewChild,\n  inject,\n} from '@angular/core';\nimport {\n  SKY_STACKING_CONTEXT,\n  SkyAffixAutoFitContext,\n  SkyAffixService,\n  SkyAffixer,\n  SkyCoreAdapterService,\n  SkyOverlayInstance,\n  SkyOverlayService,\n  SkyStackingContext,\n} from '@skyux/core';\nimport { SkyInputBoxHostService } from '@skyux/forms';\nimport { SkyThemeService } from '@skyux/theme';\n\nimport { Observable, 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 =\n    new EventEmitter<SkyDatepickerCalendarChange>();\n\n  /**\n   * @internal\n   */\n  @Output()\n  public openChange = new EventEmitter<boolean>();\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      this.#addKeyupListener();\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.applyAutoFocus(this.calendarRef);\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  #overlayKeyupListener: 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  readonly #environmentInjector = inject(EnvironmentInjector);\n  #overlayService: SkyOverlayService;\n  readonly #zIndex: Observable<number> | undefined;\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    @Optional()\n    @Inject(SKY_STACKING_CONTEXT)\n    stackingContext?: SkyStackingContext,\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    this.#zIndex = stackingContext?.zIndex;\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.openChange.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 been 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(): void {\n    this.#destroyAffixer();\n    this.#destroyOverlay();\n    this.#removePickerEventListeners();\n    this.triggerButtonRef?.nativeElement.focus();\n    this.isOpen = false;\n    this.openChange.emit(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    this.openChange.emit(true);\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        environmentInjector: this.#environmentInjector,\n      });\n\n      if (this.#zIndex) {\n        this.#zIndex\n          .pipe(takeUntil(this.#calendarUnsubscribe))\n          .subscribe((zIndex) => {\n            overlay.componentRef.instance.zIndex = zIndex.toString(10);\n          });\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      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  #addKeyupListener(): void {\n    const datepickerCalendarElement = this.calendarRef?.nativeElement;\n\n    if (datepickerCalendarElement) {\n      this.#overlayKeyupListener = fromEvent<KeyboardEvent>(\n        datepickerCalendarElement,\n        'keyup',\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\n  #removePickerEventListeners(): void {\n    this.#calendarUnsubscribe.next();\n    this.#calendarUnsubscribe.complete();\n    this.#calendarUnsubscribe = new Subject<void>();\n    this.#overlayKeyupListener?.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 />\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        inputBoxHostService?.labelText\n          ? ('skyux_datepicker_trigger_button_label_context'\n            | skyLibResources : inputBoxHostService?.labelText)\n          : ('skyux_datepicker_trigger_button_label' | skyLibResources)\n      \"\n      [attr.id]=\"triggerButtonId\"\n      [attr.title]=\"\n        inputBoxHostService?.labelText\n          ? ('skyux_datepicker_trigger_button_label_context'\n            | skyLibResources : inputBoxHostService?.labelText)\n          : ('skyux_datepicker_trigger_button_label' | skyLibResources)\n      \"\n      [disabled]=\"disabled\"\n      (click)=\"onTriggerButtonClick()\"\n      #triggerButtonRef\n    >\n      <sky-icon icon=\"calendar\" size=\"lg\" />\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      cdkTrapFocus\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"]}
384
+ //# 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  EnvironmentInjector,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewChild,\n  inject,\n} from '@angular/core';\nimport {\n  SKY_STACKING_CONTEXT,\n  SkyAffixAutoFitContext,\n  SkyAffixService,\n  SkyAffixer,\n  SkyAppFormat,\n  SkyCoreAdapterService,\n  SkyOverlayInstance,\n  SkyOverlayService,\n  SkyStackingContext,\n} from '@skyux/core';\nimport { SkyInputBoxHostService } from '@skyux/forms';\nimport { SkyLibResourcesService } from '@skyux/i18n';\nimport { SkyThemeService } from '@skyux/theme';\n\nimport { Observable, 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 set dateFormat(value: string | undefined) {\n    this.#_dateFormat = value;\n    this.dateFormatChange.emit(value);\n    this.#populateInputBoxHelpText();\n  }\n\n  public get dateFormat(): string | undefined {\n    return this.#_dateFormat;\n  }\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 =\n    new EventEmitter<SkyDatepickerCalendarChange>();\n\n  /**\n   * @internal\n   */\n  @Output()\n  public dateFormatChange = new EventEmitter<string>();\n\n  /**\n   * @internal\n   */\n  @Output()\n  public openChange = new EventEmitter<boolean>();\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      this.#addKeyupListener();\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.applyAutoFocus(this.calendarRef);\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  #overlayKeyupListener: Subscription | undefined;\n\n  #_calendarRef: ElementRef | undefined;\n\n  #_dateFormat: string | undefined;\n\n  #_disabled: boolean | undefined = false;\n\n  #_selectedDate: Date | undefined;\n\n  #affixService: SkyAffixService;\n  readonly #appFormatter = inject(SkyAppFormat);\n  #changeDetector: ChangeDetectorRef;\n  #coreAdapter: SkyCoreAdapterService;\n  #dateFormatHintTextTemplateString = '';\n  readonly #environmentInjector = inject(EnvironmentInjector);\n  readonly #resourceSvc = inject(SkyLibResourcesService);\n  #overlayService: SkyOverlayService;\n  readonly #zIndex: Observable<number> | undefined;\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    @Optional()\n    @Inject(SKY_STACKING_CONTEXT)\n    stackingContext?: SkyStackingContext,\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    this.#zIndex = stackingContext?.zIndex;\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      this.#resourceSvc\n        .getString('skyux_datepicker_format_hint_text')\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((templateString) => {\n          this.#dateFormatHintTextTemplateString = templateString;\n          this.#populateInputBoxHelpText();\n        });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.dateChange.complete();\n    this.openChange.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 been 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(): void {\n    this.#destroyAffixer();\n    this.#destroyOverlay();\n    this.#removePickerEventListeners();\n    this.triggerButtonRef?.nativeElement.focus();\n    this.isOpen = false;\n    this.openChange.emit(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    this.openChange.emit(true);\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        environmentInjector: this.#environmentInjector,\n      });\n\n      if (this.#zIndex) {\n        this.#zIndex\n          .pipe(takeUntil(this.#calendarUnsubscribe))\n          .subscribe((zIndex) => {\n            overlay.componentRef.instance.zIndex = zIndex.toString(10);\n          });\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      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  #addKeyupListener(): void {\n    const datepickerCalendarElement = this.calendarRef?.nativeElement;\n\n    if (datepickerCalendarElement) {\n      this.#overlayKeyupListener = fromEvent<KeyboardEvent>(\n        datepickerCalendarElement,\n        'keyup',\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\n  #removePickerEventListeners(): void {\n    this.#calendarUnsubscribe.next();\n    this.#calendarUnsubscribe.complete();\n    this.#calendarUnsubscribe = new Subject<void>();\n    this.#overlayKeyupListener?.unsubscribe();\n  }\n\n  #cancelCustomDatesSubscription(): void {\n    if (this.#customDatesSubscription) {\n      this.#customDatesSubscription.unsubscribe();\n      this.#customDatesSubscription = undefined;\n    }\n  }\n\n  #populateInputBoxHelpText(): void {\n    if (this.inputBoxHostService && this.inputTemplateRef) {\n      /* safety check */\n      /* istanbul ignore else */\n      if (this.dateFormat) {\n        this.inputBoxHostService?.setHintText(\n          this.#appFormatter.formatText(\n            this.#dateFormatHintTextTemplateString,\n            this.dateFormat,\n          ),\n        );\n      } else {\n        this.inputBoxHostService?.setHintText('');\n      }\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 />\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        inputBoxHostService?.labelText\n          ? ('skyux_datepicker_trigger_button_label_context'\n            | skyLibResources: inputBoxHostService?.labelText)\n          : ('skyux_datepicker_trigger_button_label' | skyLibResources)\n      \"\n      [attr.id]=\"triggerButtonId\"\n      [attr.title]=\"\n        inputBoxHostService?.labelText\n          ? ('skyux_datepicker_trigger_button_label_context'\n            | skyLibResources: inputBoxHostService?.labelText)\n          : ('skyux_datepicker_trigger_button_label' | skyLibResources)\n      \"\n      [disabled]=\"disabled\"\n      (click)=\"onTriggerButtonClick()\"\n      #triggerButtonRef\n    >\n      <sky-icon icon=\"calendar\" size=\"lg\" />\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      cdkTrapFocus\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"]}