@skyux/datetime 8.7.0 → 9.0.0-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/modules/date-pipe/date-format-utility.mjs +45 -0
- package/{esm2020 → esm2022}/lib/modules/date-pipe/date-pipe.module.mjs +5 -5
- package/esm2022/lib/modules/date-pipe/date.pipe.mjs +67 -0
- package/esm2022/lib/modules/date-pipe/fuzzy-date.pipe.mjs +47 -0
- package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +4 -4
- package/esm2022/lib/modules/date-range-picker/date-range-picker.component.mjs +518 -0
- package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker.module.mjs +19 -19
- package/esm2022/lib/modules/date-range-picker/date-range.service.mjs +97 -0
- package/esm2022/lib/modules/date-range-picker/types/date-range-calculator.mjs +54 -0
- package/esm2022/lib/modules/datepicker/date-formatter.mjs +38 -0
- package/esm2022/lib/modules/datepicker/datepicker-adapter.service.mjs +23 -0
- package/esm2022/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +332 -0
- package/esm2022/lib/modules/datepicker/datepicker-calendar.component.mjs +95 -0
- package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-config.service.mjs +4 -4
- package/esm2022/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +487 -0
- package/esm2022/lib/modules/datepicker/datepicker-input.directive.mjs +534 -0
- package/esm2022/lib/modules/datepicker/datepicker.component.mjs +327 -0
- package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker.module.mjs +35 -35
- package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/datepicker/daypicker-button.component.mjs +4 -4
- package/esm2022/lib/modules/datepicker/daypicker-cell.component.mjs +128 -0
- package/esm2022/lib/modules/datepicker/daypicker.component.mjs +224 -0
- package/esm2022/lib/modules/datepicker/fuzzy-date.service.mjs +412 -0
- package/esm2022/lib/modules/datepicker/monthpicker.component.mjs +80 -0
- package/{esm2020 → esm2022}/lib/modules/datepicker/yearpicker.component.mjs +53 -54
- package/{esm2020 → esm2022}/lib/modules/shared/sky-datetime-resources.module.mjs +11 -11
- package/esm2022/lib/modules/timepicker/timepicker.component.mjs +396 -0
- package/esm2022/lib/modules/timepicker/timepicker.directive.mjs +237 -0
- package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker.module.mjs +17 -17
- package/esm2022/testing/datepicker-fixture.mjs +55 -0
- package/esm2022/testing/timepicker-fixture.mjs +52 -0
- package/fesm2022/skyux-datetime-testing.mjs +112 -0
- package/{fesm2020 → fesm2022}/skyux-datetime-testing.mjs.map +1 -1
- package/fesm2022/skyux-datetime.mjs +5030 -0
- package/fesm2022/skyux-datetime.mjs.map +1 -0
- package/lib/modules/date-range-picker/date-range-picker.component.d.ts +1 -1
- package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +1 -1
- package/lib/modules/datepicker/datepicker-calendar.component.d.ts +1 -1
- package/lib/modules/datepicker/datepicker-input-fuzzy.directive.d.ts +1 -1
- package/lib/modules/datepicker/datepicker-input.directive.d.ts +1 -1
- package/lib/modules/datepicker/datepicker.component.d.ts +1 -1
- package/lib/modules/datepicker/daypicker-button.component.d.ts +1 -1
- package/lib/modules/datepicker/daypicker-cell.component.d.ts +1 -1
- package/lib/modules/datepicker/daypicker.component.d.ts +1 -1
- package/lib/modules/timepicker/timepicker.directive.d.ts +1 -1
- package/package.json +19 -27
- package/esm2020/lib/modules/date-pipe/date-format-utility.mjs +0 -45
- package/esm2020/lib/modules/date-pipe/date.pipe.mjs +0 -70
- package/esm2020/lib/modules/date-pipe/fuzzy-date.pipe.mjs +0 -50
- package/esm2020/lib/modules/date-range-picker/date-range-picker.component.mjs +0 -494
- package/esm2020/lib/modules/date-range-picker/date-range.service.mjs +0 -100
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator.mjs +0 -53
- package/esm2020/lib/modules/datepicker/date-formatter.mjs +0 -38
- package/esm2020/lib/modules/datepicker/datepicker-adapter.service.mjs +0 -26
- package/esm2020/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +0 -333
- package/esm2020/lib/modules/datepicker/datepicker-calendar.component.mjs +0 -96
- package/esm2020/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +0 -462
- package/esm2020/lib/modules/datepicker/datepicker-input.directive.mjs +0 -496
- package/esm2020/lib/modules/datepicker/datepicker.component.mjs +0 -319
- package/esm2020/lib/modules/datepicker/daypicker-cell.component.mjs +0 -126
- package/esm2020/lib/modules/datepicker/daypicker.component.mjs +0 -216
- package/esm2020/lib/modules/datepicker/fuzzy-date.service.mjs +0 -392
- package/esm2020/lib/modules/datepicker/monthpicker.component.mjs +0 -81
- package/esm2020/lib/modules/timepicker/timepicker.component.mjs +0 -389
- package/esm2020/lib/modules/timepicker/timepicker.directive.mjs +0 -236
- package/esm2020/testing/datepicker-fixture.mjs +0 -58
- package/esm2020/testing/timepicker-fixture.mjs +0 -55
- package/fesm2015/skyux-datetime-testing.mjs +0 -117
- package/fesm2015/skyux-datetime-testing.mjs.map +0 -1
- package/fesm2015/skyux-datetime.mjs +0 -4925
- package/fesm2015/skyux-datetime.mjs.map +0 -1
- package/fesm2020/skyux-datetime-testing.mjs +0 -117
- package/fesm2020/skyux-datetime.mjs +0 -4895
- package/fesm2020/skyux-datetime.mjs.map +0 -1
- /package/{esm2020 → esm2022}/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculation.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-config.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-id.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-default-calculator-config.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-relative-value.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-calendar-change.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-custom-date.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-date.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/datepicker/fuzzy-date.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker-time-format-type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker-time-output.mjs +0 -0
- /package/{esm2020 → esm2022}/skyux-datetime.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/skyux-datetime-testing.mjs +0 -0
@@ -0,0 +1,128 @@
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input, } from '@angular/core';
|
2
|
+
import { SkyPopoverMessageType } from '@skyux/popovers';
|
3
|
+
import { Subject } from 'rxjs';
|
4
|
+
import { takeUntil } from 'rxjs/operators';
|
5
|
+
import * as i0 from "@angular/core";
|
6
|
+
import * as i1 from "./datepicker-calendar-inner.component";
|
7
|
+
import * as i2 from "./datepicker.service";
|
8
|
+
import * as i3 from "@angular/common";
|
9
|
+
import * as i4 from "@skyux/popovers";
|
10
|
+
import * as i5 from "./daypicker-button.component";
|
11
|
+
/**
|
12
|
+
* @internal
|
13
|
+
*/
|
14
|
+
export class SkyDayPickerCellComponent {
|
15
|
+
#activeUid;
|
16
|
+
#cancelPopover;
|
17
|
+
#popoverOpen;
|
18
|
+
#ngUnsubscribe;
|
19
|
+
#datepicker;
|
20
|
+
#datepickerService;
|
21
|
+
constructor(datepicker, datepickerService) {
|
22
|
+
this.hasTooltip = false;
|
23
|
+
this.popoverController = new Subject();
|
24
|
+
this.#activeUid = '';
|
25
|
+
this.#cancelPopover = false;
|
26
|
+
this.#popoverOpen = false;
|
27
|
+
this.#ngUnsubscribe = new Subject();
|
28
|
+
this.#datepicker = datepicker;
|
29
|
+
this.#datepickerService = datepickerService;
|
30
|
+
}
|
31
|
+
ngOnInit() {
|
32
|
+
this.hasTooltip = !!(this.date &&
|
33
|
+
this.date.keyDate &&
|
34
|
+
this.date.keyDateText &&
|
35
|
+
this.date.keyDateText.length > 0 &&
|
36
|
+
this.date.keyDateText[0].length > 0);
|
37
|
+
// show the tooltip if this is the active date and is not the
|
38
|
+
// initial active date (activeDateHasChanged)
|
39
|
+
if (!!this.date &&
|
40
|
+
this.#datepicker.isActive(this.date) &&
|
41
|
+
this.activeDateHasChanged &&
|
42
|
+
this.hasTooltip) {
|
43
|
+
this.#activeUid = this.date.uid;
|
44
|
+
this.#showTooltip();
|
45
|
+
}
|
46
|
+
if (this.hasTooltip) {
|
47
|
+
this.#datepickerService.keyDatePopoverStream
|
48
|
+
.pipe(takeUntil(this.#ngUnsubscribe))
|
49
|
+
.subscribe((date) => {
|
50
|
+
if (date) {
|
51
|
+
this.#activeUid = date.uid;
|
52
|
+
}
|
53
|
+
else {
|
54
|
+
this.#activeUid = '';
|
55
|
+
}
|
56
|
+
// If this day has an open popover and they have moved off of the day close the popover.
|
57
|
+
if (this.date?.uid !== this.#activeUid) {
|
58
|
+
this.#hideTooltip();
|
59
|
+
}
|
60
|
+
});
|
61
|
+
}
|
62
|
+
}
|
63
|
+
ngOnDestroy() {
|
64
|
+
this.#ngUnsubscribe.next();
|
65
|
+
this.#ngUnsubscribe.complete();
|
66
|
+
}
|
67
|
+
onDayMouseenter() {
|
68
|
+
this.#cancelPopover = false;
|
69
|
+
if (this.hasTooltip) {
|
70
|
+
this.#showTooltip();
|
71
|
+
this.#datepickerService.keyDatePopoverStream.next(this.date);
|
72
|
+
}
|
73
|
+
}
|
74
|
+
onDayMouseleave() {
|
75
|
+
this.#cancelPopover = true;
|
76
|
+
if (this.hasTooltip) {
|
77
|
+
this.#hideTooltip();
|
78
|
+
}
|
79
|
+
this.#datepickerService.keyDatePopoverStream.next(undefined);
|
80
|
+
}
|
81
|
+
onPopoverClosed() {
|
82
|
+
this.#popoverOpen = false;
|
83
|
+
}
|
84
|
+
onPopoverOpened() {
|
85
|
+
this.#popoverOpen = true;
|
86
|
+
/* istanbul ignore else */
|
87
|
+
if (this.#cancelPopover) {
|
88
|
+
// If the popover gets opened just as a mouseout event happens, close it.
|
89
|
+
this.#hideTooltip();
|
90
|
+
this.#cancelPopover = false;
|
91
|
+
}
|
92
|
+
}
|
93
|
+
getKeyDateLabel() {
|
94
|
+
return this.hasTooltip && this.date?.keyDateText
|
95
|
+
? this.date.keyDateText.join(', ')
|
96
|
+
: '';
|
97
|
+
}
|
98
|
+
#hideTooltip() {
|
99
|
+
/* istanbul ignore else */
|
100
|
+
if (this.#popoverOpen) {
|
101
|
+
this.popoverController.next({ type: SkyPopoverMessageType.Close });
|
102
|
+
}
|
103
|
+
}
|
104
|
+
#showTooltip() {
|
105
|
+
/* istanbul ignore else */
|
106
|
+
if (this.hasTooltip && !this.#popoverOpen) {
|
107
|
+
/**
|
108
|
+
* Delay 1/2 second before opening the popover as long as mouse hasn't moved off the date.
|
109
|
+
*/
|
110
|
+
setTimeout(() => {
|
111
|
+
if (!this.#cancelPopover && this.#activeUid === this.date?.uid) {
|
112
|
+
this.popoverController.next({ type: SkyPopoverMessageType.Open });
|
113
|
+
}
|
114
|
+
}, 500);
|
115
|
+
}
|
116
|
+
}
|
117
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDayPickerCellComponent, deps: [{ token: i1.SkyDatepickerCalendarInnerComponent }, { token: i2.SkyDatepickerService }], target: i0.ɵɵFactoryTarget.Component }); }
|
118
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: SkyDayPickerCellComponent, selector: "sky-daypicker-cell", inputs: { activeDateHasChanged: "activeDateHasChanged", date: "date" }, ngImport: i0, template: "<div\n *ngIf=\"hasTooltip\"\n class=\"sky-daypicker-cell\"\n [attr.aria-label]=\"getKeyDateLabel()\"\n [skyPopover]=\"dayInfoPopover\"\n skyPopoverPlacement=\"left\"\n [skyPopoverMessageStream]=\"popoverController\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n>\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n <sky-popover\n (popoverClosed)=\"onPopoverClosed()\"\n (popoverOpened)=\"onPopoverOpened()\"\n #dayInfoPopover\n >\n <div *ngFor=\"let text of date?.keyDateText\">\n {{ text }}\n </div>\n </sky-popover>\n</div>\n<div\n *ngIf=\"!hasTooltip\"\n class=\"sky-daypicker-cell\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n>\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n</div>\n\n<ng-template #daypickerButtonTemplateRef>\n <sky-daypicker-button [date]=\"date\"> </sky-daypicker-button>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.λ6, selector: "sky-popover", inputs: ["alignment", "dismissOnBlur", "placement", "popoverTitle", "popoverType"], outputs: ["popoverClosed", "popoverOpened"] }, { kind: "directive", type: i4.λ7, selector: "[skyPopover]", inputs: ["skyPopover", "skyPopoverAlignment", "skyPopoverMessageStream", "skyPopoverPlacement", "skyPopoverTrigger"] }, { kind: "component", type: i5.SkyDayPickerButtonComponent, selector: "sky-daypicker-button", inputs: ["date"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
119
|
+
}
|
120
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDayPickerCellComponent, decorators: [{
|
121
|
+
type: Component,
|
122
|
+
args: [{ selector: 'sky-daypicker-cell', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n *ngIf=\"hasTooltip\"\n class=\"sky-daypicker-cell\"\n [attr.aria-label]=\"getKeyDateLabel()\"\n [skyPopover]=\"dayInfoPopover\"\n skyPopoverPlacement=\"left\"\n [skyPopoverMessageStream]=\"popoverController\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n>\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n <sky-popover\n (popoverClosed)=\"onPopoverClosed()\"\n (popoverOpened)=\"onPopoverOpened()\"\n #dayInfoPopover\n >\n <div *ngFor=\"let text of date?.keyDateText\">\n {{ text }}\n </div>\n </sky-popover>\n</div>\n<div\n *ngIf=\"!hasTooltip\"\n class=\"sky-daypicker-cell\"\n (mouseenter)=\"onDayMouseenter()\"\n (mouseleave)=\"onDayMouseleave()\"\n>\n <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n</div>\n\n<ng-template #daypickerButtonTemplateRef>\n <sky-daypicker-button [date]=\"date\"> </sky-daypicker-button>\n</ng-template>\n" }]
|
123
|
+
}], ctorParameters: function () { return [{ type: i1.SkyDatepickerCalendarInnerComponent }, { type: i2.SkyDatepickerService }]; }, propDecorators: { activeDateHasChanged: [{
|
124
|
+
type: Input
|
125
|
+
}], date: [{
|
126
|
+
type: Input
|
127
|
+
}] } });
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daypicker-cell.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/daypicker-cell.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/daypicker-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n} from '@angular/core';\nimport { SkyPopoverMessage, SkyPopoverMessageType } from '@skyux/popovers';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';\nimport { SkyDatepickerDate } from './datepicker-date';\nimport { SkyDatepickerService } from './datepicker.service';\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-daypicker-cell',\n  templateUrl: 'daypicker-cell.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\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: SkyDatepickerDate | 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: SkyDatepickerService;\n\n  constructor(\n    datepicker: SkyDatepickerCalendarInnerComponent,\n    datepickerService: SkyDatepickerService\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","<div\n  *ngIf=\"hasTooltip\"\n  class=\"sky-daypicker-cell\"\n  [attr.aria-label]=\"getKeyDateLabel()\"\n  [skyPopover]=\"dayInfoPopover\"\n  skyPopoverPlacement=\"left\"\n  [skyPopoverMessageStream]=\"popoverController\"\n  (mouseenter)=\"onDayMouseenter()\"\n  (mouseleave)=\"onDayMouseleave()\"\n>\n  <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n  <sky-popover\n    (popoverClosed)=\"onPopoverClosed()\"\n    (popoverOpened)=\"onPopoverOpened()\"\n    #dayInfoPopover\n  >\n    <div *ngFor=\"let text of date?.keyDateText\">\n      {{ text }}\n    </div>\n  </sky-popover>\n</div>\n<div\n  *ngIf=\"!hasTooltip\"\n  class=\"sky-daypicker-cell\"\n  (mouseenter)=\"onDayMouseenter()\"\n  (mouseleave)=\"onDayMouseleave()\"\n>\n  <ng-container *ngTemplateOutlet=\"daypickerButtonTemplateRef\"></ng-container>\n</div>\n\n<ng-template #daypickerButtonTemplateRef>\n  <sky-daypicker-button [date]=\"date\"> </sky-daypicker-button>\n</ng-template>\n"]}
|
@@ -0,0 +1,224 @@
|
|
1
|
+
import { Component, EventEmitter, Input, Output, } from '@angular/core';
|
2
|
+
import { Subject } from 'rxjs';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
import * as i1 from "./datepicker-calendar-inner.component";
|
5
|
+
import * as i2 from "@angular/common";
|
6
|
+
import * as i3 from "@skyux/indicators";
|
7
|
+
import * as i4 from "./daypicker-cell.component";
|
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 = [
|
30
|
+
31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31,
|
31
|
+
];
|
32
|
+
this.#ngUnsubscribe = new Subject();
|
33
|
+
this.datepicker = datepicker;
|
34
|
+
}
|
35
|
+
ngOnInit() {
|
36
|
+
this.datepicker.stepDay = { months: 1 };
|
37
|
+
this.#initialDate = this.datepicker.activeDate.getDate();
|
38
|
+
this.datepicker.setRefreshViewHandler(() => {
|
39
|
+
this.#refreshDayView();
|
40
|
+
}, 'day');
|
41
|
+
this.datepicker.setCompareHandler(this.#compareDays, 'day');
|
42
|
+
this.datepicker.setKeydownHandler((key, event) => {
|
43
|
+
this.#keydownDays(key, event);
|
44
|
+
}, 'day');
|
45
|
+
this.datepicker.refreshView();
|
46
|
+
}
|
47
|
+
ngOnDestroy() {
|
48
|
+
this.#ngUnsubscribe.next();
|
49
|
+
this.#ngUnsubscribe.complete();
|
50
|
+
}
|
51
|
+
getDates(startDate, n) {
|
52
|
+
const dates = new Array(n);
|
53
|
+
let current = new Date(startDate.getTime());
|
54
|
+
let i = 0;
|
55
|
+
let date;
|
56
|
+
while (i < n) {
|
57
|
+
date = new Date(current.getTime());
|
58
|
+
date = this.datepicker.fixTimeZone(date);
|
59
|
+
dates[i++] = date;
|
60
|
+
current = new Date(current.getFullYear(), current.getMonth(), current.getDate() + 1);
|
61
|
+
}
|
62
|
+
return dates;
|
63
|
+
}
|
64
|
+
#compareDays(date1, date2) {
|
65
|
+
const d1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate());
|
66
|
+
const d2 = new Date(date2.getFullYear(), date2.getMonth(), date2.getDate());
|
67
|
+
return d1.getTime() - d2.getTime();
|
68
|
+
}
|
69
|
+
#refreshDayView() {
|
70
|
+
const year = this.datepicker.activeDate.getFullYear();
|
71
|
+
const month = this.datepicker.activeDate.getMonth();
|
72
|
+
const firstDayOfMonth = new Date(year, month, 1);
|
73
|
+
const difference = this.datepicker.startingDay - firstDayOfMonth.getDay();
|
74
|
+
const numDisplayedFromPreviousMonth = difference > 0 ? 7 - difference : -difference;
|
75
|
+
const firstDate = new Date(firstDayOfMonth.getTime());
|
76
|
+
if (this.datepicker.activeDate.getDate() !== this.#initialDate) {
|
77
|
+
this.activeDateHasChanged = true;
|
78
|
+
}
|
79
|
+
/* istanbul ignore else */
|
80
|
+
/* sanity check */
|
81
|
+
if (numDisplayedFromPreviousMonth > 0) {
|
82
|
+
firstDate.setDate(-numDisplayedFromPreviousMonth + 1);
|
83
|
+
}
|
84
|
+
// 42 is the number of days on a six-week calendar
|
85
|
+
const days = this.getDates(firstDate, 42);
|
86
|
+
const pickerDates = [];
|
87
|
+
for (let i = 0; i < 42; i++) {
|
88
|
+
const _dateObject = this.datepicker.createDateObject(days[i], this.datepicker.formatDay, days[i].getMonth() !== month, this.datepicker.datepickerId + '-' + i);
|
89
|
+
pickerDates[i] = _dateObject;
|
90
|
+
}
|
91
|
+
this.labels = [];
|
92
|
+
for (let j = 0; j < 7; j++) {
|
93
|
+
this.labels[j] = {};
|
94
|
+
this.labels[j].abbr = this.datepicker.dateFilter(pickerDates[j].date, this.datepicker.formatDayHeader);
|
95
|
+
this.labels[j].full = this.datepicker.dateFilter(pickerDates[j].date, 'EEEE');
|
96
|
+
}
|
97
|
+
this.title = this.datepicker.dateFilter(this.datepicker.activeDate, this.datepicker.formatDayTitle);
|
98
|
+
const oldDateRange = this.#getDateRange(this.rows);
|
99
|
+
this.rows = this.datepicker.createCalendarRows(pickerDates, 7);
|
100
|
+
const newDateRange = this.#getDateRange(this.rows);
|
101
|
+
if (!this.#dateRangeRowsAreEqual(oldDateRange, newDateRange)) {
|
102
|
+
// Safety check
|
103
|
+
/* istanbul ignore else */
|
104
|
+
if (newDateRange) {
|
105
|
+
this.calendarDateRangeChange.next({
|
106
|
+
startDate: newDateRange.startDate,
|
107
|
+
endDate: newDateRange.endDate,
|
108
|
+
});
|
109
|
+
}
|
110
|
+
else {
|
111
|
+
this.calendarDateRangeChange.next(undefined);
|
112
|
+
}
|
113
|
+
}
|
114
|
+
}
|
115
|
+
#keydownDays(key, event) {
|
116
|
+
let date = this.datepicker.activeDate.getDate();
|
117
|
+
/* istanbul ignore else */
|
118
|
+
/* sanity check */
|
119
|
+
if (key === 'left') {
|
120
|
+
date = date - 1;
|
121
|
+
}
|
122
|
+
else if (key === 'up') {
|
123
|
+
date = date - 7;
|
124
|
+
}
|
125
|
+
else if (key === 'right') {
|
126
|
+
date = date + 1;
|
127
|
+
}
|
128
|
+
else if (key === 'down') {
|
129
|
+
date = date + 7;
|
130
|
+
}
|
131
|
+
else if (key === 'pageup' || key === 'pagedown') {
|
132
|
+
const month = this.datepicker.activeDate.getMonth() + (key === 'pageup' ? -1 : 1);
|
133
|
+
this.datepicker.activeDate.setMonth(month, 1);
|
134
|
+
date = Math.min(this.#getDaysInMonth(this.datepicker.activeDate.getFullYear(), this.datepicker.activeDate.getMonth()), date);
|
135
|
+
}
|
136
|
+
else if (key === 'home') {
|
137
|
+
date = 1;
|
138
|
+
}
|
139
|
+
else if (key === 'end') {
|
140
|
+
date = this.#getDaysInMonth(this.datepicker.activeDate.getFullYear(), this.datepicker.activeDate.getMonth());
|
141
|
+
}
|
142
|
+
this.datepicker.activeDate.setDate(date);
|
143
|
+
}
|
144
|
+
#getDaysInMonth(year, month) {
|
145
|
+
return month === 1 &&
|
146
|
+
year % 4 === 0 &&
|
147
|
+
(year % 400 === 0 || year % 100 !== 0)
|
148
|
+
? 29
|
149
|
+
: this.#daysInMonth[month];
|
150
|
+
}
|
151
|
+
/**
|
152
|
+
* Applies custom date properties to the existing dates displayed in the calendar.
|
153
|
+
*/
|
154
|
+
#applyCustomDates(customDates, dateRows) {
|
155
|
+
let date;
|
156
|
+
let newDate;
|
157
|
+
let dateIndex;
|
158
|
+
/* istanbul ignore else */
|
159
|
+
if (customDates && dateRows) {
|
160
|
+
customDates.forEach((customDate) => {
|
161
|
+
dateIndex = -1;
|
162
|
+
dateRows.forEach((row) => {
|
163
|
+
if (dateIndex === -1) {
|
164
|
+
dateIndex = row.findIndex((d) => {
|
165
|
+
return d.date.getTime() === customDate.date.getTime();
|
166
|
+
});
|
167
|
+
if (dateIndex > -1) {
|
168
|
+
date = row[dateIndex];
|
169
|
+
// Replace the date with a new instance so the display gets updated.
|
170
|
+
newDate = {
|
171
|
+
current: date.current,
|
172
|
+
date: date.date,
|
173
|
+
disabled: !!date.disabled || !!customDate.disabled,
|
174
|
+
keyDate: !!customDate.keyDate || !!date.keyDate,
|
175
|
+
keyDateText: customDate.keyDateText || date.keyDateText,
|
176
|
+
label: date.label,
|
177
|
+
secondary: date.secondary,
|
178
|
+
selected: date.selected,
|
179
|
+
uid: date.uid,
|
180
|
+
};
|
181
|
+
row[dateIndex] = newDate;
|
182
|
+
}
|
183
|
+
}
|
184
|
+
});
|
185
|
+
});
|
186
|
+
}
|
187
|
+
}
|
188
|
+
#dateRangeRowsAreEqual(rangeA, rangeB) {
|
189
|
+
/* istanbul ignore if */
|
190
|
+
if (!rangeA && !rangeB) {
|
191
|
+
return true;
|
192
|
+
}
|
193
|
+
else if (rangeA && rangeB) {
|
194
|
+
return (this.#compareDays(rangeA.startDate, rangeB.startDate) === 0 &&
|
195
|
+
this.#compareDays(rangeA.endDate, rangeB.endDate) === 0);
|
196
|
+
}
|
197
|
+
else {
|
198
|
+
return false;
|
199
|
+
}
|
200
|
+
}
|
201
|
+
#getDateRange(rows) {
|
202
|
+
/* istanbul ignore else */
|
203
|
+
if (rows && rows.length > 0) {
|
204
|
+
return {
|
205
|
+
startDate: rows[0][0].date,
|
206
|
+
endDate: rows[rows.length - 1][rows[rows.length - 1].length - 1].date,
|
207
|
+
};
|
208
|
+
}
|
209
|
+
return undefined;
|
210
|
+
}
|
211
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDayPickerComponent, deps: [{ token: i1.SkyDatepickerCalendarInnerComponent }], target: i0.ɵɵFactoryTarget.Component }); }
|
212
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: SkyDayPickerComponent, selector: "sky-daypicker", inputs: { customDates: "customDates", isWaiting: "isWaiting" }, outputs: { calendarDateRangeChange: "calendarDateRangeChange" }, ngImport: i0, template: "<div *ngIf=\"datepicker.datepickerMode === 'day'\" class=\"sky-daypicker-wrapper\">\n <table\n class=\"sky-daypicker-table\"\n role=\"grid\"\n [attr.aria-labelledby]=\"datepicker.datepickerId + '-title'\"\n >\n <thead>\n <tr>\n <th class=\"sky-datepicker-header-left\" scope=\"col\">\n <button\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-previous\"\n (click)=\"datepicker.moveCalendar($event, -1)\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n >\n <sky-icon\n class=\"sky-datepicker-chevron-default\"\n icon=\"chevron-left\"\n ></sky-icon>\n <sky-icon\n class=\"sky-datepicker-chevron-modern\"\n icon=\"chevron-left\"\n iconType=\"skyux\"\n ></sky-icon>\n </button>\n </th>\n <th scope=\"col\" [attr.colspan]=\"5\">\n <button\n [id]=\"datepicker.datepickerId + '-title'\"\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-calendar-title\"\n (click)=\"datepicker.toggleModeCalendar($event)\"\n [disabled]=\"datepicker.datepickerMode === datepicker.maxMode\"\n [ngClass]=\"{\n 'sky-btn-disabled':\n datepicker.datepickerMode === datepicker.maxMode\n }\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n >\n <strong>{{ title }}</strong>\n </button>\n </th>\n <th class=\"sky-datepicker-header-right\" scope=\"col\">\n <button\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-next\"\n (click)=\"datepicker.moveCalendar($event, 1)\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n >\n <sky-icon\n class=\"sky-datepicker-chevron-default\"\n icon=\"chevron-right\"\n ></sky-icon>\n <sky-icon\n class=\"sky-datepicker-chevron-modern\"\n icon=\"chevron-right\"\n iconType=\"skyux\"\n ></sky-icon>\n </button>\n </th>\n </tr>\n <tr>\n <th\n scope=\"col\"\n *ngFor=\"let label of labels\"\n class=\"sky-datepicker-center sky-datepicker-weekdays\"\n >\n <small [attr.aria-label]=\"label.full\">\n <b>{{ label.abbr }}</b>\n </small>\n </th>\n </tr>\n </thead>\n <tbody>\n <!-- Wait indicator for async custom date stream -->\n <sky-wait [isWaiting]=\"isWaiting\"> </sky-wait>\n <ng-template ngFor [ngForOf]=\"rows\" let-row=\"$implicit\" let-index=\"index\">\n <tr role=\"row\">\n <td\n *ngFor=\"let date of row\"\n class=\"sky-datepicker-center\"\n role=\"gridcell\"\n [id]=\"date.uid\"\n >\n <sky-daypicker-cell\n [activeDateHasChanged]=\"activeDateHasChanged\"\n [date]=\"date\"\n >\n </sky-daypicker-cell>\n </td>\n </tr>\n </ng-template>\n </tbody>\n </table>\n</div>\n", styles: [":host-context(.sky-theme-modern) :host:focus{outline:none}.sky-theme-modern :host:focus{outline:none}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "component", type: i3.λ14, selector: "sky-wait", inputs: ["ariaLabel", "isWaiting", "isFullPage", "isNonBlocking", "screenReaderCompletedText"] }, { kind: "component", type: i4.SkyDayPickerCellComponent, selector: "sky-daypicker-cell", inputs: ["activeDateHasChanged", "date"] }] }); }
|
213
|
+
}
|
214
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDayPickerComponent, decorators: [{
|
215
|
+
type: Component,
|
216
|
+
args: [{ selector: 'sky-daypicker', template: "<div *ngIf=\"datepicker.datepickerMode === 'day'\" class=\"sky-daypicker-wrapper\">\n <table\n class=\"sky-daypicker-table\"\n role=\"grid\"\n [attr.aria-labelledby]=\"datepicker.datepickerId + '-title'\"\n >\n <thead>\n <tr>\n <th class=\"sky-datepicker-header-left\" scope=\"col\">\n <button\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-previous\"\n (click)=\"datepicker.moveCalendar($event, -1)\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n >\n <sky-icon\n class=\"sky-datepicker-chevron-default\"\n icon=\"chevron-left\"\n ></sky-icon>\n <sky-icon\n class=\"sky-datepicker-chevron-modern\"\n icon=\"chevron-left\"\n iconType=\"skyux\"\n ></sky-icon>\n </button>\n </th>\n <th scope=\"col\" [attr.colspan]=\"5\">\n <button\n [id]=\"datepicker.datepickerId + '-title'\"\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-calendar-title\"\n (click)=\"datepicker.toggleModeCalendar($event)\"\n [disabled]=\"datepicker.datepickerMode === datepicker.maxMode\"\n [ngClass]=\"{\n 'sky-btn-disabled':\n datepicker.datepickerMode === datepicker.maxMode\n }\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n >\n <strong>{{ title }}</strong>\n </button>\n </th>\n <th class=\"sky-datepicker-header-right\" scope=\"col\">\n <button\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-next\"\n (click)=\"datepicker.moveCalendar($event, 1)\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n >\n <sky-icon\n class=\"sky-datepicker-chevron-default\"\n icon=\"chevron-right\"\n ></sky-icon>\n <sky-icon\n class=\"sky-datepicker-chevron-modern\"\n icon=\"chevron-right\"\n iconType=\"skyux\"\n ></sky-icon>\n </button>\n </th>\n </tr>\n <tr>\n <th\n scope=\"col\"\n *ngFor=\"let label of labels\"\n class=\"sky-datepicker-center sky-datepicker-weekdays\"\n >\n <small [attr.aria-label]=\"label.full\">\n <b>{{ label.abbr }}</b>\n </small>\n </th>\n </tr>\n </thead>\n <tbody>\n <!-- Wait indicator for async custom date stream -->\n <sky-wait [isWaiting]=\"isWaiting\"> </sky-wait>\n <ng-template ngFor [ngForOf]=\"rows\" let-row=\"$implicit\" let-index=\"index\">\n <tr role=\"row\">\n <td\n *ngFor=\"let date of row\"\n class=\"sky-datepicker-center\"\n role=\"gridcell\"\n [id]=\"date.uid\"\n >\n <sky-daypicker-cell\n [activeDateHasChanged]=\"activeDateHasChanged\"\n [date]=\"date\"\n >\n </sky-daypicker-cell>\n </td>\n </tr>\n </ng-template>\n </tbody>\n </table>\n</div>\n", styles: [":host-context(.sky-theme-modern) :host:focus{outline:none}.sky-theme-modern :host:focus{outline:none}\n"] }]
|
217
|
+
}], ctorParameters: function () { return [{ type: i1.SkyDatepickerCalendarInnerComponent }]; }, propDecorators: { customDates: [{
|
218
|
+
type: Input
|
219
|
+
}], calendarDateRangeChange: [{
|
220
|
+
type: Output
|
221
|
+
}], isWaiting: [{
|
222
|
+
type: Input
|
223
|
+
}] } });
|
224
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daypicker.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/daypicker.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/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';\n\nimport { Subject } from 'rxjs';\n\nimport { SkyDatepickerCalendarChange } from './datepicker-calendar-change';\nimport { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';\nimport { SkyDatepickerCustomDate } from './datepicker-custom-date';\nimport { SkyDatepickerDate } from './datepicker-date';\n\n/**\n * Helper interface to compare date ranges.\n * @internal\n */\ninterface SkyDateRange {\n  endDate: Date;\n\n  startDate: Date;\n}\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-daypicker',\n  templateUrl: 'daypicker.component.html',\n  styleUrls: ['./daypicker.component.scss'],\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: Array<Array<SkyDatepickerDate>> = [];\n  public weekNumbers: number[] = [];\n  public datepicker: SkyDatepickerCalendarInnerComponent;\n  public CURRENT_THEME_TEMPLATE: any;\n\n  #daysInMonth: Array<number> = [\n    31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31,\n  ];\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(() => {\n      this.#refreshDayView();\n    }, '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() {\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: Array<SkyDatepickerDate> = [];\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    this.title = this.datepicker.dateFilter(\n      this.datepicker.activeDate,\n      this.datepicker.formatDayTitle\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\n  #keydownDays(key: string, event: KeyboardEvent) {\n    let date = this.datepicker.activeDate.getDate();\n    /* istanbul ignore else */\n    /* sanity check */\n    if (key === 'left') {\n      date = date - 1;\n    } else if (key === 'up') {\n      date = date - 7;\n    } else if (key === 'right') {\n      date = date + 1;\n    } else if (key === 'down') {\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  }\n\n  #getDaysInMonth(year: number, month: 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: SkyDatepickerDate[][]\n  ): void {\n    let date: SkyDatepickerDate;\n    let newDate: SkyDatepickerDate;\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(\n    rows: Array<Array<SkyDatepickerDate>>\n  ): 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","<div *ngIf=\"datepicker.datepickerMode === 'day'\" class=\"sky-daypicker-wrapper\">\n  <table\n    class=\"sky-daypicker-table\"\n    role=\"grid\"\n    [attr.aria-labelledby]=\"datepicker.datepickerId + '-title'\"\n  >\n    <thead>\n      <tr>\n        <th class=\"sky-datepicker-header-left\" scope=\"col\">\n          <button\n            type=\"button\"\n            class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-previous\"\n            (click)=\"datepicker.moveCalendar($event, -1)\"\n            tabindex=\"-1\"\n            aria-hidden=\"true\"\n          >\n            <sky-icon\n              class=\"sky-datepicker-chevron-default\"\n              icon=\"chevron-left\"\n            ></sky-icon>\n            <sky-icon\n              class=\"sky-datepicker-chevron-modern\"\n              icon=\"chevron-left\"\n              iconType=\"skyux\"\n            ></sky-icon>\n          </button>\n        </th>\n        <th scope=\"col\" [attr.colspan]=\"5\">\n          <button\n            [id]=\"datepicker.datepickerId + '-title'\"\n            type=\"button\"\n            class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-calendar-title\"\n            (click)=\"datepicker.toggleModeCalendar($event)\"\n            [disabled]=\"datepicker.datepickerMode === datepicker.maxMode\"\n            [ngClass]=\"{\n              'sky-btn-disabled':\n                datepicker.datepickerMode === datepicker.maxMode\n            }\"\n            tabindex=\"-1\"\n            aria-hidden=\"true\"\n          >\n            <strong>{{ title }}</strong>\n          </button>\n        </th>\n        <th class=\"sky-datepicker-header-right\" scope=\"col\">\n          <button\n            type=\"button\"\n            class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-next\"\n            (click)=\"datepicker.moveCalendar($event, 1)\"\n            tabindex=\"-1\"\n            aria-hidden=\"true\"\n          >\n            <sky-icon\n              class=\"sky-datepicker-chevron-default\"\n              icon=\"chevron-right\"\n            ></sky-icon>\n            <sky-icon\n              class=\"sky-datepicker-chevron-modern\"\n              icon=\"chevron-right\"\n              iconType=\"skyux\"\n            ></sky-icon>\n          </button>\n        </th>\n      </tr>\n      <tr>\n        <th\n          scope=\"col\"\n          *ngFor=\"let label of labels\"\n          class=\"sky-datepicker-center sky-datepicker-weekdays\"\n        >\n          <small [attr.aria-label]=\"label.full\">\n            <b>{{ label.abbr }}</b>\n          </small>\n        </th>\n      </tr>\n    </thead>\n    <tbody>\n      <!-- Wait indicator for async custom date stream -->\n      <sky-wait [isWaiting]=\"isWaiting\"> </sky-wait>\n      <ng-template ngFor [ngForOf]=\"rows\" let-row=\"$implicit\" let-index=\"index\">\n        <tr role=\"row\">\n          <td\n            *ngFor=\"let date of row\"\n            class=\"sky-datepicker-center\"\n            role=\"gridcell\"\n            [id]=\"date.uid\"\n          >\n            <sky-daypicker-cell\n              [activeDateHasChanged]=\"activeDateHasChanged\"\n              [date]=\"date\"\n            >\n            </sky-daypicker-cell>\n          </td>\n        </tr>\n      </ng-template>\n    </tbody>\n  </table>\n</div>\n"]}
|