@skyux/datetime 9.0.0-alpha.8 → 9.0.0-alpha.9

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.
@@ -2,7 +2,6 @@ import { Directive, HostListener, Input, forwardRef, } from '@angular/core';
2
2
  import { NG_VALIDATORS, NG_VALUE_ACCESSOR, } from '@angular/forms';
3
3
  import moment from 'moment';
4
4
  import * as i0 from "@angular/core";
5
- import * as i1 from "@skyux/i18n";
6
5
  const SKY_TIMEPICKER_VALUE_ACCESSOR = {
7
6
  provide: NG_VALUE_ACCESSOR,
8
7
  useExisting: forwardRef(() => SkyTimepickerInputDirective),
@@ -71,12 +70,10 @@ export class SkyTimepickerInputDirective {
71
70
  #_skyTimepickerInput;
72
71
  #renderer;
73
72
  #elRef;
74
- #resourcesService;
75
73
  #changeDetector;
76
- constructor(renderer, elRef, resourcesService, changeDetector) {
74
+ constructor(renderer, elRef, changeDetector) {
77
75
  this.#renderer = renderer;
78
76
  this.#elRef = elRef;
79
- this.#resourcesService = resourcesService;
80
77
  this.#changeDetector = changeDetector;
81
78
  }
82
79
  ngOnInit() {
@@ -86,14 +83,6 @@ export class SkyTimepickerInputDirective {
86
83
  this.writeValue(newTime);
87
84
  this.#_onTouched();
88
85
  });
89
- /* istanbul ignore else */
90
- if (!this.#elRef.nativeElement.getAttribute('aria-label')) {
91
- this.#resourcesService
92
- .getString('skyux_timepicker_input_default_label')
93
- .subscribe((value) => {
94
- this.#renderer.setAttribute(this.#elRef.nativeElement, 'aria-label', value);
95
- });
96
- }
97
86
  }
98
87
  ngAfterContentInit() {
99
88
  // Watch for the control to be added and initialize the value immediately.
@@ -210,7 +199,7 @@ export class SkyTimepickerInputDirective {
210
199
  /* istanbul ignore next */
211
200
  // eslint-disable-next-line @typescript-eslint/no-empty-function
212
201
  #_validatorChange = () => { };
213
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyTimepickerInputDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i1.SkyLibResourcesService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
202
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyTimepickerInputDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
214
203
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.1", type: SkyTimepickerInputDirective, selector: "[skyTimepickerInput]", inputs: { skyTimepickerInput: "skyTimepickerInput", timeFormat: "timeFormat", returnFormat: "returnFormat", disabled: "disabled" }, host: { listeners: { "change": "onChange($event)", "blur": "onBlur()" } }, providers: [SKY_TIMEPICKER_VALUE_ACCESSOR, SKY_TIMEPICKER_VALIDATOR], usesOnChanges: true, ngImport: i0 }); }
215
204
  }
216
205
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyTimepickerInputDirective, decorators: [{
@@ -219,7 +208,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
219
208
  selector: '[skyTimepickerInput]',
220
209
  providers: [SKY_TIMEPICKER_VALUE_ACCESSOR, SKY_TIMEPICKER_VALIDATOR],
221
210
  }]
222
- }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i1.SkyLibResourcesService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { skyTimepickerInput: [{
211
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { skyTimepickerInput: [{
223
212
  type: Input
224
213
  }], timeFormat: [{
225
214
  type: Input
@@ -234,4 +223,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
234
223
  type: HostListener,
235
224
  args: ['blur']
236
225
  }] } });
237
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/timepicker/timepicker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\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 { SkyLibResourcesService } from '@skyux/i18n';\n\nimport moment from 'moment';\nimport { Subscription } from 'rxjs';\n\nimport { SkyTimepickerTimeFormatType } from './timepicker-time-format-type';\nimport { SkyTimepickerTimeOutput } from './timepicker-time-output';\nimport { SkyTimepickerComponent } from './timepicker.component';\n\nconst SKY_TIMEPICKER_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => SkyTimepickerInputDirective),\n  multi: true,\n};\n\nconst SKY_TIMEPICKER_VALIDATOR = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => SkyTimepickerInputDirective),\n  multi: true,\n};\n\n@Directive({\n  selector: '[skyTimepickerInput]',\n  providers: [SKY_TIMEPICKER_VALUE_ACCESSOR, SKY_TIMEPICKER_VALIDATOR],\n})\nexport class SkyTimepickerInputDirective\n  implements\n    OnInit,\n    OnDestroy,\n    ControlValueAccessor,\n    Validator,\n    OnChanges,\n    AfterContentInit\n{\n  public pickerChangedSubscription: Subscription | undefined;\n  #_timeFormat: SkyTimepickerTimeFormatType = 'hh';\n\n  // TODO: In a future breaking change - grab the parent component through dependency injection and remove this setter.\n  /**\n   * Creates the timepicker input field and picker. Place this attribute on an `input` element,\n   * and wrap the input in a `sky-timepicker` component.\n   * This attribute must be set to the instance of the `sky-timepicker`.\n   * @required\n   */\n  @Input()\n  public get skyTimepickerInput(): SkyTimepickerComponent | undefined {\n    return this.#_skyTimepickerInput;\n  }\n\n  public set skyTimepickerInput(value: SkyTimepickerComponent | undefined) {\n    this.#_skyTimepickerInput = value;\n    this.#updateTimepickerInput();\n  }\n\n  // TODO: In a future breaking change - make this more specific than \"string\"\n  /**\n   * The 12-hour `hh` or 24-hour `HH` time format for the input.\n   * @default \"hh\"\n   */\n  @Input()\n  public set timeFormat(value: SkyTimepickerTimeFormatType | undefined) {\n    this.#_timeFormat = value || 'hh';\n  }\n\n  public get timeFormat(): SkyTimepickerTimeFormatType {\n    return this.#_timeFormat;\n  }\n\n  /**\n   * The custom time format. For examples,\n   * see the [moment.js](https://momentjs.com/docs/#/displaying/format/) docs.\n   */\n  @Input()\n  public returnFormat: string | undefined;\n\n  /**\n   * Whether to disable the timepicker 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 get disabled(): boolean {\n    return this.#_disabled;\n  }\n\n  public set disabled(value: boolean | undefined) {\n    this.#_disabled = value || false;\n\n    this.#updateTimepickerInput();\n\n    this.#renderer.setProperty(this.#elRef.nativeElement, 'disabled', value);\n  }\n\n  get #modelValue(): SkyTimepickerTimeOutput | undefined {\n    return this.#_modelValue;\n  }\n\n  set #modelValue(value: SkyTimepickerTimeOutput | undefined) {\n    if (value !== this.#_modelValue) {\n      this.#_modelValue = value;\n      this.#updateTimepickerInput();\n      this.#setInputValue(value);\n      this.#_validatorChange();\n      this.#_onChange(value);\n    }\n  }\n\n  #control: AbstractControl | undefined;\n\n  #_disabled = false;\n  #_modelValue: SkyTimepickerTimeOutput | undefined;\n  #_skyTimepickerInput: SkyTimepickerComponent | undefined;\n\n  #renderer: Renderer2;\n  #elRef: ElementRef;\n  #resourcesService: SkyLibResourcesService;\n  #changeDetector: ChangeDetectorRef;\n\n  constructor(\n    renderer: Renderer2,\n    elRef: ElementRef,\n    resourcesService: SkyLibResourcesService,\n    changeDetector: ChangeDetectorRef\n  ) {\n    this.#renderer = renderer;\n    this.#elRef = elRef;\n    this.#resourcesService = resourcesService;\n    this.#changeDetector = changeDetector;\n  }\n\n  public ngOnInit() {\n    this.#renderer.addClass(this.#elRef.nativeElement, 'sky-form-control');\n    this.pickerChangedSubscription =\n      this.skyTimepickerInput?.selectedTimeChanged.subscribe(\n        (newTime: string) => {\n          this.writeValue(newTime);\n          this.#_onTouched();\n        }\n      );\n\n    /* istanbul ignore else */\n    if (!this.#elRef.nativeElement.getAttribute('aria-label')) {\n      this.#resourcesService\n        .getString('skyux_timepicker_input_default_label')\n        .subscribe((value: string) => {\n          this.#renderer.setAttribute(\n            this.#elRef.nativeElement,\n            'aria-label',\n            value\n          );\n        });\n    }\n  }\n\n  public ngAfterContentInit(): void {\n    // Watch for the control to be added and initialize the value immediately.\n    /* istanbul ignore else */\n    if (this.#control && this.#control.parent) {\n      this.#control.setValue(this.#modelValue, {\n        emitEvent: false,\n      });\n      this.#changeDetector.markForCheck();\n    }\n  }\n\n  public ngOnDestroy() {\n    /* istanbul ignore else */\n    if (this.pickerChangedSubscription) {\n      this.pickerChangedSubscription.unsubscribe();\n    }\n  }\n\n  public ngOnChanges() {\n    if (this.skyTimepickerInput) {\n      this.skyTimepickerInput.setFormat(this.timeFormat);\n      this.skyTimepickerInput.returnFormat = this.returnFormat;\n    }\n  }\n\n  @HostListener('change', ['$event'])\n  public onChange(event: any) {\n    this.writeValue(event.target.value);\n  }\n\n  /* istanbul ignore next */\n  @HostListener('blur')\n  public onBlur() {\n    this.#_onTouched();\n  }\n\n  public registerOnChange(fn: (value: any) => any): void {\n    this.#_onChange = fn;\n  }\n  public registerOnTouched(fn: () => any): void {\n    this.#_onTouched = fn;\n  }\n  public registerOnValidatorChange(fn: () => void): void {\n    this.#_validatorChange = fn;\n  }\n\n  public setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  public writeValue(value: any) {\n    this.#modelValue = this.#formatter(value);\n  }\n\n  public validate(control: AbstractControl): ValidationErrors | null {\n    if (!this.#control) {\n      this.#control = control;\n    }\n\n    const value = control.value;\n    if (!value) {\n      return null;\n    }\n\n    /* istanbul ignore next */\n    if (value.local === 'Invalid date') {\n      return {\n        skyTime: {\n          invalid: control.value,\n        },\n      };\n    }\n\n    return null;\n  }\n\n  #setInputValue(value: SkyTimepickerTimeOutput | undefined): void {\n    let formattedValue = '';\n    if (value) {\n      const output = moment(value).format(value.customFormat);\n      /* istanbul ignore else */\n      if (output !== 'Invalid date') {\n        formattedValue = output;\n      }\n    }\n\n    this.#renderer.setProperty(\n      this.#elRef.nativeElement,\n      'value',\n      formattedValue\n    );\n  }\n\n  #formatter(time: any) {\n    if (time && typeof time !== 'string' && 'local' in time) {\n      return time;\n    }\n    if (typeof time === 'string') {\n      if (time.length === 0) {\n        return '';\n      }\n      const currentFormat = this.timeFormat === 'HH' ? 'H:mm' : 'h:mm A';\n\n      if (typeof this.returnFormat === 'undefined') {\n        this.returnFormat = currentFormat;\n      }\n\n      const formatTime: SkyTimepickerTimeOutput = {\n        hour: moment(time, currentFormat).hour(),\n        minute: moment(time, currentFormat).minute(),\n        meridie: moment(time, currentFormat).format('A'),\n        timezone: parseInt(moment(time, currentFormat).format('Z'), 10),\n        iso8601: moment(time, currentFormat).toDate(),\n        local: moment(time, currentFormat).format(currentFormat),\n        customFormat: this.returnFormat,\n      };\n      return formatTime;\n    }\n  }\n\n  #updateTimepickerInput(): void {\n    if (this.skyTimepickerInput) {\n      this.skyTimepickerInput.disabled = this.disabled;\n\n      /* istanbul ignore else */\n      if (this.skyTimepickerInput.selectedTime !== this.#modelValue) {\n        this.skyTimepickerInput.selectedTime = this.#modelValue;\n      }\n    }\n  }\n\n  /* istanbul ignore next */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function, @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any\n  #_onChange = (_: any): void => {};\n  /* istanbul ignore next */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  #_onTouched = (): void => {};\n  /* istanbul ignore next */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  #_validatorChange = (): void => {};\n}\n"]}
226
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/timepicker/timepicker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  HostListener,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\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';\n\nimport moment from 'moment';\nimport { Subscription } from 'rxjs';\n\nimport { SkyTimepickerTimeFormatType } from './timepicker-time-format-type';\nimport { SkyTimepickerTimeOutput } from './timepicker-time-output';\nimport { SkyTimepickerComponent } from './timepicker.component';\n\nconst SKY_TIMEPICKER_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => SkyTimepickerInputDirective),\n  multi: true,\n};\n\nconst SKY_TIMEPICKER_VALIDATOR = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => SkyTimepickerInputDirective),\n  multi: true,\n};\n\n@Directive({\n  selector: '[skyTimepickerInput]',\n  providers: [SKY_TIMEPICKER_VALUE_ACCESSOR, SKY_TIMEPICKER_VALIDATOR],\n})\nexport class SkyTimepickerInputDirective\n  implements\n    OnInit,\n    OnDestroy,\n    ControlValueAccessor,\n    Validator,\n    OnChanges,\n    AfterContentInit\n{\n  public pickerChangedSubscription: Subscription | undefined;\n  #_timeFormat: SkyTimepickerTimeFormatType = 'hh';\n\n  // TODO: In a future breaking change - grab the parent component through dependency injection and remove this setter.\n  /**\n   * Creates the timepicker input field and picker. Place this attribute on an `input` element,\n   * and wrap the input in a `sky-timepicker` component.\n   * This attribute must be set to the instance of the `sky-timepicker`.\n   * @required\n   */\n  @Input()\n  public get skyTimepickerInput(): SkyTimepickerComponent | undefined {\n    return this.#_skyTimepickerInput;\n  }\n\n  public set skyTimepickerInput(value: SkyTimepickerComponent | undefined) {\n    this.#_skyTimepickerInput = value;\n    this.#updateTimepickerInput();\n  }\n\n  // TODO: In a future breaking change - make this more specific than \"string\"\n  /**\n   * The 12-hour `hh` or 24-hour `HH` time format for the input.\n   * @default \"hh\"\n   */\n  @Input()\n  public set timeFormat(value: SkyTimepickerTimeFormatType | undefined) {\n    this.#_timeFormat = value || 'hh';\n  }\n\n  public get timeFormat(): SkyTimepickerTimeFormatType {\n    return this.#_timeFormat;\n  }\n\n  /**\n   * The custom time format. For examples,\n   * see the [moment.js](https://momentjs.com/docs/#/displaying/format/) docs.\n   */\n  @Input()\n  public returnFormat: string | undefined;\n\n  /**\n   * Whether to disable the timepicker 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 get disabled(): boolean {\n    return this.#_disabled;\n  }\n\n  public set disabled(value: boolean | undefined) {\n    this.#_disabled = value || false;\n\n    this.#updateTimepickerInput();\n\n    this.#renderer.setProperty(this.#elRef.nativeElement, 'disabled', value);\n  }\n\n  get #modelValue(): SkyTimepickerTimeOutput | undefined {\n    return this.#_modelValue;\n  }\n\n  set #modelValue(value: SkyTimepickerTimeOutput | undefined) {\n    if (value !== this.#_modelValue) {\n      this.#_modelValue = value;\n      this.#updateTimepickerInput();\n      this.#setInputValue(value);\n      this.#_validatorChange();\n      this.#_onChange(value);\n    }\n  }\n\n  #control: AbstractControl | undefined;\n\n  #_disabled = false;\n  #_modelValue: SkyTimepickerTimeOutput | undefined;\n  #_skyTimepickerInput: SkyTimepickerComponent | undefined;\n\n  #renderer: Renderer2;\n  #elRef: ElementRef;\n  #changeDetector: ChangeDetectorRef;\n\n  constructor(\n    renderer: Renderer2,\n    elRef: ElementRef,\n    changeDetector: ChangeDetectorRef\n  ) {\n    this.#renderer = renderer;\n    this.#elRef = elRef;\n    this.#changeDetector = changeDetector;\n  }\n\n  public ngOnInit() {\n    this.#renderer.addClass(this.#elRef.nativeElement, 'sky-form-control');\n    this.pickerChangedSubscription =\n      this.skyTimepickerInput?.selectedTimeChanged.subscribe(\n        (newTime: string) => {\n          this.writeValue(newTime);\n          this.#_onTouched();\n        }\n      );\n  }\n\n  public ngAfterContentInit(): void {\n    // Watch for the control to be added and initialize the value immediately.\n    /* istanbul ignore else */\n    if (this.#control && this.#control.parent) {\n      this.#control.setValue(this.#modelValue, {\n        emitEvent: false,\n      });\n      this.#changeDetector.markForCheck();\n    }\n  }\n\n  public ngOnDestroy() {\n    /* istanbul ignore else */\n    if (this.pickerChangedSubscription) {\n      this.pickerChangedSubscription.unsubscribe();\n    }\n  }\n\n  public ngOnChanges() {\n    if (this.skyTimepickerInput) {\n      this.skyTimepickerInput.setFormat(this.timeFormat);\n      this.skyTimepickerInput.returnFormat = this.returnFormat;\n    }\n  }\n\n  @HostListener('change', ['$event'])\n  public onChange(event: any) {\n    this.writeValue(event.target.value);\n  }\n\n  /* istanbul ignore next */\n  @HostListener('blur')\n  public onBlur() {\n    this.#_onTouched();\n  }\n\n  public registerOnChange(fn: (value: any) => any): void {\n    this.#_onChange = fn;\n  }\n  public registerOnTouched(fn: () => any): void {\n    this.#_onTouched = fn;\n  }\n  public registerOnValidatorChange(fn: () => void): void {\n    this.#_validatorChange = fn;\n  }\n\n  public setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  public writeValue(value: any) {\n    this.#modelValue = this.#formatter(value);\n  }\n\n  public validate(control: AbstractControl): ValidationErrors | null {\n    if (!this.#control) {\n      this.#control = control;\n    }\n\n    const value = control.value;\n    if (!value) {\n      return null;\n    }\n\n    /* istanbul ignore next */\n    if (value.local === 'Invalid date') {\n      return {\n        skyTime: {\n          invalid: control.value,\n        },\n      };\n    }\n\n    return null;\n  }\n\n  #setInputValue(value: SkyTimepickerTimeOutput | undefined): void {\n    let formattedValue = '';\n    if (value) {\n      const output = moment(value).format(value.customFormat);\n      /* istanbul ignore else */\n      if (output !== 'Invalid date') {\n        formattedValue = output;\n      }\n    }\n\n    this.#renderer.setProperty(\n      this.#elRef.nativeElement,\n      'value',\n      formattedValue\n    );\n  }\n\n  #formatter(time: any) {\n    if (time && typeof time !== 'string' && 'local' in time) {\n      return time;\n    }\n    if (typeof time === 'string') {\n      if (time.length === 0) {\n        return '';\n      }\n      const currentFormat = this.timeFormat === 'HH' ? 'H:mm' : 'h:mm A';\n\n      if (typeof this.returnFormat === 'undefined') {\n        this.returnFormat = currentFormat;\n      }\n\n      const formatTime: SkyTimepickerTimeOutput = {\n        hour: moment(time, currentFormat).hour(),\n        minute: moment(time, currentFormat).minute(),\n        meridie: moment(time, currentFormat).format('A'),\n        timezone: parseInt(moment(time, currentFormat).format('Z'), 10),\n        iso8601: moment(time, currentFormat).toDate(),\n        local: moment(time, currentFormat).format(currentFormat),\n        customFormat: this.returnFormat,\n      };\n      return formatTime;\n    }\n  }\n\n  #updateTimepickerInput(): void {\n    if (this.skyTimepickerInput) {\n      this.skyTimepickerInput.disabled = this.disabled;\n\n      /* istanbul ignore else */\n      if (this.skyTimepickerInput.selectedTime !== this.#modelValue) {\n        this.skyTimepickerInput.selectedTime = this.#modelValue;\n      }\n    }\n  }\n\n  /* istanbul ignore next */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function, @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any\n  #_onChange = (_: any): void => {};\n  /* istanbul ignore next */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  #_onTouched = (): void => {};\n  /* istanbul ignore next */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  #_validatorChange = (): void => {};\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { CommonModule } from '@angular/common';
2
2
  import { NgModule } from '@angular/core';
3
- import { SkyAffixModule, SkyOverlayModule } from '@skyux/core';
3
+ import { SkyAffixModule } from '@skyux/core';
4
4
  import { SkyIconModule } from '@skyux/indicators';
5
5
  import { SkyThemeModule } from '@skyux/theme';
6
6
  import { SkyDatetimeResourcesModule } from '../shared/sky-datetime-resources.module';
@@ -13,13 +13,11 @@ export class SkyTimepickerModule {
13
13
  SkyIconModule,
14
14
  SkyDatetimeResourcesModule,
15
15
  SkyAffixModule,
16
- SkyOverlayModule,
17
16
  SkyThemeModule], exports: [SkyTimepickerInputDirective, SkyTimepickerComponent] }); }
