@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.
Files changed (57) hide show
  1. package/documentation.json +1532 -991
  2. package/esm2020/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +20 -0
  3. package/esm2020/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +20 -0
  4. package/esm2020/lib/modules/date-range-picker/date-range-picker.component.mjs +262 -204
  5. package/esm2020/lib/modules/date-range-picker/date-range-picker.module.mjs +11 -3
  6. package/esm2020/lib/modules/date-range-picker/date-range.service.mjs +42 -38
  7. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +1 -1
  8. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +1 -1
  9. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator.mjs +15 -15
  10. package/esm2020/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +4 -2
  11. package/esm2020/lib/modules/date-range-picker/types/date-range.mjs +1 -1
  12. package/esm2020/lib/modules/datepicker/date-formatter.mjs +2 -2
  13. package/esm2020/lib/modules/datepicker/datepicker-adapter.service.mjs +7 -14
  14. package/esm2020/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +43 -20
  15. package/esm2020/lib/modules/datepicker/datepicker-calendar.component.mjs +28 -35
  16. package/esm2020/lib/modules/datepicker/datepicker-config.service.mjs +1 -1
  17. package/esm2020/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +223 -209
  18. package/esm2020/lib/modules/datepicker/datepicker-input.directive.mjs +212 -220
  19. package/esm2020/lib/modules/datepicker/datepicker.component.mjs +117 -138
  20. package/esm2020/lib/modules/datepicker/daypicker-button.component.mjs +3 -3
  21. package/esm2020/lib/modules/datepicker/daypicker-cell.component.mjs +61 -59
  22. package/esm2020/lib/modules/datepicker/daypicker.component.mjs +143 -137
  23. package/esm2020/lib/modules/datepicker/fuzzy-date.service.mjs +123 -132
  24. package/esm2020/lib/modules/datepicker/monthpicker.component.mjs +51 -49
  25. package/esm2020/lib/modules/datepicker/yearpicker.component.mjs +52 -50
  26. package/esm2020/lib/modules/timepicker/timepicker.component.mjs +104 -88
  27. package/esm2020/lib/modules/timepicker/timepicker.directive.mjs +105 -98
  28. package/fesm2015/skyux-datetime.mjs +1642 -1516
  29. package/fesm2015/skyux-datetime.mjs.map +1 -1
  30. package/fesm2020/skyux-datetime.mjs +1618 -1510
  31. package/fesm2020/skyux-datetime.mjs.map +1 -1
  32. package/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.d.ts +8 -0
  33. package/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.d.ts +8 -0
  34. package/lib/modules/date-range-picker/date-range-picker.component.d.ts +14 -43
  35. package/lib/modules/date-range-picker/date-range-picker.module.d.ts +9 -7
  36. package/lib/modules/date-range-picker/date-range.service.d.ts +1 -5
  37. package/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.d.ts +1 -1
  38. package/lib/modules/date-range-picker/types/date-range-calculator-validate-function.d.ts +1 -1
  39. package/lib/modules/date-range-picker/types/date-range-calculator.d.ts +3 -8
  40. package/lib/modules/date-range-picker/types/date-range.d.ts +2 -2
  41. package/lib/modules/datepicker/date-formatter.d.ts +3 -3
  42. package/lib/modules/datepicker/datepicker-adapter.service.d.ts +1 -5
  43. package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +18 -19
  44. package/lib/modules/datepicker/datepicker-calendar.component.d.ts +14 -25
  45. package/lib/modules/datepicker/datepicker-config.service.d.ts +3 -3
  46. package/lib/modules/datepicker/datepicker-input-fuzzy.directive.d.ts +17 -53
  47. package/lib/modules/datepicker/datepicker-input.directive.d.ts +13 -68
  48. package/lib/modules/datepicker/datepicker.component.d.ts +21 -58
  49. package/lib/modules/datepicker/daypicker-button.component.d.ts +1 -1
  50. package/lib/modules/datepicker/daypicker-cell.component.d.ts +3 -10
  51. package/lib/modules/datepicker/daypicker.component.d.ts +4 -16
  52. package/lib/modules/datepicker/fuzzy-date.service.d.ts +6 -30
  53. package/lib/modules/datepicker/monthpicker.component.d.ts +1 -4
  54. package/lib/modules/datepicker/yearpicker.component.d.ts +1 -3
  55. package/lib/modules/timepicker/timepicker.component.d.ts +14 -32
  56. package/lib/modules/timepicker/timepicker.directive.d.ts +9 -27
  57. 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.daysInMonth = [
24
+ _SkyDayPickerComponent_daysInMonth.set(this, [
21
25
  31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31,
22
- ];
23
- this.ngUnsubscribe = new Subject();
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.applyCustomDates(value, this.rows);
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.initialDate = this.datepicker.activeDate.getDate();
39
+ __classPrivateFieldSet(this, _SkyDayPickerComponent_initialDate, this.datepicker.activeDate.getDate(), "f");
35
40
  this.datepicker.setRefreshViewHandler(() => {
36
- this.refreshDayView();
41
+ __classPrivateFieldGet(this, _SkyDayPickerComponent_instances, "m", _SkyDayPickerComponent_refreshDayView).call(this);
37
42
  }, 'day');
38
- this.datepicker.setCompareHandler(this.compareDays, 'day');
43
+ this.datepicker.setCompareHandler(__classPrivateFieldGet(this, _SkyDayPickerComponent_instances, "m", _SkyDayPickerComponent_compareDays), 'day');
39
44
  this.datepicker.setKeydownHandler((key, event) => {
40
- this.keydownDays(key, event);
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.ngUnsubscribe.next();
46
- this.ngUnsubscribe.complete();
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
- compareDays(date1, date2) {
62
- const d1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate());
63
- const d2 = new Date(date2.getFullYear(), date2.getMonth(), date2.getDate());
64
- return d1.getTime() - d2.getTime();
65
- }
66
- refreshDayView() {
67
- const year = this.datepicker.activeDate.getFullYear();
68
- const month = this.datepicker.activeDate.getMonth();
69
- const firstDayOfMonth = new Date(year, month, 1);
70
- const difference = this.datepicker.startingDay - firstDayOfMonth.getDay();
71
- const numDisplayedFromPreviousMonth = difference > 0 ? 7 - difference : -difference;
72
- const firstDate = new Date(firstDayOfMonth.getTime());
73
- if (this.datepicker.activeDate.getDate() !== this.initialDate) {
74
- this.activeDateHasChanged = true;
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
- /* sanity check */
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
- keydownDays(key, event) {
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
- this.datepicker.activeDate.setDate(date);
133
- }
134
- getDaysInMonth(year, month) {
135
- return month === 1 &&
136
- year % 4 === 0 &&
137
- (year % 400 === 0 || year % 100 !== 0)
138
- ? 29
139
- : this.daysInMonth[month];
140
- }
141
- /**
142
- * Applies custom date properties to the existing dates displayed in the calendar.
143
- */
144
- applyCustomDates(customDates, dateRows) {
145
- let date;
146
- let newDate;
147
- let dateIndex;
148
- /* istanbul ignore else */
149
- if (customDates && dateRows) {
150
- customDates.forEach((customDate) => {
151
- dateIndex = -1;
152
- dateRows.forEach((row) => {
153
- if (dateIndex === -1) {
154
- dateIndex = row.findIndex((d) => {
155
- return d.date.getTime() === customDate.date.getTime();
156
- });
157
- if (dateIndex > -1) {
158
- date = row[dateIndex];
159
- // Replace the date with a new instance so the display gets updated.
160
- newDate = {
161
- current: date.current,
162
- date: date.date,
163
- disabled: !!date.disabled || !!customDate.disabled,
164
- keyDate: !!customDate.keyDate || !!date.keyDate,
165
- keyDateText: customDate.keyDateText || date.keyDateText,
166
- label: date.label,
167
- secondary: date.secondary,
168
- selected: date.selected,
169
- uid: date.uid,
170
- };
171
- row[dateIndex] = newDate;
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
- dateRangeRowsAreEqual(rangeA, rangeB) {
179
- /* istanbul ignore if */
180
- if (!rangeA && !rangeB) {
181
- return true;
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
- getDateRange(rows) {
190
- /* istanbul ignore else */
191
- if (rows && rows.length > 0) {
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"]}