@skyux/datetime 11.31.0 → 12.0.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (65) hide show
  1. package/documentation.json +925 -917
  2. package/fesm2022/skyux-datetime.mjs +105 -102
  3. package/fesm2022/skyux-datetime.mjs.map +1 -1
  4. package/package.json +15 -19
  5. package/esm2022/index.mjs +0 -23
  6. package/esm2022/lib/modules/date-pipe/date-pipe.module.mjs +0 -20
  7. package/esm2022/lib/modules/date-pipe/date.pipe.mjs +0 -68
  8. package/esm2022/lib/modules/date-pipe/date.service.mjs +0 -94
  9. package/esm2022/lib/modules/date-pipe/fuzzy-date.pipe.mjs +0 -47
  10. package/esm2022/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +0 -21
  11. package/esm2022/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +0 -21
  12. package/esm2022/lib/modules/date-range-picker/date-range-picker.component.mjs +0 -445
  13. package/esm2022/lib/modules/date-range-picker/date-range-picker.module.mjs +0 -17
  14. package/esm2022/lib/modules/date-range-picker/date-range.service.mjs +0 -95
  15. package/esm2022/lib/modules/date-range-picker/types/date-range-calculation.mjs +0 -2
  16. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-config.mjs +0 -2
  17. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +0 -2
  18. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-id.mjs +0 -118
  19. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-type.mjs +0 -23
  20. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +0 -2
  21. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator.mjs +0 -71
  22. package/esm2022/lib/modules/date-range-picker/types/date-range-default-calculator-config.mjs +0 -2
  23. package/esm2022/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +0 -173
  24. package/esm2022/lib/modules/date-range-picker/types/date-range-relative-value.mjs +0 -249
  25. package/esm2022/lib/modules/date-range-picker/types/date-range.mjs +0 -2
  26. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar-change.mjs +0 -2
  27. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar-inner.component.mjs +0 -383
  28. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar-label.pipe.mjs +0 -39
  29. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar.component.mjs +0 -100
  30. package/esm2022/lib/modules/datepicker/calendar/datepicker-calendar.service.mjs +0 -22
  31. package/esm2022/lib/modules/datepicker/calendar/daypicker-button.component.mjs +0 -23
  32. package/esm2022/lib/modules/datepicker/calendar/daypicker-cell.component.mjs +0 -129
  33. package/esm2022/lib/modules/datepicker/calendar/daypicker-context.mjs +0 -2
  34. package/esm2022/lib/modules/datepicker/calendar/daypicker.component.mjs +0 -221
  35. package/esm2022/lib/modules/datepicker/calendar/monthpicker.component.mjs +0 -80
  36. package/esm2022/lib/modules/datepicker/calendar/yearpicker.component.mjs +0 -87
  37. package/esm2022/lib/modules/datepicker/date-formatter.mjs +0 -38
  38. package/esm2022/lib/modules/datepicker/datepicker-config.service.mjs +0 -21
  39. package/esm2022/lib/modules/datepicker/datepicker-custom-date.mjs +0 -2
  40. package/esm2022/lib/modules/datepicker/datepicker-host.service.mjs +0 -61
  41. package/esm2022/lib/modules/datepicker/datepicker-input.directive.mjs +0 -526
  42. package/esm2022/lib/modules/datepicker/datepicker.component.mjs +0 -419
  43. package/esm2022/lib/modules/datepicker/datepicker.module.mjs +0 -62
  44. package/esm2022/lib/modules/datepicker/fuzzy/datepicker-input-fuzzy.directive.mjs +0 -516
  45. package/esm2022/lib/modules/datepicker/fuzzy/fuzzy-date.mjs +0 -2
  46. package/esm2022/lib/modules/datepicker/fuzzy/fuzzy-date.service.mjs +0 -411
  47. package/esm2022/lib/modules/shared/sky-datetime-resources.module.mjs +0 -130
  48. package/esm2022/lib/modules/timepicker/timepicker-time-format-type.mjs +0 -2
  49. package/esm2022/lib/modules/timepicker/timepicker-time-output.mjs +0 -2
  50. package/esm2022/lib/modules/timepicker/timepicker.component.mjs +0 -415
  51. package/esm2022/lib/modules/timepicker/timepicker.directive.mjs +0 -226
  52. package/esm2022/lib/modules/timepicker/timepicker.module.mjs +0 -37
  53. package/esm2022/skyux-datetime.mjs +0 -5
  54. package/esm2022/testing/legacy/datepicker-fixture.mjs +0 -56
  55. package/esm2022/testing/legacy/timepicker-fixture.mjs +0 -52
  56. package/esm2022/testing/modules/date-range-picker/date-range-picker-harness.filters.mjs +0 -2
  57. package/esm2022/testing/modules/date-range-picker/date-range-picker-harness.mjs +0 -193
  58. package/esm2022/testing/modules/datepicker/datepicker-calendar-harness.filters.mjs +0 -2
  59. package/esm2022/testing/modules/datepicker/datepicker-calendar-harness.mjs +0 -88
  60. package/esm2022/testing/modules/datepicker/datepicker-harness.filters.mjs +0 -2
  61. package/esm2022/testing/modules/datepicker/datepicker-harness.mjs +0 -60
  62. package/esm2022/testing/modules/datepicker/datepicker-input-harness.mjs +0 -29
  63. package/esm2022/testing/modules/datepicker/fuzzy-datepicker-input-harness.mjs +0 -29
  64. package/esm2022/testing/public-api.mjs +0 -6
  65. package/esm2022/testing/skyux-datetime-testing.mjs +0 -5