18
17
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyTimepickerModule, imports: [CommonModule,
19
18
  SkyIconModule,
20
19
  SkyDatetimeResourcesModule,
21
20
  SkyAffixModule,
22
- SkyOverlayModule,
23
21
  SkyThemeModule] }); }
24
22
  }
25
23
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyTimepickerModule, decorators: [{
@@ -31,10 +29,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
31
29
  SkyIconModule,
32
30
  SkyDatetimeResourcesModule,
33
31
  SkyAffixModule,
34
- SkyOverlayModule,
35
32
  SkyThemeModule,
36
33
  ],
37
34
  exports: [SkyTimepickerInputDirective, SkyTimepickerComponent],
38
35
  }]
39
36
  }] });
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZXBpY2tlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZGF0ZXRpbWUvc3JjL2xpYi9tb2R1bGVzL3RpbWVwaWNrZXIvdGltZXBpY2tlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGNBQWMsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUMvRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDbEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUU5QyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUVyRixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUNoRSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFjckUsTUFBTSxPQUFPLG1CQUFtQjs4R0FBbkIsbUJBQW1COytHQUFuQixtQkFBbUIsaUJBWGYsMkJBQTJCLEVBQUUsc0JBQXNCLGFBRWhFLFlBQVk7WUFDWixhQUFhO1lBQ2IsMEJBQTBCO1lBQzFCLGNBQWM7WUFDZCxnQkFBZ0I7WUFDaEIsY0FBYyxhQUVOLDJCQUEyQixFQUFFLHNCQUFzQjsrR0FFbEQsbUJBQW1CLFlBVDVCLFlBQVk7WUFDWixhQUFhO1lBQ2IsMEJBQTBCO1lBQzFCLGNBQWM7WUFDZCxnQkFBZ0I7WUFDaEIsY0FBYzs7MkZBSUwsbUJBQW1CO2tCQVovQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLDJCQUEyQixFQUFFLHNCQUFzQixDQUFDO29CQUNuRSxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixhQUFhO3dCQUNiLDBCQUEwQjt3QkFDMUIsY0FBYzt3QkFDZCxnQkFBZ0I7d0JBQ2hCLGNBQWM7cUJBQ2Y7b0JBQ0QsT0FBTyxFQUFFLENBQUMsMkJBQTJCLEVBQUUsc0JBQXNCLENBQUM7aUJBQy9EIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTa3lBZmZpeE1vZHVsZSwgU2t5T3ZlcmxheU1vZHVsZSB9IGZyb20gJ0Bza3l1eC9jb3JlJztcbmltcG9ydCB7IFNreUljb25Nb2R1bGUgfSBmcm9tICdAc2t5dXgvaW5kaWNhdG9ycyc7XG5pbXBvcnQgeyBTa3lUaGVtZU1vZHVsZSB9IGZyb20gJ0Bza3l1eC90aGVtZSc7XG5cbmltcG9ydCB7IFNreURhdGV0aW1lUmVzb3VyY2VzTW9kdWxlIH0gZnJvbSAnLi4vc2hhcmVkL3NreS1kYXRldGltZS1yZXNvdXJjZXMubW9kdWxlJztcblxuaW1wb3J0IHsgU2t5VGltZXBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vdGltZXBpY2tlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2t5VGltZXBpY2tlcklucHV0RGlyZWN0aXZlIH0gZnJvbSAnLi90aW1lcGlja2VyLmRpcmVjdGl2ZSc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1NreVRpbWVwaWNrZXJJbnB1dERpcmVjdGl2ZSwgU2t5VGltZXBpY2tlckNvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgU2t5SWNvbk1vZHVsZSxcbiAgICBTa3lEYXRldGltZVJlc291cmNlc01vZHVsZSxcbiAgICBTa3lBZmZpeE1vZHVsZSxcbiAgICBTa3lPdmVybGF5TW9kdWxlLFxuICAgIFNreVRoZW1lTW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbU2t5VGltZXBpY2tlcklucHV0RGlyZWN0aXZlLCBTa3lUaW1lcGlja2VyQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5VGltZXBpY2tlck1vZHVsZSB7fVxuIl19
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZXBpY2tlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZGF0ZXRpbWUvc3JjL2xpYi9tb2R1bGVzL3RpbWVwaWNrZXIvdGltZXBpY2tlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUM3QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDbEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUU5QyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUVyRixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUNoRSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFhckUsTUFBTSxPQUFPLG1CQUFtQjs4R0FBbkIsbUJBQW1COytHQUFuQixtQkFBbUIsaUJBVmYsMkJBQTJCLEVBQUUsc0JBQXNCLGFBRWhFLFlBQVk7WUFDWixhQUFhO1lBQ2IsMEJBQTBCO1lBQzFCLGNBQWM7WUFDZCxjQUFjLGFBRU4sMkJBQTJCLEVBQUUsc0JBQXNCOytHQUVsRCxtQkFBbUIsWUFSNUIsWUFBWTtZQUNaLGFBQWE7WUFDYiwwQkFBMEI7WUFDMUIsY0FBYztZQUNkLGNBQWM7OzJGQUlMLG1CQUFtQjtrQkFYL0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQywyQkFBMkIsRUFBRSxzQkFBc0IsQ0FBQztvQkFDbkUsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osYUFBYTt3QkFDYiwwQkFBMEI7d0JBQzFCLGNBQWM7d0JBQ2QsY0FBYztxQkFDZjtvQkFDRCxPQUFPLEVBQUUsQ0FBQywyQkFBMkIsRUFBRSxzQkFBc0IsQ0FBQztpQkFDL0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNreUFmZml4TW9kdWxlIH0gZnJvbSAnQHNreXV4L2NvcmUnO1xuaW1wb3J0IHsgU2t5SWNvbk1vZHVsZSB9IGZyb20gJ0Bza3l1eC9pbmRpY2F0b3JzJztcbmltcG9ydCB7IFNreVRoZW1lTW9kdWxlIH0gZnJvbSAnQHNreXV4L3RoZW1lJztcblxuaW1wb3J0IHsgU2t5RGF0ZXRpbWVSZXNvdXJjZXNNb2R1bGUgfSBmcm9tICcuLi9zaGFyZWQvc2t5LWRhdGV0aW1lLXJlc291cmNlcy5tb2R1bGUnO1xuXG5pbXBvcnQgeyBTa3lUaW1lcGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi90aW1lcGlja2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTa3lUaW1lcGlja2VySW5wdXREaXJlY3RpdmUgfSBmcm9tICcuL3RpbWVwaWNrZXIuZGlyZWN0aXZlJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbU2t5VGltZXBpY2tlcklucHV0RGlyZWN0aXZlLCBTa3lUaW1lcGlja2VyQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBTa3lJY29uTW9kdWxlLFxuICAgIFNreURhdGV0aW1lUmVzb3VyY2VzTW9kdWxlLFxuICAgIFNreUFmZml4TW9kdWxlLFxuICAgIFNreVRoZW1lTW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbU2t5VGltZXBpY2tlcklucHV0RGlyZWN0aXZlLCBTa3lUaW1lcGlja2VyQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5VGltZXBpY2tlck1vZHVsZSB7fVxuIl19
@@ -1,7 +1,7 @@
1
1
  import * as i0 from '@angular/core';
