@skyux/datetime 10.0.0-alpha.0 → 10.0.0-alpha.2
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 +1949 -1859
- 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 +3 -3
- package/esm2022/lib/modules/date-range-picker/date-range-picker.module.mjs +4 -4
- package/esm2022/lib/modules/date-range-picker/date-range.service.mjs +4 -4
- package/esm2022/lib/modules/datepicker/datepicker-adapter.service.mjs +3 -3
- package/esm2022/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +64 -27
- package/esm2022/lib/modules/datepicker/datepicker-calendar.component.mjs +10 -9
- 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 +3 -3
- package/esm2022/lib/modules/datepicker/datepicker.component.mjs +11 -10
- package/esm2022/lib/modules/datepicker/datepicker.module.mjs +10 -6
- package/esm2022/lib/modules/datepicker/datepicker.service.mjs +3 -3
- package/esm2022/lib/modules/datepicker/daypicker-button.component.mjs +3 -3
- package/esm2022/lib/modules/datepicker/daypicker-cell.component.mjs +3 -3
- package/esm2022/lib/modules/datepicker/daypicker.component.mjs +12 -16
- package/esm2022/lib/modules/datepicker/fuzzy-date.service.mjs +5 -6
- package/esm2022/lib/modules/datepicker/monthpicker.component.mjs +11 -14
- package/esm2022/lib/modules/datepicker/yearpicker.component.mjs +12 -14
- package/esm2022/lib/modules/shared/sky-datetime-resources.module.mjs +11 -5
- package/esm2022/lib/modules/timepicker/timepicker.component.mjs +16 -8
- 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 +207 -161
- package/fesm2022/skyux-datetime.mjs.map +1 -1
- package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +9 -6
- 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.module.d.ts +9 -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 +14 -13
@@ -1,8 +1,10 @@
|
|
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 { SkyLibResourcesService } from '@skyux/i18n';
|
3
|
+
import { Subject, takeUntil } from 'rxjs';
|
3
4
|
import { SkyDateFormatter } from './date-formatter';
|
4
5
|
import * as i0 from "@angular/core";
|
5
6
|
import * as i1 from "@angular/common";
|
7
|
+
import * as i2 from "@skyux/indicators";
|
6
8
|
let nextDatepickerId = 0;
|
7
9
|
/**
|
8
10
|
* @internal
|
@@ -14,6 +16,7 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
14
16
|
// 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
17
|
this.activeDate = new Date();
|
16
18
|
this.activeDateId = '';
|
19
|
+
this.title = '';
|
17
20
|
this.minMode = 'day';
|
18
21
|
this.maxMode = 'year';
|
19
22
|
this.monthColLimit = 3;
|
@@ -32,20 +35,22 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
32
35
|
this.stepYear = {};
|
33
36
|
this.modes = ['day', 'month', 'year'];
|
34
37
|
this.dateFormatter = new SkyDateFormatter();
|
35
|
-
this.keys =
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
38
|
+
this.keys = [
|
39
|
+
'enter',
|
40
|
+
' ',
|
41
|
+
'spacebar',
|
42
|
+
'pageup',
|
43
|
+
'pagedown',
|
44
|
+
'end',
|
45
|
+
'home',
|
46
|
+
'arrowleft',
|
47
|
+
'arrowup',
|
48
|
+
'arrowright',
|
49
|
+
'arrowdown',
|
50
|
+
];
|
47
51
|
this.#ngUnsubscribe = new Subject();
|
48
52
|
this.#_startingDay = 0;
|
53
|
+
this.#resourcesSvc = inject(SkyLibResourcesService);
|
49
54
|
}
|
50
55
|
set startingDay(value) {
|
51
56
|
this.#_startingDay = value || 0;
|
@@ -67,8 +72,15 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
67
72
|
return this.#_selectedDate;
|
68
73
|
}
|
69
74
|
#ngUnsubscribe;
|
75
|
+
#prevDay;
|
76
|
+
#nextDay;
|
77
|
+
#prevMonth;
|
78
|
+
#nextMonth;
|
79
|
+
#prevYear;
|
80
|
+
#nextYear;
|
70
81
|
#_selectedDate;
|
71
82
|
#_startingDay;
|
83
|
+
#resourcesSvc;
|
72
84
|
ngOnInit() {
|
73
85
|
if (this.selectedDate) {
|
74
86
|
this.activeDate = new Date(this.selectedDate);
|
@@ -76,6 +88,25 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
76
88
|
else {
|
77
89
|
this.activeDate = new Date();
|
78
90
|
}
|
91
|
+
this.#resourcesSvc
|
92
|
+
.getStrings({
|
93
|
+
prevDay: 'skyux_datepicker_move_calendar_previous_day',
|
94
|
+
nextDay: 'skyux_datepicker_move_calendar_next_day',
|
95
|
+
prevMonth: 'skyux_datepicker_move_calendar_previous_month',
|
96
|
+
nextMonth: 'skyux_datepicker_move_calendar_next_month',
|
97
|
+
prevYear: 'skyux_datepicker_move_calendar_previous_year',
|
98
|
+
nextYear: 'skyux_datepicker_move_calendar_next_year',
|
99
|
+
})
|
100
|
+
.pipe(takeUntil(this.#ngUnsubscribe))
|
101
|
+
.subscribe((resources) => {
|
102
|
+
this.#prevDay = resources.prevDay;
|
103
|
+
this.#nextDay = resources.nextDay;
|
104
|
+
this.#prevMonth = resources.prevMonth;
|
105
|
+
this.#nextMonth = resources.nextMonth;
|
106
|
+
this.#prevYear = resources.prevYear;
|
107
|
+
this.#nextYear = resources.nextYear;
|
108
|
+
this.refreshView();
|
109
|
+
});
|
79
110
|
}
|
80
111
|
ngOnChanges(changes) {
|
81
112
|
this.refreshView();
|
@@ -126,13 +157,19 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
126
157
|
}
|
127
158
|
refreshView() {
|
128
159
|
if (this.datepickerMode === 'day' && this.refreshViewHandlerDay) {
|
129
|
-
this.refreshViewHandlerDay();
|
160
|
+
this.title = this.refreshViewHandlerDay();
|
161
|
+
this.previousLabel = this.#prevDay;
|
162
|
+
this.nextLabel = this.#nextDay;
|
130
163
|
}
|
131
164
|
if (this.datepickerMode === 'month' && this.refreshViewHandlerMonth) {
|
132
|
-
this.refreshViewHandlerMonth();
|
165
|
+
this.title = this.refreshViewHandlerMonth();
|
166
|
+
this.previousLabel = this.#prevMonth;
|
167
|
+
this.nextLabel = this.#nextMonth;
|
133
168
|
}
|
134
169
|
if (this.datepickerMode === 'year' && this.refreshViewHandlerYear) {
|
135
|
-
this.refreshViewHandlerYear();
|
170
|
+
this.title = this.refreshViewHandlerYear();
|
171
|
+
this.previousLabel = this.#prevYear;
|
172
|
+
this.nextLabel = this.#nextYear;
|
136
173
|
}
|
137
174
|
}
|
138
175
|
setKeydownHandler(handler, type) {
|
@@ -168,20 +205,20 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
168
205
|
return false;
|
169
206
|
}
|
170
207
|
onKeydown(event) {
|
171
|
-
const key =
|
172
|
-
if (!key || event.shiftKey || event.altKey) {
|
208
|
+
const key = event.key?.toLowerCase();
|
209
|
+
if (!this.keys.includes(key) || event.shiftKey || event.altKey) {
|
173
210
|
return;
|
174
211
|
}
|
175
212
|
event.preventDefault();
|
176
213
|
event.stopPropagation();
|
177
|
-
if (key === 'enter' || key === '
|
214
|
+
if (key === 'enter' || key === 'spacebar' || key === ' ') {
|
178
215
|
if (this.isDisabled(this.activeDate)) {
|
179
216
|
return;
|
180
217
|
}
|
181
218
|
this.select(this.activeDate);
|
182
219
|
}
|
183
|
-
else if (event.ctrlKey && (key === '
|
184
|
-
this.toggleMode(key === '
|
220
|
+
else if (event.ctrlKey && (key === 'arrowup' || key === 'arrowdown')) {
|
221
|
+
this.toggleMode(key === 'arrowup' ? 1 : -1);
|
185
222
|
}
|
186
223
|
else {
|
187
224
|
this.handleKeydown(key, event);
|
@@ -308,12 +345,12 @@ export class SkyDatepickerCalendarInnerComponent {
|
|
308
345
|
}
|
309
346
|
return undefined;
|
310
347
|
}
|
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.
|
348
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerCalendarInnerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
349
|
+
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
350
|
}
|
314
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.
|
351
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerCalendarInnerComponent, decorators: [{
|
315
352
|
type: Component,
|
316
|
-
args: [{ selector: 'sky-datepicker-inner', encapsulation: ViewEncapsulation.None, template: "<div
|
353
|
+
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
354
|
}], propDecorators: { customDates: [{
|
318
355
|
type: Input
|
319
356
|
}], startingDay: [{
|
@@ -329,4 +366,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
329
366
|
}], calendarModeChange: [{
|
330
367
|
type: Output
|
331
368
|
}] } });
|
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"]}
|
369
|
+
//# 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 { 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\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\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 || event.altKey) {\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  /**\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"]}
|
@@ -4,10 +4,11 @@ import { SkyDatepickerAdapterService } from './datepicker-adapter.service';
|
|
4
4
|
import { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';
|
5
5
|
import * as i0 from "@angular/core";
|
6
6
|
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 "./
|
7
|
+
import * as i2 from "@angular/common";
|
8
|
+
import * as i3 from "./datepicker-calendar-inner.component";
|
9
|
+
import * as i4 from "./daypicker.component";
|
10
|
+
import * as i5 from "./monthpicker.component";
|
11
|
+
import * as i6 from "./yearpicker.component";
|
11
12
|
/**
|
12
13
|
* @internal
|
13
14
|
*/
|
@@ -61,12 +62,12 @@ export class SkyDatepickerCalendarComponent {
|
|
61
62
|
this.datepicker?.select(new Date(), false);
|
62
63
|
}
|
63
64
|
}
|
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.
|
65
|
+
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 }); }
|
66
|
+
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" }, providers: [SkyDatepickerAdapterService], 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
67
|
}
|
67
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.
|
68
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerCalendarComponent, decorators: [{
|
68
69
|
type: Component,
|
69
|
-
args: [{ selector: 'sky-datepicker-calendar', providers: [SkyDatepickerAdapterService], 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 <sky-
|
70
|
+
args: [{ selector: 'sky-datepicker-calendar', providers: [SkyDatepickerAdapterService], 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
71
|
}], ctorParameters: () => [{ type: i1.SkyDatepickerConfigService }], propDecorators: { customDates: [{
|
71
72
|
type: Input
|
72
73
|
}], isDaypickerWaiting: [{
|
@@ -92,4 +93,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
92
93
|
static: true,
|
93
94
|
}]
|
94
95
|
}] } });
|
95
|
-
//# sourceMappingURL=data:application/json;base64,
|
96
|
+
//# 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 { SkyDatepickerAdapterService } from './datepicker-adapter.service';\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  providers: [SkyDatepickerAdapterService],\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]',
|
@@ -475,14 +475,14 @@ export class SkyDatepickerInputDirective {
|
|
475
475
|
}
|
476
476
|
}
|
477
477
|
}
|
478
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.
|
479
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.
|
478
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerInputDirective, deps: [{ token: i1.SkyDatepickerAdapterService }, { token: i0.ChangeDetectorRef }, { token: i2.SkyDatepickerConfigService }, { token: i0.ElementRef }, { token: i3.SkyAppLocaleProvider }, { token: i0.Renderer2 }, { token: i4.SkyDatepickerComponent, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
479
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.1", type: SkyDatepickerInputDirective, selector: "[skyDatepickerInput]", inputs: { dateFormat: "dateFormat", disabled: "disabled", maxDate: "maxDate", minDate: "minDate", skyDatepickerInput: "skyDatepickerInput", skyDatepickerNoValidate: "skyDatepickerNoValidate", startingDay: "startingDay", strict: "strict" }, host: { listeners: { "change": "onInputChange($event)", "blur": "onInputBlur()", "input": "onInput()" } }, providers: [
|
480
480
|
SKY_DATEPICKER_VALUE_ACCESSOR,
|
481
481
|
SKY_DATEPICKER_VALIDATOR,
|
482
482
|
SkyDatepickerAdapterService,
|
483
483
|
], ngImport: i0 }); }
|
484
484
|
}
|
485
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.
|
485
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: SkyDatepickerInputDirective, decorators: [{
|
486
486
|
type: Directive,
|
487
487
|
args: [{
|
488
488
|
selector: '[skyDatepickerInput]',
|