@skyux/datetime 7.0.0-beta.12 → 7.0.0-beta.13
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 +1532 -991
- package/esm2020/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +20 -0
- package/esm2020/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +20 -0
- package/esm2020/lib/modules/date-range-picker/date-range-picker.component.mjs +262 -204
- package/esm2020/lib/modules/date-range-picker/date-range-picker.module.mjs +11 -3
- package/esm2020/lib/modules/date-range-picker/date-range.service.mjs +42 -38
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +1 -1
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +1 -1
- package/esm2020/lib/modules/date-range-picker/types/date-range-calculator.mjs +15 -15
- package/esm2020/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +4 -2
- package/esm2020/lib/modules/date-range-picker/types/date-range.mjs +1 -1
- package/esm2020/lib/modules/datepicker/date-formatter.mjs +2 -2
- package/esm2020/lib/modules/datepicker/datepicker-adapter.service.mjs +7 -14
- package/esm2020/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +43 -20
- package/esm2020/lib/modules/datepicker/datepicker-calendar.component.mjs +28 -35
- package/esm2020/lib/modules/datepicker/datepicker-config.service.mjs +1 -1
- package/esm2020/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +223 -209
- package/esm2020/lib/modules/datepicker/datepicker-input.directive.mjs +212 -220
- package/esm2020/lib/modules/datepicker/datepicker.component.mjs +117 -138
- package/esm2020/lib/modules/datepicker/daypicker-button.component.mjs +3 -3
- package/esm2020/lib/modules/datepicker/daypicker-cell.component.mjs +61 -59
- package/esm2020/lib/modules/datepicker/daypicker.component.mjs +143 -137
- package/esm2020/lib/modules/datepicker/fuzzy-date.service.mjs +123 -132
- package/esm2020/lib/modules/datepicker/monthpicker.component.mjs +51 -49
- package/esm2020/lib/modules/datepicker/yearpicker.component.mjs +52 -50
- package/esm2020/lib/modules/timepicker/timepicker.component.mjs +104 -88
- package/esm2020/lib/modules/timepicker/timepicker.directive.mjs +105 -98
- package/fesm2015/skyux-datetime.mjs +1642 -1516
- package/fesm2015/skyux-datetime.mjs.map +1 -1
- package/fesm2020/skyux-datetime.mjs +1618 -1510
- package/fesm2020/skyux-datetime.mjs.map +1 -1
- package/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.d.ts +8 -0
- package/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.d.ts +8 -0
- package/lib/modules/date-range-picker/date-range-picker.component.d.ts +14 -43
- package/lib/modules/date-range-picker/date-range-picker.module.d.ts +9 -7
- package/lib/modules/date-range-picker/date-range.service.d.ts +1 -5
- package/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.d.ts +1 -1
- package/lib/modules/date-range-picker/types/date-range-calculator-validate-function.d.ts +1 -1
- package/lib/modules/date-range-picker/types/date-range-calculator.d.ts +3 -8
- package/lib/modules/date-range-picker/types/date-range.d.ts +2 -2
- package/lib/modules/datepicker/date-formatter.d.ts +3 -3
- package/lib/modules/datepicker/datepicker-adapter.service.d.ts +1 -5
- package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +18 -19
- package/lib/modules/datepicker/datepicker-calendar.component.d.ts +14 -25
- package/lib/modules/datepicker/datepicker-config.service.d.ts +3 -3
- package/lib/modules/datepicker/datepicker-input-fuzzy.directive.d.ts +17 -53
- package/lib/modules/datepicker/datepicker-input.directive.d.ts +13 -68
- package/lib/modules/datepicker/datepicker.component.d.ts +21 -58
- package/lib/modules/datepicker/daypicker-button.component.d.ts +1 -1
- package/lib/modules/datepicker/daypicker-cell.component.d.ts +3 -10
- package/lib/modules/datepicker/daypicker.component.d.ts +4 -16
- package/lib/modules/datepicker/fuzzy-date.service.d.ts +6 -30
- package/lib/modules/datepicker/monthpicker.component.d.ts +1 -4
- package/lib/modules/datepicker/yearpicker.component.d.ts +1 -3
- package/lib/modules/timepicker/timepicker.component.d.ts +14 -32
- package/lib/modules/timepicker/timepicker.directive.d.ts +9 -27
- package/package.json +8 -8
@@ -1,3 +1,5 @@
|
|
1
|
+
var _SkyDayPickerComponent_instances, _SkyDayPickerComponent_daysInMonth, _SkyDayPickerComponent_initialDate, _SkyDayPickerComponent_ngUnsubscribe, _SkyDayPickerComponent_compareDays, _SkyDayPickerComponent_refreshDayView, _SkyDayPickerComponent_keydownDays, _SkyDayPickerComponent_getDaysInMonth, _SkyDayPickerComponent_applyCustomDates, _SkyDayPickerComponent_dateRangeRowsAreEqual, _SkyDayPickerComponent_getDateRange;
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
1
3
|
import { Component, EventEmitter, Input, Output, } from '@angular/core';
|
2
4
|
import { Subject } from 'rxjs';
|
3
5
|
import { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';
|
@@ -11,39 +13,42 @@ import * as i4 from "./daypicker-cell.component";
|
|
11
13
|
*/
|
12
14
|
export class SkyDayPickerComponent {
|
13
15
|
constructor(datepicker) {
|
16
|
+
_SkyDayPickerComponent_instances.add(this);
|
14
17
|
this.calendarDateRangeChange = new EventEmitter();
|
15
18
|
this.isWaiting = false;
|
16
19
|
this.activeDateHasChanged = false;
|
17
20
|
this.labels = [];
|
21
|
+
this.title = '';
|
18
22
|
this.rows = [];
|
19
23
|
this.weekNumbers = [];
|
20
|
-
this
|
24
|
+
_SkyDayPickerComponent_daysInMonth.set(this, [
|
21
25
|
31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31,
|
22
|
-
];
|
23
|
-
this
|
26
|
+
]);
|
27
|
+
_SkyDayPickerComponent_initialDate.set(this, void 0);
|
28
|
+
_SkyDayPickerComponent_ngUnsubscribe.set(this, new Subject());
|
24
29
|
this.datepicker = datepicker;
|
25
30
|
}
|
26
31
|
set customDates(value) {
|
27
32
|
/* istanbul ignore else */
|
28
33
|
if (value) {
|
29
|
-
this.
|
34
|
+
__classPrivateFieldGet(this, _SkyDayPickerComponent_instances, "m", _SkyDayPickerComponent_applyCustomDates).call(this, value, this.rows);
|
30
35
|
}
|
31
36
|
}
|
32
37
|
ngOnInit() {
|
33
38
|
this.datepicker.stepDay = { months: 1 };
|
34
|
-
this
|
39
|
+
__classPrivateFieldSet(this, _SkyDayPickerComponent_initialDate, this.datepicker.activeDate.getDate(), "f");
|
35
40
|
this.datepicker.setRefreshViewHandler(() => {
|
36
|
-
this.
|
41
|
+
__classPrivateFieldGet(this, _SkyDayPickerComponent_instances, "m", _SkyDayPickerComponent_refreshDayView).call(this);
|
37
42
|
}, 'day');
|
38
|
-
this.datepicker.setCompareHandler(this
|
43
|
+
this.datepicker.setCompareHandler(__classPrivateFieldGet(this, _SkyDayPickerComponent_instances, "m", _SkyDayPickerComponent_compareDays), 'day');
|
39
44
|
this.datepicker.setKeydownHandler((key, event) => {
|
40
|
-
this.
|
45
|
+
__classPrivateFieldGet(this, _SkyDayPickerComponent_instances, "m", _SkyDayPickerComponent_keydownDays).call(this, key, event);
|
41
46
|
}, 'day');
|
42
47
|
this.datepicker.refreshView();
|
43
48
|
}
|
44
49
|
ngOnDestroy() {
|
45
|
-
this.
|
46
|
-
this.
|
50
|
+
__classPrivateFieldGet(this, _SkyDayPickerComponent_ngUnsubscribe, "f").next();
|
51
|
+
__classPrivateFieldGet(this, _SkyDayPickerComponent_ngUnsubscribe, "f").complete();
|
47
52
|
}
|
48
53
|
getDates(startDate, n) {
|
49
54
|
const dates = new Array(n);
|
@@ -58,144 +63,145 @@ export class SkyDayPickerComponent {
|
|
58
63
|
}
|
59
64
|
return dates;
|
60
65
|
}
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
66
|
+
}
|
67
|
+
_SkyDayPickerComponent_daysInMonth = new WeakMap(), _SkyDayPickerComponent_initialDate = new WeakMap(), _SkyDayPickerComponent_ngUnsubscribe = new WeakMap(), _SkyDayPickerComponent_instances = new WeakSet(), _SkyDayPickerComponent_compareDays = function _SkyDayPickerComponent_compareDays(date1, date2) {
|
68
|
+
const d1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate());
|
69
|
+
const d2 = new Date(date2.getFullYear(), date2.getMonth(), date2.getDate());
|
70
|
+
return d1.getTime() - d2.getTime();
|
71
|
+
}, _SkyDayPickerComponent_refreshDayView = function _SkyDayPickerComponent_refreshDayView() {
|
72
|
+
const year = this.datepicker.activeDate.getFullYear();
|
73
|
+
const month = this.datepicker.activeDate.getMonth();
|
74
|
+
const firstDayOfMonth = new Date(year, month, 1);
|
75
|
+
const difference = this.datepicker.startingDay - firstDayOfMonth.getDay();
|
76
|
+
const numDisplayedFromPreviousMonth = difference > 0 ? 7 - difference : -difference;
|
77
|
+
const firstDate = new Date(firstDayOfMonth.getTime());
|
78
|
+
if (this.datepicker.activeDate.getDate() !== __classPrivateFieldGet(this, _SkyDayPickerComponent_initialDate, "f")) {
|
79
|
+
this.activeDateHasChanged = true;
|
80
|
+
}
|
81
|
+
/* istanbul ignore else */
|
82
|
+
/* sanity check */
|
83
|
+
if (numDisplayedFromPreviousMonth > 0) {
|
84
|
+
firstDate.setDate(-numDisplayedFromPreviousMonth + 1);
|
85
|
+
}
|
86
|
+
// 42 is the number of days on a six-week calendar
|
87
|
+
const days = this.getDates(firstDate, 42);
|
88
|
+
const pickerDates = [];
|
89
|
+
for (let i = 0; i < 42; i++) {
|
90
|
+
const _dateObject = this.datepicker.createDateObject(days[i], this.datepicker.formatDay, days[i].getMonth() !== month, this.datepicker.datepickerId + '-' + i);
|
91
|
+
pickerDates[i] = _dateObject;
|
92
|
+
}
|
93
|
+
this.labels = [];
|
94
|
+
for (let j = 0; j < 7; j++) {
|
95
|
+
this.labels[j] = {};
|
96
|
+
this.labels[j].abbr = this.datepicker.dateFilter(pickerDates[j].date, this.datepicker.formatDayHeader);
|
97
|
+
this.labels[j].full = this.datepicker.dateFilter(pickerDates[j].date, 'EEEE');
|
98
|
+
}
|
99
|
+
this.title = this.datepicker.dateFilter(this.datepicker.activeDate, this.datepicker.formatDayTitle);
|
100
|
+
const oldDateRange = __classPrivateFieldGet(this, _SkyDayPickerComponent_instances, "m", _SkyDayPickerComponent_getDateRange).call(this, this.rows);
|
101
|
+
this.rows = this.datepicker.createCalendarRows(pickerDates, 7);
|
102
|
+
const newDateRange = __classPrivateFieldGet(this, _SkyDayPickerComponent_instances, "m", _SkyDayPickerComponent_getDateRange).call(this, this.rows);
|
103
|
+
if (!__classPrivateFieldGet(this, _SkyDayPickerComponent_instances, "m", _SkyDayPickerComponent_dateRangeRowsAreEqual).call(this, oldDateRange, newDateRange)) {
|
104
|
+
// Safety check
|
76
105
|
/* istanbul ignore else */
|
77
|
-
|
78
|
-
if (numDisplayedFromPreviousMonth > 0) {
|
79
|
-
firstDate.setDate(-numDisplayedFromPreviousMonth + 1);
|
80
|
-
}
|
81
|
-
// 42 is the number of days on a six-week calendar
|
82
|
-
const days = this.getDates(firstDate, 42);
|
83
|
-
const pickerDates = [];
|
84
|
-
for (let i = 0; i < 42; i++) {
|
85
|
-
const _dateObject = this.datepicker.createDateObject(days[i], this.datepicker.formatDay, days[i].getMonth() !== month, this.datepicker.datepickerId + '-' + i);
|
86
|
-
pickerDates[i] = _dateObject;
|
87
|
-
}
|
88
|
-
this.labels = [];
|
89
|
-
for (let j = 0; j < 7; j++) {
|
90
|
-
this.labels[j] = {};
|
91
|
-
this.labels[j].abbr = this.datepicker.dateFilter(pickerDates[j].date, this.datepicker.formatDayHeader);
|
92
|
-
this.labels[j].full = this.datepicker.dateFilter(pickerDates[j].date, 'EEEE');
|
93
|
-
}
|
94
|
-
this.title = this.datepicker.dateFilter(this.datepicker.activeDate, this.datepicker.formatDayTitle);
|
95
|
-
const oldDateRange = this.getDateRange(this.rows);
|
96
|
-
this.rows = this.datepicker.createCalendarRows(pickerDates, 7);
|
97
|
-
const newDateRange = this.getDateRange(this.rows);
|
98
|
-
if (!this.dateRangeRowsAreEqual(oldDateRange, newDateRange)) {
|
106
|
+
if (newDateRange) {
|
99
107
|
this.calendarDateRangeChange.next({
|
100
108
|
startDate: newDateRange.startDate,
|
101
109
|
endDate: newDateRange.endDate,
|
102
110
|
});
|
103
111
|
}
|
104
|
-
|
105
|
-
|
106
|
-
let date = this.datepicker.activeDate.getDate();
|
107
|
-
/* istanbul ignore else */
|
108
|
-
/* sanity check */
|
109
|
-
if (key === 'left') {
|
110
|
-
date = date - 1;
|
111
|
-
}
|
112
|
-
else if (key === 'up') {
|
113
|
-
date = date - 7;
|
114
|
-
}
|
115
|
-
else if (key === 'right') {
|
116
|
-
date = date + 1;
|
117
|
-
}
|
118
|
-
else if (key === 'down') {
|
119
|
-
date = date + 7;
|
120
|
-
}
|
121
|
-
else if (key === 'pageup' || key === 'pagedown') {
|
122
|
-
const month = this.datepicker.activeDate.getMonth() + (key === 'pageup' ? -1 : 1);
|
123
|
-
this.datepicker.activeDate.setMonth(month, 1);
|
124
|
-
date = Math.min(this.getDaysInMonth(this.datepicker.activeDate.getFullYear(), this.datepicker.activeDate.getMonth()), date);
|
125
|
-
}
|
126
|
-
else if (key === 'home') {
|
127
|
-
date = 1;
|
128
|
-
}
|
129
|
-
else if (key === 'end') {
|
130
|
-
date = this.getDaysInMonth(this.datepicker.activeDate.getFullYear(), this.datepicker.activeDate.getMonth());
|
112
|
+
else {
|
113
|
+
this.calendarDateRangeChange.next(undefined);
|
131
114
|
}
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
115
|
+
}
|
116
|
+
}, _SkyDayPickerComponent_keydownDays = function _SkyDayPickerComponent_keydownDays(key, event) {
|
117
|
+
let date = this.datepicker.activeDate.getDate();
|
118
|
+
/* istanbul ignore else */
|
119
|
+
/* sanity check */
|
120
|
+
if (key === 'left') {
|
121
|
+
date = date - 1;
|
122
|
+
}
|
123
|
+
else if (key === 'up') {
|
124
|
+
date = date - 7;
|
125
|
+
}
|
126
|
+
else if (key === 'right') {
|
127
|
+
date = date + 1;
|
128
|
+
}
|
129
|
+
else if (key === 'down') {
|
130
|
+
date = date + 7;
|
131
|
+
}
|
132
|
+
else if (key === 'pageup' || key === 'pagedown') {
|
133
|
+
const month = this.datepicker.activeDate.getMonth() + (key === 'pageup' ? -1 : 1);
|
134
|
+
this.datepicker.activeDate.setMonth(month, 1);
|
135
|
+
date = Math.min(__classPrivateFieldGet(this, _SkyDayPickerComponent_instances, "m", _SkyDayPickerComponent_getDaysInMonth).call(this, this.datepicker.activeDate.getFullYear(), this.datepicker.activeDate.getMonth()), date);
|
136
|
+
}
|
137
|
+
else if (key === 'home') {
|
138
|
+
date = 1;
|
139
|
+
}
|
140
|
+
else if (key === 'end') {
|
141
|
+
date = __classPrivateFieldGet(this, _SkyDayPickerComponent_instances, "m", _SkyDayPickerComponent_getDaysInMonth).call(this, this.datepicker.activeDate.getFullYear(), this.datepicker.activeDate.getMonth());
|
142
|
+
}
|
143
|
+
this.datepicker.activeDate.setDate(date);
|
144
|
+
}, _SkyDayPickerComponent_getDaysInMonth = function _SkyDayPickerComponent_getDaysInMonth(year, month) {
|
145
|
+
return month === 1 &&
|
146
|
+
year % 4 === 0 &&
|
147
|
+
(year % 400 === 0 || year % 100 !== 0)
|
148
|
+
? 29
|
149
|
+
: __classPrivateFieldGet(this, _SkyDayPickerComponent_daysInMonth, "f")[month];
|
150
|
+
}, _SkyDayPickerComponent_applyCustomDates = function _SkyDayPickerComponent_applyCustomDates(customDates, dateRows) {
|
151
|
+
let date;
|
152
|
+
let newDate;
|
153
|
+
let dateIndex;
|
154
|
+
/* istanbul ignore else */
|
155
|
+
if (customDates && dateRows) {
|
156
|
+
customDates.forEach((customDate) => {
|
157
|
+
dateIndex = -1;
|
158
|
+
dateRows.forEach((row) => {
|
159
|
+
if (dateIndex === -1) {
|
160
|
+
dateIndex = row.findIndex((d) => {
|
161
|
+
return d.date.getTime() === customDate.date.getTime();
|
162
|
+
});
|
163
|
+
if (dateIndex > -1) {
|
164
|
+
date = row[dateIndex];
|
165
|
+
// Replace the date with a new instance so the display gets updated.
|
166
|
+
newDate = {
|
167
|
+
current: date.current,
|
168
|
+
date: date.date,
|
169
|
+
disabled: !!date.disabled || !!customDate.disabled,
|
170
|
+
keyDate: !!customDate.keyDate || !!date.keyDate,
|
171
|
+
keyDateText: customDate.keyDateText || date.keyDateText,
|
172
|
+
label: date.label,
|
173
|
+
secondary: date.secondary,
|
174
|
+
selected: date.selected,
|
175
|
+
uid: date.uid,
|
176
|
+
};
|
177
|
+
row[dateIndex] = newDate;
|
173
178
|
}
|
174
|
-
}
|
179
|
+
}
|
175
180
|
});
|
176
|
-
}
|
181
|
+
});
|
177
182
|
}
|
178
|
-
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
}
|
183
|
-
else if ((rangeA && !rangeB) || (!rangeA && rangeB)) {
|
184
|
-
return false;
|
185
|
-
}
|
186
|
-
return (this.compareDays(rangeA.startDate, rangeB.startDate) === 0 &&
|
187
|
-
this.compareDays(rangeA.endDate, rangeB.endDate) === 0);
|
183
|
+
}, _SkyDayPickerComponent_dateRangeRowsAreEqual = function _SkyDayPickerComponent_dateRangeRowsAreEqual(rangeA, rangeB) {
|
184
|
+
/* istanbul ignore if */
|
185
|
+
if (!rangeA && !rangeB) {
|
186
|
+
return true;
|
188
187
|
}
|
189
|
-
|
190
|
-
|
191
|
-
|
192
|
-
return {
|
193
|
-
startDate: rows[0][0].date,
|
194
|
-
endDate: rows[rows.length - 1][rows[rows.length - 1].length - 1].date,
|
195
|
-
};
|
196
|
-
}
|
188
|
+
else if (rangeA && rangeB) {
|
189
|
+
return (__classPrivateFieldGet(this, _SkyDayPickerComponent_instances, "m", _SkyDayPickerComponent_compareDays).call(this, rangeA.startDate, rangeB.startDate) === 0 &&
|
190
|
+
__classPrivateFieldGet(this, _SkyDayPickerComponent_instances, "m", _SkyDayPickerComponent_compareDays).call(this, rangeA.endDate, rangeB.endDate) === 0);
|
197
191
|
}
|
198
|
-
|
192
|
+
else {
|
193
|
+
return false;
|
194
|
+
}
|
195
|
+
}, _SkyDayPickerComponent_getDateRange = function _SkyDayPickerComponent_getDateRange(rows) {
|
196
|
+
/* istanbul ignore else */
|
197
|
+
if (rows && rows.length > 0) {
|
198
|
+
return {
|
199
|
+
startDate: rows[0][0].date,
|
200
|
+
endDate: rows[rows.length - 1][rows[rows.length - 1].length - 1].date,
|
201
|
+
};
|
202
|
+
}
|
203
|
+
return undefined;
|
204
|
+
};
|
199
205
|
SkyDayPickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDayPickerComponent, deps: [{ token: i1.SkyDatepickerCalendarInnerComponent }], target: i0.ɵɵFactoryTarget.Component });
|
200
206
|
SkyDayPickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyDayPickerComponent, selector: "sky-daypicker", inputs: { customDates: "customDates", isWaiting: "isWaiting" }, outputs: { calendarDateRangeChange: "calendarDateRangeChange" }, ngImport: i0, template: "<div *ngIf=\"datepicker.datepickerMode === 'day'\" class=\"sky-daypicker-wrapper\">\n <table\n class=\"sky-daypicker-table\"\n role=\"grid\"\n [attr.aria-labelledby]=\"datepicker.datepickerId + '-title'\"\n >\n <thead>\n <tr>\n <th class=\"sky-datepicker-header-left\" scope=\"col\">\n <button\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-previous\"\n (click)=\"datepicker.moveCalendar($event, -1)\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n >\n <sky-icon\n class=\"sky-datepicker-chevron-default\"\n icon=\"chevron-left\"\n ></sky-icon>\n <sky-icon\n class=\"sky-datepicker-chevron-modern\"\n icon=\"chevron-left\"\n iconType=\"skyux\"\n ></sky-icon>\n </button>\n </th>\n <th scope=\"col\" [attr.colspan]=\"5\">\n <button\n [id]=\"datepicker.datepickerId + '-title'\"\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-calendar-title\"\n (click)=\"datepicker.toggleModeCalendar($event)\"\n [disabled]=\"datepicker.datepickerMode === datepicker.maxMode\"\n [ngClass]=\"{\n 'sky-btn-disabled':\n datepicker.datepickerMode === datepicker.maxMode\n }\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n >\n <strong>{{ title }}</strong>\n </button>\n </th>\n <th class=\"sky-datepicker-header-right\" scope=\"col\">\n <button\n type=\"button\"\n class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-next\"\n (click)=\"datepicker.moveCalendar($event, 1)\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n >\n <sky-icon\n class=\"sky-datepicker-chevron-default\"\n icon=\"chevron-right\"\n ></sky-icon>\n <sky-icon\n class=\"sky-datepicker-chevron-modern\"\n icon=\"chevron-right\"\n iconType=\"skyux\"\n ></sky-icon>\n </button>\n </th>\n </tr>\n <tr>\n <th\n scope=\"col\"\n *ngFor=\"let label of labels\"\n class=\"sky-datepicker-center sky-datepicker-weekdays\"\n >\n <small [attr.aria-label]=\"label.full\">\n <b>{{ label.abbr }}</b>\n </small>\n </th>\n </tr>\n </thead>\n <tbody>\n <!-- Wait indicator for async custom date stream -->\n <sky-wait [isWaiting]=\"isWaiting\"> </sky-wait>\n <ng-template ngFor [ngForOf]=\"rows\" let-row=\"$implicit\" let-index=\"index\">\n <tr role=\"row\">\n <td\n *ngFor=\"let date of row\"\n class=\"sky-datepicker-center\"\n role=\"gridcell\"\n [id]=\"date.uid\"\n >\n <sky-daypicker-cell\n [activeDateHasChanged]=\"activeDateHasChanged\"\n [date]=\"date\"\n >\n </sky-daypicker-cell>\n </td>\n </tr>\n </ng-template>\n </tbody>\n </table>\n</div>\n", styles: [":host-context(.sky-theme-modern) :host:focus{outline:none}.sky-theme-modern :host:focus{outline:none}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "component", type: i3.λ14, selector: "sky-wait", inputs: ["ariaLabel", "isWaiting", "isFullPage", "isNonBlocking"] }, { kind: "component", type: i4.SkyDayPickerCellComponent, selector: "sky-daypicker-cell", inputs: ["activeDateHasChanged", "date"] }] });
|
201
207
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyDayPickerComponent, decorators: [{
|
@@ -208,4 +214,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
208
214
|
}], isWaiting: [{
|
209
215
|
type: Input
|
210
216
|
}] } });
|
211
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daypicker.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/daypicker.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/daypicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\n\nimport { SkyDatepickerCalendarChange } from './datepicker-calendar-change';\nimport { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';\nimport { SkyDatepickerCustomDate } from './datepicker-custom-date';\nimport { SkyDatepickerDate } from './datepicker-date';\n\n/**\n * Helper interface to compare date ranges.\n * @internal\n */\ninterface SkyDateRange {\n  endDate: Date;\n\n  startDate: Date;\n}\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-daypicker',\n  templateUrl: 'daypicker.component.html',\n  styleUrls: ['./daypicker.component.scss'],\n})\nexport class SkyDayPickerComponent implements OnDestroy, OnInit {\n  @Input()\n  public set customDates(value: SkyDatepickerCustomDate[]) {\n    /* istanbul ignore else */\n    if (value) {\n      this.applyCustomDates(value, this.rows);\n    }\n  }\n\n  @Output()\n  public calendarDateRangeChange: EventEmitter<SkyDatepickerCalendarChange> = new EventEmitter<SkyDatepickerCalendarChange>();\n\n  @Input()\n  public isWaiting = false;\n\n  public activeDateHasChanged = false;\n  public labels: any[] = [];\n  public title: string;\n  public rows: Array<Array<SkyDatepickerDate>> = [];\n  public weekNumbers: number[] = [];\n  public datepicker: SkyDatepickerCalendarInnerComponent;\n  public CURRENT_THEME_TEMPLATE: any;\n\n  private daysInMonth: Array<number> = [\n    31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31,\n  ];\n  private initialDate: number;\n  private ngUnsubscribe = new Subject<void>();\n\n  public constructor(datepicker: SkyDatepickerCalendarInnerComponent) {\n    this.datepicker = datepicker;\n  }\n\n  public ngOnInit(): void {\n    this.datepicker.stepDay = { months: 1 };\n    this.initialDate = this.datepicker.activeDate.getDate();\n\n    this.datepicker.setRefreshViewHandler(() => {\n      this.refreshDayView();\n    }, 'day');\n\n    this.datepicker.setCompareHandler(this.compareDays, 'day');\n\n    this.datepicker.setKeydownHandler((key: string, event: KeyboardEvent) => {\n      this.keydownDays(key, event);\n    }, 'day');\n\n    this.datepicker.refreshView();\n  }\n\n  public ngOnDestroy(): void {\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n  }\n\n  protected getDates(startDate: Date, n: number): Date[] {\n    const dates: Date[] = new Array(n);\n    let current = new Date(startDate.getTime());\n    let i = 0;\n    let date: Date;\n    while (i < n) {\n      date = new Date(current.getTime());\n      date = this.datepicker.fixTimeZone(date);\n      dates[i++] = date;\n      current = new Date(\n        current.getFullYear(),\n        current.getMonth(),\n        current.getDate() + 1\n      );\n    }\n    return dates;\n  }\n\n  private compareDays(date1: Date, date2: Date): number {\n    const d1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate());\n    const d2 = new Date(date2.getFullYear(), date2.getMonth(), date2.getDate());\n    return d1.getTime() - d2.getTime();\n  }\n\n  private refreshDayView() {\n    const year = this.datepicker.activeDate.getFullYear();\n    const month = this.datepicker.activeDate.getMonth();\n    const firstDayOfMonth = new Date(year, month, 1);\n    const difference = this.datepicker.startingDay - firstDayOfMonth.getDay();\n    const numDisplayedFromPreviousMonth =\n      difference > 0 ? 7 - difference : -difference;\n    const firstDate = new Date(firstDayOfMonth.getTime());\n\n    if (this.datepicker.activeDate.getDate() !== this.initialDate) {\n      this.activeDateHasChanged = true;\n    }\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (numDisplayedFromPreviousMonth > 0) {\n      firstDate.setDate(-numDisplayedFromPreviousMonth + 1);\n    }\n\n    // 42 is the number of days on a six-week calendar\n    const days: Date[] = this.getDates(firstDate, 42);\n    const pickerDates: Array<SkyDatepickerDate> = [];\n    for (let i = 0; i < 42; i++) {\n      const _dateObject = this.datepicker.createDateObject(\n        days[i],\n        this.datepicker.formatDay,\n        days[i].getMonth() !== month,\n        this.datepicker.datepickerId + '-' + i\n      );\n      pickerDates[i] = _dateObject;\n    }\n\n    this.labels = [];\n    for (let j = 0; j < 7; j++) {\n      this.labels[j] = {};\n      this.labels[j].abbr = this.datepicker.dateFilter(\n        pickerDates[j].date,\n        this.datepicker.formatDayHeader\n      );\n      this.labels[j].full = this.datepicker.dateFilter(\n        pickerDates[j].date,\n        'EEEE'\n      );\n    }\n\n    this.title = this.datepicker.dateFilter(\n      this.datepicker.activeDate,\n      this.datepicker.formatDayTitle\n    );\n\n    const oldDateRange = this.getDateRange(this.rows);\n    this.rows = this.datepicker.createCalendarRows(pickerDates, 7);\n    const newDateRange = this.getDateRange(this.rows);\n\n    if (!this.dateRangeRowsAreEqual(oldDateRange, newDateRange)) {\n      this.calendarDateRangeChange.next({\n        startDate: newDateRange.startDate,\n        endDate: newDateRange.endDate,\n      });\n    }\n  }\n\n  private keydownDays(key: string, event: KeyboardEvent) {\n    let date = this.datepicker.activeDate.getDate();\n    /* istanbul ignore else */\n    /* sanity check */\n    if (key === 'left') {\n      date = date - 1;\n    } else if (key === 'up') {\n      date = date - 7;\n    } else if (key === 'right') {\n      date = date + 1;\n    } else if (key === 'down') {\n      date = date + 7;\n    } else if (key === 'pageup' || key === 'pagedown') {\n      const month =\n        this.datepicker.activeDate.getMonth() + (key === 'pageup' ? -1 : 1);\n      this.datepicker.activeDate.setMonth(month, 1);\n      date = Math.min(\n        this.getDaysInMonth(\n          this.datepicker.activeDate.getFullYear(),\n          this.datepicker.activeDate.getMonth()\n        ),\n        date\n      );\n    } else if (key === 'home') {\n      date = 1;\n    } else if (key === 'end') {\n      date = this.getDaysInMonth(\n        this.datepicker.activeDate.getFullYear(),\n        this.datepicker.activeDate.getMonth()\n      );\n    }\n    this.datepicker.activeDate.setDate(date);\n  }\n\n  private getDaysInMonth(year: number, month: number) {\n    return month === 1 &&\n      year % 4 === 0 &&\n      (year % 400 === 0 || year % 100 !== 0)\n      ? 29\n      : this.daysInMonth[month];\n  }\n\n  /**\n   * Applies custom date properties to the existing dates displayed in the calendar.\n   */\n  private applyCustomDates(\n    customDates: SkyDatepickerCustomDate[],\n    dateRows: SkyDatepickerDate[][]\n  ): void {\n    let date: SkyDatepickerDate;\n    let newDate: SkyDatepickerDate;\n    let dateIndex: number;\n\n    /* istanbul ignore else */\n    if (customDates && dateRows) {\n      customDates.forEach((customDate) => {\n        dateIndex = -1;\n        dateRows.forEach((row) => {\n          if (dateIndex === -1) {\n            dateIndex = row.findIndex((d) => {\n              return d.date.getTime() === customDate.date.getTime();\n            });\n            if (dateIndex > -1) {\n              date = row[dateIndex];\n              // Replace the date with a new instance so the display gets updated.\n              newDate = {\n                current: date.current,\n                date: date.date,\n                disabled: !!date.disabled || !!customDate.disabled,\n                keyDate: !!customDate.keyDate || !!date.keyDate,\n                keyDateText: customDate.keyDateText || date.keyDateText,\n                label: date.label,\n                secondary: date.secondary,\n                selected: date.selected,\n                uid: date.uid,\n              };\n              row[dateIndex] = newDate;\n            }\n          }\n        });\n      });\n    }\n  }\n\n  private dateRangeRowsAreEqual(\n    rangeA: SkyDateRange,\n    rangeB: SkyDateRange\n  ): boolean | undefined {\n    /* istanbul ignore if */\n    if (!rangeA && !rangeB) {\n      return true;\n    } else if ((rangeA && !rangeB) || (!rangeA && rangeB)) {\n      return false;\n    }\n\n    return (\n      this.compareDays(rangeA.startDate, rangeB.startDate) === 0 &&\n      this.compareDays(rangeA.endDate, rangeB.endDate) === 0\n    );\n  }\n\n  private getDateRange(\n    rows: Array<Array<SkyDatepickerDate>>\n  ): SkyDateRange | undefined {\n    /* istanbul ignore else */\n    if (rows && rows.length > 0) {\n      return {\n        startDate: rows[0][0].date,\n        endDate: rows[rows.length - 1][rows[rows.length - 1].length - 1].date,\n      };\n    }\n  }\n}\n","<div *ngIf=\"datepicker.datepickerMode === 'day'\" class=\"sky-daypicker-wrapper\">\n  <table\n    class=\"sky-daypicker-table\"\n    role=\"grid\"\n    [attr.aria-labelledby]=\"datepicker.datepickerId + '-title'\"\n  >\n    <thead>\n      <tr>\n        <th class=\"sky-datepicker-header-left\" scope=\"col\">\n          <button\n            type=\"button\"\n            class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-previous\"\n            (click)=\"datepicker.moveCalendar($event, -1)\"\n            tabindex=\"-1\"\n            aria-hidden=\"true\"\n          >\n            <sky-icon\n              class=\"sky-datepicker-chevron-default\"\n              icon=\"chevron-left\"\n            ></sky-icon>\n            <sky-icon\n              class=\"sky-datepicker-chevron-modern\"\n              icon=\"chevron-left\"\n              iconType=\"skyux\"\n            ></sky-icon>\n          </button>\n        </th>\n        <th scope=\"col\" [attr.colspan]=\"5\">\n          <button\n            [id]=\"datepicker.datepickerId + '-title'\"\n            type=\"button\"\n            class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-calendar-title\"\n            (click)=\"datepicker.toggleModeCalendar($event)\"\n            [disabled]=\"datepicker.datepickerMode === datepicker.maxMode\"\n            [ngClass]=\"{\n              'sky-btn-disabled':\n                datepicker.datepickerMode === datepicker.maxMode\n            }\"\n            tabindex=\"-1\"\n            aria-hidden=\"true\"\n          >\n            <strong>{{ title }}</strong>\n          </button>\n        </th>\n        <th class=\"sky-datepicker-header-right\" scope=\"col\">\n          <button\n            type=\"button\"\n            class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-next\"\n            (click)=\"datepicker.moveCalendar($event, 1)\"\n            tabindex=\"-1\"\n            aria-hidden=\"true\"\n          >\n            <sky-icon\n              class=\"sky-datepicker-chevron-default\"\n              icon=\"chevron-right\"\n            ></sky-icon>\n            <sky-icon\n              class=\"sky-datepicker-chevron-modern\"\n              icon=\"chevron-right\"\n              iconType=\"skyux\"\n            ></sky-icon>\n          </button>\n        </th>\n      </tr>\n      <tr>\n        <th\n          scope=\"col\"\n          *ngFor=\"let label of labels\"\n          class=\"sky-datepicker-center sky-datepicker-weekdays\"\n        >\n          <small [attr.aria-label]=\"label.full\">\n            <b>{{ label.abbr }}</b>\n          </small>\n        </th>\n      </tr>\n    </thead>\n    <tbody>\n      <!-- Wait indicator for async custom date stream -->\n      <sky-wait [isWaiting]=\"isWaiting\"> </sky-wait>\n      <ng-template ngFor [ngForOf]=\"rows\" let-row=\"$implicit\" let-index=\"index\">\n        <tr role=\"row\">\n          <td\n            *ngFor=\"let date of row\"\n            class=\"sky-datepicker-center\"\n            role=\"gridcell\"\n            [id]=\"date.uid\"\n          >\n            <sky-daypicker-cell\n              [activeDateHasChanged]=\"activeDateHasChanged\"\n              [date]=\"date\"\n            >\n            </sky-daypicker-cell>\n          </td>\n        </tr>\n      </ng-template>\n    </tbody>\n  </table>\n</div>\n"]}
|
217
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daypicker.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/daypicker.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/daypicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\n\nimport { SkyDatepickerCalendarChange } from './datepicker-calendar-change';\nimport { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';\nimport { SkyDatepickerCustomDate } from './datepicker-custom-date';\nimport { SkyDatepickerDate } from './datepicker-date';\n\n/**\n * Helper interface to compare date ranges.\n * @internal\n */\ninterface SkyDateRange {\n  endDate: Date;\n\n  startDate: Date;\n}\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-daypicker',\n  templateUrl: 'daypicker.component.html',\n  styleUrls: ['./daypicker.component.scss'],\n})\nexport class SkyDayPickerComponent implements OnDestroy, OnInit {\n  @Input()\n  public set customDates(value: SkyDatepickerCustomDate[] | undefined) {\n    /* istanbul ignore else */\n    if (value) {\n      this.#applyCustomDates(value, this.rows);\n    }\n  }\n\n  @Output()\n  public calendarDateRangeChange = new EventEmitter<\n    SkyDatepickerCalendarChange | undefined\n  >();\n\n  @Input()\n  public isWaiting: boolean | undefined = false;\n\n  public activeDateHasChanged = false;\n  public labels: any[] = [];\n  public title = '';\n  public rows: Array<Array<SkyDatepickerDate>> = [];\n  public weekNumbers: number[] = [];\n  public datepicker: SkyDatepickerCalendarInnerComponent;\n  public CURRENT_THEME_TEMPLATE: any;\n\n  #daysInMonth: Array<number> = [\n    31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31,\n  ];\n  #initialDate: number | undefined;\n  #ngUnsubscribe = new Subject<void>();\n\n  public constructor(datepicker: SkyDatepickerCalendarInnerComponent) {\n    this.datepicker = datepicker;\n  }\n\n  public ngOnInit(): void {\n    this.datepicker.stepDay = { months: 1 };\n    this.#initialDate = this.datepicker.activeDate.getDate();\n\n    this.datepicker.setRefreshViewHandler(() => {\n      this.#refreshDayView();\n    }, 'day');\n\n    this.datepicker.setCompareHandler(this.#compareDays, 'day');\n\n    this.datepicker.setKeydownHandler((key: string, event: KeyboardEvent) => {\n      this.#keydownDays(key, event);\n    }, 'day');\n\n    this.datepicker.refreshView();\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  protected getDates(startDate: Date, n: number): Date[] {\n    const dates: Date[] = new Array(n);\n    let current = new Date(startDate.getTime());\n    let i = 0;\n    let date: Date;\n    while (i < n) {\n      date = new Date(current.getTime());\n      date = this.datepicker.fixTimeZone(date);\n      dates[i++] = date;\n      current = new Date(\n        current.getFullYear(),\n        current.getMonth(),\n        current.getDate() + 1\n      );\n    }\n    return dates;\n  }\n\n  #compareDays(date1: Date, date2: Date): number {\n    const d1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate());\n    const d2 = new Date(date2.getFullYear(), date2.getMonth(), date2.getDate());\n    return d1.getTime() - d2.getTime();\n  }\n\n  #refreshDayView() {\n    const year = this.datepicker.activeDate.getFullYear();\n    const month = this.datepicker.activeDate.getMonth();\n    const firstDayOfMonth = new Date(year, month, 1);\n    const difference = this.datepicker.startingDay - firstDayOfMonth.getDay();\n    const numDisplayedFromPreviousMonth =\n      difference > 0 ? 7 - difference : -difference;\n    const firstDate = new Date(firstDayOfMonth.getTime());\n\n    if (this.datepicker.activeDate.getDate() !== this.#initialDate) {\n      this.activeDateHasChanged = true;\n    }\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (numDisplayedFromPreviousMonth > 0) {\n      firstDate.setDate(-numDisplayedFromPreviousMonth + 1);\n    }\n\n    // 42 is the number of days on a six-week calendar\n    const days: Date[] = this.getDates(firstDate, 42);\n    const pickerDates: Array<SkyDatepickerDate> = [];\n    for (let i = 0; i < 42; i++) {\n      const _dateObject = this.datepicker.createDateObject(\n        days[i],\n        this.datepicker.formatDay,\n        days[i].getMonth() !== month,\n        this.datepicker.datepickerId + '-' + i\n      );\n      pickerDates[i] = _dateObject;\n    }\n\n    this.labels = [];\n    for (let j = 0; j < 7; j++) {\n      this.labels[j] = {};\n      this.labels[j].abbr = this.datepicker.dateFilter(\n        pickerDates[j].date,\n        this.datepicker.formatDayHeader\n      );\n      this.labels[j].full = this.datepicker.dateFilter(\n        pickerDates[j].date,\n        'EEEE'\n      );\n    }\n\n    this.title = this.datepicker.dateFilter(\n      this.datepicker.activeDate,\n      this.datepicker.formatDayTitle\n    );\n\n    const oldDateRange = this.#getDateRange(this.rows);\n    this.rows = this.datepicker.createCalendarRows(pickerDates, 7);\n    const newDateRange = this.#getDateRange(this.rows);\n\n    if (!this.#dateRangeRowsAreEqual(oldDateRange, newDateRange)) {\n      // Safety check\n      /* istanbul ignore else */\n      if (newDateRange) {\n        this.calendarDateRangeChange.next({\n          startDate: newDateRange.startDate,\n          endDate: newDateRange.endDate,\n        });\n      } else {\n        this.calendarDateRangeChange.next(undefined);\n      }\n    }\n  }\n\n  #keydownDays(key: string, event: KeyboardEvent) {\n    let date = this.datepicker.activeDate.getDate();\n    /* istanbul ignore else */\n    /* sanity check */\n    if (key === 'left') {\n      date = date - 1;\n    } else if (key === 'up') {\n      date = date - 7;\n    } else if (key === 'right') {\n      date = date + 1;\n    } else if (key === 'down') {\n      date = date + 7;\n    } else if (key === 'pageup' || key === 'pagedown') {\n      const month =\n        this.datepicker.activeDate.getMonth() + (key === 'pageup' ? -1 : 1);\n      this.datepicker.activeDate.setMonth(month, 1);\n      date = Math.min(\n        this.#getDaysInMonth(\n          this.datepicker.activeDate.getFullYear(),\n          this.datepicker.activeDate.getMonth()\n        ),\n        date\n      );\n    } else if (key === 'home') {\n      date = 1;\n    } else if (key === 'end') {\n      date = this.#getDaysInMonth(\n        this.datepicker.activeDate.getFullYear(),\n        this.datepicker.activeDate.getMonth()\n      );\n    }\n    this.datepicker.activeDate.setDate(date);\n  }\n\n  #getDaysInMonth(year: number, month: number) {\n    return month === 1 &&\n      year % 4 === 0 &&\n      (year % 400 === 0 || year % 100 !== 0)\n      ? 29\n      : this.#daysInMonth[month];\n  }\n\n  /**\n   * Applies custom date properties to the existing dates displayed in the calendar.\n   */\n  #applyCustomDates(\n    customDates: SkyDatepickerCustomDate[],\n    dateRows: SkyDatepickerDate[][]\n  ): void {\n    let date: SkyDatepickerDate;\n    let newDate: SkyDatepickerDate;\n    let dateIndex: number;\n\n    /* istanbul ignore else */\n    if (customDates && dateRows) {\n      customDates.forEach((customDate) => {\n        dateIndex = -1;\n        dateRows.forEach((row) => {\n          if (dateIndex === -1) {\n            dateIndex = row.findIndex((d) => {\n              return d.date.getTime() === customDate.date.getTime();\n            });\n            if (dateIndex > -1) {\n              date = row[dateIndex];\n              // Replace the date with a new instance so the display gets updated.\n              newDate = {\n                current: date.current,\n                date: date.date,\n                disabled: !!date.disabled || !!customDate.disabled,\n                keyDate: !!customDate.keyDate || !!date.keyDate,\n                keyDateText: customDate.keyDateText || date.keyDateText,\n                label: date.label,\n                secondary: date.secondary,\n                selected: date.selected,\n                uid: date.uid,\n              };\n              row[dateIndex] = newDate;\n            }\n          }\n        });\n      });\n    }\n  }\n\n  #dateRangeRowsAreEqual(\n    rangeA?: SkyDateRange,\n    rangeB?: SkyDateRange\n  ): boolean | undefined {\n    /* istanbul ignore if */\n    if (!rangeA && !rangeB) {\n      return true;\n    } else if (rangeA && rangeB) {\n      return (\n        this.#compareDays(rangeA.startDate, rangeB.startDate) === 0 &&\n        this.#compareDays(rangeA.endDate, rangeB.endDate) === 0\n      );\n    } else {\n      return false;\n    }\n  }\n\n  #getDateRange(\n    rows: Array<Array<SkyDatepickerDate>>\n  ): SkyDateRange | undefined {\n    /* istanbul ignore else */\n    if (rows && rows.length > 0) {\n      return {\n        startDate: rows[0][0].date,\n        endDate: rows[rows.length - 1][rows[rows.length - 1].length - 1].date,\n      };\n    }\n    return undefined;\n  }\n}\n","<div *ngIf=\"datepicker.datepickerMode === 'day'\" class=\"sky-daypicker-wrapper\">\n  <table\n    class=\"sky-daypicker-table\"\n    role=\"grid\"\n    [attr.aria-labelledby]=\"datepicker.datepickerId + '-title'\"\n  >\n    <thead>\n      <tr>\n        <th class=\"sky-datepicker-header-left\" scope=\"col\">\n          <button\n            type=\"button\"\n            class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-previous\"\n            (click)=\"datepicker.moveCalendar($event, -1)\"\n            tabindex=\"-1\"\n            aria-hidden=\"true\"\n          >\n            <sky-icon\n              class=\"sky-datepicker-chevron-default\"\n              icon=\"chevron-left\"\n            ></sky-icon>\n            <sky-icon\n              class=\"sky-datepicker-chevron-modern\"\n              icon=\"chevron-left\"\n              iconType=\"skyux\"\n            ></sky-icon>\n          </button>\n        </th>\n        <th scope=\"col\" [attr.colspan]=\"5\">\n          <button\n            [id]=\"datepicker.datepickerId + '-title'\"\n            type=\"button\"\n            class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-calendar-title\"\n            (click)=\"datepicker.toggleModeCalendar($event)\"\n            [disabled]=\"datepicker.datepickerMode === datepicker.maxMode\"\n            [ngClass]=\"{\n              'sky-btn-disabled':\n                datepicker.datepickerMode === datepicker.maxMode\n            }\"\n            tabindex=\"-1\"\n            aria-hidden=\"true\"\n          >\n            <strong>{{ title }}</strong>\n          </button>\n        </th>\n        <th class=\"sky-datepicker-header-right\" scope=\"col\">\n          <button\n            type=\"button\"\n            class=\"sky-btn sky-btn-default sky-btn-sm sky-datepicker-btn-next\"\n            (click)=\"datepicker.moveCalendar($event, 1)\"\n            tabindex=\"-1\"\n            aria-hidden=\"true\"\n          >\n            <sky-icon\n              class=\"sky-datepicker-chevron-default\"\n              icon=\"chevron-right\"\n            ></sky-icon>\n            <sky-icon\n              class=\"sky-datepicker-chevron-modern\"\n              icon=\"chevron-right\"\n              iconType=\"skyux\"\n            ></sky-icon>\n          </button>\n        </th>\n      </tr>\n      <tr>\n        <th\n          scope=\"col\"\n          *ngFor=\"let label of labels\"\n          class=\"sky-datepicker-center sky-datepicker-weekdays\"\n        >\n          <small [attr.aria-label]=\"label.full\">\n            <b>{{ label.abbr }}</b>\n          </small>\n        </th>\n      </tr>\n    </thead>\n    <tbody>\n      <!-- Wait indicator for async custom date stream -->\n      <sky-wait [isWaiting]=\"isWaiting\"> </sky-wait>\n      <ng-template ngFor [ngForOf]=\"rows\" let-row=\"$implicit\" let-index=\"index\">\n        <tr role=\"row\">\n          <td\n            *ngFor=\"let date of row\"\n            class=\"sky-datepicker-center\"\n            role=\"gridcell\"\n            [id]=\"date.uid\"\n          >\n            <sky-daypicker-cell\n              [activeDateHasChanged]=\"activeDateHasChanged\"\n              [date]=\"date\"\n            >\n            </sky-daypicker-cell>\n          </td>\n        </tr>\n      </ng-template>\n    </tbody>\n  </table>\n</div>\n"]}
|