2
- import { inject, Injectable, Pipe, NgModule, EventEmitter, Component, ViewEncapsulation, Input, Output, ChangeDetectionStrategy, ViewChild, ElementRef, TemplateRef, Optional, Inject, forwardRef, Directive, HostListener } from '@angular/core';
2
+ import { inject, Injectable, Pipe, NgModule, EventEmitter, Component, ViewEncapsulation, Input, Output, ChangeDetectionStrategy, ViewChild, EnvironmentInjector, ElementRef, TemplateRef, Optional, Inject, forwardRef, Directive, HostListener } from '@angular/core';
3
3
  import * as i3 from '@skyux/i18n';
4
- import { SkyAppLocaleProvider, SkyIntlDateFormatter, getLibStringForLocale, SkyI18nModule, SKY_LIB_RESOURCES_PROVIDERS } from '@skyux/i18n';
4
+ import { SkyAppLocaleProvider, SkyIntlDateFormatter, SkyLibResourcesService, getLibStringForLocale, SkyI18nModule, SKY_LIB_RESOURCES_PROVIDERS } from '@skyux/i18n';
5
5
  import { Subject, fromEvent, BehaviorSubject, forkJoin, combineLatest } from 'rxjs';
6
6
  import { takeUntil, debounceTime, distinctUntilChanged, first, map } from 'rxjs/operators';