@@ -1,100 +0,0 @@
1
- import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
- import { SkyDateFormatter } from '../date-formatter';
3
- import { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';
4
- import { SkyDayPickerComponent } from './daypicker.component';
5
- import { SkyMonthPickerComponent } from './monthpicker.component';
6
- import { SkyYearPickerComponent } from './yearpicker.component';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "../datepicker-config.service";
9
- /**
10
- * @internal
11
- */
12
- export class SkyDatepickerCalendarComponent {
13
- /** starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday) */
14
- set startingDay(start) {
15
- this.#_startingDay = start ?? 0;
16
- }
17
- get startingDay() {
18
- return this.#_startingDay;
19
- }
20
- #formatter;
21
- #_startingDay;
22
- #config;
23
- constructor(config) {
24
- this.calendarDateRangeChange = new EventEmitter();
25
- this.calendarModeChange = new EventEmitter();
26
- this.selectedDateChange = new EventEmitter(undefined);
27
- this._now = new Date();
28
- this.#formatter = new SkyDateFormatter();
29
- this.#_startingDay = 0;
30
- this.#config = config;
31
- this.configureOptions();
32
- }
33
- configureOptions() {
34
- Object.assign(this, this.#config);
35
- }
36
- onCalendarDateRangeChange(event) {
37
- this.calendarDateRangeChange.next(event);
38
- }
39
- onCalendarModeChange(event) {
40
- this.calendarModeChange.emit(event);
41
- }
42
- onSelectedDateChange(event) {
43
- this.selectedDateChange.emit(event);
44
- }
45
- writeValue(value) {
46
- if (value !== undefined &&
47
- this.#formatter.dateIsValid(value) &&
48
- this.selectedDate !== undefined &&
49
- this.datepicker?.compareHandlerDay &&
50
- this.datepicker.compareHandlerDay(value, this.selectedDate) === 0) {
51
- return;
52
- }
53
- if (value && this.#formatter.dateIsValid(value)) {
54
- this.selectedDate = value;
55
- this.datepicker?.select(value, false);
56
- }
57
- else {
58
- this.selectedDate = this.startAtDate ?? new Date();
59
- this.datepicker?.select(this.startAtDate ?? new Date(), false);
60
- }
61
- }
62
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDatepickerCalendarComponent, deps: [{ token: i1.SkyDatepickerConfigService }], target: i0.ɵɵFactoryTarget.Component }); }
63
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: SkyDatepickerCalendarComponent, isStandalone: true, selector: "sky-datepicker-calendar", inputs: { customDates: "customDates", isDaypickerWaiting: "isDaypickerWaiting", minDate: "minDate", maxDate: "maxDate", startAtDate: "startAtDate", selectedDate: "selectedDate", startingDay: "startingDay" }, outputs: { calendarDateRangeChange: "calendarDateRangeChange", calendarModeChange: "calendarModeChange", selectedDateChange: "selectedDateChange" }, viewQueries: [{ propertyName: "datepicker", first: true, predicate: SkyDatepickerCalendarInnerComponent, descendants: true, read: SkyDatepickerCalendarInnerComponent, static: true }], ngImport: i0, template: "<div class=\"sky-datepicker-calendar\">\n <sky-datepicker-inner\n [customDates]=\"customDates\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [startAtDate]=\"startAtDate\"\n [selectedDate]=\"selectedDate\"\n [startingDay]=\"startingDay\"\n (calendarModeChange)=\"onCalendarModeChange($event)\"\n (selectedDateChange)=\"onSelectedDateChange($event)\"\n >\n <div\n class=\"sky-datepicker-calendar-table-container\"\n autofocus\n tabindex=\"0\"\n (keydown)=\"datepicker?.onKeydown($event)\"\n >\n @if (datepicker?.datepickerMode === 'day') {\n <sky-daypicker\n [customDates]=\"customDates\"\n [isWaiting]=\"isDaypickerWaiting\"\n (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n />\n } @else if (datepicker?.datepickerMode === 'month') {\n <sky-monthpicker />\n } @else if (datepicker?.datepickerMode === 'year') {\n <sky-yearpicker />\n }\n </div>\n </sky-datepicker-inner>\n</div>\n", styles: [".sky-datepicker-calendar{display:block}\n"], dependencies: [{ kind: "component", type: SkyDatepickerCalendarInnerComponent, selector: "sky-datepicker-inner", inputs: ["customDates", "startingDay", "minDate", "maxDate", "startAtDate", "selectedDate"], outputs: ["selectedDateChange", "calendarModeChange"] }, { kind: "component", type: SkyDayPickerComponent, selector: "sky-daypicker", inputs: ["customDates", "isWaiting"], outputs: ["calendarDateRangeChange"] }, { kind: "component", type: SkyMonthPickerComponent, selector: "sky-monthpicker" }, { kind: "component", type: SkyYearPickerComponent, selector: "sky-yearpicker" }] }); }
64
- }
65
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDatepickerCalendarComponent, decorators: [{
66
- type: Component,
67
- args: [{ imports: [
68
- SkyDatepickerCalendarInnerComponent,
69
- SkyDayPickerComponent,
70
- SkyMonthPickerComponent,
71
- SkyYearPickerComponent,
72
- ], selector: 'sky-datepicker-calendar', standalone: true, template: "<div class=\"sky-datepicker-calendar\">\n <sky-datepicker-inner\n [customDates]=\"customDates\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [startAtDate]=\"startAtDate\"\n [selectedDate]=\"selectedDate\"\n [startingDay]=\"startingDay\"\n (calendarModeChange)=\"onCalendarModeChange($event)\"\n (selectedDateChange)=\"onSelectedDateChange($event)\"\n >\n <div\n class=\"sky-datepicker-calendar-table-container\"\n autofocus\n tabindex=\"0\"\n (keydown)=\"datepicker?.onKeydown($event)\"\n >\n @if (datepicker?.datepickerMode === 'day') {\n <sky-daypicker\n [customDates]=\"customDates\"\n [isWaiting]=\"isDaypickerWaiting\"\n (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n />\n } @else if (datepicker?.datepickerMode === 'month') {\n <sky-monthpicker />\n } @else if (datepicker?.datepickerMode === 'year') {\n <sky-yearpicker />\n }\n </div>\n </sky-datepicker-inner>\n</div>\n", styles: [".sky-datepicker-calendar{display:block}\n"] }]
73
- }], ctorParameters: () => [{ type: i1.SkyDatepickerConfigService }], propDecorators: { customDates: [{
74
- type: Input
75
- }], isDaypickerWaiting: [{
76
- type: Input
77
- }], minDate: [{
78
- type: Input
79
- }], maxDate: [{
80
- type: Input
81
- }], startAtDate: [{
82
- type: Input
83
- }], selectedDate: [{
84
- type: Input
85
- }], startingDay: [{
86
- type: Input
87
- }], calendarDateRangeChange: [{
88
- type: Output
89
- }], calendarModeChange: [{
90
- type: Output
91
- }], selectedDateChange: [{
92
- type: Output
93
- }], datepicker: [{
94
- type: ViewChild,
95
- args: [SkyDatepickerCalendarInnerComponent, {
96
- read: SkyDatepickerCalendarInnerComponent,
97
- static: true,
98
- }]
99
- }] } });
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-calendar.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/calendar/datepicker-calendar.component.ts","../../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/calendar/datepicker-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core';\n\nimport { SkyDateFormatter } from '../date-formatter';\nimport { SkyDatepickerConfigService } from '../datepicker-config.service';\nimport { SkyDatepickerCustomDate } from '../datepicker-custom-date';\n\nimport { SkyDatepickerCalendarChange } from './datepicker-calendar-change';\nimport { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';\nimport { SkyDayPickerComponent } from './daypicker.component';\nimport { SkyMonthPickerComponent } from './monthpicker.component';\nimport { SkyYearPickerComponent } from './yearpicker.component';\n\n/**\n * @internal\n */\n@Component({\n  imports: [\n    SkyDatepickerCalendarInnerComponent,\n    SkyDayPickerComponent,\n    SkyMonthPickerComponent,\n    SkyYearPickerComponent,\n  ],\n  selector: 'sky-datepicker-calendar',\n  standalone: true,\n  styleUrl: './datepicker-calendar.component.scss',\n  templateUrl: './datepicker-calendar.component.html',\n})\nexport class SkyDatepickerCalendarComponent {\n  @Input()\n  public customDates: SkyDatepickerCustomDate[] | undefined;\n\n  @Input()\n  public isDaypickerWaiting: boolean | undefined;\n\n  @Input()\n  public minDate: Date | undefined;\n\n  @Input()\n  public maxDate: Date | undefined;\n\n  @Input()\n  public startAtDate: Date | undefined;\n\n  /** currently selected date */\n  @Input()\n  public selectedDate: Date | undefined;\n\n  /** starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday) */\n  @Input()\n  public set startingDay(start: number | undefined) {\n    this.#_startingDay = start ?? 0;\n  }\n\n  public get startingDay(): number {\n    return this.#_startingDay;\n  }\n\n  @Output()\n  public calendarDateRangeChange = new EventEmitter<\n    SkyDatepickerCalendarChange | undefined\n  >();\n\n  @Output()\n  public calendarModeChange = new EventEmitter<string>();\n\n  @Output()\n  public selectedDateChange = new EventEmitter<Date>(undefined);\n\n  @ViewChild(SkyDatepickerCalendarInnerComponent, {\n    read: SkyDatepickerCalendarInnerComponent,\n    static: true,\n  })\n  public datepicker: SkyDatepickerCalendarInnerComponent | undefined;\n\n  protected _now: Date = new Date();\n\n  #formatter = new SkyDateFormatter();\n\n  #_startingDay = 0;\n\n  #config: SkyDatepickerConfigService;\n\n  constructor(config: SkyDatepickerConfigService) {\n    this.#config = config;\n    this.configureOptions();\n  }\n\n  public configureOptions(): void {\n    Object.assign(this, this.#config);\n  }\n\n  public onCalendarDateRangeChange(\n    event: SkyDatepickerCalendarChange | undefined,\n  ): void {\n    this.calendarDateRangeChange.next(event);\n  }\n\n  public onCalendarModeChange(event: string): void {\n    this.calendarModeChange.emit(event);\n  }\n\n  public onSelectedDateChange(event: Date): void {\n    this.selectedDateChange.emit(event);\n  }\n\n  public writeValue(value: Date | undefined): void {\n    if (\n      value !== undefined &&\n      this.#formatter.dateIsValid(value) &&\n      this.selectedDate !== undefined &&\n      this.datepicker?.compareHandlerDay &&\n      this.datepicker.compareHandlerDay(value, this.selectedDate) === 0\n    ) {\n      return;\n    }\n\n    if (value && this.#formatter.dateIsValid(value)) {\n      this.selectedDate = value;\n      this.datepicker?.select(value, false);\n    } else {\n      this.selectedDate = this.startAtDate ?? new Date();\n      this.datepicker?.select(this.startAtDate ?? new Date(), false);\n    }\n  }\n}\n","<div class=\"sky-datepicker-calendar\">\n  <sky-datepicker-inner\n    [customDates]=\"customDates\"\n    [maxDate]=\"maxDate\"\n    [minDate]=\"minDate\"\n    [startAtDate]=\"startAtDate\"\n    [selectedDate]=\"selectedDate\"\n    [startingDay]=\"startingDay\"\n    (calendarModeChange)=\"onCalendarModeChange($event)\"\n    (selectedDateChange)=\"onSelectedDateChange($event)\"\n  >\n    <div\n      class=\"sky-datepicker-calendar-table-container\"\n      autofocus\n      tabindex=\"0\"\n      (keydown)=\"datepicker?.onKeydown($event)\"\n    >\n      @if (datepicker?.datepickerMode === 'day') {\n        <sky-daypicker\n          [customDates]=\"customDates\"\n          [isWaiting]=\"isDaypickerWaiting\"\n          (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n        />\n      } @else if (datepicker?.datepickerMode === 'month') {\n        <sky-monthpicker />\n      } @else if (datepicker?.datepickerMode === 'year') {\n        <sky-yearpicker />\n      }\n    </div>\n  </sky-datepicker-inner>\n</div>\n"]}
@@ -1,22 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
- import { Subject } from 'rxjs';
3
- import * as i0 from "@angular/core";
4
- /**
5
- * Manages the state of the calendar picker.
6
- * @internal
7
- */
8
- export class SkyDatepickerCalendarService {
9
- constructor() {
10
- /**
11
- * Whether a key date popover is currently displayed.
12
- * Useful for communicating across all daypicker siblings when a popover is displayed.
13
- */
14
- this.keyDatePopoverStream = new Subject();
15
- }
16
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDatepickerCalendarService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
17
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDatepickerCalendarService }); }
18
- }
19
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDatepickerCalendarService, decorators: [{
20
- type: Injectable
21
- }] });
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci1jYWxlbmRhci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2RhdGV0aW1lL3NyYy9saWIvbW9kdWxlcy9kYXRlcGlja2VyL2NhbGVuZGFyL2RhdGVwaWNrZXItY2FsZW5kYXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBSS9COzs7R0FHRztBQUVILE1BQU0sT0FBTyw0QkFBNEI7SUFEekM7UUFFRTs7O1dBR0c7UUFDSSx5QkFBb0IsR0FDekIsSUFBSSxPQUFPLEVBQW1DLENBQUM7S0FDbEQ7K0dBUFksNEJBQTRCO21IQUE1Qiw0QkFBNEI7OzRGQUE1Qiw0QkFBNEI7a0JBRHhDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgU2t5RGF5UGlja2VyQ29udGV4dCB9IGZyb20gJy4vZGF5cGlja2VyLWNvbnRleHQnO1xuXG4vKipcbiAqIE1hbmFnZXMgdGhlIHN0YXRlIG9mIHRoZSBjYWxlbmRhciBwaWNrZXIuXG4gKiBAaW50ZXJuYWxcbiAqL1xuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFNreURhdGVwaWNrZXJDYWxlbmRhclNlcnZpY2Uge1xuICAvKipcbiAgICogV2hldGhlciBhIGtleSBkYXRlIHBvcG92ZXIgaXMgY3VycmVudGx5IGRpc3BsYXllZC5cbiAgICogVXNlZnVsIGZvciBjb21tdW5pY2F0aW5nIGFjcm9zcyBhbGwgZGF5cGlja2VyIHNpYmxpbmdzIHdoZW4gYSBwb3BvdmVyIGlzIGRpc3BsYXllZC5cbiAgICovXG4gIHB1YmxpYyBrZXlEYXRlUG9wb3ZlclN0cmVhbTogU3ViamVjdDxTa3lEYXlQaWNrZXJDb250ZXh0IHwgdW5kZWZpbmVkPiA9XG4gICAgbmV3IFN1YmplY3Q8U2t5RGF5UGlja2VyQ29udGV4dCB8IHVuZGVmaW5lZD4oKTtcbn1cbiJdfQ==
@@ -1,23 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { Component, Input } from '@angular/core';
3
- import { SkyDatepickerCalendarLabelPipe } from './datepicker-calendar-label.pipe';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "./datepicker-calendar-inner.component";
6
- import * as i2 from "@angular/common";
7
- /**
8
- * @internal
9
- */
10
- export class SkyDayPickerButtonComponent {
11
- constructor(datepicker) {
12
- this.datepicker = datepicker;
13
- }
14
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDayPickerButtonComponent, deps: [{ token: i1.SkyDatepickerCalendarInnerComponent }], target: i0.ɵɵFactoryTarget.Component }); }
15
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: SkyDayPickerButtonComponent, isStandalone: true, selector: "sky-daypicker-button", inputs: { date: "date" }, ngImport: i0, template: "@if (date) {\n <button\n class=\"sky-btn sky-btn-sm sky-btn-default sky-datepicker-btn-date\"\n tabindex=\"-1\"\n type=\"button\"\n [disabled]=\"date.disabled\"\n [ngClass]=\"{\n 'sky-datepicker-btn-selected': date.selected,\n 'sky-btn-disabled': date.disabled,\n 'sky-btn-active': datepicker.isActive(date),\n 'sky-datepicker-btn-disabled': date.disabled,\n 'sky-datepicker-btn-key-date': date.keyDate\n }\"\n [attr.aria-label]=\"date.date | skyDatepickerCalendarLabel\"\n (click)=\"datepicker.selectCalendar($event, date.date, true)\"\n >\n <span [ngClass]=\"{ 'sky-datepicker-secondary': date.secondary }\">\n {{ date.label }}\n </span>\n </button>\n}\n", styles: [".sky-datepicker-btn-date:not(.sky-theme-modern *){--sky-override-daypicker-disabled-style: italic;--sky-override-daypicker-key-date-color: #d93a3d;--sky-override-daypicker-key-date-left: 15px;--sky-override-daypicker-key-date-size: 5px;--sky-override-daypicker-key-date-top: 22px}:host-context(.sky-theme-modern:not(.sky-theme-brand-blackbaud)) .sky-datepicker-btn-date{--sky-override-daypicker-disabled-style: italic;--sky-override-daypicker-key-date-left: 12px;--sky-override-daypicker-key-date-top: 22px}.sky-datepicker-btn-disabled{font-style:var(--sky-override-daypicker-disabled-style)}.sky-datepicker-btn-key-date{position:relative}.sky-datepicker-btn-key-date:before{position:absolute;content:\"\";height:var(--sky-override-daypicker-key-date-size, var(--sky-size-icon-xxs));width:var(--sky-override-daypicker-key-date-size, var(--sky-size-icon-xxs));background-color:var(--sky-override-daypicker-key-date-color, var(--sky-color-icon-danger));border-radius:50%;left:var(--sky-override-daypicker-key-date-left, calc(50% - var(--sky-size-icon-xxs) / 2));top:var(--sky-override-daypicker-key-date-top, calc(50% + var(--sky-font-size-body-m) * var(--sky-font-line_height-body-m) / 2 - var(--sky-size-icon-xxs) / 2))}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: SkyDatepickerCalendarLabelPipe, name: "skyDatepickerCalendarLabel" }] }); }
16
- }
17
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDayPickerButtonComponent, decorators: [{
18
- type: Component,
19
- args: [{ imports: [CommonModule, SkyDatepickerCalendarLabelPipe], selector: 'sky-daypicker-button', standalone: true, template: "@if (date) {\n <button\n class=\"sky-btn sky-btn-sm sky-btn-default sky-datepicker-btn-date\"\n tabindex=\"-1\"\n type=\"button\"\n [disabled]=\"date.disabled\"\n [ngClass]=\"{\n 'sky-datepicker-btn-selected': date.selected,\n 'sky-btn-disabled': date.disabled,\n 'sky-btn-active': datepicker.isActive(date),\n 'sky-datepicker-btn-disabled': date.disabled,\n 'sky-datepicker-btn-key-date': date.keyDate\n }\"\n [attr.aria-label]=\"date.date | skyDatepickerCalendarLabel\"\n (click)=\"datepicker.selectCalendar($event, date.date, true)\"\n >\n <span [ngClass]=\"{ 'sky-datepicker-secondary': date.secondary }\">\n {{ date.label }}\n </span>\n </button>\n}\n", styles: [".sky-datepicker-btn-date:not(.sky-theme-modern *){--sky-override-daypicker-disabled-style: italic;--sky-override-daypicker-key-date-color: #d93a3d;--sky-override-daypicker-key-date-left: 15px;--sky-override-daypicker-key-date-size: 5px;--sky-override-daypicker-key-date-top: 22px}:host-context(.sky-theme-modern:not(.sky-theme-brand-blackbaud)) .sky-datepicker-btn-date{--sky-override-daypicker-disabled-style: italic;--sky-override-daypicker-key-date-left: 12px;--sky-override-daypicker-key-date-top: 22px}.sky-datepicker-btn-disabled{font-style:var(--sky-override-daypicker-disabled-style)}.sky-datepicker-btn-key-date{position:relative}.sky-datepicker-btn-key-date:before{position:absolute;content:\"\";height:var(--sky-override-daypicker-key-date-size, var(--sky-size-icon-xxs));width:var(--sky-override-daypicker-key-date-size, var(--sky-size-icon-xxs));background-color:var(--sky-override-daypicker-key-date-color, var(--sky-color-icon-danger));border-radius:50%;left:var(--sky-override-daypicker-key-date-left, calc(50% - var(--sky-size-icon-xxs) / 2));top:var(--sky-override-daypicker-key-date-top, calc(50% + var(--sky-font-size-body-m) * var(--sky-font-line_height-body-m) / 2 - var(--sky-size-icon-xxs) / 2))}\n"] }]
20
- }], ctorParameters: () => [{ type: i1.SkyDatepickerCalendarInnerComponent }], propDecorators: { date: [{
21
- type: Input
22
- }] } });
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF5cGlja2VyLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZGF0ZXRpbWUvc3JjL2xpYi9tb2R1bGVzL2RhdGVwaWNrZXIvY2FsZW5kYXIvZGF5cGlja2VyLWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZGF0ZXRpbWUvc3JjL2xpYi9tb2R1bGVzL2RhdGVwaWNrZXIvY2FsZW5kYXIvZGF5cGlja2VyLWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHakQsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sa0NBQWtDLENBQUM7Ozs7QUFHbEY7O0dBRUc7QUFRSCxNQUFNLE9BQU8sMkJBQTJCO0lBT3RDLFlBQW1CLFVBQStDO1FBQS9DLGVBQVUsR0FBVixVQUFVLENBQXFDO0lBQUcsQ0FBQzsrR0FQM0QsMkJBQTJCO21HQUEzQiwyQkFBMkIsMEdDakJ4QyxpdEJBcUJBLCt2Q0RWWSxZQUFZLHdIQUFFLDhCQUE4Qjs7NEZBTTNDLDJCQUEyQjtrQkFQdkMsU0FBUzs4QkFDQyxDQUFDLFlBQVksRUFBRSw4QkFBOEIsQ0FBQyxZQUM3QyxzQkFBc0IsY0FDcEIsSUFBSTt3R0FTVCxJQUFJO3NCQURWLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTa3lEYXRlcGlja2VyQ2FsZW5kYXJJbm5lckNvbXBvbmVudCB9IGZyb20gJy4vZGF0ZXBpY2tlci1jYWxlbmRhci1pbm5lci5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2t5RGF0ZXBpY2tlckNhbGVuZGFyTGFiZWxQaXBlIH0gZnJvbSAnLi9kYXRlcGlja2VyLWNhbGVuZGFyLWxhYmVsLnBpcGUnO1xuaW1wb3J0IHsgU2t5RGF5UGlja2VyQ29udGV4dCB9IGZyb20gJy4vZGF5cGlja2VyLWNvbnRleHQnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5AQ29tcG9uZW50KHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgU2t5RGF0ZXBpY2tlckNhbGVuZGFyTGFiZWxQaXBlXSxcbiAgc2VsZWN0b3I6ICdza3ktZGF5cGlja2VyLWJ1dHRvbicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHN0eWxlVXJsOiAnLi9kYXlwaWNrZXItYnV0dG9uLmNvbXBvbmVudC5zY3NzJyxcbiAgdGVtcGxhdGVVcmw6ICdkYXlwaWNrZXItYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgU2t5RGF5UGlja2VyQnV0dG9uQ29tcG9uZW50IHtcbiAgLyoqXG4gICAqIFRoZSBkYXRlIHRoaXMgcGlja2VyIGJ1dHRvbiB3aWxsIHJlcHJlc2VudCBvbiB0aGUgY2FsZW5kYXIuXG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgZGF0ZTogU2t5RGF5UGlja2VyQ29udGV4dCB8IHVuZGVmaW5lZDtcblxuICBjb25zdHJ1Y3RvcihwdWJsaWMgZGF0ZXBpY2tlcjogU2t5RGF0ZXBpY2tlckNhbGVuZGFySW5uZXJDb21wb25lbnQpIHt9XG59XG4iLCJAaWYgKGRhdGUpIHtcbiAgPGJ1dHRvblxuICAgIGNsYXNzPVwic2t5LWJ0biBza3ktYnRuLXNtIHNreS1idG4tZGVmYXVsdCBza3ktZGF0ZXBpY2tlci1idG4tZGF0ZVwiXG4gICAgdGFiaW5kZXg9XCItMVwiXG4gICAgdHlwZT1cImJ1dHRvblwiXG4gICAgW2Rpc2FibGVkXT1cImRhdGUuZGlzYWJsZWRcIlxuICAgIFtuZ0NsYXNzXT1cIntcbiAgICAgICdza3ktZGF0ZXBpY2tlci1idG4tc2VsZWN0ZWQnOiBkYXRlLnNlbGVjdGVkLFxuICAgICAgJ3NreS1idG4tZGlzYWJsZWQnOiBkYXRlLmRpc2FibGVkLFxuICAgICAgJ3NreS1idG4tYWN0aXZlJzogZGF0ZXBpY2tlci5pc0FjdGl2ZShkYXRlKSxcbiAgICAgICdza3ktZGF0ZXBpY2tlci1idG4tZGlzYWJsZWQnOiBkYXRlLmRpc2FibGVkLFxuICAgICAgJ3NreS1kYXRlcGlja2VyLWJ0bi1rZXktZGF0ZSc6IGRhdGUua2V5RGF0ZVxuICAgIH1cIlxuICAgIFthdHRyLmFyaWEtbGFiZWxdPVwiZGF0ZS5kYXRlIHwgc2t5RGF0ZXBpY2tlckNhbGVuZGFyTGFiZWxcIlxuICAgIChjbGljayk9XCJkYXRlcGlja2VyLnNlbGVjdENhbGVuZGFyKCRldmVudCwgZGF0ZS5kYXRlLCB0cnVlKVwiXG4gID5cbiAgICA8c3BhbiBbbmdDbGFzc109XCJ7ICdza3ktZGF0ZXBpY2tlci1zZWNvbmRhcnknOiBkYXRlLnNlY29uZGFyeSB9XCI+XG4gICAgICB7eyBkYXRlLmxhYmVsIH19XG4gICAgPC9zcGFuPlxuICA8L2J1dHRvbj5cbn1cbiJdfQ==
@@ -1,129 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, Input, } from '@angular/core';
3
- import { SkyPopoverMessageType, SkyPopoverModule, } from '@skyux/popovers';
4
- import { Subject } from 'rxjs';
5
- import { takeUntil } from 'rxjs/operators';
6
- import { SkyDayPickerButtonComponent } from './daypicker-button.component';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "./datepicker-calendar-inner.component";
9
- import * as i2 from "./datepicker-calendar.service";
10
- import * as i3 from "@angular/common";
11
- import * as i4 from "@skyux/popovers";
12
- /**
13
- * @internal
14
- */
15
- export class SkyDayPickerCellComponent {
16
- #activeUid;
17
- #cancelPopover;
18
- #popoverOpen;
19
- #ngUnsubscribe;
20
- #datepicker;
21
- #datepickerService;
22
- constructor(datepicker, datepickerService) {
23
- this.hasTooltip = false;
24
- this.popoverController = new Subject();
25
- this.#activeUid = '';
26
- this.#cancelPopover = false;
27
- this.#popoverOpen = false;
28
- this.#ngUnsubscribe = new Subject();
29
- this.#datepicker = datepicker;
30
- this.#datepickerService = datepickerService;
31
- }
32
- ngOnInit() {
33
- this.hasTooltip = !!(this.date &&
34
- this.date.keyDate &&
35
- this.date.keyDateText &&
36
- this.date.keyDateText.length > 0 &&
37
- this.date.keyDateText[0].length > 0);
38
- // show the tooltip if this is the active date and is not the
39
- // initial active date (activeDateHasChanged)
40
- if (!!this.date &&
41
- this.#datepicker.isActive(this.date) &&
42
- this.activeDateHasChanged &&
43
- this.hasTooltip) {
44
- this.#activeUid = this.date.uid;
45
- this.#showTooltip();
46
- }
47
- if (this.hasTooltip) {
48
- this.#datepickerService.keyDatePopoverStream
49
- .pipe(takeUntil(this.#ngUnsubscribe))
50
- .subscribe((date) => {
51
- if (date) {
52
- this.#activeUid = date.uid;
53
- }
54
- else {
55
- this.#activeUid = '';
56
- }
57
- // If this day has an open popover and they have moved off of the day close the popover.
58
- if (this.date?.uid !== this.#activeUid) {
59
- this.#hideTooltip();
60
- }
61
- });
62
- }
63
- }
64
- ngOnDestroy() {
65
- this.#ngUnsubscribe.next();
66
- this.#ngUnsubscribe.complete();
67
- }
68
- onDayMouseenter() {
69
- this.#cancelPopover = false;
70
- if (this.hasTooltip) {
71
- this.#showTooltip();
72
- this.#datepickerService.keyDatePopoverStream.next(this.date);
73
- }
74
- }
75
- onDayMouseleave() {
76
- this.#cancelPopover = true;
77
- if (this.hasTooltip) {
78
- this.#hideTooltip();
79
- }
80
- this.#datepickerService.keyDatePopoverStream.next(undefined);
81
- }
82
- onPopoverClosed() {
83
- this.#popoverOpen = false;
84
- }
85
- onPopoverOpened() {
86
- this.#popoverOpen = true;
87
- /* istanbul ignore else */
88
- if (this.#cancelPopover) {
89
- // If the popover gets opened just as a mouseout event happens, close it.
90
- this.#hideTooltip();
91
- this.#cancelPopover = false;
92
- }
93
- }
94
- getKeyDateLabel() {
95
- return this.hasTooltip && this.date?.keyDateText
96
- ? this.date.keyDateText.join(', ')
97
- : '';
98
- }
99
- #hideTooltip() {
100
- /* istanbul ignore else */
101
- if (this.#popoverOpen) {
102
- this.popoverController.next({ type: SkyPopoverMessageType.Close });
103
- }
104
- }
105
- #showTooltip() {
106
- /* istanbul ignore else */
107
- if (this.hasTooltip && !this.#popoverOpen) {
108
- /**
109
- * Delay 1/2 second before opening the popover as long as mouse hasn't moved off the date.
110
- */
111
- setTimeout(() => {
112
- if (!this.#cancelPopover && this.#activeUid === this.date?.uid) {
113
- this.popoverController.next({ type: SkyPopoverMessageType.Open });
114
- }
115
- }, 500);
116
- }
117
- }
118
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDayPickerCellComponent, deps: [{ token: i1.SkyDatepickerCalendarInnerComponent }, { token: i2.SkyDatepickerCalendarService }], target: i0.ɵɵFactoryTarget.Component }); }
119
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: SkyDayPickerCellComponent, isStandalone: true, selector: "sky-daypicker-cell", inputs: { activeDateHasChanged: "activeDateHasChanged", date: "date" }, ngImport: i0, template: "@if (hasTooltip) {\n <div\n class=\"sky-daypicker-cell\"\n skyPopoverPlacement=\"left\"\n [attr.aria-label]=\"getKeyDateLabel()\"\n [skyPopover]=\"dayInfoPopover\"\n [skyPopoverMessageStream]=\"popoverController\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n >\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\" />\n <sky-popover\n #dayInfoPopover\n (popoverClosed)=\"onPopoverClosed()\"\n (popoverOpened)=\"onPopoverOpened()\"\n >\n @for (text of date?.keyDateText; track text) {\n <div>\n {{ text }}\n </div>\n }\n </sky-popover>\n </div>\n} @else {\n <div\n class=\"sky-daypicker-cell\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n >\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\" />\n </div>\n}\n\n<ng-template #daypickerButtonTemplateRef>\n <sky-daypicker-button [date]=\"date\" />\n</ng-template>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: SkyDayPickerButtonComponent, selector: "sky-daypicker-button", inputs: ["date"] }, { kind: "ngmodule", type: SkyPopoverModule }, { kind: "component", type: i4.λ6, selector: "sky-popover", inputs: ["alignment", "placement", "popoverTitle", "popoverType"], outputs: ["popoverClosed", "popoverOpened"] }, { kind: "directive", type: i4.λ7, selector: "[skyPopover]", inputs: ["skyPopover", "skyPopoverAlignment", "skyPopoverMessageStream", "skyPopoverPlacement", "skyPopoverTrigger"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
120
- }
121
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDayPickerCellComponent, decorators: [{
122
- type: Component,
123
- args: [{ changeDetection: ChangeDetectionStrategy.OnPush, imports: [CommonModule, SkyDayPickerButtonComponent, SkyPopoverModule], selector: 'sky-daypicker-cell', standalone: true, template: "@if (hasTooltip) {\n <div\n class=\"sky-daypicker-cell\"\n skyPopoverPlacement=\"left\"\n [attr.aria-label]=\"getKeyDateLabel()\"\n [skyPopover]=\"dayInfoPopover\"\n [skyPopoverMessageStream]=\"popoverController\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n >\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\" />\n <sky-popover\n #dayInfoPopover\n (popoverClosed)=\"onPopoverClosed()\"\n (popoverOpened)=\"onPopoverOpened()\"\n >\n @for (text of date?.keyDateText; track text) {\n <div>\n {{ text }}\n </div>\n }\n </sky-popover>\n </div>\n} @else {\n <div\n class=\"sky-daypicker-cell\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n >\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\" />\n </div>\n}\n\n<ng-template #daypickerButtonTemplateRef>\n <sky-daypicker-button [date]=\"date\" />\n</ng-template>\n" }]
124
- }], ctorParameters: () => [{ type: i1.SkyDatepickerCalendarInnerComponent }, { type: i2.SkyDatepickerCalendarService }], propDecorators: { activeDateHasChanged: [{
125
- type: Input
126
- }], date: [{
127
- type: Input
128
- }] } });
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daypicker-cell.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/calendar/daypicker-cell.component.ts","../../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/calendar/daypicker-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n} from '@angular/core';\nimport {\n  SkyPopoverMessage,\n  SkyPopoverMessageType,\n  SkyPopoverModule,\n} from '@skyux/popovers';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';\nimport { SkyDatepickerCalendarService } from './datepicker-calendar.service';\nimport { SkyDayPickerButtonComponent } from './daypicker-button.component';\nimport { SkyDayPickerContext } from './daypicker-context';\n\n/**\n * @internal\n */\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [CommonModule, SkyDayPickerButtonComponent, SkyPopoverModule],\n  selector: 'sky-daypicker-cell',\n  standalone: true,\n  templateUrl: 'daypicker-cell.component.html',\n})\nexport class SkyDayPickerCellComponent implements OnInit, OnDestroy {\n  /**\n   * Whether the active date has been changed.\n   */\n  @Input()\n  public activeDateHasChanged: boolean | undefined;\n\n  /**\n   * The date this picker cell will represent on the calendar.\n   */\n  @Input()\n  public date: SkyDayPickerContext | undefined;\n\n  public hasTooltip = false;\n\n  public popoverController = new Subject<SkyPopoverMessage>();\n\n  #activeUid = '';\n\n  #cancelPopover = false;\n\n  #popoverOpen = false;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #datepicker: SkyDatepickerCalendarInnerComponent;\n  #datepickerService: SkyDatepickerCalendarService;\n\n  constructor(\n    datepicker: SkyDatepickerCalendarInnerComponent,\n    datepickerService: SkyDatepickerCalendarService,\n  ) {\n    this.#datepicker = datepicker;\n    this.#datepickerService = datepickerService;\n  }\n\n  public ngOnInit(): void {\n    this.hasTooltip = !!(\n      this.date &&\n      this.date.keyDate &&\n      this.date.keyDateText &&\n      this.date.keyDateText.length > 0 &&\n      this.date.keyDateText[0].length > 0\n    );\n\n    // show the tooltip if this is the active date and is not the\n    // initial active date (activeDateHasChanged)\n    if (\n      !!this.date &&\n      this.#datepicker.isActive(this.date) &&\n      this.activeDateHasChanged &&\n      this.hasTooltip\n    ) {\n      this.#activeUid = this.date.uid;\n      this.#showTooltip();\n    }\n\n    if (this.hasTooltip) {\n      this.#datepickerService.keyDatePopoverStream\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((date) => {\n          if (date) {\n            this.#activeUid = date.uid;\n          } else {\n            this.#activeUid = '';\n          }\n          // If this day has an open popover and they have moved off of the day close the popover.\n          if (this.date?.uid !== this.#activeUid) {\n            this.#hideTooltip();\n          }\n        });\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public onDayMouseenter(): void {\n    this.#cancelPopover = false;\n    if (this.hasTooltip) {\n      this.#showTooltip();\n      this.#datepickerService.keyDatePopoverStream.next(this.date);\n    }\n  }\n\n  public onDayMouseleave(): void {\n    this.#cancelPopover = true;\n    if (this.hasTooltip) {\n      this.#hideTooltip();\n    }\n    this.#datepickerService.keyDatePopoverStream.next(undefined);\n  }\n\n  public onPopoverClosed(): void {\n    this.#popoverOpen = false;\n  }\n\n  public onPopoverOpened(): void {\n    this.#popoverOpen = true;\n    /* istanbul ignore else */\n    if (this.#cancelPopover) {\n      // If the popover gets opened just as a mouseout event happens, close it.\n      this.#hideTooltip();\n      this.#cancelPopover = false;\n    }\n  }\n\n  public getKeyDateLabel(): string {\n    return this.hasTooltip && this.date?.keyDateText\n      ? this.date.keyDateText.join(', ')\n      : '';\n  }\n\n  #hideTooltip(): void {\n    /* istanbul ignore else */\n    if (this.#popoverOpen) {\n      this.popoverController.next({ type: SkyPopoverMessageType.Close });\n    }\n  }\n\n  #showTooltip(): void {\n    /* istanbul ignore else */\n    if (this.hasTooltip && !this.#popoverOpen) {\n      /**\n       * Delay 1/2 second before opening the popover as long as mouse hasn't moved off the date.\n       */\n      setTimeout(() => {\n        if (!this.#cancelPopover && this.#activeUid === this.date?.uid) {\n          this.popoverController.next({ type: SkyPopoverMessageType.Open });\n        }\n      }, 500);\n    }\n  }\n}\n","@if (hasTooltip) {\n  <div\n    class=\"sky-daypicker-cell\"\n    skyPopoverPlacement=\"left\"\n    [attr.aria-label]=\"getKeyDateLabel()\"\n    [skyPopover]=\"dayInfoPopover\"\n    [skyPopoverMessageStream]=\"popoverController\"\n    (mouseenter)=\"onDayMouseenter()\"\n    (mouseleave)=\"onDayMouseleave()\"\n  >\n    <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\" />\n    <sky-popover\n      #dayInfoPopover\n      (popoverClosed)=\"onPopoverClosed()\"\n      (popoverOpened)=\"onPopoverOpened()\"\n    >\n      @for (text of date?.keyDateText; track text) {\n        <div>\n          {{ text }}\n        </div>\n      }\n    </sky-popover>\n  </div>\n} @else {\n  <div\n    class=\"sky-daypicker-cell\"\n    (mouseenter)=\"onDayMouseenter()\"\n    (mouseleave)=\"onDayMouseleave()\"\n  >\n    <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\" />\n  </div>\n}\n\n<ng-template #daypickerButtonTemplateRef>\n  <sky-daypicker-button [date]=\"date\" />\n</ng-template>\n"]}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF5cGlja2VyLWNvbnRleHQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZGF0ZXRpbWUvc3JjL2xpYi9tb2R1bGVzL2RhdGVwaWNrZXIvY2FsZW5kYXIvZGF5cGlja2VyLWNvbnRleHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogSW5mb3JtYXRpb24gYWJvdXQgYSBzcGVjaWZpYyBkYXkgaW4gdGhlIGNhbGVuZGFyLlxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2t5RGF5UGlja2VyQ29udGV4dCB7XG4gIGRhdGU6IERhdGU7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHNlbGVjdGVkOiBib29sZWFuO1xuICBkaXNhYmxlZDogYm9vbGVhbjtcbiAgY3VycmVudDogYm9vbGVhbjtcbiAgc2Vjb25kYXJ5OiBib29sZWFuO1xuICB1aWQ6IHN0cmluZztcbiAga2V5RGF0ZT86IGJvb2xlYW47XG4gIGtleURhdGVUZXh0Pzogc3RyaW5nW107XG59XG4iXX0=
@@ -1,221 +0,0 @@
1
- import { Component, EventEmitter, Input, Output, } from '@angular/core';
2
- import { SkyWaitModule } from '@skyux/indicators';
3
- import { Subject } from 'rxjs';
4
- import { SkyDayPickerCellComponent } from './daypicker-cell.component';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "./datepicker-calendar-inner.component";
7
- import * as i2 from "@skyux/indicators";
8
- /**
9
- * @internal
10
- */
11
- export class SkyDayPickerComponent {
12
- set customDates(value) {
13
- /* istanbul ignore else */
14
- if (value) {
15
- this.#applyCustomDates(value, this.rows);
16
- }
17
- }
18
- #daysInMonth;
19
- #initialDate;
20
- #ngUnsubscribe;
21
- constructor(datepicker) {
22
- this.calendarDateRangeChange = new EventEmitter();
23
- this.isWaiting = false;
24
- this.activeDateHasChanged = false;
25
- this.labels = [];
26
- this.title = '';
27
- this.rows = [];
28
- this.weekNumbers = [];
29
- this.#daysInMonth = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
30
- this.#ngUnsubscribe = new Subject();
31
- this.datepicker = datepicker;
32
- }
33
- ngOnInit() {
34
- this.datepicker.stepDay = { months: 1 };
35
- this.#initialDate = this.datepicker.activeDate.getDate();
36
- this.datepicker.setRefreshViewHandler(() => this.#refreshDayView(), 'day');
37
- this.datepicker.setCompareHandler(this.#compareDays, 'day');
38
- this.datepicker.setKeydownHandler((key, event) => {
39
- this.#keydownDays(key, event);
40
- }, 'day');
41
- this.datepicker.refreshView();
42
- }
43
- ngOnDestroy() {
44
- this.#ngUnsubscribe.next();
45
- this.#ngUnsubscribe.complete();
46
- }
47
- getDates(startDate, n) {
48
- const dates = new Array(n);
49
- let current = new Date(startDate.getTime());
50
- let i = 0;
51
- let date;
52
- while (i < n) {
53
- date = new Date(current.getTime());
54
- date = this.datepicker.fixTimeZone(date);
55
- dates[i++] = date;
56
- current = new Date(current.getFullYear(), current.getMonth(), current.getDate() + 1);
57
- }
58
- return dates;
59
- }
60
- #compareDays(date1, date2) {
61
- const d1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate());
62
- const d2 = new Date(date2.getFullYear(), date2.getMonth(), date2.getDate());
63
- return d1.getTime() - d2.getTime();
64
- }
65
- #refreshDayView() {
66
- const year = this.datepicker.activeDate.getFullYear();
67
- const month = this.datepicker.activeDate.getMonth();
68
- const firstDayOfMonth = new Date(year, month, 1);
69
- const difference = this.datepicker.startingDay - firstDayOfMonth.getDay();
70
- const numDisplayedFromPreviousMonth = difference > 0 ? 7 - difference : -difference;
71
- const firstDate = new Date(firstDayOfMonth.getTime());
72
- if (this.datepicker.activeDate.getDate() !== this.#initialDate) {
73
- this.activeDateHasChanged = true;
74
- }
75
- /* istanbul ignore else */
76
- /* sanity check */
77
- if (numDisplayedFromPreviousMonth > 0) {
78
- firstDate.setDate(-numDisplayedFromPreviousMonth + 1);
79
- }
80
- // 42 is the number of days on a six-week calendar
81
- const days = this.getDates(firstDate, 42);
82
- const pickerDates = [];
83
- for (let i = 0; i < 42; i++) {
84
- const _dateObject = this.datepicker.createDateObject(days[i], this.datepicker.formatDay, days[i].getMonth() !== month, this.datepicker.datepickerId + '-' + i);
85
- pickerDates[i] = _dateObject;
86
- }
87
- this.labels = [];
88
- for (let j = 0; j < 7; j++) {
89
- this.labels[j] = {};
90
- this.labels[j].abbr = this.datepicker.dateFilter(pickerDates[j].date, this.datepicker.formatDayHeader);
91
- this.labels[j].full = this.datepicker.dateFilter(pickerDates[j].date, 'EEEE');
92
- }
93
- const oldDateRange = this.#getDateRange(this.rows);
94
- this.rows = this.datepicker.createCalendarRows(pickerDates, 7);
95
- const newDateRange = this.#getDateRange(this.rows);
96
- if (!this.#dateRangeRowsAreEqual(oldDateRange, newDateRange)) {
97
- // Safety check
98
- /* istanbul ignore else */
99
- if (newDateRange) {
100
- this.calendarDateRangeChange.next({
101
- startDate: newDateRange.startDate,
102
- endDate: newDateRange.endDate,
103
- });
104
- }
105
- else {
106
- this.calendarDateRangeChange.next(undefined);
107
- }
108
- }
109
- return this.datepicker.dateFilter(this.datepicker.activeDate, this.datepicker.formatDayTitle);
110
- }
111
- #keydownDays(key, event) {
112
- let date = this.datepicker.activeDate.getDate();
113
- /* istanbul ignore else */
114
- /* sanity check */
115
- if (key === 'arrowleft') {
116
- date = date - 1;
117
- }
118
- else if (key === 'arrowup') {
119
- date = date - 7;
120
- }
121
- else if (key === 'arrowright') {
122
- date = date + 1;
123
- }
124
- else if (key === 'arrowdown') {
125
- date = date + 7;
126
- }
127
- else if (key === 'pageup' || key === 'pagedown') {
128
- const month = this.datepicker.activeDate.getMonth() + (key === 'pageup' ? -1 : 1);
129
- this.datepicker.activeDate.setMonth(month, 1);
130
- date = Math.min(this.#getDaysInMonth(this.datepicker.activeDate.getFullYear(), this.datepicker.activeDate.getMonth()), date);
131
- }
132
- else if (key === 'home') {
133
- date = 1;
134
- }
135
- else if (key === 'end') {
136
- date = this.#getDaysInMonth(this.datepicker.activeDate.getFullYear(), this.datepicker.activeDate.getMonth());
137
- }
138
- this.datepicker.activeDate.setDate(date);
139
- this.datepicker.announceDate(this.datepicker.activeDate, this.datepicker.formatDayLabel);
140
- }
141
- #getDaysInMonth(year, month) {
142
- return month === 1 &&
143
- year % 4 === 0 &&
144
- (year % 400 === 0 || year % 100 !== 0)
145
- ? 29
146
- : this.#daysInMonth[month];
147
- }
148
- /**
149
- * Applies custom date properties to the existing dates displayed in the calendar.
150
- */
151
- #applyCustomDates(customDates, dateRows) {
152
- let date;
153
- let newDate;
154
- let dateIndex;
155
- /* istanbul ignore else */
156
- if (customDates && dateRows) {
157
- customDates.forEach((customDate) => {
158
- dateIndex = -1;
159
- dateRows.forEach((row) => {
160
- if (dateIndex === -1) {
161
- dateIndex = row.findIndex((d) => {
162
- return d.date.getTime() === customDate.date.getTime();
163
- });
164
- if (dateIndex > -1) {
165
- date = row[dateIndex];
166
- // Replace the date with a new instance so the display gets updated.
167
- newDate = {
168
- current: date.current,
169
- date: date.date,
170
- disabled: !!date.disabled || !!customDate.disabled,
171
- keyDate: !!customDate.keyDate || !!date.keyDate,
172
- keyDateText: customDate.keyDateText || date.keyDateText,
173
- label: date.label,
174
- secondary: date.secondary,
175
- selected: date.selected,
176
- uid: date.uid,
177
- };
178
- row[dateIndex] = newDate;
179
- }
180
- }
181
- });
182
- });
183
- }
184
- }
185
- #dateRangeRowsAreEqual(rangeA, rangeB) {
186
- /* istanbul ignore if */
187
- if (!rangeA && !rangeB) {
188
- return true;
189
- }
190
- else if (rangeA && rangeB) {
191
- return (this.#compareDays(rangeA.startDate, rangeB.startDate) === 0 &&
192
- this.#compareDays(rangeA.endDate, rangeB.endDate) === 0);
193
- }
194
- else {
195
- return false;
196
- }
197
- }
198
- #getDateRange(rows) {
199
- /* istanbul ignore else */
200
- if (rows && rows.length > 0) {
201
- return {
202
- startDate: rows[0][0].date,
203
- endDate: rows[rows.length - 1][rows[rows.length - 1].length - 1].date,
204
- };
205
- }
206
- return undefined;
207
- }
208
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDayPickerComponent, deps: [{ token: i1.SkyDatepickerCalendarInnerComponent }], target: i0.ɵɵFactoryTarget.Component }); }
209
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: SkyDayPickerComponent, isStandalone: true, selector: "sky-daypicker", inputs: { customDates: "customDates", isWaiting: "isWaiting" }, outputs: { calendarDateRangeChange: "calendarDateRangeChange" }, ngImport: i0, template: "<table\n class=\"sky-daypicker-table\"\n role=\"grid\"\n [attr.aria-labelledby]=\"datepicker.datepickerId + '-title'\"\n>\n <thead>\n <tr>\n @for (label of labels; track label.full) {\n <th scope=\"col\" class=\"sky-datepicker-center sky-datepicker-weekdays\">\n <!-- display: inline -->\n <span\n class=\"sky-datepicker-weekday-text\"\n [attr.aria-label]=\"label.full\"\n >{{ label.abbr }}</span\n >\n </th>\n }\n </tr>\n </thead>\n <tbody>\n <!-- Wait indicator for async custom date stream -->\n <sky-wait [isWaiting]=\"isWaiting\" />\n @for (row of rows; track $index) {\n <tr role=\"row\">\n @for (date of row; track date.uid) {\n <td class=\"sky-datepicker-center\" role=\"gridcell\" [id]=\"date.uid\">\n <sky-daypicker-cell\n [activeDateHasChanged]=\"activeDateHasChanged\"\n [date]=\"date\"\n />\n </td>\n }\n </tr>\n }\n </tbody>\n</table>\n", dependencies: [{ kind: "component", type: SkyDayPickerCellComponent, selector: "sky-daypicker-cell", inputs: ["activeDateHasChanged", "date"] }, { kind: "ngmodule", type: SkyWaitModule }, { kind: "component", type: i2.λ14, selector: "sky-wait", inputs: ["ariaLabel", "isWaiting", "isFullPage", "isNonBlocking", "screenReaderCompletedText"] }] }); }
210
- }
211
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyDayPickerComponent, decorators: [{
212
- type: Component,
213
- args: [{ imports: [SkyDayPickerCellComponent, SkyWaitModule], selector: 'sky-daypicker', standalone: true, template: "<table\n class=\"sky-daypicker-table\"\n role=\"grid\"\n [attr.aria-labelledby]=\"datepicker.datepickerId + '-title'\"\n>\n <thead>\n <tr>\n @for (label of labels; track label.full) {\n <th scope=\"col\" class=\"sky-datepicker-center sky-datepicker-weekdays\">\n <!-- display: inline -->\n <span\n class=\"sky-datepicker-weekday-text\"\n [attr.aria-label]=\"label.full\"\n >{{ label.abbr }}</span\n >\n </th>\n }\n </tr>\n </thead>\n <tbody>\n <!-- Wait indicator for async custom date stream -->\n <sky-wait [isWaiting]=\"isWaiting\" />\n @for (row of rows; track $index) {\n <tr role=\"row\">\n @for (date of row; track date.uid) {\n <td class=\"sky-datepicker-center\" role=\"gridcell\" [id]=\"date.uid\">\n <sky-daypicker-cell\n [activeDateHasChanged]=\"activeDateHasChanged\"\n [date]=\"date\"\n />\n </td>\n }\n </tr>\n }\n </tbody>\n</table>\n" }]
214
- }], ctorParameters: () => [{ type: i1.SkyDatepickerCalendarInnerComponent }], propDecorators: { customDates: [{
215
- type: Input
216
- }], calendarDateRangeChange: [{
217
- type: Output
218
- }], isWaiting: [{
219
- type: Input
220
- }] } });
221
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daypicker.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/calendar/daypicker.component.ts","../../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/calendar/daypicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport { SkyWaitModule } from '@skyux/indicators';\n\nimport { Subject } from 'rxjs';\n\nimport { SkyDatepickerCustomDate } from '../datepicker-custom-date';\n\nimport { SkyDatepickerCalendarChange } from './datepicker-calendar-change';\nimport { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';\nimport { SkyDayPickerCellComponent } from './daypicker-cell.component';\nimport { SkyDayPickerContext } from './daypicker-context';\n\n/**\n * Helper interface to compare date ranges.\n * @internal\n */\ninterface SkyDateRange {\n  endDate: Date;\n  startDate: Date;\n}\n\n/**\n * @internal\n */\n@Component({\n  imports: [SkyDayPickerCellComponent, SkyWaitModule],\n  selector: 'sky-daypicker',\n  standalone: true,\n  templateUrl: 'daypicker.component.html',\n})\nexport class SkyDayPickerComponent implements OnDestroy, OnInit {\n  @Input()\n  public set customDates(value: SkyDatepickerCustomDate[] | undefined) {\n    /* istanbul ignore else */\n    if (value) {\n      this.#applyCustomDates(value, this.rows);\n    }\n  }\n\n  @Output()\n  public calendarDateRangeChange = new EventEmitter<\n    SkyDatepickerCalendarChange | undefined\n  >();\n\n  @Input()\n  public isWaiting: boolean | undefined = false;\n\n  public activeDateHasChanged = false;\n  public labels: any[] = [];\n  public title = '';\n  public rows: SkyDayPickerContext[][] = [];\n  public weekNumbers: number[] = [];\n  public datepicker: SkyDatepickerCalendarInnerComponent;\n  public CURRENT_THEME_TEMPLATE: any;\n\n  #daysInMonth: number[] = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\n  #initialDate: number | undefined;\n  #ngUnsubscribe = new Subject<void>();\n\n  constructor(datepicker: SkyDatepickerCalendarInnerComponent) {\n    this.datepicker = datepicker;\n  }\n\n  public ngOnInit(): void {\n    this.datepicker.stepDay = { months: 1 };\n    this.#initialDate = this.datepicker.activeDate.getDate();\n\n    this.datepicker.setRefreshViewHandler(() => this.#refreshDayView(), 'day');\n\n    this.datepicker.setCompareHandler(this.#compareDays, 'day');\n\n    this.datepicker.setKeydownHandler((key: string, event: KeyboardEvent) => {\n      this.#keydownDays(key, event);\n    }, 'day');\n\n    this.datepicker.refreshView();\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  protected getDates(startDate: Date, n: number): Date[] {\n    const dates: Date[] = new Array(n);\n    let current = new Date(startDate.getTime());\n    let i = 0;\n    let date: Date;\n    while (i < n) {\n      date = new Date(current.getTime());\n      date = this.datepicker.fixTimeZone(date);\n      dates[i++] = date;\n      current = new Date(\n        current.getFullYear(),\n        current.getMonth(),\n        current.getDate() + 1,\n      );\n    }\n    return dates;\n  }\n\n  #compareDays(date1: Date, date2: Date): number {\n    const d1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate());\n    const d2 = new Date(date2.getFullYear(), date2.getMonth(), date2.getDate());\n    return d1.getTime() - d2.getTime();\n  }\n\n  #refreshDayView(): string {\n    const year = this.datepicker.activeDate.getFullYear();\n    const month = this.datepicker.activeDate.getMonth();\n    const firstDayOfMonth = new Date(year, month, 1);\n    const difference = this.datepicker.startingDay - firstDayOfMonth.getDay();\n    const numDisplayedFromPreviousMonth =\n      difference > 0 ? 7 - difference : -difference;\n    const firstDate = new Date(firstDayOfMonth.getTime());\n\n    if (this.datepicker.activeDate.getDate() !== this.#initialDate) {\n      this.activeDateHasChanged = true;\n    }\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (numDisplayedFromPreviousMonth > 0) {\n      firstDate.setDate(-numDisplayedFromPreviousMonth + 1);\n    }\n\n    // 42 is the number of days on a six-week calendar\n    const days: Date[] = this.getDates(firstDate, 42);\n    const pickerDates: SkyDayPickerContext[] = [];\n    for (let i = 0; i < 42; i++) {\n      const _dateObject = this.datepicker.createDateObject(\n        days[i],\n        this.datepicker.formatDay,\n        days[i].getMonth() !== month,\n        this.datepicker.datepickerId + '-' + i,\n      );\n      pickerDates[i] = _dateObject;\n    }\n\n    this.labels = [];\n    for (let j = 0; j < 7; j++) {\n      this.labels[j] = {};\n      this.labels[j].abbr = this.datepicker.dateFilter(\n        pickerDates[j].date,\n        this.datepicker.formatDayHeader,\n      );\n      this.labels[j].full = this.datepicker.dateFilter(\n        pickerDates[j].date,\n        'EEEE',\n      );\n    }\n\n    const oldDateRange = this.#getDateRange(this.rows);\n    this.rows = this.datepicker.createCalendarRows(pickerDates, 7);\n    const newDateRange = this.#getDateRange(this.rows);\n\n    if (!this.#dateRangeRowsAreEqual(oldDateRange, newDateRange)) {\n      // Safety check\n      /* istanbul ignore else */\n      if (newDateRange) {\n        this.calendarDateRangeChange.next({\n          startDate: newDateRange.startDate,\n          endDate: newDateRange.endDate,\n        });\n      } else {\n        this.calendarDateRangeChange.next(undefined);\n      }\n    }\n\n    return this.datepicker.dateFilter(\n      this.datepicker.activeDate,\n      this.datepicker.formatDayTitle,\n    );\n  }\n\n  #keydownDays(key: string, event: KeyboardEvent): void {\n    let date = this.datepicker.activeDate.getDate();\n    /* istanbul ignore else */\n    /* sanity check */\n    if (key === 'arrowleft') {\n      date = date - 1;\n    } else if (key === 'arrowup') {\n      date = date - 7;\n    } else if (key === 'arrowright') {\n      date = date + 1;\n    } else if (key === 'arrowdown') {\n      date = date + 7;\n    } else if (key === 'pageup' || key === 'pagedown') {\n      const month =\n        this.datepicker.activeDate.getMonth() + (key === 'pageup' ? -1 : 1);\n      this.datepicker.activeDate.setMonth(month, 1);\n      date = Math.min(\n        this.#getDaysInMonth(\n          this.datepicker.activeDate.getFullYear(),\n          this.datepicker.activeDate.getMonth(),\n        ),\n        date,\n      );\n    } else if (key === 'home') {\n      date = 1;\n    } else if (key === 'end') {\n      date = this.#getDaysInMonth(\n        this.datepicker.activeDate.getFullYear(),\n        this.datepicker.activeDate.getMonth(),\n      );\n    }\n    this.datepicker.activeDate.setDate(date);\n    this.datepicker.announceDate(\n      this.datepicker.activeDate,\n      this.datepicker.formatDayLabel,\n    );\n  }\n\n  #getDaysInMonth(year: number, month: number): number {\n    return month === 1 &&\n      year % 4 === 0 &&\n      (year % 400 === 0 || year % 100 !== 0)\n      ? 29\n      : this.#daysInMonth[month];\n  }\n\n  /**\n   * Applies custom date properties to the existing dates displayed in the calendar.\n   */\n  #applyCustomDates(\n    customDates: SkyDatepickerCustomDate[],\n    dateRows: SkyDayPickerContext[][],\n  ): void {\n    let date: SkyDayPickerContext;\n    let newDate: SkyDayPickerContext;\n    let dateIndex: number;\n\n    /* istanbul ignore else */\n    if (customDates && dateRows) {\n      customDates.forEach((customDate) => {\n        dateIndex = -1;\n        dateRows.forEach((row) => {\n          if (dateIndex === -1) {\n            dateIndex = row.findIndex((d) => {\n              return d.date.getTime() === customDate.date.getTime();\n            });\n            if (dateIndex > -1) {\n              date = row[dateIndex];\n              // Replace the date with a new instance so the display gets updated.\n              newDate = {\n                current: date.current,\n                date: date.date,\n                disabled: !!date.disabled || !!customDate.disabled,\n                keyDate: !!customDate.keyDate || !!date.keyDate,\n                keyDateText: customDate.keyDateText || date.keyDateText,\n                label: date.label,\n                secondary: date.secondary,\n                selected: date.selected,\n                uid: date.uid,\n              };\n              row[dateIndex] = newDate;\n            }\n          }\n        });\n      });\n    }\n  }\n\n  #dateRangeRowsAreEqual(\n    rangeA?: SkyDateRange,\n    rangeB?: SkyDateRange,\n  ): boolean | undefined {\n    /* istanbul ignore if */\n    if (!rangeA && !rangeB) {\n      return true;\n    } else if (rangeA && rangeB) {\n      return (\n        this.#compareDays(rangeA.startDate, rangeB.startDate) === 0 &&\n        this.#compareDays(rangeA.endDate, rangeB.endDate) === 0\n      );\n    } else {\n      return false;\n    }\n  }\n\n  #getDateRange(rows: SkyDayPickerContext[][]): SkyDateRange | undefined {\n    /* istanbul ignore else */\n    if (rows && rows.length > 0) {\n      return {\n        startDate: rows[0][0].date,\n        endDate: rows[rows.length - 1][rows[rows.length - 1].length - 1].date,\n      };\n    }\n    return undefined;\n  }\n}\n","<table\n  class=\"sky-daypicker-table\"\n  role=\"grid\"\n  [attr.aria-labelledby]=\"datepicker.datepickerId + '-title'\"\n>\n  <thead>\n    <tr>\n      @for (label of labels; track label.full) {\n        <th scope=\"col\" class=\"sky-datepicker-center sky-datepicker-weekdays\">\n          <!-- display: inline -->\n          <span\n            class=\"sky-datepicker-weekday-text\"\n            [attr.aria-label]=\"label.full\"\n            >{{ label.abbr }}</span\n          >\n        </th>\n      }\n    </tr>\n  </thead>\n  <tbody>\n    <!-- Wait indicator for async custom date stream -->\n    <sky-wait [isWaiting]=\"isWaiting\" />\n    @for (row of rows; track $index) {\n      <tr role=\"row\">\n        @for (date of row; track date.uid) {\n          <td class=\"sky-datepicker-center\" role=\"gridcell\" [id]=\"date.uid\">\n            <sky-daypicker-cell\n              [activeDateHasChanged]=\"activeDateHasChanged\"\n              [date]=\"date\"\n            />\n          </td>\n        }\n      </tr>\n    }\n  </tbody>\n</table>\n"]}