@skyux/datetime 4.12.3 → 4.13.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/CHANGELOG.md +4 -0
- package/bundles/skyux-datetime.umd.js +1294 -941
- package/bundles/skyux-datetime.umd.js.map +1 -1
- package/bundles/skyux-datetime.umd.min.js +2 -2
- package/bundles/skyux-datetime.umd.min.js.map +1 -1
- package/esm2015/modules/datepicker/datepicker-calendar-change.js +1 -0
- package/esm2015/modules/datepicker/datepicker-calendar-inner.component.js +30 -4
- package/esm2015/modules/datepicker/datepicker-calendar.component.js +15 -2
- package/esm2015/modules/datepicker/datepicker-custom-date.js +1 -0
- package/esm2015/modules/datepicker/datepicker-date.js +1 -1
- package/esm2015/modules/datepicker/datepicker.component.js +47 -4
- package/esm2015/modules/datepicker/datepicker.module.js +20 -9
- package/esm2015/modules/datepicker/datepicker.service.js +20 -0
- package/esm2015/modules/datepicker/daypicker-button.component.js +26 -0
- package/esm2015/modules/datepicker/daypicker-cell.component.js +131 -0
- package/esm2015/modules/datepicker/daypicker.component.js +95 -3
- package/esm2015/public_api.js +1 -1
- package/esm2015/skyux-datetime.js +6 -3
- package/esm5/modules/datepicker/datepicker-calendar-change.js +1 -0
- package/esm5/modules/datepicker/datepicker-calendar-inner.component.js +30 -4
- package/esm5/modules/datepicker/datepicker-calendar.component.js +15 -2
- package/esm5/modules/datepicker/datepicker-custom-date.js +1 -0
- package/esm5/modules/datepicker/datepicker-date.js +1 -1
- package/esm5/modules/datepicker/datepicker.component.js +48 -4
- package/esm5/modules/datepicker/datepicker.module.js +20 -9
- package/esm5/modules/datepicker/datepicker.service.js +21 -0
- package/esm5/modules/datepicker/daypicker-button.component.js +27 -0
- package/esm5/modules/datepicker/daypicker-cell.component.js +134 -0
- package/esm5/modules/datepicker/daypicker.component.js +99 -3
- package/esm5/public_api.js +1 -1
- package/esm5/skyux-datetime.js +6 -3
- package/fesm2015/skyux-datetime.js +1380 -1039
- package/fesm2015/skyux-datetime.js.map +1 -1
- package/fesm5/skyux-datetime.js +1289 -938
- package/fesm5/skyux-datetime.js.map +1 -1
- package/modules/datepicker/datepicker-calendar-change.d.ts +24 -0
- package/modules/datepicker/datepicker-calendar-inner.component.d.ts +12 -2
- package/modules/datepicker/datepicker-calendar.component.d.ts +6 -0
- package/modules/datepicker/datepicker-custom-date.d.ts +21 -0
- package/modules/datepicker/datepicker-date.d.ts +2 -0
- package/modules/datepicker/datepicker.component.d.ts +13 -0
- package/modules/datepicker/datepicker.service.d.ts +12 -0
- package/modules/datepicker/daypicker-button.component.d.ts +13 -0
- package/modules/datepicker/daypicker-cell.component.d.ts +37 -0
- package/modules/datepicker/daypicker.component.d.ts +17 -2
- package/package.json +3 -2
- package/public_api.d.ts +2 -0
- package/skyux-datetime.d.ts +5 -2
- package/skyux-datetime.metadata.json +1 -1
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
4
|
+
/**
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
let SkyDatepickerService = class SkyDatepickerService {
|
|
8
|
+
constructor() {
|
|
9
|
+
/**
|
|
10
|
+
* Specifies if a key date popover is currently displayed.
|
|
11
|
+
* Useful for communicating across all daypicker siblings when a popover is displayed.
|
|
12
|
+
*/
|
|
13
|
+
this.keyDatePopoverStream = new Subject();
|
|
14
|
+
}
|
|
15
|
+
};
|
|
16
|
+
SkyDatepickerService = __decorate([
|
|
17
|
+
Injectable()
|
|
18
|
+
], SkyDatepickerService);
|
|
19
|
+
export { SkyDatepickerService };
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNreXV4L2RhdGV0aW1lLyIsInNvdXJjZXMiOlsibW9kdWxlcy9kYXRlcGlja2VyL2RhdGVwaWNrZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUNMLFVBQVUsRUFDWCxNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQ0wsT0FBTyxFQUNSLE1BQU0sTUFBTSxDQUFDO0FBTWQ7O0dBRUc7QUFFSCxJQUFhLG9CQUFvQixHQUFqQyxNQUFhLG9CQUFvQjtJQUFqQztRQUVFOzs7V0FHRztRQUNJLHlCQUFvQixHQUErQixJQUFJLE9BQU8sRUFBcUIsQ0FBQztJQUU3RixDQUFDO0NBQUEsQ0FBQTtBQVJZLG9CQUFvQjtJQURoQyxVQUFVLEVBQUU7R0FDQSxvQkFBb0IsQ0FRaEM7U0FSWSxvQkFBb0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBJbmplY3RhYmxlXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge1xuICBTdWJqZWN0XG59IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQge1xuICBTa3lEYXRlcGlja2VyRGF0ZVxufSBmcm9tICcuL2RhdGVwaWNrZXItZGF0ZSc7XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBTa3lEYXRlcGlja2VyU2VydmljZSB7XG5cbiAgLyoqXG4gICAqIFNwZWNpZmllcyBpZiBhIGtleSBkYXRlIHBvcG92ZXIgaXMgY3VycmVudGx5IGRpc3BsYXllZC5cbiAgICogVXNlZnVsIGZvciBjb21tdW5pY2F0aW5nIGFjcm9zcyBhbGwgZGF5cGlja2VyIHNpYmxpbmdzIHdoZW4gYSBwb3BvdmVyIGlzIGRpc3BsYXllZC5cbiAgICovXG4gIHB1YmxpYyBrZXlEYXRlUG9wb3ZlclN0cmVhbTogU3ViamVjdDxTa3lEYXRlcGlja2VyRGF0ZT4gPSBuZXcgU3ViamVjdDxTa3lEYXRlcGlja2VyRGF0ZT4oKTtcblxufVxuIl19
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Component, Input } from '@angular/core';
|
|
3
|
+
import { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';
|
|
4
|
+
/**
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
let SkyDayPickerButtonComponent = class SkyDayPickerButtonComponent {
|
|
8
|
+
constructor(datepicker) {
|
|
9
|
+
this.datepicker = datepicker;
|
|
10
|
+
}
|
|
11
|
+
};
|
|
12
|
+
SkyDayPickerButtonComponent.ctorParameters = () => [
|
|
13
|
+
{ type: SkyDatepickerCalendarInnerComponent }
|
|
14
|
+
];
|
|
15
|
+
__decorate([
|
|
16
|
+
Input()
|
|
17
|
+
], SkyDayPickerButtonComponent.prototype, "date", void 0);
|
|
18
|
+
SkyDayPickerButtonComponent = __decorate([
|
|
19
|
+
Component({
|
|
20
|
+
selector: 'sky-daypicker-button',
|
|
21
|
+
template: "<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 (click)=\"datepicker.selectCalendar($event, date.date, true)\"\n>\n <span\n [ngClass]=\"{ 'sky-datepicker-secondary': date.secondary }\"\n >\n {{date.label}}\n </span>\n</button>\n",
|
|
22
|
+
styles: [".sky-datepicker-btn-disabled{font-style:italic}.sky-datepicker-btn-key-date{position:relative}.sky-datepicker-btn-key-date::before{position:absolute;content:\"\";height:5px;width:5px;background-color:#d93a3d;border-radius:50%;left:15px;top:22px}:host-context(.sky-theme-modern) .sky-datepicker-btn-key-date::before{left:12px}.sky-theme-modern .sky-datepicker-btn-key-date::before{left:12px}"]
|
|
23
|
+
})
|
|
24
|
+
], SkyDayPickerButtonComponent);
|
|
25
|
+
export { SkyDayPickerButtonComponent };
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF5cGlja2VyLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2t5dXgvZGF0ZXRpbWUvIiwic291cmNlcyI6WyJtb2R1bGVzL2RhdGVwaWNrZXIvZGF5cGlja2VyLWJ1dHRvbi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1QsS0FBSyxFQUNOLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFDTCxtQ0FBbUMsRUFDcEMsTUFBTSx1Q0FBdUMsQ0FBQztBQU0vQzs7R0FFRztBQU1ILElBQWEsMkJBQTJCLEdBQXhDLE1BQWEsMkJBQTJCO0lBUXRDLFlBQ1MsVUFBK0M7UUFBL0MsZUFBVSxHQUFWLFVBQVUsQ0FBcUM7SUFDckQsQ0FBQztDQUVMLENBQUE7O1lBSHNCLG1DQUFtQzs7QUFIeEQ7SUFEQyxLQUFLLEVBQUU7eURBQ3VCO0FBTnBCLDJCQUEyQjtJQUx2QyxTQUFTLENBQUM7UUFDVCxRQUFRLEVBQUUsc0JBQXNCO1FBQ2hDLHVuQkFBOEM7O0tBRS9DLENBQUM7R0FDVywyQkFBMkIsQ0FZdkM7U0FaWSwyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb21wb25lbnQsXG4gIElucHV0XG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge1xuICBTa3lEYXRlcGlja2VyQ2FsZW5kYXJJbm5lckNvbXBvbmVudFxufSBmcm9tICcuL2RhdGVwaWNrZXItY2FsZW5kYXItaW5uZXIuY29tcG9uZW50JztcblxuaW1wb3J0IHtcbiAgU2t5RGF0ZXBpY2tlckRhdGVcbn0gZnJvbSAnLi9kYXRlcGlja2VyLWRhdGUnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdza3ktZGF5cGlja2VyLWJ1dHRvbicsXG4gIHRlbXBsYXRlVXJsOiAnZGF5cGlja2VyLWJ1dHRvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2RheXBpY2tlci1idXR0b24uY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBTa3lEYXlQaWNrZXJCdXR0b25Db21wb25lbnQge1xuXG4gIC8qKlxuICAgKiBTcGVjaWZpZXMgdGhlIGRhdGUgdGhpcyBwaWNrZXIgYnV0dG9uIHdpbGwgcmVwcmVzZW50IG9uIHRoZSBjYWxlbmRhci5cbiAgICovXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBkYXRlOiBTa3lEYXRlcGlja2VyRGF0ZTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgZGF0ZXBpY2tlcjogU2t5RGF0ZXBpY2tlckNhbGVuZGFySW5uZXJDb21wb25lbnRcbiAgKSB7fVxuXG59XG4iXX0=
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
3
|
+
import { SkyPopoverMessageType } from '@skyux/popovers';
|
|
4
|
+
import { takeUntil } from 'rxjs/operators';
|
|
5
|
+
import { Subject } from 'rxjs';
|
|
6
|
+
import { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';
|
|
7
|
+
import { SkyDatepickerService } from './datepicker.service';
|
|
8
|
+
/**
|
|
9
|
+
* @internal
|
|
10
|
+
*/
|
|
11
|
+
let SkyDayPickerCellComponent = class SkyDayPickerCellComponent {
|
|
12
|
+
constructor(datepicker, datepickerService) {
|
|
13
|
+
this.datepicker = datepicker;
|
|
14
|
+
this.datepickerService = datepickerService;
|
|
15
|
+
this.hasTooltip = false;
|
|
16
|
+
this.popoverController = new Subject();
|
|
17
|
+
this.activeUid = '';
|
|
18
|
+
this.cancelPopover = false;
|
|
19
|
+
this.popoverOpen = false;
|
|
20
|
+
this.ngUnsubscribe = new Subject();
|
|
21
|
+
}
|
|
22
|
+
ngOnInit() {
|
|
23
|
+
this.hasTooltip =
|
|
24
|
+
this.date.keyDate &&
|
|
25
|
+
this.date.keyDateText &&
|
|
26
|
+
this.date.keyDateText.length > 0 &&
|
|
27
|
+
this.date.keyDateText[0].length > 0;
|
|
28
|
+
// show the tooltip if this is the active date and is not the
|
|
29
|
+
// initial active date (activeDateHasChanged)
|
|
30
|
+
if (this.datepicker.isActive(this.date) &&
|
|
31
|
+
this.activeDateHasChanged &&
|
|
32
|
+
this.hasTooltip) {
|
|
33
|
+
this.activeUid = this.date.uid;
|
|
34
|
+
this.showTooltip();
|
|
35
|
+
}
|
|
36
|
+
if (this.hasTooltip) {
|
|
37
|
+
this.datepickerService.keyDatePopoverStream
|
|
38
|
+
.pipe(takeUntil(this.ngUnsubscribe))
|
|
39
|
+
.subscribe(date => {
|
|
40
|
+
if (date) {
|
|
41
|
+
this.activeUid = date.uid;
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
this.activeUid = '';
|
|
45
|
+
}
|
|
46
|
+
// If this day has an open popover and they have moved off of the day close the popover.
|
|
47
|
+
if (this.date.uid !== this.activeUid) {
|
|
48
|
+
this.hideTooltip();
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
ngOnDestroy() {
|
|
54
|
+
this.ngUnsubscribe.next();
|
|
55
|
+
this.ngUnsubscribe.complete();
|
|
56
|
+
}
|
|
57
|
+
onDayMouseenter() {
|
|
58
|
+
this.cancelPopover = false;
|
|
59
|
+
if (this.hasTooltip) {
|
|
60
|
+
this.showTooltip();
|
|
61
|
+
this.datepickerService.keyDatePopoverStream.next(this.date);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
onDayMouseleave() {
|
|
65
|
+
this.cancelPopover = true;
|
|
66
|
+
if (this.hasTooltip) {
|
|
67
|
+
this.hideTooltip();
|
|
68
|
+
}
|
|
69
|
+
this.datepickerService.keyDatePopoverStream.next(undefined);
|
|
70
|
+
}
|
|
71
|
+
onPopoverClosed() {
|
|
72
|
+
this.popoverOpen = false;
|
|
73
|
+
}
|
|
74
|
+
onPopoverOpened() {
|
|
75
|
+
this.popoverOpen = true;
|
|
76
|
+
/* istanbul ignore else */
|
|
77
|
+
if (this.cancelPopover) {
|
|
78
|
+
// If the popover gets opened just as a mouseout event happens, close it.
|
|
79
|
+
this.hideTooltip();
|
|
80
|
+
this.cancelPopover = false;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
getKeyDateLabel() {
|
|
84
|
+
if (this.hasTooltip) {
|
|
85
|
+
return this.date.keyDateText.join(', ');
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
return '';
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
hideTooltip() {
|
|
92
|
+
/* istanbul ignore else */
|
|
93
|
+
if (this.popoverOpen) {
|
|
94
|
+
this.popoverController.next({ type: SkyPopoverMessageType.Close });
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
showTooltip() {
|
|
98
|
+
/* istanbul ignore else */
|
|
99
|
+
if (this.hasTooltip &&
|
|
100
|
+
!this.popoverOpen) {
|
|
101
|
+
/**
|
|
102
|
+
* Delay 1/2 second before opening the popover as long as mouse hasn't moved off the date.
|
|
103
|
+
*/
|
|
104
|
+
setTimeout(() => {
|
|
105
|
+
if (!this.cancelPopover &&
|
|
106
|
+
this.activeUid === this.date.uid) {
|
|
107
|
+
this.popoverController.next({ type: SkyPopoverMessageType.Open });
|
|
108
|
+
}
|
|
109
|
+
}, 500);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
};
|
|
113
|
+
SkyDayPickerCellComponent.ctorParameters = () => [
|
|
114
|
+
{ type: SkyDatepickerCalendarInnerComponent },
|
|
115
|
+
{ type: SkyDatepickerService }
|
|
116
|
+
];
|
|
117
|
+
__decorate([
|
|
118
|
+
Input()
|
|
119
|
+
], SkyDayPickerCellComponent.prototype, "activeDateHasChanged", void 0);
|
|
120
|
+
__decorate([
|
|
121
|
+
Input()
|
|
122
|
+
], SkyDayPickerCellComponent.prototype, "date", void 0);
|
|
123
|
+
SkyDayPickerCellComponent = __decorate([
|
|
124
|
+
Component({
|
|
125
|
+
selector: 'sky-daypicker-cell',
|
|
126
|
+
template: "<div *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 *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\n [date]=\"date\"\n >\n </sky-daypicker-button>\n</ng-template>\n",
|
|
127
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
128
|
+
})
|
|
129
|
+
], SkyDayPickerCellComponent);
|
|
130
|
+
export { SkyDayPickerCellComponent };
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daypicker-cell.component.js","sourceRoot":"ng://@skyux/datetime/","sources":["modules/datepicker/daypicker-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit\n} from '@angular/core';\n\nimport {\n  SkyPopoverMessage,\n  SkyPopoverMessageType\n} from '@skyux/popovers';\n\nimport {\n  takeUntil\n} from 'rxjs/operators';\n\nimport {\n  Subject\n} from 'rxjs';\n\nimport {\n  SkyDatepickerCalendarInnerComponent\n} from './datepicker-calendar-inner.component';\n\nimport {\n  SkyDatepickerDate\n} from './datepicker-date';\n\nimport {\n  SkyDatepickerService\n} 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  /**\n   * Specifies if the active date has been changed.\n   */\n  @Input()\n  public activeDateHasChanged: boolean;\n\n  /**\n   * Specifies the date this picker cell will represent on the calendar.\n   */\n  @Input()\n  public date: SkyDatepickerDate;\n\n  public hasTooltip: boolean = false;\n\n  public popoverController = new Subject<SkyPopoverMessage>();\n\n  private activeUid: string = '';\n\n  private cancelPopover: boolean = false;\n\n  private popoverOpen: boolean = false;\n\n  private ngUnsubscribe = new Subject<void>();\n\n  public constructor(\n    private datepicker: SkyDatepickerCalendarInnerComponent,\n    private datepickerService: SkyDatepickerService\n  ) {}\n\n  public ngOnInit(): void {\n    this.hasTooltip =\n      this.date.keyDate &&\n      this.date.keyDateText &&\n      this.date.keyDateText.length > 0 &&\n      this.date.keyDateText[0].length > 0;\n\n    // show the tooltip if this is the active date and is not the\n    // initial active date (activeDateHasChanged)\n    if (\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\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    if (this.hasTooltip) {\n      return this.date.keyDateText.join(', ');\n    } else {\n      return '';\n    }\n  }\n\n  private hideTooltip(): void {\n    /* istanbul ignore else */\n    if (this.popoverOpen) {\n      this.popoverController.next({ type: SkyPopoverMessageType.Close });\n    }\n  }\n\n  private showTooltip(): void {\n    /* istanbul ignore else */\n    if (\n      this.hasTooltip &&\n      !this.popoverOpen\n    ) {\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 (\n          !this.cancelPopover &&\n          this.activeUid === this.date.uid\n        ) {\n          this.popoverController.next({ type: SkyPopoverMessageType.Open });\n        }\n      }, 500);\n    }\n  }\n}\n"]}
|
|
@@ -1,19 +1,31 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { Component } from '@angular/core';
|
|
2
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
3
4
|
import { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';
|
|
4
5
|
/**
|
|
5
6
|
* @internal
|
|
6
7
|
*/
|
|
7
8
|
let SkyDayPickerComponent = class SkyDayPickerComponent {
|
|
8
9
|
constructor(datepicker) {
|
|
10
|
+
this.calendarDateRangeChange = new EventEmitter();
|
|
11
|
+
this.isWaiting = false;
|
|
9
12
|
this.labels = [];
|
|
10
13
|
this.rows = [];
|
|
11
14
|
this.weekNumbers = [];
|
|
15
|
+
this.activeDateHasChanged = false;
|
|
12
16
|
this.daysInMonth = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
|
|
17
|
+
this.ngUnsubscribe = new Subject();
|
|
13
18
|
this.datepicker = datepicker;
|
|
14
19
|
}
|
|
20
|
+
set customDates(value) {
|
|
21
|
+
/* istanbul ignore else */
|
|
22
|
+
if (value) {
|
|
23
|
+
this.applyCustomDates(value, this.rows);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
15
26
|
ngOnInit() {
|
|
16
27
|
this.datepicker.stepDay = { months: 1 };
|
|
28
|
+
this.initialDate = this.datepicker.activeDate.getDate();
|
|
17
29
|
this.datepicker.setRefreshViewHandler(() => {
|
|
18
30
|
this.refreshDayView();
|
|
19
31
|
}, 'day');
|
|
@@ -23,6 +35,10 @@ let SkyDayPickerComponent = class SkyDayPickerComponent {
|
|
|
23
35
|
}, 'day');
|
|
24
36
|
this.datepicker.refreshView();
|
|
25
37
|
}
|
|
38
|
+
ngOnDestroy() {
|
|
39
|
+
this.ngUnsubscribe.next();
|
|
40
|
+
this.ngUnsubscribe.complete();
|
|
41
|
+
}
|
|
26
42
|
getDates(startDate, n) {
|
|
27
43
|
let dates = new Array(n);
|
|
28
44
|
let current = new Date(startDate.getTime());
|
|
@@ -50,6 +66,9 @@ let SkyDayPickerComponent = class SkyDayPickerComponent {
|
|
|
50
66
|
? 7 - difference
|
|
51
67
|
: -difference;
|
|
52
68
|
let firstDate = new Date(firstDayOfMonth.getTime());
|
|
69
|
+
if (this.datepicker.activeDate.getDate() !== this.initialDate) {
|
|
70
|
+
this.activeDateHasChanged = true;
|
|
71
|
+
}
|
|
53
72
|
/* istanbul ignore else */
|
|
54
73
|
/* sanity check */
|
|
55
74
|
if (numDisplayedFromPreviousMonth > 0) {
|
|
@@ -71,7 +90,15 @@ let SkyDayPickerComponent = class SkyDayPickerComponent {
|
|
|
71
90
|
}
|
|
72
91
|
this.title =
|
|
73
92
|
this.datepicker.dateFilter(this.datepicker.activeDate, this.datepicker.formatDayTitle);
|
|
93
|
+
const oldDateRange = this.getDateRange(this.rows);
|
|
74
94
|
this.rows = this.datepicker.createCalendarRows(pickerDates, 7);
|
|
95
|
+
const newDateRange = this.getDateRange(this.rows);
|
|
96
|
+
if (!this.dateRangeRowsAreEqual(oldDateRange, newDateRange)) {
|
|
97
|
+
this.calendarDateRangeChange.next({
|
|
98
|
+
startDate: newDateRange.startDate,
|
|
99
|
+
endDate: newDateRange.endDate
|
|
100
|
+
});
|
|
101
|
+
}
|
|
75
102
|
}
|
|
76
103
|
keydownDays(key, event) {
|
|
77
104
|
let date = this.datepicker.activeDate.getDate();
|
|
@@ -107,16 +134,81 @@ let SkyDayPickerComponent = class SkyDayPickerComponent {
|
|
|
107
134
|
return month === 1 && year % 4 === 0 &&
|
|
108
135
|
(year % 400 === 0 || year % 100 !== 0) ? 29 : this.daysInMonth[month];
|
|
109
136
|
}
|
|
137
|
+
/**
|
|
138
|
+
* Applies custom date properties to the existing dates displayed in the calendar.
|
|
139
|
+
*/
|
|
140
|
+
applyCustomDates(customDates, dateRows) {
|
|
141
|
+
let date;
|
|
142
|
+
let newDate;
|
|
143
|
+
let dateIndex;
|
|
144
|
+
/* istanbul ignore else */
|
|
145
|
+
if (customDates && dateRows) {
|
|
146
|
+
customDates.forEach(customDate => {
|
|
147
|
+
dateIndex = -1;
|
|
148
|
+
dateRows.forEach(row => {
|
|
149
|
+
if (dateIndex === -1) {
|
|
150
|
+
dateIndex = row.findIndex(d => {
|
|
151
|
+
return d.date.getTime() === customDate.date.getTime();
|
|
152
|
+
});
|
|
153
|
+
if (dateIndex > -1) {
|
|
154
|
+
date = row[dateIndex];
|
|
155
|
+
// Replace the date with a new instance so the display gets updated.
|
|
156
|
+
newDate = {
|
|
157
|
+
current: date.current,
|
|
158
|
+
date: date.date,
|
|
159
|
+
disabled: !!date.disabled || !!customDate.disabled,
|
|
160
|
+
keyDate: !!customDate.keyDate || !!date.keyDate,
|
|
161
|
+
keyDateText: customDate.keyDateText || date.keyDateText,
|
|
162
|
+
label: date.label,
|
|
163
|
+
secondary: date.secondary,
|
|
164
|
+
selected: date.selected,
|
|
165
|
+
uid: date.uid
|
|
166
|
+
};
|
|
167
|
+
row[dateIndex] = newDate;
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
});
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
dateRangeRowsAreEqual(rangeA, rangeB) {
|
|
175
|
+
/* istanbul ignore if */
|
|
176
|
+
if (!rangeA && !rangeB) {
|
|
177
|
+
return true;
|
|
178
|
+
}
|
|
179
|
+
else if ((rangeA && !rangeB) || (!rangeA && rangeB)) {
|
|
180
|
+
return false;
|
|
181
|
+
}
|
|
182
|
+
return this.compareDays(rangeA.startDate, rangeB.startDate) === 0 &&
|
|
183
|
+
this.compareDays(rangeA.endDate, rangeB.endDate) === 0;
|
|
184
|
+
}
|
|
185
|
+
getDateRange(rows) {
|
|
186
|
+
if (rows && rows.length > 0) {
|
|
187
|
+
return {
|
|
188
|
+
startDate: rows[0][0].date,
|
|
189
|
+
endDate: rows[rows.length - 1][rows[rows.length - 1].length - 1].date
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
}
|
|
110
193
|
};
|
|
111
194
|
SkyDayPickerComponent.ctorParameters = () => [
|
|
112
195
|
{ type: SkyDatepickerCalendarInnerComponent }
|
|
113
196
|
];
|
|
197
|
+
__decorate([
|
|
198
|
+
Input()
|
|
199
|
+
], SkyDayPickerComponent.prototype, "customDates", null);
|
|
200
|
+
__decorate([
|
|
201
|
+
Output()
|
|
202
|
+
], SkyDayPickerComponent.prototype, "calendarDateRangeChange", void 0);
|
|
203
|
+
__decorate([
|
|
204
|
+
Input()
|
|
205
|
+
], SkyDayPickerComponent.prototype, "isWaiting", void 0);
|
|
114
206
|
SkyDayPickerComponent = __decorate([
|
|
115
207
|
Component({
|
|
116
208
|
selector: 'sky-daypicker',
|
|
117
|
-
template: "<div *ngIf=\"datepicker.datepickerMode === 'day'\"\n class=\"sky-daypicker-wrapper\"\n>\n
|
|
209
|
+
template: "<div *ngIf=\"datepicker.datepickerMode === 'day'\"\n class=\"sky-daypicker-wrapper\"\n>\n <table\n class=\"sky-daypicker-table\"\n role=\"grid\"\n [attr.aria-labelledby]=\"datepicker.datepickerId+'-title'\"\n [attr.aria-activedescendant]=\"datepicker.activeDateId\"\n >\n <thead>\n <tr>\n <th\n class=\"sky-datepicker-header-left\"\n scope=\"col\"\n >\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\n scope=\"col\"\n [attr.colspan]=\"5\"\n >\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]=\"{'sky-btn-disabled': datepicker.datepickerMode === datepicker.maxMode}\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n >\n <strong>{{title}}</strong>\n </button>\n </th>\n <th\n class=\"sky-datepicker-header-right\"\n scope=\"col\"\n >\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 <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\n [isWaiting]=\"isWaiting\"\n >\n </sky-wait>\n <ng-template\n ngFor\n [ngForOf]=\"rows\"\n let-row=\"$implicit\"\n let-index=\"index\"\n >\n <tr role=\"row\">\n <td *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",
|
|
118
210
|
styles: [":host-context(.sky-theme-modern) :host:focus{outline:0}.sky-theme-modern :host:focus{outline:0}"]
|
|
119
211
|
})
|
|
120
212
|
], SkyDayPickerComponent);
|
|
121
213
|
export { SkyDayPickerComponent };
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daypicker.component.js","sourceRoot":"ng://@skyux/datetime/","sources":["modules/datepicker/daypicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit\n} from '@angular/core';\nimport {\n  SkyDatepickerCalendarInnerComponent\n} from './datepicker-calendar-inner.component';\n\nimport {\n  SkyDatepickerDate\n} from './datepicker-date';\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 OnInit {\n\n  public labels: any[] = [];\n  public title: string;\n  public rows: Array<Array<SkyDatepickerDate>> = [];\n  public weekNumbers: number[] = [];\n  public datepicker: SkyDatepickerCalendarInnerComponent;\n  public CURRENT_THEME_TEMPLATE: any;\n\n  private daysInMonth: Array<number> = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\n\n  public constructor(datepicker: SkyDatepickerCalendarInnerComponent) {\n    this.datepicker = datepicker;\n  }\n\n  public ngOnInit(): void {\n\n    this.datepicker.stepDay = {months: 1};\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  protected getDates(startDate: Date, n: number): Date[] {\n    let 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(current.getFullYear(), current.getMonth(), current.getDate() + 1);\n    }\n    return dates;\n  }\n\n  private compareDays(date1: Date, date2: Date): number {\n    let d1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate());\n    let d2 = new Date(date2.getFullYear(), date2.getMonth(), date2.getDate());\n    return d1.getTime() - d2.getTime();\n  }\n\n  private refreshDayView() {\n    let year = this.datepicker.activeDate.getFullYear();\n    let month = this.datepicker.activeDate.getMonth();\n    let firstDayOfMonth = new Date(year, month, 1);\n    let difference = this.datepicker.startingDay - firstDayOfMonth.getDay();\n    let numDisplayedFromPreviousMonth = (difference > 0)\n      ? 7 - difference\n      : -difference;\n    let firstDate = new Date(firstDayOfMonth.getTime());\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    let days: Date[] = this.getDates(firstDate, 42);\n    let pickerDates: Array<SkyDatepickerDate> = [];\n    for (let i = 0; i < 42; i++) {\n      let _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 =\n        this.datepicker.dateFilter(pickerDates[j].date, this.datepicker.formatDayHeader);\n      this.labels[j].full = this.datepicker.dateFilter(pickerDates[j].date, 'EEEE');\n    }\n\n    this.title =\n      this.datepicker.dateFilter(this.datepicker.activeDate, this.datepicker.formatDayTitle);\n    this.rows = this.datepicker.createCalendarRows(pickerDates, 7);\n  }\n\n  private 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      let month = this.datepicker.activeDate.getMonth() + (key === 'pageup' ? - 1 : 1);\n      this.datepicker.activeDate.setMonth(month, 1);\n      date =\n      Math.min(\n        this.getDaysInMonth(\n          this.datepicker.activeDate.getFullYear(),\n          this.datepicker.activeDate.getMonth()\n        ),\n        date);\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  private getDaysInMonth(year: number, month: number) {\n    return month === 1 && year % 4 === 0 &&\n      (year % 400 === 0 || year % 100 !== 0) ? 29 : this.daysInMonth[month];\n  }\n\n}\n"]}
|
|
214
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daypicker.component.js","sourceRoot":"ng://@skyux/datetime/","sources":["modules/datepicker/daypicker.component.ts"],"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 {\n  Subject\n} from 'rxjs';\n\nimport {\n  SkyDatepickerCalendarInnerComponent\n} from './datepicker-calendar-inner.component';\n\nimport {\n  SkyDatepickerCustomDate\n} from './datepicker-custom-date';\n\nimport {\n  SkyDatepickerDate\n} from './datepicker-date';\n\nimport {\n  SkyDatepickerCalendarChange\n} from './datepicker-calendar-change';\n\n/**\n * Helper interface to compare date ranges.\n * @internal\n */\ninterface SkyDateRange {\n\n  startDate: Date;\n\n  endDate: Date;\n\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 OnInit, OnDestroy {\n\n  @Input()\n  public set customDates(value: SkyDatepickerCustomDate[]) {\n    /* istanbul ignore else */\n    if (value) {\n      this.applyCustomDates(value, this.rows);\n    }\n  }\n\n  @Output()\n  public calendarDateRangeChange: EventEmitter<SkyDatepickerCalendarChange> = new EventEmitter<SkyDatepickerCalendarChange>();\n\n  @Input()\n  public isWaiting: boolean = false;\n\n  public labels: any[] = [];\n  public title: string;\n  public rows: Array<Array<SkyDatepickerDate>> = [];\n  public weekNumbers: number[] = [];\n  public datepicker: SkyDatepickerCalendarInnerComponent;\n  public CURRENT_THEME_TEMPLATE: any;\n  public activeDateHasChanged: boolean = false;\n\n  private daysInMonth: Array<number> = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\n  private initialDate: number;\n  private ngUnsubscribe = new Subject<void>();\n\n  public constructor(\n    datepicker: SkyDatepickerCalendarInnerComponent\n  ) {\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    let 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(current.getFullYear(), current.getMonth(), current.getDate() + 1);\n    }\n    return dates;\n  }\n\n  private compareDays(date1: Date, date2: Date): number {\n    let d1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate());\n    let d2 = new Date(date2.getFullYear(), date2.getMonth(), date2.getDate());\n    return d1.getTime() - d2.getTime();\n  }\n\n  private refreshDayView() {\n    let year = this.datepicker.activeDate.getFullYear();\n    let month = this.datepicker.activeDate.getMonth();\n    let firstDayOfMonth = new Date(year, month, 1);\n    let difference = this.datepicker.startingDay - firstDayOfMonth.getDay();\n    let numDisplayedFromPreviousMonth = (difference > 0)\n      ? 7 - difference\n      : -difference;\n    let 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    let days: Date[] = this.getDates(firstDate, 42);\n    let pickerDates: Array<SkyDatepickerDate> = [];\n    for (let i = 0; i < 42; i++) {\n      let _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 =\n        this.datepicker.dateFilter(pickerDates[j].date, this.datepicker.formatDayHeader);\n      this.labels[j].full = this.datepicker.dateFilter(pickerDates[j].date, 'EEEE');\n    }\n\n    this.title =\n      this.datepicker.dateFilter(this.datepicker.activeDate, this.datepicker.formatDayTitle);\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      this.calendarDateRangeChange.next({\n        startDate: newDateRange.startDate,\n        endDate: newDateRange.endDate\n      });\n    }\n  }\n\n  private 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      let month = this.datepicker.activeDate.getMonth() + (key === 'pageup' ? - 1 : 1);\n      this.datepicker.activeDate.setMonth(month, 1);\n      date =\n      Math.min(\n        this.getDaysInMonth(\n          this.datepicker.activeDate.getFullYear(),\n          this.datepicker.activeDate.getMonth()\n        ),\n        date);\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  private getDaysInMonth(year: number, month: number) {\n    return month === 1 && year % 4 === 0 &&\n      (year % 400 === 0 || year % 100 !== 0) ? 29 : this.daysInMonth[month];\n  }\n\n  /**\n   * Applies custom date properties to the existing dates displayed in the calendar.\n   */\n  private 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  private dateRangeRowsAreEqual(rangeA: SkyDateRange, rangeB: SkyDateRange): boolean | undefined {\n    /* istanbul ignore if */\n    if (!rangeA && !rangeB) {\n      return true;\n    } else if ((rangeA && !rangeB) || (!rangeA && rangeB)) {\n      return false;\n    }\n\n    return this.compareDays(rangeA.startDate, rangeB.startDate) === 0 &&\n            this.compareDays(rangeA.endDate, rangeB.endDate) === 0;\n  }\n\n  private getDateRange(rows: Array<Array<SkyDatepickerDate>>): SkyDateRange | undefined {\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  }\n\n}\n"]}
|
package/esm2015/public_api.js
CHANGED
|
@@ -9,4 +9,4 @@ export * from './modules/datepicker/datepicker-config.service';
|
|
|
9
9
|
export * from './modules/datepicker/datepicker.module';
|
|
10
10
|
export * from './modules/datepicker/fuzzy-date.service';
|
|
11
11
|
export * from './modules/timepicker/timepicker.module';
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0Bza3l1eC9kYXRldGltZS8iLCJzb3VyY2VzIjpbInB1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHNDQUFzQyxDQUFDO0FBRXJELGNBQWMscUNBQXFDLENBQUM7QUFJcEQsY0FBYyw0REFBNEQsQ0FBQztBQUMzRSxjQUFjLDhEQUE4RCxDQUFDO0FBQzdFLGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyxnREFBZ0QsQ0FBQztBQUUvRCxjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsd0NBQXdDLENBQUM7QUFFdkQsY0FBYyx5Q0FBeUMsQ0FBQztBQUd4RCxjQUFjLHdDQUF3QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9tb2R1bGVzL2RhdGUtcGlwZS9kYXRlLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9tb2R1bGVzL2RhdGUtcGlwZS9kYXRlLXBpcGUubW9kdWxlJztcblxuZXhwb3J0ICogZnJvbSAnLi9tb2R1bGVzL2RhdGUtcGlwZS9mdXp6eS1kYXRlLnBpcGUnO1xuXG5leHBvcnQgKiBmcm9tICcuL21vZHVsZXMvZGF0ZS1yYW5nZS1waWNrZXIvdHlwZXMvZGF0ZS1yYW5nZS1jYWxjdWxhdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL21vZHVsZXMvZGF0ZS1yYW5nZS1waWNrZXIvdHlwZXMvZGF0ZS1yYW5nZS1jYWxjdWxhdG9yLWNvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL21vZHVsZXMvZGF0ZS1yYW5nZS1waWNrZXIvdHlwZXMvZGF0ZS1yYW5nZS1jYWxjdWxhdG9yLWlkJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kdWxlcy9kYXRlLXJhbmdlLXBpY2tlci90eXBlcy9kYXRlLXJhbmdlLWNhbGN1bGF0b3ItdHlwZSc7XG5leHBvcnQgKiBmcm9tICcuL21vZHVsZXMvZGF0ZS1yYW5nZS1waWNrZXIvZGF0ZS1yYW5nZS1waWNrZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kdWxlcy9kYXRlLXJhbmdlLXBpY2tlci9kYXRlLXJhbmdlLnNlcnZpY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLWNvbmZpZy5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kdWxlcy9kYXRlcGlja2VyL2RhdGVwaWNrZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kdWxlcy9kYXRlcGlja2VyL2Z1enp5LWRhdGUnO1xuZXhwb3J0ICogZnJvbSAnLi9tb2R1bGVzL2RhdGVwaWNrZXIvZnV6enktZGF0ZS5zZXJ2aWNlJztcblxuZXhwb3J0ICogZnJvbSAnLi9tb2R1bGVzL3RpbWVwaWNrZXIvdGltZXBpY2tlci5pbnRlcmZhY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9tb2R1bGVzL3RpbWVwaWNrZXIvdGltZXBpY2tlci5tb2R1bGUnO1xuXG5leHBvcnQgKiBmcm9tICcuL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLWNhbGVuZGFyLWNoYW5nZSc7XG5leHBvcnQgKiBmcm9tICcuL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLWN1c3RvbS1kYXRlJztcbiJdfQ==
|
|
@@ -9,11 +9,14 @@ export { SkyDatepickerCalendarComponent as ɵd } from './modules/datepicker/date
|
|
|
9
9
|
export { SkyFuzzyDatepickerInputDirective as ɵl } from './modules/datepicker/datepicker-input-fuzzy.directive';
|
|
10
10
|
export { SkyDatepickerInputDirective as ɵk } from './modules/datepicker/datepicker-input.directive';
|
|
11
11
|
export { SkyDatepickerComponent as ɵj } from './modules/datepicker/datepicker.component';
|
|
12
|
+
export { SkyDatepickerService as ɵn } from './modules/datepicker/datepicker.service';
|
|
13
|
+
export { SkyDayPickerButtonComponent as ɵo } from './modules/datepicker/daypicker-button.component';
|
|
14
|
+
export { SkyDayPickerCellComponent as ɵm } from './modules/datepicker/daypicker-cell.component';
|
|
12
15
|
export { SkyDayPickerComponent as ɵg } from './modules/datepicker/daypicker.component';
|
|
13
16
|
export { SkyMonthPickerComponent as ɵh } from './modules/datepicker/monthpicker.component';
|
|
14
17
|
export { SkyYearPickerComponent as ɵi } from './modules/datepicker/yearpicker.component';
|
|
15
18
|
export { SkyDateTimeResourcesModule as ɵa } from './modules/shared/datetime-resources.module';
|
|
16
|
-
export { SkyTimepickerComponent as
|
|
17
|
-
export { SkyTimepickerInputDirective as
|
|
19
|
+
export { SkyTimepickerComponent as ɵq } from './modules/timepicker/timepicker.component';
|
|
20
|
+
export { SkyTimepickerInputDirective as ɵp } from './modules/timepicker/timepicker.directive';
|
|
18
21
|
export { SkyDateTimeResourcesProvider as ɵb } from './plugin-resources/datetime-resources-provider';
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2t5dXgtZGF0ZXRpbWUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2t5dXgvZGF0ZXRpbWUvIiwic291cmNlcyI6WyJza3l1eC1kYXRldGltZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDO0FBRTdCLE9BQU8sRUFBQywyQkFBMkIsSUFBSSxFQUFFLEVBQUMsTUFBTSx5REFBeUQsQ0FBQztBQUMxRyxPQUFPLEVBQUMsMkJBQTJCLElBQUksRUFBRSxFQUFDLE1BQU0saURBQWlELENBQUM7QUFDbEcsT0FBTyxFQUFDLG1DQUFtQyxJQUFJLEVBQUUsRUFBQyxNQUFNLDBEQUEwRCxDQUFDO0FBQ25ILE9BQU8sRUFBQyw4QkFBOEIsSUFBSSxFQUFFLEVBQUMsTUFBTSxvREFBb0QsQ0FBQztBQUN4RyxPQUFPLEVBQUMsZ0NBQWdDLElBQUksRUFBRSxFQUFDLE1BQU0sdURBQXVELENBQUM7QUFDN0csT0FBTyxFQUFDLDJCQUEyQixJQUFJLEVBQUUsRUFBQyxNQUFNLGlEQUFpRCxDQUFDO0FBQ2xHLE9BQU8sRUFBQyxzQkFBc0IsSUFBSSxFQUFFLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUN2RixPQUFPLEVBQUMsb0JBQW9CLElBQUksRUFBRSxFQUFDLE1BQU0seUNBQXlDLENBQUM7QUFDbkYsT0FBTyxFQUFDLDJCQUEyQixJQUFJLEVBQUUsRUFBQyxNQUFNLGlEQUFpRCxDQUFDO0FBQ2xHLE9BQU8sRUFBQyx5QkFBeUIsSUFBSSxFQUFFLEVBQUMsTUFBTSwrQ0FBK0MsQ0FBQztBQUM5RixPQUFPLEVBQUMscUJBQXFCLElBQUksRUFBRSxFQUFDLE1BQU0sMENBQTBDLENBQUM7QUFDckYsT0FBTyxFQUFDLHVCQUF1QixJQUFJLEVBQUUsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBQ3pGLE9BQU8sRUFBQyxzQkFBc0IsSUFBSSxFQUFFLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUN2RixPQUFPLEVBQUMsMEJBQTBCLElBQUksRUFBRSxFQUFDLE1BQU0sNENBQTRDLENBQUM7QUFDNUYsT0FBTyxFQUFDLHNCQUFzQixJQUFJLEVBQUUsRUFBQyxNQUFNLDJDQUEyQyxDQUFDO0FBQ3ZGLE9BQU8sRUFBQywyQkFBMkIsSUFBSSxFQUFFLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUM1RixPQUFPLEVBQUMsNEJBQTRCLElBQUksRUFBRSxFQUFDLE1BQU0sZ0RBQWdELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG5cbmV4cG9ydCB7U2t5RGF0ZVJhbmdlUGlja2VyQ29tcG9uZW50IGFzIMm1Y30gZnJvbSAnLi9tb2R1bGVzL2RhdGUtcmFuZ2UtcGlja2VyL2RhdGUtcmFuZ2UtcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQge1NreURhdGVwaWNrZXJBZGFwdGVyU2VydmljZSBhcyDJtWV9IGZyb20gJy4vbW9kdWxlcy9kYXRlcGlja2VyL2RhdGVwaWNrZXItYWRhcHRlci5zZXJ2aWNlJztcbmV4cG9ydCB7U2t5RGF0ZXBpY2tlckNhbGVuZGFySW5uZXJDb21wb25lbnQgYXMgybVmfSBmcm9tICcuL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLWNhbGVuZGFyLWlubmVyLmNvbXBvbmVudCc7XG5leHBvcnQge1NreURhdGVwaWNrZXJDYWxlbmRhckNvbXBvbmVudCBhcyDJtWR9IGZyb20gJy4vbW9kdWxlcy9kYXRlcGlja2VyL2RhdGVwaWNrZXItY2FsZW5kYXIuY29tcG9uZW50JztcbmV4cG9ydCB7U2t5RnV6enlEYXRlcGlja2VySW5wdXREaXJlY3RpdmUgYXMgybVsfSBmcm9tICcuL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLWlucHV0LWZ1enp5LmRpcmVjdGl2ZSc7XG5leHBvcnQge1NreURhdGVwaWNrZXJJbnB1dERpcmVjdGl2ZSBhcyDJtWt9IGZyb20gJy4vbW9kdWxlcy9kYXRlcGlja2VyL2RhdGVwaWNrZXItaW5wdXQuZGlyZWN0aXZlJztcbmV4cG9ydCB7U2t5RGF0ZXBpY2tlckNvbXBvbmVudCBhcyDJtWp9IGZyb20gJy4vbW9kdWxlcy9kYXRlcGlja2VyL2RhdGVwaWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCB7U2t5RGF0ZXBpY2tlclNlcnZpY2UgYXMgybVufSBmcm9tICcuL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLnNlcnZpY2UnO1xuZXhwb3J0IHtTa3lEYXlQaWNrZXJCdXR0b25Db21wb25lbnQgYXMgybVvfSBmcm9tICcuL21vZHVsZXMvZGF0ZXBpY2tlci9kYXlwaWNrZXItYnV0dG9uLmNvbXBvbmVudCc7XG5leHBvcnQge1NreURheVBpY2tlckNlbGxDb21wb25lbnQgYXMgybVtfSBmcm9tICcuL21vZHVsZXMvZGF0ZXBpY2tlci9kYXlwaWNrZXItY2VsbC5jb21wb25lbnQnO1xuZXhwb3J0IHtTa3lEYXlQaWNrZXJDb21wb25lbnQgYXMgybVnfSBmcm9tICcuL21vZHVsZXMvZGF0ZXBpY2tlci9kYXlwaWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCB7U2t5TW9udGhQaWNrZXJDb21wb25lbnQgYXMgybVofSBmcm9tICcuL21vZHVsZXMvZGF0ZXBpY2tlci9tb250aHBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0IHtTa3lZZWFyUGlja2VyQ29tcG9uZW50IGFzIMm1aX0gZnJvbSAnLi9tb2R1bGVzL2RhdGVwaWNrZXIveWVhcnBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0IHtTa3lEYXRlVGltZVJlc291cmNlc01vZHVsZSBhcyDJtWF9IGZyb20gJy4vbW9kdWxlcy9zaGFyZWQvZGF0ZXRpbWUtcmVzb3VyY2VzLm1vZHVsZSc7XG5leHBvcnQge1NreVRpbWVwaWNrZXJDb21wb25lbnQgYXMgybVxfSBmcm9tICcuL21vZHVsZXMvdGltZXBpY2tlci90aW1lcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQge1NreVRpbWVwaWNrZXJJbnB1dERpcmVjdGl2ZSBhcyDJtXB9IGZyb20gJy4vbW9kdWxlcy90aW1lcGlja2VyL3RpbWVwaWNrZXIuZGlyZWN0aXZlJztcbmV4cG9ydCB7U2t5RGF0ZVRpbWVSZXNvdXJjZXNQcm92aWRlciBhcyDJtWJ9IGZyb20gJy4vcGx1Z2luLXJlc291cmNlcy9kYXRldGltZS1yZXNvdXJjZXMtcHJvdmlkZXInOyJdfQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci1jYWxlbmRhci1jaGFuZ2UuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2t5dXgvZGF0ZXRpbWUvIiwic291cmNlcyI6WyJtb2R1bGVzL2RhdGVwaWNrZXIvZGF0ZXBpY2tlci1jYWxlbmRhci1jaGFuZ2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIE9ic2VydmFibGVcbn0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7XG4gIFNreURhdGVwaWNrZXJDdXN0b21EYXRlXG59IGZyb20gJy4uLy4uL3B1YmxpY19hcGknO1xuXG4vKipcbiAqIFNwZWNpZmllcyBjaGFuZ2VzIGluIHRoZSBkYXRlcGlja2VyIGNhbGVuZGFyLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNreURhdGVwaWNrZXJDYWxlbmRhckNoYW5nZSB7XG5cbiAgLyoqXG4gICAqIFRoZSBlbmQgZGF0ZS5cbiAgICovXG4gIGVuZERhdGU6IERhdGU7XG5cbiAgLyoqXG4gICAqIFRoZSBzdGFydCBkYXRlLlxuICAgKi9cbiAgc3RhcnREYXRlOiBEYXRlO1xuXG4gIC8qKlxuICAgKiBQcm92aWRlcyBhbiBvYnNlcnZhYmxlIHRoYXQgYWxsb3dzIHRoZSBjb25zdW1lciB0byBwdXNoIGN1c3RvbSBkYXRlcyBiYWNrIHRvIHRoZSBjYWxlbmRhclxuICAgKiB3aGVuIHRoZSBgU2t5Q2FsZW5kYXJEYXRlUmFuZ2VDaGFuZ2VFdmVudGAgZXZlbnQgZmlyZXMuIFRoaXMgaXMgdXNlZnVsXG4gICAqIGZvciBkaXNwbGF5aW5nIGtleSBkYXRlcyBvciBkaXNhYmxlZCBkYXRlcyBlYWNoIHRpbWUgdGhlIGNhbGVuZGFyIGNoYW5nZXMuIElmIGRpc2FibGVkIGRhdGVzXG4gICAqIGFyZSBwcm92aWRlZCwgU0tZIFVYIHdpbGwgcHJldmVudCB0aGUgdXNlciBmcm9tIHNlbGVjdGluZyB0aGUgZGF0ZSBmcm9tIHRoZSBjYWxlbmRhci5cbiAgICogSG93ZXZlciwgY29uc3VtZXJzIHdpbGwgc3RpbGwgbmVlZCB0byBhZGQgYSBjdXN0b20gdmFsaWRhdG9yIHRvIHByZXZlbnQgdXNlcnMgZnJvbSBlbnRlcmluZ1xuICAgKiBkaXNhYmxlZCBkYXRlcyBpbiB0aGUgdGV4dCBpbnB1dC5cbiAgICovXG4gIGN1c3RvbURhdGVzPzogT2JzZXJ2YWJsZTxTa3lEYXRlcGlja2VyQ3VzdG9tRGF0ZVtdPjtcblxufVxuIl19
|