7
7
  import moment from 'moment';
@@ -12,7 +12,7 @@ import { NG_VALUE_ACCESSOR, NG_VALIDATORS, FormsModule, UntypedFormControl, Reac
12
12
  import * as i2$1 from '@skyux/forms';
13
13
  import { SkyInputBoxModule } from '@skyux/forms';
14
14
  import * as i1 from '@skyux/core';
15
- import { SkyAffixAutoFitContext, SKY_STACKING_CONTEXT, SkyAffixModule, SkyOverlayModule } from '@skyux/core';
15
+ import { SkyAffixAutoFitContext, SKY_STACKING_CONTEXT, SkyAffixModule } from '@skyux/core';
16
16
  import * as i3$1 from '@skyux/indicators';
17
17
  import { SkyIconModule, SkyWaitModule } from '@skyux/indicators';
18
18
  import * as i4 from '@skyux/popovers';
@@ -78,10 +78,13 @@ class SkyDateService {
78
78
  return SkyIntlDateFormatter.format(date, locale || this.#defaultLocale, this.#ALIASES[pattern] || pattern);
79
79
  }
80
80
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyDateService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
81
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyDateService }); }
81
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyDateService, providedIn: 'root' }); }
82
82
  }
83
83
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyDateService, decorators: [{
84
- type: Injectable
84
+ type: Injectable,
85
+ args: [{
86
+ providedIn: 'root',
87
+ }]
85
88
  }], ctorParameters: function () { return []; } });
