@skyux/datetime 10.0.0-alpha.1 → 10.0.0-alpha.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/documentation.json +1812 -1740
- package/esm2022/lib/modules/date-pipe/date-pipe.module.mjs +4 -4
- package/esm2022/lib/modules/date-pipe/date.pipe.mjs +3 -3
- package/esm2022/lib/modules/date-pipe/date.service.mjs +4 -4
- package/esm2022/lib/modules/date-pipe/fuzzy-date.pipe.mjs +3 -3
- package/esm2022/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +3 -3
- package/esm2022/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +3 -3
- package/esm2022/lib/modules/date-range-picker/date-range-picker.component.mjs +4 -4
- package/esm2022/lib/modules/date-range-picker/date-range-picker.module.mjs +5 -7
- package/esm2022/lib/modules/date-range-picker/date-range.service.mjs +8 -5
- package/esm2022/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +74 -27
- package/esm2022/lib/modules/datepicker/datepicker-calendar-label.pipe.mjs +39 -0
- package/esm2022/lib/modules/datepicker/datepicker-calendar.component.mjs +10 -10
- package/esm2022/lib/modules/datepicker/datepicker-config.service.mjs +3 -3
- package/esm2022/lib/modules/datepicker/datepicker-custom-date.mjs +1 -1
- package/esm2022/lib/modules/datepicker/datepicker-date.mjs +1 -1
- package/esm2022/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +3 -3
- package/esm2022/lib/modules/datepicker/datepicker-input.directive.mjs +12 -31
- package/esm2022/lib/modules/datepicker/datepicker.component.mjs +53 -11
- package/esm2022/lib/modules/datepicker/datepicker.module.mjs +13 -6
- package/esm2022/lib/modules/datepicker/datepicker.service.mjs +3 -3
- package/esm2022/lib/modules/datepicker/daypicker-button.component.mjs +6 -5
- package/esm2022/lib/modules/datepicker/daypicker-cell.component.mjs +3 -3
- package/esm2022/lib/modules/datepicker/daypicker.component.mjs +13 -16
- package/esm2022/lib/modules/datepicker/fuzzy-date.service.mjs +5 -6
- package/esm2022/lib/modules/datepicker/monthpicker.component.mjs +13 -14
- package/esm2022/lib/modules/datepicker/yearpicker.component.mjs +14 -14
- package/esm2022/lib/modules/shared/sky-datetime-resources.module.mjs +12 -5
- package/esm2022/lib/modules/timepicker/timepicker.component.mjs +17 -9
- package/esm2022/lib/modules/timepicker/timepicker.directive.mjs +3 -3
- package/esm2022/lib/modules/timepicker/timepicker.module.mjs +4 -4
- package/fesm2022/skyux-datetime.mjs +301 -200
- package/fesm2022/skyux-datetime.mjs.map +1 -1
- package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +13 -6
- package/lib/modules/datepicker/datepicker-calendar-label.pipe.d.ts +23 -0
- package/lib/modules/datepicker/datepicker-custom-date.d.ts +1 -1
- package/lib/modules/datepicker/datepicker-date.d.ts +1 -1
- package/lib/modules/datepicker/datepicker-input.directive.d.ts +2 -3
- package/lib/modules/datepicker/datepicker.component.d.ts +7 -1
- package/lib/modules/datepicker/datepicker.module.d.ts +10 -8
- package/lib/modules/datepicker/daypicker.component.d.ts +1 -1
- package/lib/modules/datepicker/monthpicker.component.d.ts +1 -1
- package/lib/modules/datepicker/yearpicker.component.d.ts +1 -1
- package/lib/modules/timepicker/timepicker.component.d.ts +2 -2
- package/package.json +13 -12
- package/esm2022/lib/modules/datepicker/datepicker-adapter.service.mjs +0 -23
- package/lib/modules/datepicker/datepicker-adapter.service.d.ts +0 -13
@@ -1,8 +1,11 @@
|
|
1
|
-
import { Component, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core';
|
2
|
-
import {
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewEncapsulation, inject, } from '@angular/core';
|
2
|
+
import { SkyLiveAnnouncerService } from '@skyux/core';
|
3
|
+
import { SkyLibResourcesService } from '@skyux/i18n';
|
4
|
+
import { Subject, takeUntil } from 'rxjs';
|
3
5
|
import { SkyDateFormatter } from './date-formatter';
|
4
6
|
import * as i0 from "@angular/core";
|
5
7
|
import * as i1 from "@angular/common";
|
8
|
+
import * as i2 from "@skyux/indicators";
|
6
9
|
let nextDatepickerId = 0;
|
7
10
|
/**
|
8
11
|
* @internal
|
@@ -14,6 +17,7 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
14
17
|
// TODO: `activeDate` is very similar to `selectedDate` and at the very least should be able to be undefined. However, this would take considerable refactoring to do and thus has been deferred.
|
15
18
|
this.activeDate = new Date();
|
16
19
|
this.activeDateId = '';
|
20
|
+
this.title = '';
|
17
21
|
this.minMode = 'day';
|
18
22
|
this.maxMode = 'year';
|
19
23
|
this.monthColLimit = 3;
|
@@ -26,26 +30,32 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
26
30
|
this.formatDayHeader = 'dd';
|
27
31
|
this.formatDayTitle = 'MMMM YYYY';
|
28
32
|
this.formatMonthTitle = 'YYYY';
|
33
|
+
this.formatDayLabel = 'dddd, MMMM Do YYYY';
|
34
|
+
this.formatMonthLabel = 'MMMM YYYY';
|
35
|
+
this.formatYearLabel = 'YYYY';
|
29
36
|
this.datepickerId = `sky-datepicker-${++nextDatepickerId}`;
|
30
37
|
this.stepDay = {};
|
31
38
|
this.stepMonth = {};
|
32
39
|
this.stepYear = {};
|
33
40
|
this.modes = ['day', 'month', 'year'];
|
34
41
|
this.dateFormatter = new SkyDateFormatter();
|
35
|
-
this.keys =
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
42
|
+
this.keys = [
|
43
|
+
'enter',
|
44
|
+
' ',
|
45
|
+
'spacebar',
|
46
|
+
'pageup',
|
47
|
+
'pagedown',
|
48
|
+
'end',
|
49
|
+
'home',
|
50
|
+
'arrowleft',
|
51
|
+
'arrowup',
|
52
|
+
'arrowright',
|
53
|
+
'arrowdown',
|
54
|
+
];
|
47
55
|
this.#ngUnsubscribe = new Subject();
|
48
56
|
this.#_startingDay = 0;
|
57
|
+
this.#resourcesSvc = inject(SkyLibResourcesService);
|
58
|
+
this.#liveAnnouncerSvc = inject(SkyLiveAnnouncerService);
|
49
59
|
}
|
50
60
|
set startingDay(value) {
|
51
61
|
this.#_startingDay = value || 0;
|
@@ -67,8 +77,16 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
67
77
|
return this.#_selectedDate;
|
68
78
|
}
|
69
79
|
#ngUnsubscribe;
|
80
|
+
#prevDay;
|
81
|
+
#nextDay;
|
82
|
+
#prevMonth;
|
83
|
+
#nextMonth;
|
84
|
+
#prevYear;
|
85
|
+
#nextYear;
|
70
86
|
#_selectedDate;
|
71
87
|
#_startingDay;
|
88
|
+
#resourcesSvc;
|
89
|
+
#liveAnnouncerSvc;
|
72
90
|
ngOnInit() {
|
73
91
|
if (this.selectedDate) {
|
74
92
|
this.activeDate = new Date(this.selectedDate);
|
@@ -76,6 +94,25 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
76
94
|
else {
|
77
95
|
this.activeDate = new Date();
|
78
96
|
}
|
97
|
+
this.#resourcesSvc
|
98
|
+
.getStrings({
|
99
|
+
prevDay: 'skyux_datepicker_move_calendar_previous_day',
|
100
|
+
nextDay: 'skyux_datepicker_move_calendar_next_day',
|
101
|
+
prevMonth: 'skyux_datepicker_move_calendar_previous_month',
|
102
|
+
nextMonth: 'skyux_datepicker_move_calendar_next_month',
|
103
|
+
prevYear: 'skyux_datepicker_move_calendar_previous_year',
|
104
|
+
nextYear: 'skyux_datepicker_move_calendar_next_year',
|
105
|
+
})
|
106
|
+
.pipe(takeUntil(this.#ngUnsubscribe))
|
107
|
+
.subscribe((resources) => {
|
108
|
+
this.#prevDay = resources.prevDay;
|
109
|
+
this.#nextDay = resources.nextDay;
|
110
|
+
this.#prevMonth = resources.prevMonth;
|
111
|
+
this.#nextMonth = resources.nextMonth;
|
112
|
+
this.#prevYear = resources.prevYear;
|
113
|
+
this.#nextYear = resources.nextYear;
|
114
|
+
this.refreshView();
|
115
|
+
});
|
79
116
|
}
|
80
117
|
ngOnChanges(changes) {
|
81
118
|
this.refreshView();
|
@@ -126,13 +163,19 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
126
163
|
}
|
127
164
|
refreshView() {
|
128
165
|
if (this.datepickerMode === 'day' && this.refreshViewHandlerDay) {
|
129
|
-
this.refreshViewHandlerDay();
|
166
|
+
this.title = this.refreshViewHandlerDay();
|
167
|
+
this.previousLabel = this.#prevDay;
|
168
|
+
this.nextLabel = this.#nextDay;
|
130
169
|
}
|
131
170
|
if (this.datepickerMode === 'month' && this.refreshViewHandlerMonth) {
|
132
|
-
this.refreshViewHandlerMonth();
|
171
|
+
this.title = this.refreshViewHandlerMonth();
|
172
|
+
this.previousLabel = this.#prevMonth;
|
173
|
+
this.nextLabel = this.#nextMonth;
|
133
174
|
}
|
134
175
|
if (this.datepickerMode === 'year' && this.refreshViewHandlerYear) {
|
135
|
-
this.refreshViewHandlerYear();
|
176
|
+
this.title = this.refreshViewHandlerYear();
|
177
|
+
this.previousLabel = this.#prevYear;
|
178
|
+
this.nextLabel = this.#nextYear;
|
136
179
|
}
|
137
180
|
}
|
138
181
|
setKeydownHandler(handler, type) {
|
@@ -168,20 +211,20 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
168
211
|
return false;
|
169
212
|
}
|
170
213
|
onKeydown(event) {
|
171
|
-
const key =
|
172
|
-
if (!key || event.shiftKey
|
214
|
+
const key = event.key?.toLowerCase();
|
215
|
+
if (!this.keys.includes(key) || event.shiftKey) {
|
173
216
|
return;
|
174
217
|
}
|
175
218
|
event.preventDefault();
|
176
219
|
event.stopPropagation();
|
177
|
-
if (key === 'enter' || key === '
|
220
|
+
if (key === 'enter' || key === 'spacebar' || key === ' ') {
|
178
221
|
if (this.isDisabled(this.activeDate)) {
|
179
222
|
return;
|
180
223
|
}
|
181
224
|
this.select(this.activeDate);
|
182
225
|
}
|
183
|
-
else if (event.ctrlKey && (key === '
|
184
|
-
this.toggleMode(key === '
|
226
|
+
else if (event.ctrlKey && (key === 'arrowup' || key === 'arrowdown')) {
|
227
|
+
this.toggleMode(key === 'arrowup' ? 1 : -1);
|
185
228
|
}
|
186
229
|
else {
|
187
230
|
this.handleKeydown(key, event);
|
@@ -287,6 +330,10 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
287
330
|
this.refreshView();
|
288
331
|
}
|
289
332
|
}
|
333
|
+
announceDate(date, format) {
|
334
|
+
const caption = this.dateFilter(date, format);
|
335
|
+
this.#liveAnnouncerSvc.announce(caption);
|
336
|
+
}
|
290
337
|
/**
|
291
338
|
* Date is disabled if it meets any of these criteria:
|
292
339
|
* 1. Date falls outside the min or max dates set by the SkyDatepickerConfigService.
|
@@ -308,12 +355,12 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
308
355
|
}
|
309
356
|
return undefined;
|
310
357
|
}
|
311
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.
|
312
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.
|
358
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerCalendarInnerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
359
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.1", type: SkyDatepickerCalendarInnerComponent, selector: "sky-datepicker-inner", inputs: { customDates: "customDates", startingDay: "startingDay", minDate: "minDate", maxDate: "maxDate", selectedDate: "selectedDate" }, outputs: { selectedDateChange: "selectedDateChange", calendarModeChange: "calendarModeChange" }, usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"datepickerMode\" class=\"sky-datepicker-calendar-inner\">\n <div class=\"sky-datepicker-calendar-header\">\n <span class=\"sky-datepicker-header-left\">\n <button\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-previous\"\n [attr.aria-label]=\"previousLabel\"\n (click)=\"moveCalendar($event, -1)\"\n >\n <sky-icon class=\"sky-datepicker-chevron\" icon=\"chevron-left\" />\n </button>\n </span>\n <span class=\"sky-datepicker-header-center\">\n <button\n [id]=\"datepickerId + '-title'\"\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-calendar-title\"\n (click)=\"toggleModeCalendar($event)\"\n [disabled]=\"datepickerMode === maxMode\"\n [ngClass]=\"{\n 'sky-btn-disabled': datepickerMode === maxMode\n }\"\n >\n <strong>{{ title }}</strong>\n </button>\n </span>\n <span class=\"sky-datepicker-header-right\">\n <button\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-next\"\n [attr.aria-label]=\"nextLabel\"\n (click)=\"moveCalendar($event, 1)\"\n >\n <sky-icon class=\"sky-datepicker-chevron\" icon=\"chevron-right\" />\n </button>\n </span>\n </div>\n <ng-content />\n</div>\n", styles: [".sky-datepicker-calendar-inner{border-radius:5px;background-color:#fff;border-top:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-right:1px solid #e2e3e4}.sky-datepicker-calendar-inner .sky-datepicker-calendar-header{width:100%;display:flex}.sky-datepicker-calendar-inner .sky-btn-default{border-color:transparent;border:2px solid #ffffff}.sky-datepicker-calendar-inner .sky-btn-default:hover{border-color:#eeeeef}.sky-datepicker-calendar-inner .sky-datepicker-center{text-align:center}.sky-datepicker-calendar-inner .sky-datepicker-btn-selected,.sky-datepicker-calendar-inner .sky-btn-default.sky-datepicker-btn-selected:hover{background-color:#c1e8fb;border:2px solid #00b4f1}.sky-datepicker-calendar-inner .sky-btn.sky-btn-active{box-shadow:none}.sky-datepicker-calendar-inner .sky-datepicker-secondary{color:#686c73}.sky-datepicker-calendar-inner .sky-datepicker-btn-date{min-width:100%}.sky-datepicker-calendar-inner .sky-datepicker-calendar-title{width:100%}.sky-datepicker-calendar-inner .sky-datepicker-header-left{text-align:left}.sky-datepicker-calendar-inner .sky-datepicker-header-center{display:flex;width:100%}.sky-datepicker-calendar-inner .sky-datepicker-header-right{text-align:right}.sky-theme-modern .sky-datepicker-calendar-inner{border:none;box-shadow:inset 0 0 0 1px #d2d2d2;border-radius:6px;padding:5px 10px}.sky-theme-modern .sky-datepicker-calendar-inner .sky-datepicker-calendar-table-container:focus-visible{outline:none}.sky-theme-modern .sky-datepicker-calendar-inner .sky-datepicker-calendar-table-container:focus-visible .sky-btn-active{border:none;box-shadow:inset 0 0 0 2px #1870b8}.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default{border:none;box-shadow:inset 0 0 0 1px transparent;padding:5px 7px}.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-active,.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default:hover{border:none;box-shadow:inset 0 0 0 1px #1870b8}.sky-theme-modern .sky-datepicker-calendar-inner .sky-datepicker-btn-selected,.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default.sky-datepicker-btn-selected:hover{background-color:var(--sky-background-color-input-selected)}.sky-theme-modern .sky-btn-sm.sky-datepicker-btn-date{height:30px;min-width:0;padding:0;width:30px}.sky-theme-modern .sky-datepicker-chevron{font-size:16px}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner{background-color:transparent}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner:not(:focus-within){border:none;box-shadow:inset 0 0 0 1px #686c73}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner .sky-datepicker-btn-selected{background-color:#009cd1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
313
360
|
}
|
314
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.
|
361
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerCalendarInnerComponent, decorators: [{
|
315
362
|
type: Component,
|
316
|
-
args: [{ selector: 'sky-datepicker-inner', encapsulation: ViewEncapsulation.None, template: "<div
|
363
|
+
args: [{ selector: 'sky-datepicker-inner', encapsulation: ViewEncapsulation.None, template: "<div *ngIf=\"datepickerMode\" class=\"sky-datepicker-calendar-inner\">\n <div class=\"sky-datepicker-calendar-header\">\n <span class=\"sky-datepicker-header-left\">\n <button\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-previous\"\n [attr.aria-label]=\"previousLabel\"\n (click)=\"moveCalendar($event, -1)\"\n >\n <sky-icon class=\"sky-datepicker-chevron\" icon=\"chevron-left\" />\n </button>\n </span>\n <span class=\"sky-datepicker-header-center\">\n <button\n [id]=\"datepickerId + '-title'\"\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-calendar-title\"\n (click)=\"toggleModeCalendar($event)\"\n [disabled]=\"datepickerMode === maxMode\"\n [ngClass]=\"{\n 'sky-btn-disabled': datepickerMode === maxMode\n }\"\n >\n <strong>{{ title }}</strong>\n </button>\n </span>\n <span class=\"sky-datepicker-header-right\">\n <button\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-next\"\n [attr.aria-label]=\"nextLabel\"\n (click)=\"moveCalendar($event, 1)\"\n >\n <sky-icon class=\"sky-datepicker-chevron\" icon=\"chevron-right\" />\n </button>\n </span>\n </div>\n <ng-content />\n</div>\n", styles: [".sky-datepicker-calendar-inner{border-radius:5px;background-color:#fff;border-top:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-right:1px solid #e2e3e4}.sky-datepicker-calendar-inner .sky-datepicker-calendar-header{width:100%;display:flex}.sky-datepicker-calendar-inner .sky-btn-default{border-color:transparent;border:2px solid #ffffff}.sky-datepicker-calendar-inner .sky-btn-default:hover{border-color:#eeeeef}.sky-datepicker-calendar-inner .sky-datepicker-center{text-align:center}.sky-datepicker-calendar-inner .sky-datepicker-btn-selected,.sky-datepicker-calendar-inner .sky-btn-default.sky-datepicker-btn-selected:hover{background-color:#c1e8fb;border:2px solid #00b4f1}.sky-datepicker-calendar-inner .sky-btn.sky-btn-active{box-shadow:none}.sky-datepicker-calendar-inner .sky-datepicker-secondary{color:#686c73}.sky-datepicker-calendar-inner .sky-datepicker-btn-date{min-width:100%}.sky-datepicker-calendar-inner .sky-datepicker-calendar-title{width:100%}.sky-datepicker-calendar-inner .sky-datepicker-header-left{text-align:left}.sky-datepicker-calendar-inner .sky-datepicker-header-center{display:flex;width:100%}.sky-datepicker-calendar-inner .sky-datepicker-header-right{text-align:right}.sky-theme-modern .sky-datepicker-calendar-inner{border:none;box-shadow:inset 0 0 0 1px #d2d2d2;border-radius:6px;padding:5px 10px}.sky-theme-modern .sky-datepicker-calendar-inner .sky-datepicker-calendar-table-container:focus-visible{outline:none}.sky-theme-modern .sky-datepicker-calendar-inner .sky-datepicker-calendar-table-container:focus-visible .sky-btn-active{border:none;box-shadow:inset 0 0 0 2px #1870b8}.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default{border:none;box-shadow:inset 0 0 0 1px transparent;padding:5px 7px}.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-active,.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default:hover{border:none;box-shadow:inset 0 0 0 1px #1870b8}.sky-theme-modern .sky-datepicker-calendar-inner .sky-datepicker-btn-selected,.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default.sky-datepicker-btn-selected:hover{background-color:var(--sky-background-color-input-selected)}.sky-theme-modern .sky-btn-sm.sky-datepicker-btn-date{height:30px;min-width:0;padding:0;width:30px}.sky-theme-modern .sky-datepicker-chevron{font-size:16px}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner{background-color:transparent}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner:not(:focus-within){border:none;box-shadow:inset 0 0 0 1px #686c73}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner .sky-datepicker-btn-selected{background-color:#009cd1}\n"] }]
|
317
364
|
}], propDecorators: { customDates: [{
|
318
365
|
type: Input
|
319
366
|
}], startingDay: [{
|
@@ -329,4 +376,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
329
376
|
}], calendarModeChange: [{
|
330
377
|
type: Output
|
331
378
|
}] } });
|
332
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-calendar-inner.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar-inner.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar-inner.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\n\nimport { SkyDateFormatter } from './date-formatter';\nimport { SkyDatepickerCustomDate } from './datepicker-custom-date';\nimport { SkyDatepickerDate } from './datepicker-date';\n\ntype DateComparator = (date1: Date, date2: Date) => number | undefined;\ntype KeyboardEventHandler = (key: string, event: KeyboardEvent) => void;\n\nlet nextDatepickerId = 0;\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-datepicker-inner',\n  templateUrl: './datepicker-calendar-inner.component.html',\n  styleUrls: ['./datepicker-calendar-inner.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SkyDatepickerCalendarInnerComponent\n  implements OnDestroy, OnInit, OnChanges\n{\n  @Input()\n  public customDates: SkyDatepickerCustomDate[] | undefined;\n\n  @Input()\n  public set startingDay(value: number | undefined) {\n    this.#_startingDay = value || 0;\n  }\n\n  public get startingDay(): number {\n    return this.#_startingDay;\n  }\n\n  @Input()\n  public minDate: Date | undefined;\n\n  @Input()\n  public maxDate: Date | undefined;\n\n  @Input()\n  public set selectedDate(value: Date | undefined) {\n    if (value && this.dateFormatter.dateIsValid(value)) {\n      this.#_selectedDate = value;\n      this.activeDate = value;\n    } else {\n      this.#_selectedDate = undefined;\n      this.activeDate = new Date();\n    }\n  }\n\n  public get selectedDate(): Date | undefined {\n    return this.#_selectedDate;\n  }\n\n  @Output()\n  public selectedDateChange: EventEmitter<Date> = new EventEmitter<Date>(\n    undefined,\n  );\n\n  @Output()\n  public calendarModeChange: EventEmitter<string> = new EventEmitter<string>();\n\n  // TODO: `activeDate` is very similar to `selectedDate` and at the very least should be able to be undefined. However, this would take considerable refactoring to do and thus has been deferred.\n  public activeDate = new Date();\n  public activeDateId = '';\n\n  public minMode = 'day';\n  public maxMode = 'year';\n  public monthColLimit = 3;\n  public yearColLimit = 5;\n  public datepickerMode = 'day';\n  public yearRange = 20;\n\n  public formatDay = 'DD';\n  public formatMonth = 'MMMM';\n  public formatYear = 'YYYY';\n  public formatDayHeader = 'dd';\n  public formatDayTitle = 'MMMM YYYY';\n  public formatMonthTitle = 'YYYY';\n\n  public datepickerId = `sky-datepicker-${++nextDatepickerId}`;\n\n  public stepDay: any = {};\n  public stepMonth: any = {};\n  public stepYear: any = {};\n\n  protected modes: string[] = ['day', 'month', 'year'];\n  protected dateFormatter: SkyDateFormatter = new SkyDateFormatter();\n\n  public refreshViewHandlerDay: (() => void) | undefined;\n  public compareHandlerDay: DateComparator | undefined;\n  public refreshViewHandlerMonth: (() => void) | undefined;\n  public compareHandlerMonth: DateComparator | undefined;\n  public refreshViewHandlerYear: (() => void) | undefined;\n  public compareHandlerYear: DateComparator | undefined;\n\n  public handleKeydownDay: KeyboardEventHandler | undefined;\n  public handleKeydownMonth: KeyboardEventHandler | undefined;\n  public handleKeydownYear: KeyboardEventHandler | undefined;\n\n  public keys: any = {\n    13: 'enter',\n    32: 'space',\n    33: 'pageup',\n    34: 'pagedown',\n    35: 'end',\n    36: 'home',\n    37: 'left',\n    38: 'up',\n    39: 'right',\n    40: 'down',\n  };\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #_selectedDate: Date | undefined;\n  #_startingDay = 0;\n\n  public ngOnInit(): void {\n    if (this.selectedDate) {\n      this.activeDate = new Date(this.selectedDate);\n    } else {\n      this.activeDate = new Date();\n    }\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    this.refreshView();\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public setCompareHandler(handler: DateComparator, type: string): void {\n    if (type === 'day') {\n      this.compareHandlerDay = handler;\n    }\n\n    if (type === 'month') {\n      this.compareHandlerMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.compareHandlerYear = handler;\n    }\n  }\n\n  public compare(\n    date1: Date | undefined,\n    date2: Date | undefined,\n  ): number | undefined {\n    if (date1 === undefined || date2 === undefined) {\n      return undefined;\n    }\n\n    if (this.datepickerMode === 'day' && this.compareHandlerDay) {\n      return this.compareHandlerDay(date1, date2);\n    }\n\n    if (this.datepickerMode === 'month' && this.compareHandlerMonth) {\n      return this.compareHandlerMonth(date1, date2);\n    }\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (this.datepickerMode === 'year' && this.compareHandlerYear) {\n      return this.compareHandlerYear(date1, date2);\n    }\n\n    /* istanbul ignore next */\n    return undefined;\n  }\n\n  public setRefreshViewHandler(handler: () => void, type: string): void {\n    if (type === 'day') {\n      this.refreshViewHandlerDay = handler;\n    }\n\n    if (type === 'month') {\n      this.refreshViewHandlerMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.refreshViewHandlerYear = handler;\n    }\n  }\n\n  public refreshView(): void {\n    if (this.datepickerMode === 'day' && this.refreshViewHandlerDay) {\n      this.refreshViewHandlerDay();\n    }\n\n    if (this.datepickerMode === 'month' && this.refreshViewHandlerMonth) {\n      this.refreshViewHandlerMonth();\n    }\n\n    if (this.datepickerMode === 'year' && this.refreshViewHandlerYear) {\n      this.refreshViewHandlerYear();\n    }\n  }\n\n  public setKeydownHandler(handler: KeyboardEventHandler, type: string) {\n    if (type === 'day') {\n      this.handleKeydownDay = handler;\n    }\n\n    if (type === 'month') {\n      this.handleKeydownMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.handleKeydownYear = handler;\n    }\n  }\n\n  public handleKeydown(key: string, event: KeyboardEvent): void {\n    if (this.datepickerMode === 'day' && this.handleKeydownDay) {\n      this.handleKeydownDay(key, event);\n    }\n\n    if (this.datepickerMode === 'month' && this.handleKeydownMonth) {\n      this.handleKeydownMonth(key, event);\n    }\n\n    if (this.datepickerMode === 'year' && this.handleKeydownYear) {\n      this.handleKeydownYear(key, event);\n    }\n  }\n\n  public dateFilter(date: Date, format: string): string {\n    return this.dateFormatter.format(date, format);\n  }\n\n  public isActive(dateObject: any): boolean {\n    if (this.compare(dateObject.date, this.activeDate) === 0) {\n      this.activeDateId = dateObject.uid;\n      return true;\n    }\n\n    return false;\n  }\n\n  public onKeydown(event: KeyboardEvent) {\n    const key = this.keys[event.which];\n\n    if (!key || event.shiftKey || event.altKey) {\n      return;\n    }\n\n    event.preventDefault();\n    event.stopPropagation();\n\n    if (key === 'enter' || key === 'space') {\n      if (this.isDisabled(this.activeDate)) {\n        return;\n      }\n      this.select(this.activeDate);\n    } else if (event.ctrlKey && (key === 'up' || key === 'down')) {\n      this.toggleMode(key === 'up' ? 1 : -1);\n    } else {\n      this.handleKeydown(key, event);\n      this.refreshView();\n    }\n  }\n\n  public createDateObject(\n    date: Date,\n    format: string,\n    isSecondary: boolean,\n    id: string,\n  ): SkyDatepickerDate {\n    const customDateMatch = this.#getCustomDate(date);\n\n    const dateObject: SkyDatepickerDate = {\n      date: new Date(date.getFullYear(), date.getMonth(), date.getDate()),\n      label: this.dateFilter(date, format),\n      selected:\n        !!this.selectedDate && this.compare(date, this.selectedDate) === 0,\n      disabled: this.isDisabled(date),\n      current: this.compare(date, new Date()) === 0,\n      secondary: isSecondary,\n      uid: id,\n      keyDate: customDateMatch ? customDateMatch.keyDate : undefined,\n      keyDateText: customDateMatch ? customDateMatch.keyDateText : [],\n    };\n\n    return dateObject;\n  }\n\n  public createCalendarRows(\n    dates: Array<SkyDatepickerDate>,\n    size: number,\n  ): Array<Array<SkyDatepickerDate>> {\n    const rows: Array<Array<SkyDatepickerDate>> = [];\n    while (dates.length > 0) {\n      rows.push(dates.splice(0, size));\n    }\n    return rows;\n  }\n\n  /*\n    This is ensures that no strangeness happens when converting a date to local time.\n  */\n  public fixTimeZone(date: Date): Date {\n    const newDate = new Date(date);\n    newDate.setFullYear(date.getFullYear(), date.getMonth(), date.getDate());\n\n    return newDate;\n  }\n\n  public selectCalendar(event: Event, date: Date, closePicker = false) {\n    if (!closePicker) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n    this.select(date);\n  }\n\n  public select(date: Date, isManual = true): void {\n    this.activeDate = new Date(\n      date.getFullYear(),\n      date.getMonth(),\n      date.getDate(),\n    );\n\n    /*\n        Only actually select date if in minMode (day picker mode).\n        Otherwise, just change the active view for the datepicker.\n    */\n    if (this.datepickerMode === this.minMode) {\n      this.selectedDate = new Date(this.activeDate);\n      if (isManual) {\n        this.selectedDateChange.emit(this.selectedDate);\n      }\n    } else {\n      this.datepickerMode =\n        this.modes[this.modes.indexOf(this.datepickerMode) - 1];\n      this.calendarModeChange.emit(this.datepickerMode);\n    }\n\n    this.refreshView();\n  }\n\n  public moveCalendar(event: Event, direction: number) {\n    event.preventDefault();\n    event.stopPropagation();\n    this.move(direction);\n  }\n\n  public move(direction: number): void {\n    let expectedStep: any;\n    if (this.datepickerMode === 'day') {\n      expectedStep = this.stepDay;\n    }\n\n    if (this.datepickerMode === 'month') {\n      expectedStep = this.stepMonth;\n    }\n\n    if (this.datepickerMode === 'year') {\n      expectedStep = this.stepYear;\n    }\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (expectedStep) {\n      const year =\n        this.activeDate.getFullYear() + direction * (expectedStep.years || 0);\n      const month =\n        this.activeDate.getMonth() + direction * (expectedStep.months || 0);\n\n      this.activeDate = new Date(year, month, 1);\n\n      this.refreshView();\n    }\n  }\n\n  public toggleModeCalendar(event: Event) {\n    event.preventDefault();\n    event.stopPropagation();\n    this.toggleMode(1);\n  }\n\n  public toggleMode(direction: number): void {\n    /*istanbul ignore next */\n    direction = direction || 1;\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (\n      !(direction === 1 && this.datepickerMode === this.maxMode) &&\n      !(this.datepickerMode === this.minMode && direction === -1)\n    ) {\n      this.datepickerMode =\n        this.modes[this.modes.indexOf(this.datepickerMode) + direction];\n      this.calendarModeChange.emit(this.datepickerMode);\n      this.refreshView();\n    }\n  }\n\n  /**\n   * Date is disabled if it meets any of these criteria:\n   * 1. Date falls outside the min or max dates set by the SkyDatepickerConfigService.\n   * 2. Date is marked as disabled in the customDates array.\n   */\n  protected isDisabled(date: Date): boolean {\n    const customDate = this.#getCustomDate(date);\n    const minDateCompare = this.compare(date, this.minDate);\n    const maxDateCompare = this.compare(date, this.maxDate);\n\n    return (\n      (minDateCompare !== undefined && minDateCompare < 0) ||\n      (maxDateCompare !== undefined && maxDateCompare > 0) ||\n      !!customDate?.disabled\n    );\n  }\n\n  #getCustomDate(date: Date): SkyDatepickerCustomDate | undefined {\n    if (this.customDates) {\n      return this.customDates.find((customDate: SkyDatepickerCustomDate) => {\n        return customDate.date.getTime() === date.getTime();\n      });\n    }\n    return undefined;\n  }\n}\n","<div\n  *ngIf=\"datepickerMode\"\n  class=\"sky-datepicker-calendar-inner\"\n  (keydown)=\"onKeydown($event)\"\n>\n  <ng-content />\n</div>\n"]}
|
379
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-calendar-inner.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar-inner.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar-inner.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewEncapsulation,\n  inject,\n} from '@angular/core';\nimport { SkyLiveAnnouncerService } from '@skyux/core';\nimport { SkyLibResourcesService } from '@skyux/i18n';\n\nimport { Subject, takeUntil } from 'rxjs';\n\nimport { SkyDateFormatter } from './date-formatter';\nimport { SkyDatepickerCustomDate } from './datepicker-custom-date';\nimport { SkyDatepickerDate } from './datepicker-date';\n\ntype DateComparator = (date1: Date, date2: Date) => number | undefined;\ntype KeyboardEventHandler = (key: string, event: KeyboardEvent) => void;\n\nlet nextDatepickerId = 0;\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-datepicker-inner',\n  templateUrl: './datepicker-calendar-inner.component.html',\n  styleUrls: ['./datepicker-calendar-inner.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SkyDatepickerCalendarInnerComponent\n  implements OnDestroy, OnInit, OnChanges\n{\n  @Input()\n  public customDates: SkyDatepickerCustomDate[] | undefined;\n\n  @Input()\n  public set startingDay(value: number | undefined) {\n    this.#_startingDay = value || 0;\n  }\n\n  public get startingDay(): number {\n    return this.#_startingDay;\n  }\n\n  @Input()\n  public minDate: Date | undefined;\n\n  @Input()\n  public maxDate: Date | undefined;\n\n  @Input()\n  public set selectedDate(value: Date | undefined) {\n    if (value && this.dateFormatter.dateIsValid(value)) {\n      this.#_selectedDate = value;\n      this.activeDate = value;\n    } else {\n      this.#_selectedDate = undefined;\n      this.activeDate = new Date();\n    }\n  }\n\n  public get selectedDate(): Date | undefined {\n    return this.#_selectedDate;\n  }\n\n  @Output()\n  public selectedDateChange: EventEmitter<Date> = new EventEmitter<Date>(\n    undefined,\n  );\n\n  @Output()\n  public calendarModeChange: EventEmitter<string> = new EventEmitter<string>();\n\n  // TODO: `activeDate` is very similar to `selectedDate` and at the very least should be able to be undefined. However, this would take considerable refactoring to do and thus has been deferred.\n  public activeDate = new Date();\n  public activeDateId = '';\n\n  public title = '';\n\n  public minMode = 'day';\n  public maxMode = 'year';\n  public monthColLimit = 3;\n  public yearColLimit = 5;\n  public datepickerMode = 'day';\n  public yearRange = 20;\n\n  public formatDay = 'DD';\n  public formatMonth = 'MMMM';\n  public formatYear = 'YYYY';\n  public formatDayHeader = 'dd';\n  public formatDayTitle = 'MMMM YYYY';\n  public formatMonthTitle = 'YYYY';\n  public formatDayLabel = 'dddd, MMMM Do YYYY';\n  public formatMonthLabel = 'MMMM YYYY';\n  public formatYearLabel = 'YYYY';\n\n  public previousLabel: string | undefined;\n  public nextLabel: string | undefined;\n\n  public datepickerId = `sky-datepicker-${++nextDatepickerId}`;\n\n  public stepDay: any = {};\n  public stepMonth: any = {};\n  public stepYear: any = {};\n\n  protected modes: string[] = ['day', 'month', 'year'];\n  protected dateFormatter: SkyDateFormatter = new SkyDateFormatter();\n\n  public refreshViewHandlerDay: (() => string) | undefined;\n  public compareHandlerDay: DateComparator | undefined;\n  public refreshViewHandlerMonth: (() => string) | undefined;\n  public compareHandlerMonth: DateComparator | undefined;\n  public refreshViewHandlerYear: (() => string) | undefined;\n  public compareHandlerYear: DateComparator | undefined;\n\n  public handleKeydownDay: KeyboardEventHandler | undefined;\n  public handleKeydownMonth: KeyboardEventHandler | undefined;\n  public handleKeydownYear: KeyboardEventHandler | undefined;\n\n  public keys = [\n    'enter',\n    ' ',\n    'spacebar',\n    'pageup',\n    'pagedown',\n    'end',\n    'home',\n    'arrowleft',\n    'arrowup',\n    'arrowright',\n    'arrowdown',\n  ];\n\n  #ngUnsubscribe = new Subject<void>();\n  #prevDay: string | undefined;\n  #nextDay: string | undefined;\n  #prevMonth: string | undefined;\n  #nextMonth: string | undefined;\n  #prevYear: string | undefined;\n  #nextYear: string | undefined;\n\n  #_selectedDate: Date | undefined;\n  #_startingDay = 0;\n\n  readonly #resourcesSvc = inject(SkyLibResourcesService);\n  readonly #liveAnnouncerSvc = inject(SkyLiveAnnouncerService);\n\n  public ngOnInit(): void {\n    if (this.selectedDate) {\n      this.activeDate = new Date(this.selectedDate);\n    } else {\n      this.activeDate = new Date();\n    }\n\n    this.#resourcesSvc\n      .getStrings({\n        prevDay: 'skyux_datepicker_move_calendar_previous_day',\n        nextDay: 'skyux_datepicker_move_calendar_next_day',\n        prevMonth: 'skyux_datepicker_move_calendar_previous_month',\n        nextMonth: 'skyux_datepicker_move_calendar_next_month',\n        prevYear: 'skyux_datepicker_move_calendar_previous_year',\n        nextYear: 'skyux_datepicker_move_calendar_next_year',\n      })\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((resources) => {\n        this.#prevDay = resources.prevDay;\n        this.#nextDay = resources.nextDay;\n        this.#prevMonth = resources.prevMonth;\n        this.#nextMonth = resources.nextMonth;\n        this.#prevYear = resources.prevYear;\n        this.#nextYear = resources.nextYear;\n\n        this.refreshView();\n      });\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    this.refreshView();\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public setCompareHandler(handler: DateComparator, type: string): void {\n    if (type === 'day') {\n      this.compareHandlerDay = handler;\n    }\n\n    if (type === 'month') {\n      this.compareHandlerMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.compareHandlerYear = handler;\n    }\n  }\n\n  public compare(\n    date1: Date | undefined,\n    date2: Date | undefined,\n  ): number | undefined {\n    if (date1 === undefined || date2 === undefined) {\n      return undefined;\n    }\n\n    if (this.datepickerMode === 'day' && this.compareHandlerDay) {\n      return this.compareHandlerDay(date1, date2);\n    }\n\n    if (this.datepickerMode === 'month' && this.compareHandlerMonth) {\n      return this.compareHandlerMonth(date1, date2);\n    }\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (this.datepickerMode === 'year' && this.compareHandlerYear) {\n      return this.compareHandlerYear(date1, date2);\n    }\n\n    /* istanbul ignore next */\n    return undefined;\n  }\n\n  public setRefreshViewHandler(handler: () => string, type: string): void {\n    if (type === 'day') {\n      this.refreshViewHandlerDay = handler;\n    }\n\n    if (type === 'month') {\n      this.refreshViewHandlerMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.refreshViewHandlerYear = handler;\n    }\n  }\n\n  public refreshView(): void {\n    if (this.datepickerMode === 'day' && this.refreshViewHandlerDay) {\n      this.title = this.refreshViewHandlerDay();\n      this.previousLabel = this.#prevDay;\n      this.nextLabel = this.#nextDay;\n    }\n\n    if (this.datepickerMode === 'month' && this.refreshViewHandlerMonth) {\n      this.title = this.refreshViewHandlerMonth();\n      this.previousLabel = this.#prevMonth;\n      this.nextLabel = this.#nextMonth;\n    }\n\n    if (this.datepickerMode === 'year' && this.refreshViewHandlerYear) {\n      this.title = this.refreshViewHandlerYear();\n      this.previousLabel = this.#prevYear;\n      this.nextLabel = this.#nextYear;\n    }\n  }\n\n  public setKeydownHandler(handler: KeyboardEventHandler, type: string): void {\n    if (type === 'day') {\n      this.handleKeydownDay = handler;\n    }\n\n    if (type === 'month') {\n      this.handleKeydownMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.handleKeydownYear = handler;\n    }\n  }\n\n  public handleKeydown(key: string, event: KeyboardEvent): void {\n    if (this.datepickerMode === 'day' && this.handleKeydownDay) {\n      this.handleKeydownDay(key, event);\n    }\n\n    if (this.datepickerMode === 'month' && this.handleKeydownMonth) {\n      this.handleKeydownMonth(key, event);\n    }\n\n    if (this.datepickerMode === 'year' && this.handleKeydownYear) {\n      this.handleKeydownYear(key, event);\n    }\n  }\n\n  public dateFilter(date: Date, format: string): string {\n    return this.dateFormatter.format(date, format);\n  }\n\n  public isActive(dateObject: any): boolean {\n    if (this.compare(dateObject.date, this.activeDate) === 0) {\n      this.activeDateId = dateObject.uid;\n      return true;\n    }\n\n    return false;\n  }\n\n  public onKeydown(event: KeyboardEvent): void {\n    const key = event.key?.toLowerCase();\n\n    if (!this.keys.includes(key) || event.shiftKey) {\n      return;\n    }\n\n    event.preventDefault();\n    event.stopPropagation();\n\n    if (key === 'enter' || key === 'spacebar' || key === ' ') {\n      if (this.isDisabled(this.activeDate)) {\n        return;\n      }\n      this.select(this.activeDate);\n    } else if (event.ctrlKey && (key === 'arrowup' || key === 'arrowdown')) {\n      this.toggleMode(key === 'arrowup' ? 1 : -1);\n    } else {\n      this.handleKeydown(key, event);\n      this.refreshView();\n    }\n  }\n\n  public createDateObject(\n    date: Date,\n    format: string,\n    isSecondary: boolean,\n    id: string,\n  ): SkyDatepickerDate {\n    const customDateMatch = this.#getCustomDate(date);\n\n    const dateObject: SkyDatepickerDate = {\n      date: new Date(date.getFullYear(), date.getMonth(), date.getDate()),\n      label: this.dateFilter(date, format),\n      selected:\n        !!this.selectedDate && this.compare(date, this.selectedDate) === 0,\n      disabled: this.isDisabled(date),\n      current: this.compare(date, new Date()) === 0,\n      secondary: isSecondary,\n      uid: id,\n      keyDate: customDateMatch ? customDateMatch.keyDate : undefined,\n      keyDateText: customDateMatch ? customDateMatch.keyDateText : [],\n    };\n\n    return dateObject;\n  }\n\n  public createCalendarRows(\n    dates: SkyDatepickerDate[],\n    size: number,\n  ): SkyDatepickerDate[][] {\n    const rows: SkyDatepickerDate[][] = [];\n    while (dates.length > 0) {\n      rows.push(dates.splice(0, size));\n    }\n    return rows;\n  }\n\n  /*\n    This is ensures that no strangeness happens when converting a date to local time.\n  */\n  public fixTimeZone(date: Date): Date {\n    const newDate = new Date(date);\n    newDate.setFullYear(date.getFullYear(), date.getMonth(), date.getDate());\n\n    return newDate;\n  }\n\n  public selectCalendar(event: Event, date: Date, closePicker = false): void {\n    if (!closePicker) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n    this.select(date);\n  }\n\n  public select(date: Date, isManual = true): void {\n    this.activeDate = new Date(\n      date.getFullYear(),\n      date.getMonth(),\n      date.getDate(),\n    );\n\n    /*\n        Only actually select date if in minMode (day picker mode).\n        Otherwise, just change the active view for the datepicker.\n    */\n    if (this.datepickerMode === this.minMode) {\n      this.selectedDate = new Date(this.activeDate);\n      if (isManual) {\n        this.selectedDateChange.emit(this.selectedDate);\n      }\n    } else {\n      this.datepickerMode =\n        this.modes[this.modes.indexOf(this.datepickerMode) - 1];\n      this.calendarModeChange.emit(this.datepickerMode);\n    }\n\n    this.refreshView();\n  }\n\n  public moveCalendar(event: Event, direction: number): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.move(direction);\n  }\n\n  public move(direction: number): void {\n    let expectedStep: any;\n    if (this.datepickerMode === 'day') {\n      expectedStep = this.stepDay;\n    }\n\n    if (this.datepickerMode === 'month') {\n      expectedStep = this.stepMonth;\n    }\n\n    if (this.datepickerMode === 'year') {\n      expectedStep = this.stepYear;\n    }\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (expectedStep) {\n      const year =\n        this.activeDate.getFullYear() + direction * (expectedStep.years || 0);\n      const month =\n        this.activeDate.getMonth() + direction * (expectedStep.months || 0);\n\n      this.activeDate = new Date(year, month, 1);\n\n      this.refreshView();\n    }\n  }\n\n  public toggleModeCalendar(event: Event): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.toggleMode(1);\n  }\n\n  public toggleMode(direction: number): void {\n    /*istanbul ignore next */\n    direction = direction || 1;\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (\n      !(direction === 1 && this.datepickerMode === this.maxMode) &&\n      !(this.datepickerMode === this.minMode && direction === -1)\n    ) {\n      this.datepickerMode =\n        this.modes[this.modes.indexOf(this.datepickerMode) + direction];\n      this.calendarModeChange.emit(this.datepickerMode);\n      this.refreshView();\n    }\n  }\n\n  public announceDate(date: Date, format: string): void {\n    const caption = this.dateFilter(date, format);\n    this.#liveAnnouncerSvc.announce(caption);\n  }\n\n  /**\n   * Date is disabled if it meets any of these criteria:\n   * 1. Date falls outside the min or max dates set by the SkyDatepickerConfigService.\n   * 2. Date is marked as disabled in the customDates array.\n   */\n  protected isDisabled(date: Date): boolean {\n    const customDate = this.#getCustomDate(date);\n    const minDateCompare = this.compare(date, this.minDate);\n    const maxDateCompare = this.compare(date, this.maxDate);\n\n    return (\n      (minDateCompare !== undefined && minDateCompare < 0) ||\n      (maxDateCompare !== undefined && maxDateCompare > 0) ||\n      !!customDate?.disabled\n    );\n  }\n\n  #getCustomDate(date: Date): SkyDatepickerCustomDate | undefined {\n    if (this.customDates) {\n      return this.customDates.find((customDate: SkyDatepickerCustomDate) => {\n        return customDate.date.getTime() === date.getTime();\n      });\n    }\n    return undefined;\n  }\n}\n","<div *ngIf=\"datepickerMode\" class=\"sky-datepicker-calendar-inner\">\n  <div class=\"sky-datepicker-calendar-header\">\n    <span class=\"sky-datepicker-header-left\">\n      <button\n        type=\"button\"\n        class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-previous\"\n        [attr.aria-label]=\"previousLabel\"\n        (click)=\"moveCalendar($event, -1)\"\n      >\n        <sky-icon class=\"sky-datepicker-chevron\" icon=\"chevron-left\" />\n      </button>\n    </span>\n    <span class=\"sky-datepicker-header-center\">\n      <button\n        [id]=\"datepickerId + '-title'\"\n        type=\"button\"\n        class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-calendar-title\"\n        (click)=\"toggleModeCalendar($event)\"\n        [disabled]=\"datepickerMode === maxMode\"\n        [ngClass]=\"{\n          'sky-btn-disabled': datepickerMode === maxMode\n        }\"\n      >\n        <strong>{{ title }}</strong>\n      </button>\n    </span>\n    <span class=\"sky-datepicker-header-right\">\n      <button\n        type=\"button\"\n        class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-next\"\n        [attr.aria-label]=\"nextLabel\"\n        (click)=\"moveCalendar($event, 1)\"\n      >\n        <sky-icon class=\"sky-datepicker-chevron\" icon=\"chevron-right\" />\n      </button>\n    </span>\n  </div>\n  <ng-content />\n</div>\n"]}
|
@@ -0,0 +1,39 @@
|
|
1
|
+
import { Pipe, inject } from '@angular/core';
|
2
|
+
import { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
/**
|
5
|
+
* Formats date values according to formatting rules.
|
6
|
+
* @example
|
7
|
+
* ```markup
|
8
|
+
* {{ myDate | skyDatepickerCalendarLabel }}
|
9
|
+
* {{ myDate | skyDatepickerCalendarLabel:'YYYY' }}
|
10
|
+
* ```
|
11
|
+
* @internal
|
12
|
+
*/
|
13
|
+
export class SkyDatepickerCalendarLabelPipe {
|
14
|
+
#datepicker = inject(SkyDatepickerCalendarInnerComponent);
|
15
|
+
#defaultFormat = this.#datepicker.formatDayLabel;
|
16
|
+
/**
|
17
|
+
* Transforms a date value using locale and format rules.
|
18
|
+
* @param value Specifies the date value to transform.
|
19
|
+
* @param format Specifies the format to apply to the transform. The format string is
|
20
|
+
* constructed by a series of symbols that represent date-time values.
|
21
|
+
*/
|
22
|
+
transform(value, format) {
|
23
|
+
let formattedValue = '';
|
24
|
+
if (value && value instanceof Date) {
|
25
|
+
formattedValue = this.#datepicker.dateFilter(value, format || this.#defaultFormat);
|
26
|
+
}
|
27
|
+
return formattedValue;
|
28
|
+
}
|
29
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerCalendarLabelPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
30
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerCalendarLabelPipe, isStandalone: true, name: "skyDatepickerCalendarLabel" }); }
|
31
|
+
}
|
32
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerCalendarLabelPipe, decorators: [{
|
33
|
+
type: Pipe,
|
34
|
+
args: [{
|
35
|
+
name: 'skyDatepickerCalendarLabel',
|
36
|
+
standalone: true,
|
37
|
+
}]
|
38
|
+
}] });
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci1jYWxlbmRhci1sYWJlbC5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2RhdGV0aW1lL3NyYy9saWIvbW9kdWxlcy9kYXRlcGlja2VyL2RhdGVwaWNrZXItY2FsZW5kYXItbGFiZWwucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFNUQsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLE1BQU0sdUNBQXVDLENBQUM7O0FBRTVGOzs7Ozs7OztHQVFHO0FBS0gsTUFBTSxPQUFPLDhCQUE4QjtJQUN6QyxXQUFXLEdBQUcsTUFBTSxDQUFDLG1DQUFtQyxDQUFDLENBQUM7SUFDMUQsY0FBYyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsY0FBYyxDQUFDO0lBRWpEOzs7OztPQUtHO0lBQ0ksU0FBUyxDQUFDLEtBQWMsRUFBRSxNQUFlO1FBQzlDLElBQUksY0FBYyxHQUFHLEVBQUUsQ0FBQztRQUV4QixJQUFJLEtBQUssSUFBSSxLQUFLLFlBQVksSUFBSSxFQUFFLENBQUM7WUFDbkMsY0FBYyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUMxQyxLQUFLLEVBQ0wsTUFBTSxJQUFJLElBQUksQ0FBQyxjQUFjLENBQzlCLENBQUM7UUFDSixDQUFDO1FBRUQsT0FBTyxjQUFjLENBQUM7SUFDeEIsQ0FBQzs4R0FyQlUsOEJBQThCOzRHQUE5Qiw4QkFBOEI7OzJGQUE5Qiw4QkFBOEI7a0JBSjFDLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLDRCQUE0QjtvQkFDbEMsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFNreURhdGVwaWNrZXJDYWxlbmRhcklubmVyQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRlcGlja2VyLWNhbGVuZGFyLWlubmVyLmNvbXBvbmVudCc7XG5cbi8qKlxuICogRm9ybWF0cyBkYXRlIHZhbHVlcyBhY2NvcmRpbmcgdG8gZm9ybWF0dGluZyBydWxlcy5cbiAqIEBleGFtcGxlXG4gKiBgYGBtYXJrdXBcbiAqIHt7IG15RGF0ZSB8IHNreURhdGVwaWNrZXJDYWxlbmRhckxhYmVsIH19XG4gKiB7eyBteURhdGUgfCBza3lEYXRlcGlja2VyQ2FsZW5kYXJMYWJlbDonWVlZWScgfX1cbiAqIGBgYFxuICogQGludGVybmFsXG4gKi9cbkBQaXBlKHtcbiAgbmFtZTogJ3NreURhdGVwaWNrZXJDYWxlbmRhckxhYmVsJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5RGF0ZXBpY2tlckNhbGVuZGFyTGFiZWxQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gICNkYXRlcGlja2VyID0gaW5qZWN0KFNreURhdGVwaWNrZXJDYWxlbmRhcklubmVyQ29tcG9uZW50KTtcbiAgI2RlZmF1bHRGb3JtYXQgPSB0aGlzLiNkYXRlcGlja2VyLmZvcm1hdERheUxhYmVsO1xuXG4gIC8qKlxuICAgKiBUcmFuc2Zvcm1zIGEgZGF0ZSB2YWx1ZSB1c2luZyBsb2NhbGUgYW5kIGZvcm1hdCBydWxlcy5cbiAgICogQHBhcmFtIHZhbHVlIFNwZWNpZmllcyB0aGUgZGF0ZSB2YWx1ZSB0byB0cmFuc2Zvcm0uXG4gICAqIEBwYXJhbSBmb3JtYXQgU3BlY2lmaWVzIHRoZSBmb3JtYXQgdG8gYXBwbHkgdG8gdGhlIHRyYW5zZm9ybS4gVGhlIGZvcm1hdCBzdHJpbmcgaXNcbiAgICogY29uc3RydWN0ZWQgYnkgYSBzZXJpZXMgb2Ygc3ltYm9scyB0aGF0IHJlcHJlc2VudCBkYXRlLXRpbWUgdmFsdWVzLlxuICAgKi9cbiAgcHVibGljIHRyYW5zZm9ybSh2YWx1ZTogdW5rbm93biwgZm9ybWF0Pzogc3RyaW5nKTogc3RyaW5nIHtcbiAgICBsZXQgZm9ybWF0dGVkVmFsdWUgPSAnJztcblxuICAgIGlmICh2YWx1ZSAmJiB2YWx1ZSBpbnN0YW5jZW9mIERhdGUpIHtcbiAgICAgIGZvcm1hdHRlZFZhbHVlID0gdGhpcy4jZGF0ZXBpY2tlci5kYXRlRmlsdGVyKFxuICAgICAgICB2YWx1ZSxcbiAgICAgICAgZm9ybWF0IHx8IHRoaXMuI2RlZmF1bHRGb3JtYXQsXG4gICAgICApO1xuICAgIH1cblxuICAgIHJldHVybiBmb3JtYXR0ZWRWYWx1ZTtcbiAgfVxufVxuIl19
|
@@ -1,13 +1,13 @@
|
|
1
1
|
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
2
2
|
import { SkyDateFormatter } from './date-formatter';
|
3
|
-
import { SkyDatepickerAdapterService } from './datepicker-adapter.service';
|
4
3
|
import { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';
|
5
4
|
import * as i0 from "@angular/core";
|
6
5
|
import * as i1 from "./datepicker-config.service";
|
7
|
-
import * as i2 from "
|
8
|
-
import * as i3 from "./
|
9
|
-
import * as i4 from "./
|
10
|
-
import * as i5 from "./
|
6
|
+
import * as i2 from "@angular/common";
|
7
|
+
import * as i3 from "./datepicker-calendar-inner.component";
|
8
|
+
import * as i4 from "./daypicker.component";
|
9
|
+
import * as i5 from "./monthpicker.component";
|
10
|
+
import * as i6 from "./yearpicker.component";
|
11
11
|
/**
|
12
12
|
* @internal
|
13
13
|
*/
|
@@ -61,12 +61,12 @@ export class SkyDatepickerCalendarComponent {
|
|
61
61
|
this.datepicker?.select(new Date(), false);
|
62
62
|
}
|
63
63
|
}
|
64
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.
|
65
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.
|
64
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerCalendarComponent, deps: [{ token: i1.SkyDatepickerConfigService }], target: i0.ɵɵFactoryTarget.Component }); }
|
65
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.1", type: SkyDatepickerCalendarComponent, selector: "sky-datepicker-calendar", inputs: { customDates: "customDates", isDaypickerWaiting: "isDaypickerWaiting", minDate: "minDate", maxDate: "maxDate", selectedDate: "selectedDate", startingDay: "startingDay" }, outputs: { calendarDateRangeChange: "calendarDateRangeChange", calendarModeChange: "calendarModeChange", selectedDateChange: "selectedDateChange" }, viewQueries: [{ propertyName: "datepicker", first: true, predicate: SkyDatepickerCalendarInnerComponent, descendants: true, read: SkyDatepickerCalendarInnerComponent, static: true }], ngImport: i0, template: "<div class=\"sky-datepicker-calendar\">\n <sky-datepicker-inner\n [customDates]=\"customDates\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [selectedDate]=\"selectedDate\"\n [startingDay]=\"startingDay\"\n (calendarModeChange)=\"onCalendarModeChange($event)\"\n (selectedDateChange)=\"onSelectedDateChange($event)\"\n >\n <div\n class=\"sky-datepicker-calendar-table-container\"\n autofocus\n tabindex=\"0\"\n (keydown)=\"datepicker?.onKeydown($event)\"\n >\n <sky-daypicker\n *ngIf=\"datepicker?.datepickerMode === 'day'\"\n [customDates]=\"customDates\"\n [isWaiting]=\"isDaypickerWaiting\"\n (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n ></sky-daypicker>\n <sky-monthpicker\n *ngIf=\"datepicker?.datepickerMode === 'month'\"\n ></sky-monthpicker>\n <sky-yearpicker\n *ngIf=\"datepicker?.datepickerMode === 'year'\"\n ></sky-yearpicker>\n </div>\n </sky-datepicker-inner>\n</div>\n", styles: [".sky-datepicker-calendar{display:block}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.SkyDatepickerCalendarInnerComponent, selector: "sky-datepicker-inner", inputs: ["customDates", "startingDay", "minDate", "maxDate", "selectedDate"], outputs: ["selectedDateChange", "calendarModeChange"] }, { kind: "component", type: i4.SkyDayPickerComponent, selector: "sky-daypicker", inputs: ["customDates", "isWaiting"], outputs: ["calendarDateRangeChange"] }, { kind: "component", type: i5.SkyMonthPickerComponent, selector: "sky-monthpicker" }, { kind: "component", type: i6.SkyYearPickerComponent, selector: "sky-yearpicker" }] }); }
|
66
66
|
}
|
67
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.
|
67
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerCalendarComponent, decorators: [{
|
68
68
|
type: Component,
|
69
|
-
args: [{ selector: 'sky-datepicker-calendar',
|
69
|
+
args: [{ selector: 'sky-datepicker-calendar', template: "<div class=\"sky-datepicker-calendar\">\n <sky-datepicker-inner\n [customDates]=\"customDates\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [selectedDate]=\"selectedDate\"\n [startingDay]=\"startingDay\"\n (calendarModeChange)=\"onCalendarModeChange($event)\"\n (selectedDateChange)=\"onSelectedDateChange($event)\"\n >\n <div\n class=\"sky-datepicker-calendar-table-container\"\n autofocus\n tabindex=\"0\"\n (keydown)=\"datepicker?.onKeydown($event)\"\n >\n <sky-daypicker\n *ngIf=\"datepicker?.datepickerMode === 'day'\"\n [customDates]=\"customDates\"\n [isWaiting]=\"isDaypickerWaiting\"\n (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n ></sky-daypicker>\n <sky-monthpicker\n *ngIf=\"datepicker?.datepickerMode === 'month'\"\n ></sky-monthpicker>\n <sky-yearpicker\n *ngIf=\"datepicker?.datepickerMode === 'year'\"\n ></sky-yearpicker>\n </div>\n </sky-datepicker-inner>\n</div>\n", styles: [".sky-datepicker-calendar{display:block}\n"] }]
|
70
70
|
}], ctorParameters: () => [{ type: i1.SkyDatepickerConfigService }], propDecorators: { customDates: [{
|
71
71
|
type: Input
|
72
72
|
}], isDaypickerWaiting: [{
|
@@ -92,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
92
92
|
static: true,
|
93
93
|
}]
|
94
94
|
}] } });
|
95
|
-
//# sourceMappingURL=data:application/json;base64,
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-calendar.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core';\n\nimport { SkyDateFormatter } from './date-formatter';\nimport { SkyDatepickerCalendarChange } from './datepicker-calendar-change';\nimport { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';\nimport { SkyDatepickerConfigService } from './datepicker-config.service';\nimport { SkyDatepickerCustomDate } from './datepicker-custom-date';\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-datepicker-calendar',\n  templateUrl: './datepicker-calendar.component.html',\n  styleUrls: ['./datepicker-calendar.component.scss'],\n})\nexport class SkyDatepickerCalendarComponent {\n  @Input()\n  public customDates: SkyDatepickerCustomDate[] | undefined;\n\n  @Input()\n  public isDaypickerWaiting: boolean | undefined;\n\n  @Input()\n  public minDate: Date | undefined;\n\n  @Input()\n  public maxDate: Date | undefined;\n\n  /** currently selected date */\n  @Input()\n  public selectedDate: Date | undefined;\n\n  /** starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday) */\n  @Input()\n  public set startingDay(start: number | undefined) {\n    this.#_startingDay = start ?? 0;\n  }\n\n  public get startingDay(): number {\n    return this.#_startingDay;\n  }\n\n  @Output()\n  public calendarDateRangeChange = new EventEmitter<\n    SkyDatepickerCalendarChange | undefined\n  >();\n\n  @Output()\n  public calendarModeChange = new EventEmitter<string>();\n\n  @Output()\n  public selectedDateChange = new EventEmitter<Date>(undefined);\n\n  @ViewChild(SkyDatepickerCalendarInnerComponent, {\n    read: SkyDatepickerCalendarInnerComponent,\n    static: true,\n  })\n  public datepicker: SkyDatepickerCalendarInnerComponent | undefined;\n\n  protected _now: Date = new Date();\n\n  #formatter = new SkyDateFormatter();\n\n  #_startingDay = 0;\n\n  #config: SkyDatepickerConfigService;\n\n  constructor(config: SkyDatepickerConfigService) {\n    this.#config = config;\n    this.configureOptions();\n  }\n\n  public configureOptions(): void {\n    Object.assign(this, this.#config);\n  }\n\n  public onCalendarDateRangeChange(\n    event: SkyDatepickerCalendarChange | undefined,\n  ): void {\n    this.calendarDateRangeChange.next(event);\n  }\n\n  public onCalendarModeChange(event: string): void {\n    this.calendarModeChange.emit(event);\n  }\n\n  public onSelectedDateChange(event: Date): void {\n    this.selectedDateChange.emit(event);\n  }\n\n  public writeValue(value: Date | undefined): void {\n    if (\n      value !== undefined &&\n      this.#formatter.dateIsValid(value) &&\n      this.selectedDate !== undefined &&\n      this.datepicker?.compareHandlerDay &&\n      this.datepicker.compareHandlerDay(value, this.selectedDate) === 0\n    ) {\n      return;\n    }\n\n    if (value && this.#formatter.dateIsValid(value)) {\n      this.selectedDate = value;\n      this.datepicker?.select(value, false);\n    } else {\n      this.selectedDate = new Date();\n      this.datepicker?.select(new Date(), false);\n    }\n  }\n}\n","<div class=\"sky-datepicker-calendar\">\n  <sky-datepicker-inner\n    [customDates]=\"customDates\"\n    [maxDate]=\"maxDate\"\n    [minDate]=\"minDate\"\n    [selectedDate]=\"selectedDate\"\n    [startingDay]=\"startingDay\"\n    (calendarModeChange)=\"onCalendarModeChange($event)\"\n    (selectedDateChange)=\"onSelectedDateChange($event)\"\n  >\n    <div\n      class=\"sky-datepicker-calendar-table-container\"\n      autofocus\n      tabindex=\"0\"\n      (keydown)=\"datepicker?.onKeydown($event)\"\n    >\n      <sky-daypicker\n        *ngIf=\"datepicker?.datepickerMode === 'day'\"\n        [customDates]=\"customDates\"\n        [isWaiting]=\"isDaypickerWaiting\"\n        (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n      ></sky-daypicker>\n      <sky-monthpicker\n        *ngIf=\"datepicker?.datepickerMode === 'month'\"\n      ></sky-monthpicker>\n      <sky-yearpicker\n        *ngIf=\"datepicker?.datepickerMode === 'year'\"\n      ></sky-yearpicker>\n    </div>\n  </sky-datepicker-inner>\n</div>\n"]}
|
@@ -9,10 +9,10 @@ export class SkyDatepickerConfigService {
|
|
9
9
|
*/
|
10
10
|
this.startingDay = 0;
|
11
11
|
}
|
12
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.
|
13
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.
|
12
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerConfigService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
13
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerConfigService, providedIn: 'root' }); }
|
14
14
|
}
|
15
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerConfigService, decorators: [{
|
16
16
|
type: Injectable,
|
17
17
|
args: [{
|
18
18
|
providedIn: 'root',
|
@@ -1,2 +1,2 @@
|
|
1
1
|
export {};
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci1jdXN0b20tZGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9kYXRldGltZS9zcmMvbGliL21vZHVsZXMvZGF0ZXBpY2tlci9kYXRlcGlja2VyLWN1c3RvbS1kYXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRoZSBjb25maWd1cmF0aW9uIGZvciBhIGN1c3RvbSBkYXRlLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNreURhdGVwaWNrZXJDdXN0b21EYXRlIHtcbiAgLyoqXG4gICAqIFRoZSBkYXRlIHRvIGN1c3RvbWl6ZS5cbiAgICovXG4gIGRhdGU6IERhdGU7XG5cbiAgLyoqXG4gICAqIFdoZXRoZXIgdG8gZGlzYWJsZSB0aGUgZGF0ZS5cbiAgICovXG4gIGRpc2FibGVkPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogV2hldGhlciB0byBkaXNwbGF5IHRoZSBkYXRlIGFzIGEga2V5IGRhdGUgaW4gdGhlIGNhbGVuZGFyLlxuICAgKi9cbiAga2V5RGF0ZT86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIERpc3BsYXlzIGEgcG9wdXAgb2YgdGhlIHByb3ZpZGVkIHRleHQgd2hlbiBob3ZlcmluZyBvdmVyIHRoZSBrZXkgZGF0ZSBpbiB0aGUgY2FsZW5kYXIuXG4gICAqL1xuICBrZXlEYXRlVGV4dD86IHN0cmluZ1tdO1xufVxuIl19
|
@@ -1,2 +1,2 @@
|
|
1
1
|
export {};
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci1kYXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2RhdGV0aW1lL3NyYy9saWIvbW9kdWxlcy9kYXRlcGlja2VyL2RhdGVwaWNrZXItZGF0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAaW50ZXJuYWxcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTa3lEYXRlcGlja2VyRGF0ZSB7XG4gIGRhdGU6IERhdGU7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHNlbGVjdGVkOiBib29sZWFuO1xuICBkaXNhYmxlZDogYm9vbGVhbjtcbiAgY3VycmVudDogYm9vbGVhbjtcbiAgc2Vjb25kYXJ5OiBib29sZWFuO1xuICB1aWQ6IHN0cmluZztcbiAga2V5RGF0ZT86IGJvb2xlYW47XG4gIGtleURhdGVUZXh0Pzogc3RyaW5nW107XG59XG4iXX0=
|
@@ -429,13 +429,13 @@ export class SkyFuzzyDatepickerInputDirective {
|
|
429
429
|
}
|
430
430
|
this.#setInputElementValue(formattedDate || '');
|
431
431
|
}
|
432
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.
|
433
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.
|
432
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyFuzzyDatepickerInputDirective, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.SkyDatepickerConfigService }, { token: i0.ElementRef }, { token: i2.SkyFuzzyDateService }, { token: i3.SkyAppLocaleProvider }, { token: i0.Renderer2 }, { token: i4.SkyDatepickerComponent, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
433
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.1", type: SkyFuzzyDatepickerInputDirective, selector: "[skyFuzzyDatepickerInput]", inputs: { dateFormat: "dateFormat", disabled: "disabled", futureDisabled: "futureDisabled", maxDate: "maxDate", minDate: "minDate", skyDatepickerNoValidate: "skyDatepickerNoValidate", startingDay: "startingDay", yearRequired: "yearRequired" }, host: { listeners: { "change": "onInputChange($event)", "blur": "onInputBlur()", "input": "onInput()" } }, providers: [
|
434
434
|
SKY_FUZZY_DATEPICKER_VALUE_ACCESSOR,
|
435
435
|
SKY_FUZZY_DATEPICKER_VALIDATOR,
|
436
436
|
], ngImport: i0 }); }
|
437
437
|
}
|
438
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.
|
438
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyFuzzyDatepickerInputDirective, decorators: [{
|
439
439
|
type: Directive,
|
440
440
|
args: [{
|
441
441
|
selector: '[skyFuzzyDatepickerInput]',
|