86
89
  function isBlank(obj) {
87
90
  return !obj;
@@ -149,6 +152,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
149
152
  }]
150
153
  }], ctorParameters: function () { return []; } });
151
154
 
155
+ /* istanbul ignore file */
152
156
  /**
153
157
  * NOTICE: DO NOT MODIFY THIS FILE!
154
158
  * The contents of this file were automatically generated by
@@ -190,11 +194,9 @@ const RESOURCES = {
190
194
  },
191
195
  },
192
196
  'EN-US': {
193
- skyux_date_field_default_label: { message: 'Date' },
194
197
  skyux_datepicker_trigger_button_label: { message: 'Select date' },
195
198
  skyux_timepicker_button_label: { message: 'Choose time' },
196
199
  skyux_timepicker_close: { message: 'Done' },
197
- skyux_timepicker_input_default_label: { message: 'Time' },
198
200
  skyux_date_range_picker_default_label: { message: 'Select a date range' },
199
201
  skyux_date_range_picker_format_label_specific_range: {
200
202
  message: 'Specific range',
@@ -244,6 +246,7 @@ const RESOURCES = {
244
246
  skyux_date_range_picker_after_date_label: { message: 'After date' },
245
247
  },
246
248
  };
249
+ SkyLibResourcesService.addResources(RESOURCES);
247
250
  class SkyDatetimeResourcesProvider {
248
251
  getString(localeInfo, name) {
249
252
  return getLibStringForLocale(RESOURCES, localeInfo.locale, name);
@@ -730,13 +733,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
730
733
  class SkyDatePipeModule {
731
734
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyDatePipeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
732
735
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.1", ngImport: i0, type: SkyDatePipeModule, declarations: [SkyDatePipe, SkyFuzzyDatePipe], imports: [CommonModule, SkyDatetimeResourcesModule], exports: [SkyDatePipe, SkyFuzzyDatePipe] }); }
733
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyDatePipeModule, providers: [SkyDatePipe, SkyFuzzyDatePipe, SkyDateService], imports: [CommonModule, SkyDatetimeResourcesModule] }); }
736
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyDatePipeModule, providers: [SkyDatePipe, SkyFuzzyDatePipe], imports: [CommonModule, SkyDatetimeResourcesModule] }); }
734
737
  }
735
738
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyDatePipeModule, decorators: [{
736
739
  type: NgModule,
737
740
  args: [{
738
741
  declarations: [SkyDatePipe, SkyFuzzyDatePipe],
739
- providers: [SkyDatePipe, SkyFuzzyDatePipe, SkyDateService],
742
+ providers: [SkyDatePipe, SkyFuzzyDatePipe],
740
743
  imports: [CommonModule, SkyDatetimeResourcesModule],
741
744
  exports: [SkyDatePipe, SkyFuzzyDatePipe],
742
745
  }]
@@ -2009,6 +2012,7 @@ class SkyDatepickerComponent {
2009
2012
  #affixService;
2010
2013
  #changeDetector;
2011
2014
  #coreAdapter;
2015
+ #environmentInjector;
2012
2016
  #overlayService;
2013
2017
  #zIndex;
2014
2018
  constructor(affixService, changeDetector, coreAdapter, overlayService, inputBoxHostService, themeSvc, stackingContext) {
@@ -2035,6 +2039,7 @@ class SkyDatepickerComponent {
2035
2039
  this.#calendarUnsubscribe = new Subject();
2036
2040
  this.#ngUnsubscribe = new Subject();
2037
2041
  this.#_disabled = false;
2042
+ this.#environmentInjector = inject(EnvironmentInjector);
2038
2043
  this.#affixService = affixService;
2039
2044
  this.#changeDetector = changeDetector;
2040
2045
  this.#coreAdapter = coreAdapter;
@@ -2172,6 +2177,7 @@ class SkyDatepickerComponent {
2172
2177
  wrapperClass: this.pickerClass,
2173
2178
  enableClose: false,
2174
2179
  enablePointerEvents: false,
2180
+ environmentInjector: this.#environmentInjector,
2175
2181
  });
2176
2182
  if (this.#zIndex) {
2177
2183
  this.#zIndex
@@ -2408,9 +2414,8 @@ class SkyFuzzyDatepickerInputDirective {
2408
2414
  #elementRef;
2409
2415
  #fuzzyDateService;
2410
2416
  #renderer;
2411
- #resourcesService;
2412
2417
  #datepickerComponent;
2413
- constructor(changeDetector, configService, elementRef, fuzzyDateService, localeProvider, renderer, resourcesService, datepickerComponent) {
2418
+ constructor(changeDetector, configService, elementRef, fuzzyDateService, localeProvider, renderer, datepickerComponent) {
2414
2419
  /**
2415
2420
  * Whether to disable date validation on the fuzzy datepicker input.
2416
2421
  * @default false
@@ -2439,7 +2444,6 @@ class SkyFuzzyDatepickerInputDirective {
2439
2444
  this.#elementRef = elementRef;
2440
2445
  this.#fuzzyDateService = fuzzyDateService;
2441
2446
  this.#renderer = renderer;
2442
- this.#resourcesService = resourcesService;
2443
2447
  this.#datepickerComponent = datepickerComponent;
2444
2448
  this.#locale = localeProvider.defaultLocale;
2445
2449
  localeProvider
@@ -2460,16 +2464,6 @@ class SkyFuzzyDatepickerInputDirective {
2460
2464
  }
2461
2465
  const element = this.#elementRef.nativeElement;
2462
2466
  this.#renderer.addClass(element, 'sky-form-control');
2463
- const hasAriaLabel = element.getAttribute('aria-label');
2464
- /* istanbul ignore else */
2465
- if (!hasAriaLabel) {
2466
- this.#resourcesService
2467
- .getString('skyux_date_field_default_label')
2468
- .pipe(takeUntil(this.#ngUnsubscribe))
2469
- .subscribe((value) => {
2470
- this.#renderer.setAttribute(element, 'aria-label', value);
2471
- });
2472
- }
2473
2467
  }
2474
2468
  ngAfterContentInit() {
2475
2469
  this.#datepickerComponent.dateChange
@@ -2708,7 +2702,7 @@ class SkyFuzzyDatepickerInputDirective {
2708
2702
  }
2709
2703
  this.#setInputElementValue(formattedDate || '');
2710
2704
  }
2711
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyFuzzyDatepickerInputDirective, deps: [{ token: i0.ChangeDetectorRef }, { token: SkyDatepickerConfigService }, { token: i0.ElementRef }, { token: SkyFuzzyDateService }, { token: i3.SkyAppLocaleProvider }, { token: i0.Renderer2 }, { token: i3.SkyLibResourcesService }, { token: SkyDatepickerComponent, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
2705
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyFuzzyDatepickerInputDirective, deps: [{ token: i0.ChangeDetectorRef }, { token: SkyDatepickerConfigService }, { token: i0.ElementRef }, { token: SkyFuzzyDateService }, { token: i3.SkyAppLocaleProvider }, { token: i0.Renderer2 }, { token: SkyDatepickerComponent, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
2712
2706
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.1", type: SkyFuzzyDatepickerInputDirective, selector: "[skyFuzzyDatepickerInput]", inputs: { dateFormat: "dateFormat", disabled: "disabled", futureDisabled: "futureDisabled", maxDate: "maxDate", minDate: "minDate", skyDatepickerNoValidate: "skyDatepickerNoValidate", startingDay: "startingDay", yearRequired: "yearRequired" }, host: { listeners: { "change": "onInputChange($event)", "blur": "onInputBlur()", "input": "onInput()" } }, providers: [
2713
2707
  SKY_FUZZY_DATEPICKER_VALUE_ACCESSOR,
2714
2708
  SKY_FUZZY_DATEPICKER_VALIDATOR,
@@ -2723,7 +2717,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
2723
2717
  SKY_FUZZY_DATEPICKER_VALIDATOR,
2724
2718
  ],
2725
2719
  }]
2726
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: SkyDatepickerConfigService }, { type: i0.ElementRef }, { type: SkyFuzzyDateService }, { type: i3.SkyAppLocaleProvider }, { type: i0.Renderer2 }, { type: i3.SkyLibResourcesService }, { type: SkyDatepickerComponent, decorators: [{
2720
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: SkyDatepickerConfigService }, { type: i0.ElementRef }, { type: SkyFuzzyDateService }, { type: i3.SkyAppLocaleProvider }, { type: i0.Renderer2 }, { type: SkyDatepickerComponent, decorators: [{
2727
2721
  type: Optional
2728
2722
  }] }]; }, propDecorators: { dateFormat: [{
2729
2723
  type: Input
@@ -2888,9 +2882,8 @@ class SkyDatepickerInputDirective {
2888
2882
  #elementRef;
2889
2883
  #localeProvider;
2890
2884
  #renderer;
2891
- #resourcesService;
2892
2885
  #datepickerComponent;
2893
- constructor(adapter, changeDetector, configService, elementRef, localeProvider, renderer, resourcesService, datepickerComponent) {
2886
+ constructor(adapter, changeDetector, configService, elementRef, localeProvider, renderer, datepickerComponent) {
2894
2887
  /**
2895
2888
  * Whether to disable date validation on the datepicker input.
2896
2889
  * @default false
@@ -2919,7 +2912,6 @@ class SkyDatepickerInputDirective {
2919
2912
  this.#elementRef = elementRef;
2920
2913
  this.#localeProvider = localeProvider;
2921
2914
  this.#renderer = renderer;
2922
- this.#resourcesService = resourcesService;
2923
2915
  this.#datepickerComponent = datepickerComponent;
2924
2916
  this.#initialPlaceholder = this.#adapter.getPlaceholder(this.#elementRef);
2925
2917
  this.#updatePlaceholder();
@@ -2936,15 +2928,6 @@ class SkyDatepickerInputDirective {
2936
2928
  ngOnInit() {
2937
2929
  const element = this.#elementRef.nativeElement;
2938
2930
  this.#renderer.addClass(element, 'sky-form-control');
2939
- const hasAriaLabel = element.getAttribute('aria-label');
2940
- if (!hasAriaLabel) {
2941
- this.#resourcesService
2942
- .getString('skyux_date_field_default_label')
2943
- .pipe(takeUntil(this.#ngUnsubscribe))
2944
- .subscribe((value) => {
2945
- this.#renderer.setAttribute(element, 'aria-label', value);
2946
- });
2947
- }
2948
2931
  }
2949
2932
  ngAfterContentInit() {
2950
2933
  this.#datepickerComponent.dateChange
@@ -3228,7 +3211,7 @@ class SkyDatepickerInputDirective {
3228
3211
  }
3229
3212
  }
3230
3213
  }
3231
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyDatepickerInputDirective, deps: [{ token: SkyDatepickerAdapterService }, { token: i0.ChangeDetectorRef }, { token: SkyDatepickerConfigService }, { token: i0.ElementRef }, { token: i3.SkyAppLocaleProvider }, { token: i0.Renderer2 }, { token: i3.SkyLibResourcesService }, { token: SkyDatepickerComponent, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
3214
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyDatepickerInputDirective, deps: [{ token: SkyDatepickerAdapterService }, { token: i0.ChangeDetectorRef }, { token: SkyDatepickerConfigService }, { token: i0.ElementRef }, { token: i3.SkyAppLocaleProvider }, { token: i0.Renderer2 }, { token: SkyDatepickerComponent, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
3232
3215
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.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: [
3233
3216
  SKY_DATEPICKER_VALUE_ACCESSOR,
3234
3217
  SKY_DATEPICKER_VALIDATOR,
@@ -3245,7 +3228,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
3245
3228
  SkyDatepickerAdapterService,
3246
3229
  ],
3247
3230
  }]
3248
- }], ctorParameters: function () { return [{ type: SkyDatepickerAdapterService }, { type: i0.ChangeDetectorRef }, { type: SkyDatepickerConfigService }, { type: i0.ElementRef }, { type: i3.SkyAppLocaleProvider }, { type: i0.Renderer2 }, { type: i3.SkyLibResourcesService }, { type: SkyDatepickerComponent, decorators: [{
3231
+ }], ctorParameters: function () { return [{ type: SkyDatepickerAdapterService }, { type: i0.ChangeDetectorRef }, { type: SkyDatepickerConfigService }, { type: i0.ElementRef }, { type: i3.SkyAppLocaleProvider }, { type: i0.Renderer2 }, { type: SkyDatepickerComponent, decorators: [{
3249
3232
  type: Optional
3250
3233
  }] }]; }, propDecorators: { dateFormat: [{
3251
3234
  type: Input
@@ -3290,7 +3273,6 @@ class SkyDatepickerModule {
3290
3273
  SkyIconModule,
3291
3274
  SkyDatetimeResourcesModule,
3292
3275
  SkyAffixModule,
3293
- SkyOverlayModule,
3294
3276
  SkyThemeModule,
3295
3277
  SkyPopoverModule,
3296
3278
  SkyWaitModule], exports: [SkyDatepickerCalendarComponent,
@@ -3302,7 +3284,6 @@ class SkyDatepickerModule {
3302
3284
  SkyIconModule,
3303
3285
  SkyDatetimeResourcesModule,
3304
3286
  SkyAffixModule,
3305
- SkyOverlayModule,
3306
3287
  SkyThemeModule,
3307
3288
  SkyPopoverModule,
3308
3289
  SkyWaitModule] }); }
@@ -3328,7 +3309,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
3328
3309
  SkyIconModule,
3329
3310
  SkyDatetimeResourcesModule,
3330
3311
  SkyAffixModule,
3331
- SkyOverlayModule,
3332
3312
  SkyThemeModule,
3333
3313
  SkyPopoverModule,
3334
3314
  SkyWaitModule,
@@ -4521,6 +4501,7 @@ class SkyTimepickerComponent {
4521
4501
  #affixService;
4522
4502
  #changeDetector;
4523
4503
  #coreAdapter;
4504
+ #environmentInjector;
4524
4505
  #overlayService;
4525
4506
  #zIndex;
4526
4507
  constructor(affixService, changeDetector, coreAdapter, overlayService, inputBoxHostService, themeSvc, stackingContext) {
@@ -4540,6 +4521,7 @@ class SkyTimepickerComponent {
4540
4521
  this.#timepickerUnsubscribe = new Subject();
4541
4522
  this.#ngUnsubscribe = new Subject();
4542
4523
  this.#_disabled = false;
4524
+ this.#environmentInjector = inject(EnvironmentInjector);
4543
4525
  this.#affixService = affixService;
4544
4526
  this.#changeDetector = changeDetector;
4545
4527
  this.#coreAdapter = coreAdapter;
@@ -4689,6 +4671,7 @@ class SkyTimepickerComponent {
4689
4671
  const overlay = this.#overlayService.create({
4690
4672
  enableClose: false,
4691
4673
  enablePointerEvents: false,
4674
+ environmentInjector: this.#environmentInjector,
4692
4675
  });
4693
4676
  if (this.#zIndex) {
4694
4677
  this.#zIndex
@@ -4852,12 +4835,10 @@ class SkyTimepickerInputDirective {
4852
4835
  #_skyTimepickerInput;
4853
4836
  #renderer;
4854
4837
  #elRef;
4855
- #resourcesService;
4856
4838
  #changeDetector;
4857
- constructor(renderer, elRef, resourcesService, changeDetector) {
4839
+ constructor(renderer, elRef, changeDetector) {
4858
4840
  this.#renderer = renderer;
4859
4841
  this.#elRef = elRef;
4860
- this.#resourcesService = resourcesService;
4861
4842
  this.#changeDetector = changeDetector;
4862
4843
  }
4863
4844
  ngOnInit() {
@@ -4867,14 +4848,6 @@ class SkyTimepickerInputDirective {
4867
4848
  this.writeValue(newTime);
4868
4849
  this.#_onTouched();
4869
4850
  });
4870
- /* istanbul ignore else */
4871
- if (!this.#elRef.nativeElement.getAttribute('aria-label')) {
4872
- this.#resourcesService
4873
- .getString('skyux_timepicker_input_default_label')
4874
- .subscribe((value) => {
4875
- this.#renderer.setAttribute(this.#elRef.nativeElement, 'aria-label', value);
4876
- });
4877
- }
4878
4851
  }
4879
4852
  ngAfterContentInit() {
4880
4853
  // Watch for the control to be added and initialize the value immediately.
@@ -4991,7 +4964,7 @@ class SkyTimepickerInputDirective {
4991
4964
  /* istanbul ignore next */
4992
4965
  // eslint-disable-next-line @typescript-eslint/no-empty-function
4993
4966
  #_validatorChange = () => { };
4994
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyTimepickerInputDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i3.SkyLibResourcesService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
4967
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyTimepickerInputDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
4995
4968
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.1", type: SkyTimepickerInputDirective, selector: "[skyTimepickerInput]", inputs: { skyTimepickerInput: "skyTimepickerInput", timeFormat: "timeFormat", returnFormat: "returnFormat", disabled: "disabled" }, host: { listeners: { "change": "onChange($event)", "blur": "onBlur()" } }, providers: [SKY_TIMEPICKER_VALUE_ACCESSOR, SKY_TIMEPICKER_VALIDATOR], usesOnChanges: true, ngImport: i0 }); }
4996
4969
  }
4997
4970
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyTimepickerInputDirective, decorators: [{
@@ -5000,7 +4973,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
5000
4973
  selector: '[skyTimepickerInput]',
5001
4974
  providers: [SKY_TIMEPICKER_VALUE_ACCESSOR, SKY_TIMEPICKER_VALIDATOR],
5002
4975
  }]
5003
- }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i3.SkyLibResourcesService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { skyTimepickerInput: [{
4976
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { skyTimepickerInput: [{
5004
4977
  type: Input
5005
4978
  }], timeFormat: [{
5006
4979
  type: Input
@@ -5022,13 +4995,11 @@ class SkyTimepickerModule {
5022
4995
  SkyIconModule,
5023
4996
  SkyDatetimeResourcesModule,
5024
4997
  SkyAffixModule,
5025
- SkyOverlayModule,
5026
4998
  SkyThemeModule], exports: [SkyTimepickerInputDirective, SkyTimepickerComponent] }); }
5027
4999
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyTimepickerModule, imports: [CommonModule,
5028
5000
  SkyIconModule,
5029
5001
  SkyDatetimeResourcesModule,
5030
5002
  SkyAffixModule,
5031
- SkyOverlayModule,
5032
5003
  SkyThemeModule] }); }
5033
5004
  }
5034
5005
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SkyTimepickerModule, decorators: [{
@@ -5040,7 +5011,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
5040
5011
  SkyIconModule,
5041
5012
  SkyDatetimeResourcesModule,
5042
5013
  SkyAffixModule,
5043
- SkyOverlayModule,
5044
5014
  SkyThemeModule,
5045
5015
  ],
5046
5016
  exports: [SkyTimepickerInputDirective, SkyTimepickerComponent],