@skyux/datetime 8.7.2 → 9.0.0-alpha.1

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 (96) hide show
  1. package/documentation.json +51 -51
  2. package/esm2022/lib/modules/date-pipe/date-format-utility.mjs +45 -0
  3. package/{esm2020 → esm2022}/lib/modules/date-pipe/date-pipe.module.mjs +5 -5
  4. package/esm2022/lib/modules/date-pipe/date.pipe.mjs +67 -0
  5. package/esm2022/lib/modules/date-pipe/fuzzy-date.pipe.mjs +47 -0
  6. package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker-end-date-resource-key.pipe.mjs +4 -4
  7. package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker-start-date-resource-key.pipe.mjs +4 -4
  8. package/esm2022/lib/modules/date-range-picker/date-range-picker.component.mjs +518 -0
  9. package/{esm2020 → esm2022}/lib/modules/date-range-picker/date-range-picker.module.mjs +19 -19
  10. package/esm2022/lib/modules/date-range-picker/date-range.service.mjs +97 -0
  11. package/esm2022/lib/modules/date-range-picker/types/date-range-calculator.mjs +54 -0
  12. package/esm2022/lib/modules/datepicker/date-formatter.mjs +38 -0
  13. package/esm2022/lib/modules/datepicker/datepicker-adapter.service.mjs +23 -0
  14. package/esm2022/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +332 -0
  15. package/esm2022/lib/modules/datepicker/datepicker-calendar.component.mjs +95 -0
  16. package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-config.service.mjs +4 -4
  17. package/esm2022/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +487 -0
  18. package/esm2022/lib/modules/datepicker/datepicker-input.directive.mjs +534 -0
  19. package/esm2022/lib/modules/datepicker/datepicker.component.mjs +327 -0
  20. package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker.module.mjs +35 -35
  21. package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker.service.mjs +4 -4
  22. package/{esm2020 → esm2022}/lib/modules/datepicker/daypicker-button.component.mjs +4 -4
  23. package/esm2022/lib/modules/datepicker/daypicker-cell.component.mjs +128 -0
  24. package/esm2022/lib/modules/datepicker/daypicker.component.mjs +224 -0
  25. package/esm2022/lib/modules/datepicker/fuzzy-date.service.mjs +412 -0
  26. package/esm2022/lib/modules/datepicker/monthpicker.component.mjs +80 -0
  27. package/{esm2020 → esm2022}/lib/modules/datepicker/yearpicker.component.mjs +53 -54
  28. package/{esm2020 → esm2022}/lib/modules/shared/sky-datetime-resources.module.mjs +11 -11
  29. package/esm2022/lib/modules/timepicker/timepicker.component.mjs +396 -0
  30. package/esm2022/lib/modules/timepicker/timepicker.directive.mjs +237 -0
  31. package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker.module.mjs +17 -17
  32. package/esm2022/testing/datepicker-fixture.mjs +55 -0
  33. package/esm2022/testing/timepicker-fixture.mjs +52 -0
  34. package/fesm2022/skyux-datetime-testing.mjs +112 -0
  35. package/{fesm2020 → fesm2022}/skyux-datetime-testing.mjs.map +1 -1
  36. package/fesm2022/skyux-datetime.mjs +5030 -0
  37. package/fesm2022/skyux-datetime.mjs.map +1 -0
  38. package/lib/modules/date-range-picker/date-range-picker.component.d.ts +1 -1
  39. package/lib/modules/datepicker/datepicker-calendar-inner.component.d.ts +1 -1
  40. package/lib/modules/datepicker/datepicker-calendar.component.d.ts +1 -1
  41. package/lib/modules/datepicker/datepicker-input-fuzzy.directive.d.ts +1 -1
  42. package/lib/modules/datepicker/datepicker-input.directive.d.ts +1 -1
  43. package/lib/modules/datepicker/datepicker.component.d.ts +1 -1
  44. package/lib/modules/datepicker/daypicker-button.component.d.ts +1 -1
  45. package/lib/modules/datepicker/daypicker-cell.component.d.ts +1 -1
  46. package/lib/modules/datepicker/daypicker.component.d.ts +1 -1
  47. package/lib/modules/timepicker/timepicker.directive.d.ts +1 -1
  48. package/package.json +19 -27
  49. package/esm2020/lib/modules/date-pipe/date-format-utility.mjs +0 -45
  50. package/esm2020/lib/modules/date-pipe/date.pipe.mjs +0 -70
  51. package/esm2020/lib/modules/date-pipe/fuzzy-date.pipe.mjs +0 -50
  52. package/esm2020/lib/modules/date-range-picker/date-range-picker.component.mjs +0 -494
  53. package/esm2020/lib/modules/date-range-picker/date-range.service.mjs +0 -100
  54. package/esm2020/lib/modules/date-range-picker/types/date-range-calculator.mjs +0 -53
  55. package/esm2020/lib/modules/datepicker/date-formatter.mjs +0 -38
  56. package/esm2020/lib/modules/datepicker/datepicker-adapter.service.mjs +0 -26
  57. package/esm2020/lib/modules/datepicker/datepicker-calendar-inner.component.mjs +0 -333
  58. package/esm2020/lib/modules/datepicker/datepicker-calendar.component.mjs +0 -96
  59. package/esm2020/lib/modules/datepicker/datepicker-input-fuzzy.directive.mjs +0 -462
  60. package/esm2020/lib/modules/datepicker/datepicker-input.directive.mjs +0 -496
  61. package/esm2020/lib/modules/datepicker/datepicker.component.mjs +0 -319
  62. package/esm2020/lib/modules/datepicker/daypicker-cell.component.mjs +0 -126
  63. package/esm2020/lib/modules/datepicker/daypicker.component.mjs +0 -216
  64. package/esm2020/lib/modules/datepicker/fuzzy-date.service.mjs +0 -392
  65. package/esm2020/lib/modules/datepicker/monthpicker.component.mjs +0 -81
  66. package/esm2020/lib/modules/timepicker/timepicker.component.mjs +0 -389
  67. package/esm2020/lib/modules/timepicker/timepicker.directive.mjs +0 -236
  68. package/esm2020/testing/datepicker-fixture.mjs +0 -58
  69. package/esm2020/testing/timepicker-fixture.mjs +0 -55
  70. package/fesm2015/skyux-datetime-testing.mjs +0 -117
  71. package/fesm2015/skyux-datetime-testing.mjs.map +0 -1
  72. package/fesm2015/skyux-datetime.mjs +0 -4925
  73. package/fesm2015/skyux-datetime.mjs.map +0 -1
  74. package/fesm2020/skyux-datetime-testing.mjs +0 -117
  75. package/fesm2020/skyux-datetime.mjs +0 -4895
  76. package/fesm2020/skyux-datetime.mjs.map +0 -1
  77. /package/{esm2020 → esm2022}/index.mjs +0 -0
  78. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculation.mjs +0 -0
  79. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-config.mjs +0 -0
  80. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-date-range-function.mjs +0 -0
  81. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-id.mjs +0 -0
  82. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-type.mjs +0 -0
  83. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-calculator-validate-function.mjs +0 -0
  84. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-default-calculator-config.mjs +0 -0
  85. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-default-calculator-configs.mjs +0 -0
  86. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range-relative-value.mjs +0 -0
  87. /package/{esm2020 → esm2022}/lib/modules/date-range-picker/types/date-range.mjs +0 -0
  88. /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-calendar-change.mjs +0 -0
  89. /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-custom-date.mjs +0 -0
  90. /package/{esm2020 → esm2022}/lib/modules/datepicker/datepicker-date.mjs +0 -0
  91. /package/{esm2020 → esm2022}/lib/modules/datepicker/fuzzy-date.mjs +0 -0
  92. /package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker-time-format-type.mjs +0 -0
  93. /package/{esm2020 → esm2022}/lib/modules/timepicker/timepicker-time-output.mjs +0 -0
  94. /package/{esm2020 → esm2022}/skyux-datetime.mjs +0 -0
  95. /package/{esm2020 → esm2022}/testing/public-api.mjs +0 -0
  96. /package/{esm2020 → esm2022}/testing/skyux-datetime-testing.mjs +0 -0
@@ -1,333 +0,0 @@
1
- var _SkyDatepickerCalendarInnerComponent_instances, _SkyDatepickerCalendarInnerComponent_ngUnsubscribe, _SkyDatepickerCalendarInnerComponent__selectedDate, _SkyDatepickerCalendarInnerComponent__startingDay, _SkyDatepickerCalendarInnerComponent_getCustomDate;
2
- import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
- import { Component, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core';
4
- import { Subject } from 'rxjs';
5
- import { SkyDateFormatter } from './date-formatter';
6
- import * as i0 from "@angular/core";
7
- import * as i1 from "@angular/common";
8
- let nextDatepickerId = 0;
9
- /**
10
- * @internal
11
- */
12
- export class SkyDatepickerCalendarInnerComponent {
13
- constructor() {
14
- _SkyDatepickerCalendarInnerComponent_instances.add(this);
15
- this.selectedDateChange = new EventEmitter(undefined);
16
- this.calendarModeChange = new EventEmitter();
17
- // TODO: `activeDate` is very similar to `selectedDate` and at the very least should be able to be undefined. However, this would take considerable refactoring to do and thus has been deferred.
18
- this.activeDate = new Date();
19
- this.activeDateId = '';
20
- this.minMode = 'day';
21
- this.maxMode = 'year';
22
- this.monthColLimit = 3;
23
- this.yearColLimit = 5;
24
- this.datepickerMode = 'day';
25
- this.yearRange = 20;
26
- this.formatDay = 'DD';
27
- this.formatMonth = 'MMMM';
28
- this.formatYear = 'YYYY';
29
- this.formatDayHeader = 'dd';
30
- this.formatDayTitle = 'MMMM YYYY';
31
- this.formatMonthTitle = 'YYYY';
32
- this.datepickerId = `sky-datepicker-${++nextDatepickerId}`;
33
- this.stepDay = {};
34
- this.stepMonth = {};
35
- this.stepYear = {};
36
- this.modes = ['day', 'month', 'year'];
37
- this.dateFormatter = new SkyDateFormatter();
38
- this.keys = {
39
- 13: 'enter',
40
- 32: 'space',
41
- 33: 'pageup',
42
- 34: 'pagedown',
43
- 35: 'end',
44
- 36: 'home',
45
- 37: 'left',
46
- 38: 'up',
47
- 39: 'right',
48
- 40: 'down',
49
- };
50
- _SkyDatepickerCalendarInnerComponent_ngUnsubscribe.set(this, new Subject());
51
- _SkyDatepickerCalendarInnerComponent__selectedDate.set(this, void 0);
52
- _SkyDatepickerCalendarInnerComponent__startingDay.set(this, 0);
53
- }
54
- set startingDay(value) {
55
- __classPrivateFieldSet(this, _SkyDatepickerCalendarInnerComponent__startingDay, value || 0, "f");
56
- }
57
- get startingDay() {
58
- return __classPrivateFieldGet(this, _SkyDatepickerCalendarInnerComponent__startingDay, "f");
59
- }
60
- set selectedDate(value) {
61
- if (value && this.dateFormatter.dateIsValid(value)) {
62
- __classPrivateFieldSet(this, _SkyDatepickerCalendarInnerComponent__selectedDate, value, "f");
63
- this.activeDate = value;
64
- }
65
- else {
66
- __classPrivateFieldSet(this, _SkyDatepickerCalendarInnerComponent__selectedDate, undefined, "f");
67
- this.activeDate = new Date();
68
- }
69
- }
70
- get selectedDate() {
71
- return __classPrivateFieldGet(this, _SkyDatepickerCalendarInnerComponent__selectedDate, "f");
72
- }
73
- ngOnInit() {
74
- if (this.selectedDate) {
75
- this.activeDate = new Date(this.selectedDate);
76
- }
77
- else {
78
- this.activeDate = new Date();
79
- }
80
- }
81
- ngOnChanges(changes) {
82
- this.refreshView();
83
- }
84
- ngOnDestroy() {
85
- __classPrivateFieldGet(this, _SkyDatepickerCalendarInnerComponent_ngUnsubscribe, "f").next();
86
- __classPrivateFieldGet(this, _SkyDatepickerCalendarInnerComponent_ngUnsubscribe, "f").complete();
87
- }
88
- setCompareHandler(handler, type) {
89
- if (type === 'day') {
90
- this.compareHandlerDay = handler;
91
- }
92
- if (type === 'month') {
93
- this.compareHandlerMonth = handler;
94
- }
95
- if (type === 'year') {
96
- this.compareHandlerYear = handler;
97
- }
98
- }
99
- compare(date1, date2) {
100
- if (date1 === undefined || date2 === undefined) {
101
- return undefined;
102
- }
103
- if (this.datepickerMode === 'day' && this.compareHandlerDay) {
104
- return this.compareHandlerDay(date1, date2);
105
- }
106
- if (this.datepickerMode === 'month' && this.compareHandlerMonth) {
107
- return this.compareHandlerMonth(date1, date2);
108
- }
109
- /* istanbul ignore else */
110
- /* sanity check */
111
- if (this.datepickerMode === 'year' && this.compareHandlerYear) {
112
- return this.compareHandlerYear(date1, date2);
113
- }
114
- /* istanbul ignore next */
115
- return undefined;
116
- }
117
- setRefreshViewHandler(handler, type) {
118
- if (type === 'day') {
119
- this.refreshViewHandlerDay = handler;
120
- }
121
- if (type === 'month') {
122
- this.refreshViewHandlerMonth = handler;
123
- }
124
- if (type === 'year') {
125
- this.refreshViewHandlerYear = handler;
126
- }
127
- }
128
- refreshView() {
129
- if (this.datepickerMode === 'day' && this.refreshViewHandlerDay) {
130
- this.refreshViewHandlerDay();
131
- }
132
- if (this.datepickerMode === 'month' && this.refreshViewHandlerMonth) {
133
- this.refreshViewHandlerMonth();
134
- }
135
- if (this.datepickerMode === 'year' && this.refreshViewHandlerYear) {
136
- this.refreshViewHandlerYear();
137
- }
138
- }
139
- setKeydownHandler(handler, type) {
140
- if (type === 'day') {
141
- this.handleKeydownDay = handler;
142
- }
143
- if (type === 'month') {
144
- this.handleKeydownMonth = handler;
145
- }
146
- if (type === 'year') {
147
- this.handleKeydownYear = handler;
148
- }
149
- }
150
- handleKeydown(key, event) {
151
- if (this.datepickerMode === 'day' && this.handleKeydownDay) {
152
- this.handleKeydownDay(key, event);
153
- }
154
- if (this.datepickerMode === 'month' && this.handleKeydownMonth) {
155
- this.handleKeydownMonth(key, event);
156
- }
157
- if (this.datepickerMode === 'year' && this.handleKeydownYear) {
158
- this.handleKeydownYear(key, event);
159
- }
160
- }
161
- dateFilter(date, format) {
162
- return this.dateFormatter.format(date, format);
163
- }
164
- isActive(dateObject) {
165
- if (this.compare(dateObject.date, this.activeDate) === 0) {
166
- this.activeDateId = dateObject.uid;
167
- return true;
168
- }
169
- return false;
170
- }
171
- onKeydown(event) {
172
- const key = this.keys[event.which];
173
- if (!key || event.shiftKey || event.altKey) {
174
- return;
175
- }
176
- event.preventDefault();
177
- event.stopPropagation();
178
- if (key === 'enter' || key === 'space') {
179
- if (this.isDisabled(this.activeDate)) {
180
- return;
181
- }
182
- this.select(this.activeDate);
183
- }
184
- else if (event.ctrlKey && (key === 'up' || key === 'down')) {
185
- this.toggleMode(key === 'up' ? 1 : -1);
186
- }
187
- else {
188
- this.handleKeydown(key, event);
189
- this.refreshView();
190
- }
191
- }
192
- createDateObject(date, format, isSecondary, id) {
193
- const customDateMatch = __classPrivateFieldGet(this, _SkyDatepickerCalendarInnerComponent_instances, "m", _SkyDatepickerCalendarInnerComponent_getCustomDate).call(this, date);
194
- const dateObject = {
195
- date: new Date(date.getFullYear(), date.getMonth(), date.getDate()),
196
- label: this.dateFilter(date, format),
197
- selected: !!this.selectedDate && this.compare(date, this.selectedDate) === 0,
198
- disabled: this.isDisabled(date),
199
- current: this.compare(date, new Date()) === 0,
200
- secondary: isSecondary,
201
- uid: id,
202
- keyDate: customDateMatch ? customDateMatch.keyDate : undefined,
203
- keyDateText: customDateMatch ? customDateMatch.keyDateText : [],
204
- };
205
- return dateObject;
206
- }
207
- createCalendarRows(dates, size) {
208
- const rows = [];
209
- while (dates.length > 0) {
210
- rows.push(dates.splice(0, size));
211
- }
212
- return rows;
213
- }
214
- /*
215
- This is ensures that no strangeness happens when converting a date to local time.
216
- */
217
- fixTimeZone(date) {
218
- const newDate = new Date(date);
219
- newDate.setFullYear(date.getFullYear(), date.getMonth(), date.getDate());
220
- return newDate;
221
- }
222
- selectCalendar(event, date, closePicker = false) {
223
- if (!closePicker) {
224
- event.preventDefault();
225
- event.stopPropagation();
226
- }
227
- this.select(date);
228
- }
229
- select(date, isManual = true) {
230
- this.activeDate = new Date(date.getFullYear(), date.getMonth(), date.getDate());
231
- /*
232
- Only actually select date if in minMode (day picker mode).
233
- Otherwise, just change the active view for the datepicker.
234
- */
235
- if (this.datepickerMode === this.minMode) {
236
- this.selectedDate = new Date(this.activeDate);
237
- if (isManual) {
238
- this.selectedDateChange.emit(this.selectedDate);
239
- }
240
- }
241
- else {
242
- this.datepickerMode =
243
- this.modes[this.modes.indexOf(this.datepickerMode) - 1];
244
- this.calendarModeChange.emit(this.datepickerMode);
245
- }
246
- this.refreshView();
247
- }
248
- moveCalendar(event, direction) {
249
- event.preventDefault();
250
- event.stopPropagation();
251
- this.move(direction);
252
- }
253
- move(direction) {
254
- let expectedStep;
255
- if (this.datepickerMode === 'day') {
256
- expectedStep = this.stepDay;
257
- }
258
- if (this.datepickerMode === 'month') {
259
- expectedStep = this.stepMonth;
260
- }
261
- if (this.datepickerMode === 'year') {
262
- expectedStep = this.stepYear;
263
- }
264
- /* istanbul ignore else */
265
- /* sanity check */
266
- if (expectedStep) {
267
- const year = this.activeDate.getFullYear() + direction * (expectedStep.years || 0);
268
- const month = this.activeDate.getMonth() + direction * (expectedStep.months || 0);
269
- this.activeDate = new Date(year, month, 1);
270
- this.refreshView();
271
- }
272
- }
273
- toggleModeCalendar(event) {
274
- event.preventDefault();
275
- event.stopPropagation();
276
- this.toggleMode(1);
277
- }
278
- toggleMode(direction) {
279
- /*istanbul ignore next */
280
- direction = direction || 1;
281
- /* istanbul ignore else */
282
- /* sanity check */
283
- if (!(direction === 1 && this.datepickerMode === this.maxMode) &&
284
- !(this.datepickerMode === this.minMode && direction === -1)) {
285
- this.datepickerMode =
286
- this.modes[this.modes.indexOf(this.datepickerMode) + direction];
287
- this.calendarModeChange.emit(this.datepickerMode);
288
- this.refreshView();
289
- }
290
- }
291
- /**
292
- * Date is disabled if it meets any of these criteria:
293
- * 1. Date falls outside the min or max dates set by the SkyDatepickerConfigService.
294
- * 2. Date is marked as disabled in the customDates array.
295
- */
296
- isDisabled(date) {
297
- const customDate = __classPrivateFieldGet(this, _SkyDatepickerCalendarInnerComponent_instances, "m", _SkyDatepickerCalendarInnerComponent_getCustomDate).call(this, date);
298
- const minDateCompare = this.compare(date, this.minDate);
299
- const maxDateCompare = this.compare(date, this.maxDate);
300
- return ((minDateCompare !== undefined && minDateCompare < 0) ||
301
- (maxDateCompare !== undefined && maxDateCompare > 0) ||
302
- !!customDate?.disabled);
303
- }
304
- }
305
- _SkyDatepickerCalendarInnerComponent_ngUnsubscribe = new WeakMap(), _SkyDatepickerCalendarInnerComponent__selectedDate = new WeakMap(), _SkyDatepickerCalendarInnerComponent__startingDay = new WeakMap(), _SkyDatepickerCalendarInnerComponent_instances = new WeakSet(), _SkyDatepickerCalendarInnerComponent_getCustomDate = function _SkyDatepickerCalendarInnerComponent_getCustomDate(date) {
306
- if (this.customDates) {
307
- return this.customDates.find((customDate) => {
308
- return customDate.date.getTime() === date.getTime();
309
- });
310
- }
311
- return undefined;
312
- };
313
- SkyDatepickerCalendarInnerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyDatepickerCalendarInnerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
314
- SkyDatepickerCalendarInnerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: SkyDatepickerCalendarInnerComponent, selector: "sky-datepicker-inner", inputs: { customDates: "customDates", startingDay: "startingDay", minDate: "minDate", maxDate: "maxDate", selectedDate: "selectedDate" }, outputs: { selectedDateChange: "selectedDateChange", calendarModeChange: "calendarModeChange" }, usesOnChanges: true, ngImport: i0, template: "<div\n *ngIf=\"datepickerMode\"\n class=\"sky-datepicker-calendar-inner\"\n (keydown)=\"onKeydown($event)\"\n>\n <ng-content></ng-content>\n</div>\n", styles: [".sky-datepicker-calendar-inner{border-radius:5px;background-color:#fff;border-top:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-right:1px solid #e2e3e4}.sky-datepicker-calendar-inner .sky-btn-default{border-color:transparent;border:2px solid #ffffff}.sky-datepicker-calendar-inner .sky-btn-default:hover{border-color:#eeeeef}.sky-datepicker-calendar-inner .sky-datepicker-center{text-align:center}.sky-datepicker-calendar-inner .sky-datepicker-btn-selected,.sky-datepicker-calendar-inner .sky-btn-default.sky-datepicker-btn-selected:hover{background-color:#c1e8fb;border:2px solid #00b4f1}.sky-datepicker-calendar-inner .sky-btn.sky-btn-active{box-shadow:none}.sky-datepicker-calendar-inner .sky-datepicker-secondary{color:#686c73}.sky-datepicker-calendar-inner .sky-datepicker-btn-date{min-width:100%}.sky-datepicker-calendar-inner .sky-datepicker-calendar-title{width:100%}.sky-datepicker-calendar-inner .sky-datepicker-chevron-modern{display:none}.sky-datepicker-calendar-inner .sky-datepicker-header-left{text-align:left}.sky-datepicker-calendar-inner .sky-datepicker-header-right{text-align:right}.sky-theme-modern .sky-datepicker-calendar-inner{border:none;box-shadow:inset 0 0 0 1px #d2d2d2;border-radius:6px;padding:5px 10px}.sky-theme-modern .sky-datepicker-calendar-inner:focus-within{border:none;box-shadow:inset 0 0 0 2px #1870b8,0 1px 3px #0000004d}.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default{border:none;box-shadow:inset 0 0 0 1px transparent;padding:5px 7px}.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-active,.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default:hover{border:none;box-shadow:inset 0 0 0 1px #1870b8}.sky-theme-modern .sky-datepicker-calendar-inner .sky-datepicker-btn-selected,.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default.sky-datepicker-btn-selected:hover{background-color:var(--sky-background-color-input-selected)}.sky-theme-modern .sky-btn-sm.sky-datepicker-btn-date{height:30px;min-width:0;padding:0;width:30px}.sky-theme-modern .sky-datepicker-chevron-default{display:none}.sky-theme-modern .sky-datepicker-chevron-modern{display:inline;font-size:16px}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner{background-color:transparent}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner:not(:focus-within){border:none;box-shadow:inset 0 0 0 1px #686c73}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner .sky-datepicker-btn-selected{background-color:#009cd1}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
315
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyDatepickerCalendarInnerComponent, decorators: [{
316
- type: Component,
317
- args: [{ selector: 'sky-datepicker-inner', encapsulation: ViewEncapsulation.None, template: "<div\n *ngIf=\"datepickerMode\"\n class=\"sky-datepicker-calendar-inner\"\n (keydown)=\"onKeydown($event)\"\n>\n <ng-content></ng-content>\n</div>\n", styles: [".sky-datepicker-calendar-inner{border-radius:5px;background-color:#fff;border-top:1px solid #e2e3e4;border-bottom:1px solid #e2e3e4;border-left:1px solid #e2e3e4;border-right:1px solid #e2e3e4}.sky-datepicker-calendar-inner .sky-btn-default{border-color:transparent;border:2px solid #ffffff}.sky-datepicker-calendar-inner .sky-btn-default:hover{border-color:#eeeeef}.sky-datepicker-calendar-inner .sky-datepicker-center{text-align:center}.sky-datepicker-calendar-inner .sky-datepicker-btn-selected,.sky-datepicker-calendar-inner .sky-btn-default.sky-datepicker-btn-selected:hover{background-color:#c1e8fb;border:2px solid #00b4f1}.sky-datepicker-calendar-inner .sky-btn.sky-btn-active{box-shadow:none}.sky-datepicker-calendar-inner .sky-datepicker-secondary{color:#686c73}.sky-datepicker-calendar-inner .sky-datepicker-btn-date{min-width:100%}.sky-datepicker-calendar-inner .sky-datepicker-calendar-title{width:100%}.sky-datepicker-calendar-inner .sky-datepicker-chevron-modern{display:none}.sky-datepicker-calendar-inner .sky-datepicker-header-left{text-align:left}.sky-datepicker-calendar-inner .sky-datepicker-header-right{text-align:right}.sky-theme-modern .sky-datepicker-calendar-inner{border:none;box-shadow:inset 0 0 0 1px #d2d2d2;border-radius:6px;padding:5px 10px}.sky-theme-modern .sky-datepicker-calendar-inner:focus-within{border:none;box-shadow:inset 0 0 0 2px #1870b8,0 1px 3px #0000004d}.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default{border:none;box-shadow:inset 0 0 0 1px transparent;padding:5px 7px}.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-active,.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default:hover{border:none;box-shadow:inset 0 0 0 1px #1870b8}.sky-theme-modern .sky-datepicker-calendar-inner .sky-datepicker-btn-selected,.sky-theme-modern .sky-datepicker-calendar-inner .sky-btn-default.sky-datepicker-btn-selected:hover{background-color:var(--sky-background-color-input-selected)}.sky-theme-modern .sky-btn-sm.sky-datepicker-btn-date{height:30px;min-width:0;padding:0;width:30px}.sky-theme-modern .sky-datepicker-chevron-default{display:none}.sky-theme-modern .sky-datepicker-chevron-modern{display:inline;font-size:16px}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner{background-color:transparent}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner:not(:focus-within){border:none;box-shadow:inset 0 0 0 1px #686c73}.sky-theme-modern.sky-theme-mode-dark .sky-datepicker-calendar-inner .sky-datepicker-btn-selected{background-color:#009cd1}\n"] }]
318
- }], propDecorators: { customDates: [{
319
- type: Input
320
- }], startingDay: [{
321
- type: Input
322
- }], minDate: [{
323
- type: Input
324
- }], maxDate: [{
325
- type: Input
326
- }], selectedDate: [{
327
- type: Input
328
- }], selectedDateChange: [{
329
- type: Output
330
- }], calendarModeChange: [{
331
- type: Output
332
- }] } });
333
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-calendar-inner.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar-inner.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar-inner.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\n\nimport { SkyDateFormatter } from './date-formatter';\nimport { SkyDatepickerCustomDate } from './datepicker-custom-date';\nimport { SkyDatepickerDate } from './datepicker-date';\n\ntype DateComparator = (date1: Date, date2: Date) => number | undefined;\ntype KeyboardEventHandler = (key: string, event: KeyboardEvent) => void;\n\nlet nextDatepickerId = 0;\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-datepicker-inner',\n  templateUrl: './datepicker-calendar-inner.component.html',\n  styleUrls: ['./datepicker-calendar-inner.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class SkyDatepickerCalendarInnerComponent\n  implements OnDestroy, OnInit, OnChanges\n{\n  @Input()\n  public customDates: SkyDatepickerCustomDate[] | undefined;\n\n  @Input()\n  public set startingDay(value: number | undefined) {\n    this.#_startingDay = value || 0;\n  }\n\n  public get startingDay(): number {\n    return this.#_startingDay;\n  }\n\n  @Input()\n  public minDate: Date | undefined;\n\n  @Input()\n  public maxDate: Date | undefined;\n\n  @Input()\n  public set selectedDate(value: Date | undefined) {\n    if (value && this.dateFormatter.dateIsValid(value)) {\n      this.#_selectedDate = value;\n      this.activeDate = value;\n    } else {\n      this.#_selectedDate = undefined;\n      this.activeDate = new Date();\n    }\n  }\n\n  public get selectedDate(): Date | undefined {\n    return this.#_selectedDate;\n  }\n\n  @Output()\n  public selectedDateChange: EventEmitter<Date> = new EventEmitter<Date>(\n    undefined\n  );\n\n  @Output()\n  public calendarModeChange: EventEmitter<string> = new EventEmitter<string>();\n\n  // TODO: `activeDate` is very similar to `selectedDate` and at the very least should be able to be undefined. However, this would take considerable refactoring to do and thus has been deferred.\n  public activeDate = new Date();\n  public activeDateId = '';\n\n  public minMode = 'day';\n  public maxMode = 'year';\n  public monthColLimit = 3;\n  public yearColLimit = 5;\n  public datepickerMode = 'day';\n  public yearRange = 20;\n\n  public formatDay = 'DD';\n  public formatMonth = 'MMMM';\n  public formatYear = 'YYYY';\n  public formatDayHeader = 'dd';\n  public formatDayTitle = 'MMMM YYYY';\n  public formatMonthTitle = 'YYYY';\n\n  public datepickerId = `sky-datepicker-${++nextDatepickerId}`;\n\n  public stepDay: any = {};\n  public stepMonth: any = {};\n  public stepYear: any = {};\n\n  protected modes: string[] = ['day', 'month', 'year'];\n  protected dateFormatter: SkyDateFormatter = new SkyDateFormatter();\n\n  public refreshViewHandlerDay: (() => void) | undefined;\n  public compareHandlerDay: DateComparator | undefined;\n  public refreshViewHandlerMonth: (() => void) | undefined;\n  public compareHandlerMonth: DateComparator | undefined;\n  public refreshViewHandlerYear: (() => void) | undefined;\n  public compareHandlerYear: DateComparator | undefined;\n\n  public handleKeydownDay: KeyboardEventHandler | undefined;\n  public handleKeydownMonth: KeyboardEventHandler | undefined;\n  public handleKeydownYear: KeyboardEventHandler | undefined;\n\n  public keys: any = {\n    13: 'enter',\n    32: 'space',\n    33: 'pageup',\n    34: 'pagedown',\n    35: 'end',\n    36: 'home',\n    37: 'left',\n    38: 'up',\n    39: 'right',\n    40: 'down',\n  };\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #_selectedDate: Date | undefined;\n  #_startingDay = 0;\n\n  public ngOnInit(): void {\n    if (this.selectedDate) {\n      this.activeDate = new Date(this.selectedDate);\n    } else {\n      this.activeDate = new Date();\n    }\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    this.refreshView();\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public setCompareHandler(handler: DateComparator, type: string): void {\n    if (type === 'day') {\n      this.compareHandlerDay = handler;\n    }\n\n    if (type === 'month') {\n      this.compareHandlerMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.compareHandlerYear = handler;\n    }\n  }\n\n  public compare(\n    date1: Date | undefined,\n    date2: Date | undefined\n  ): number | undefined {\n    if (date1 === undefined || date2 === undefined) {\n      return undefined;\n    }\n\n    if (this.datepickerMode === 'day' && this.compareHandlerDay) {\n      return this.compareHandlerDay(date1, date2);\n    }\n\n    if (this.datepickerMode === 'month' && this.compareHandlerMonth) {\n      return this.compareHandlerMonth(date1, date2);\n    }\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (this.datepickerMode === 'year' && this.compareHandlerYear) {\n      return this.compareHandlerYear(date1, date2);\n    }\n\n    /* istanbul ignore next */\n    return undefined;\n  }\n\n  public setRefreshViewHandler(handler: () => void, type: string): void {\n    if (type === 'day') {\n      this.refreshViewHandlerDay = handler;\n    }\n\n    if (type === 'month') {\n      this.refreshViewHandlerMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.refreshViewHandlerYear = handler;\n    }\n  }\n\n  public refreshView(): void {\n    if (this.datepickerMode === 'day' && this.refreshViewHandlerDay) {\n      this.refreshViewHandlerDay();\n    }\n\n    if (this.datepickerMode === 'month' && this.refreshViewHandlerMonth) {\n      this.refreshViewHandlerMonth();\n    }\n\n    if (this.datepickerMode === 'year' && this.refreshViewHandlerYear) {\n      this.refreshViewHandlerYear();\n    }\n  }\n\n  public setKeydownHandler(handler: KeyboardEventHandler, type: string) {\n    if (type === 'day') {\n      this.handleKeydownDay = handler;\n    }\n\n    if (type === 'month') {\n      this.handleKeydownMonth = handler;\n    }\n\n    if (type === 'year') {\n      this.handleKeydownYear = handler;\n    }\n  }\n\n  public handleKeydown(key: string, event: KeyboardEvent): void {\n    if (this.datepickerMode === 'day' && this.handleKeydownDay) {\n      this.handleKeydownDay(key, event);\n    }\n\n    if (this.datepickerMode === 'month' && this.handleKeydownMonth) {\n      this.handleKeydownMonth(key, event);\n    }\n\n    if (this.datepickerMode === 'year' && this.handleKeydownYear) {\n      this.handleKeydownYear(key, event);\n    }\n  }\n\n  public dateFilter(date: Date, format: string): string {\n    return this.dateFormatter.format(date, format);\n  }\n\n  public isActive(dateObject: any): boolean {\n    if (this.compare(dateObject.date, this.activeDate) === 0) {\n      this.activeDateId = dateObject.uid;\n      return true;\n    }\n\n    return false;\n  }\n\n  public onKeydown(event: KeyboardEvent) {\n    const key = this.keys[event.which];\n\n    if (!key || event.shiftKey || event.altKey) {\n      return;\n    }\n\n    event.preventDefault();\n    event.stopPropagation();\n\n    if (key === 'enter' || key === 'space') {\n      if (this.isDisabled(this.activeDate)) {\n        return;\n      }\n      this.select(this.activeDate);\n    } else if (event.ctrlKey && (key === 'up' || key === 'down')) {\n      this.toggleMode(key === 'up' ? 1 : -1);\n    } else {\n      this.handleKeydown(key, event);\n      this.refreshView();\n    }\n  }\n\n  public createDateObject(\n    date: Date,\n    format: string,\n    isSecondary: boolean,\n    id: string\n  ): SkyDatepickerDate {\n    const customDateMatch = this.#getCustomDate(date);\n\n    const dateObject: SkyDatepickerDate = {\n      date: new Date(date.getFullYear(), date.getMonth(), date.getDate()),\n      label: this.dateFilter(date, format),\n      selected:\n        !!this.selectedDate && this.compare(date, this.selectedDate) === 0,\n      disabled: this.isDisabled(date),\n      current: this.compare(date, new Date()) === 0,\n      secondary: isSecondary,\n      uid: id,\n      keyDate: customDateMatch ? customDateMatch.keyDate : undefined,\n      keyDateText: customDateMatch ? customDateMatch.keyDateText : [],\n    };\n\n    return dateObject;\n  }\n\n  public createCalendarRows(\n    dates: Array<SkyDatepickerDate>,\n    size: number\n  ): Array<Array<SkyDatepickerDate>> {\n    const rows: Array<Array<SkyDatepickerDate>> = [];\n    while (dates.length > 0) {\n      rows.push(dates.splice(0, size));\n    }\n    return rows;\n  }\n\n  /*\n    This is ensures that no strangeness happens when converting a date to local time.\n  */\n  public fixTimeZone(date: Date): Date {\n    const newDate = new Date(date);\n    newDate.setFullYear(date.getFullYear(), date.getMonth(), date.getDate());\n\n    return newDate;\n  }\n\n  public selectCalendar(\n    event: Event,\n    date: Date,\n    closePicker: boolean = false\n  ) {\n    if (!closePicker) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n    this.select(date);\n  }\n\n  public select(date: Date, isManual: boolean = true): void {\n    this.activeDate = new Date(\n      date.getFullYear(),\n      date.getMonth(),\n      date.getDate()\n    );\n\n    /*\n        Only actually select date if in minMode (day picker mode).\n        Otherwise, just change the active view for the datepicker.\n    */\n    if (this.datepickerMode === this.minMode) {\n      this.selectedDate = new Date(this.activeDate);\n      if (isManual) {\n        this.selectedDateChange.emit(this.selectedDate);\n      }\n    } else {\n      this.datepickerMode =\n        this.modes[this.modes.indexOf(this.datepickerMode) - 1];\n      this.calendarModeChange.emit(this.datepickerMode);\n    }\n\n    this.refreshView();\n  }\n\n  public moveCalendar(event: Event, direction: number) {\n    event.preventDefault();\n    event.stopPropagation();\n    this.move(direction);\n  }\n\n  public move(direction: number): void {\n    let expectedStep: any;\n    if (this.datepickerMode === 'day') {\n      expectedStep = this.stepDay;\n    }\n\n    if (this.datepickerMode === 'month') {\n      expectedStep = this.stepMonth;\n    }\n\n    if (this.datepickerMode === 'year') {\n      expectedStep = this.stepYear;\n    }\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (expectedStep) {\n      const year =\n        this.activeDate.getFullYear() + direction * (expectedStep.years || 0);\n      const month =\n        this.activeDate.getMonth() + direction * (expectedStep.months || 0);\n\n      this.activeDate = new Date(year, month, 1);\n\n      this.refreshView();\n    }\n  }\n\n  public toggleModeCalendar(event: Event) {\n    event.preventDefault();\n    event.stopPropagation();\n    this.toggleMode(1);\n  }\n\n  public toggleMode(direction: number): void {\n    /*istanbul ignore next */\n    direction = direction || 1;\n\n    /* istanbul ignore else */\n    /* sanity check */\n    if (\n      !(direction === 1 && this.datepickerMode === this.maxMode) &&\n      !(this.datepickerMode === this.minMode && direction === -1)\n    ) {\n      this.datepickerMode =\n        this.modes[this.modes.indexOf(this.datepickerMode) + direction];\n      this.calendarModeChange.emit(this.datepickerMode);\n      this.refreshView();\n    }\n  }\n\n  /**\n   * Date is disabled if it meets any of these criteria:\n   * 1. Date falls outside the min or max dates set by the SkyDatepickerConfigService.\n   * 2. Date is marked as disabled in the customDates array.\n   */\n  protected isDisabled(date: Date): boolean {\n    const customDate = this.#getCustomDate(date);\n    const minDateCompare = this.compare(date, this.minDate);\n    const maxDateCompare = this.compare(date, this.maxDate);\n\n    return (\n      (minDateCompare !== undefined && minDateCompare < 0) ||\n      (maxDateCompare !== undefined && maxDateCompare > 0) ||\n      !!customDate?.disabled\n    );\n  }\n\n  #getCustomDate(date: Date): SkyDatepickerCustomDate | undefined {\n    if (this.customDates) {\n      return this.customDates.find((customDate: SkyDatepickerCustomDate) => {\n        return customDate.date.getTime() === date.getTime();\n      });\n    }\n    return undefined;\n  }\n}\n","<div\n  *ngIf=\"datepickerMode\"\n  class=\"sky-datepicker-calendar-inner\"\n  (keydown)=\"onKeydown($event)\"\n>\n  <ng-content></ng-content>\n</div>\n"]}
@@ -1,96 +0,0 @@
1
- var _SkyDatepickerCalendarComponent_formatter, _SkyDatepickerCalendarComponent__startingDay, _SkyDatepickerCalendarComponent_config;
2
- import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
- import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
4
- import { SkyDateFormatter } from './date-formatter';
5
- import { SkyDatepickerAdapterService } from './datepicker-adapter.service';
6
- import { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "./datepicker-config.service";
9
- import * as i2 from "./datepicker-calendar-inner.component";
10
- import * as i3 from "./daypicker.component";
11
- import * as i4 from "./monthpicker.component";
12
- import * as i5 from "./yearpicker.component";
13
- /**
14
- * @internal
15
- */
16
- export class SkyDatepickerCalendarComponent {
17
- /** starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday) */
18
- set startingDay(start) {
19
- __classPrivateFieldSet(this, _SkyDatepickerCalendarComponent__startingDay, start ?? 0, "f");
20
- }
21
- get startingDay() {
22
- return __classPrivateFieldGet(this, _SkyDatepickerCalendarComponent__startingDay, "f");
23
- }
24
- constructor(config) {
25
- this.calendarDateRangeChange = new EventEmitter();
26
- this.calendarModeChange = new EventEmitter();
27
- this.selectedDateChange = new EventEmitter(undefined);
28
- this._now = new Date();
29
- _SkyDatepickerCalendarComponent_formatter.set(this, new SkyDateFormatter());
30
- _SkyDatepickerCalendarComponent__startingDay.set(this, 0);
31
- _SkyDatepickerCalendarComponent_config.set(this, void 0);
32
- __classPrivateFieldSet(this, _SkyDatepickerCalendarComponent_config, config, "f");
33
- this.configureOptions();
34
- }
35
- configureOptions() {
36
- Object.assign(this, __classPrivateFieldGet(this, _SkyDatepickerCalendarComponent_config, "f"));
37
- }
38
- onCalendarDateRangeChange(event) {
39
- this.calendarDateRangeChange.next(event);
40
- }
41
- onCalendarModeChange(event) {
42
- this.calendarModeChange.emit(event);
43
- }
44
- onSelectedDateChange(event) {
45
- this.selectedDateChange.emit(event);
46
- }
47
- writeValue(value) {
48
- if (value !== undefined &&
49
- __classPrivateFieldGet(this, _SkyDatepickerCalendarComponent_formatter, "f").dateIsValid(value) &&
50
- this.selectedDate !== undefined &&
51
- this.datepicker?.compareHandlerDay &&
52
- this.datepicker.compareHandlerDay(value, this.selectedDate) === 0) {
53
- return;
54
- }
55
- if (value && __classPrivateFieldGet(this, _SkyDatepickerCalendarComponent_formatter, "f").dateIsValid(value)) {
56
- this.selectedDate = value;
57
- this.datepicker?.select(value, false);
58
- }
59
- else {
60
- this.selectedDate = new Date();
61
- this.datepicker?.select(new Date(), false);
62
- }
63
- }
64
- }
65
- _SkyDatepickerCalendarComponent_formatter = new WeakMap(), _SkyDatepickerCalendarComponent__startingDay = new WeakMap(), _SkyDatepickerCalendarComponent_config = new WeakMap();
66
- SkyDatepickerCalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyDatepickerCalendarComponent, deps: [{ token: i1.SkyDatepickerConfigService }], target: i0.ɵɵFactoryTarget.Component });
67
- SkyDatepickerCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: SkyDatepickerCalendarComponent, selector: "sky-datepicker-calendar", inputs: { customDates: "customDates", isDaypickerWaiting: "isDaypickerWaiting", minDate: "minDate", maxDate: "maxDate", selectedDate: "selectedDate", startingDay: "startingDay" }, outputs: { calendarDateRangeChange: "calendarDateRangeChange", calendarModeChange: "calendarModeChange", selectedDateChange: "selectedDateChange" }, providers: [SkyDatepickerAdapterService], viewQueries: [{ propertyName: "datepicker", first: true, predicate: SkyDatepickerCalendarInnerComponent, descendants: true, read: SkyDatepickerCalendarInnerComponent, static: true }], ngImport: i0, template: "<div class=\"sky-datepicker-calendar\">\n <sky-datepicker-inner\n [customDates]=\"customDates\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [selectedDate]=\"selectedDate\"\n [startingDay]=\"startingDay\"\n (calendarModeChange)=\"onCalendarModeChange($event)\"\n (selectedDateChange)=\"onSelectedDateChange($event)\"\n >\n <sky-daypicker\n tabindex=\"0\"\n [customDates]=\"customDates\"\n [isWaiting]=\"isDaypickerWaiting\"\n (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n ></sky-daypicker>\n <sky-monthpicker tabindex=\"0\"></sky-monthpicker>\n <sky-yearpicker tabindex=\"0\"></sky-yearpicker>\n </sky-datepicker-inner>\n</div>\n", styles: [".sky-datepicker-calendar{display:block}\n"], dependencies: [{ kind: "component", type: i2.SkyDatepickerCalendarInnerComponent, selector: "sky-datepicker-inner", inputs: ["customDates", "startingDay", "minDate", "maxDate", "selectedDate"], outputs: ["selectedDateChange", "calendarModeChange"] }, { kind: "component", type: i3.SkyDayPickerComponent, selector: "sky-daypicker", inputs: ["customDates", "isWaiting"], outputs: ["calendarDateRangeChange"] }, { kind: "component", type: i4.SkyMonthPickerComponent, selector: "sky-monthpicker" }, { kind: "component", type: i5.SkyYearPickerComponent, selector: "sky-yearpicker" }] });
68
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyDatepickerCalendarComponent, decorators: [{
69
- type: Component,
70
- args: [{ selector: 'sky-datepicker-calendar', providers: [SkyDatepickerAdapterService], template: "<div class=\"sky-datepicker-calendar\">\n <sky-datepicker-inner\n [customDates]=\"customDates\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [selectedDate]=\"selectedDate\"\n [startingDay]=\"startingDay\"\n (calendarModeChange)=\"onCalendarModeChange($event)\"\n (selectedDateChange)=\"onSelectedDateChange($event)\"\n >\n <sky-daypicker\n tabindex=\"0\"\n [customDates]=\"customDates\"\n [isWaiting]=\"isDaypickerWaiting\"\n (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n ></sky-daypicker>\n <sky-monthpicker tabindex=\"0\"></sky-monthpicker>\n <sky-yearpicker tabindex=\"0\"></sky-yearpicker>\n </sky-datepicker-inner>\n</div>\n", styles: [".sky-datepicker-calendar{display:block}\n"] }]
71
- }], ctorParameters: function () { return [{ type: i1.SkyDatepickerConfigService }]; }, propDecorators: { customDates: [{
72
- type: Input
73
- }], isDaypickerWaiting: [{
74
- type: Input
75
- }], minDate: [{
76
- type: Input
77
- }], maxDate: [{
78
- type: Input
79
- }], selectedDate: [{
80
- type: Input
81
- }], startingDay: [{
82
- type: Input
83
- }], calendarDateRangeChange: [{
84
- type: Output
85
- }], calendarModeChange: [{
86
- type: Output
87
- }], selectedDateChange: [{
88
- type: Output
89
- }], datepicker: [{
90
- type: ViewChild,
91
- args: [SkyDatepickerCalendarInnerComponent, {
92
- read: SkyDatepickerCalendarInnerComponent,
93
- static: true,
94
- }]
95
- }] } });
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-calendar.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar.component.ts","../../../../../../../../libs/components/datetime/src/lib/modules/datepicker/datepicker-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core';\n\nimport { SkyDateFormatter } from './date-formatter';\nimport { SkyDatepickerAdapterService } from './datepicker-adapter.service';\nimport { SkyDatepickerCalendarChange } from './datepicker-calendar-change';\nimport { SkyDatepickerCalendarInnerComponent } from './datepicker-calendar-inner.component';\nimport { SkyDatepickerConfigService } from './datepicker-config.service';\nimport { SkyDatepickerCustomDate } from './datepicker-custom-date';\n\n/**\n * @internal\n */\n@Component({\n  selector: 'sky-datepicker-calendar',\n  templateUrl: './datepicker-calendar.component.html',\n  styleUrls: ['./datepicker-calendar.component.scss'],\n  providers: [SkyDatepickerAdapterService],\n})\nexport class SkyDatepickerCalendarComponent {\n  @Input()\n  public customDates: SkyDatepickerCustomDate[] | undefined;\n\n  @Input()\n  public isDaypickerWaiting: boolean | undefined;\n\n  @Input()\n  public minDate: Date | undefined;\n\n  @Input()\n  public maxDate: Date | undefined;\n\n  /** currently selected date */\n  @Input()\n  public selectedDate: Date | undefined;\n\n  /** starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday) */\n  @Input()\n  public set startingDay(start: number | undefined) {\n    this.#_startingDay = start ?? 0;\n  }\n\n  public get startingDay(): number {\n    return this.#_startingDay;\n  }\n\n  @Output()\n  public calendarDateRangeChange = new EventEmitter<\n    SkyDatepickerCalendarChange | undefined\n  >();\n\n  @Output()\n  public calendarModeChange = new EventEmitter<string>();\n\n  @Output()\n  public selectedDateChange = new EventEmitter<Date>(undefined);\n\n  @ViewChild(SkyDatepickerCalendarInnerComponent, {\n    read: SkyDatepickerCalendarInnerComponent,\n    static: true,\n  })\n  public datepicker: SkyDatepickerCalendarInnerComponent | undefined;\n\n  protected _now: Date = new Date();\n\n  #formatter = new SkyDateFormatter();\n\n  #_startingDay = 0;\n\n  #config: SkyDatepickerConfigService;\n\n  constructor(config: SkyDatepickerConfigService) {\n    this.#config = config;\n    this.configureOptions();\n  }\n\n  public configureOptions(): void {\n    Object.assign(this, this.#config);\n  }\n\n  public onCalendarDateRangeChange(\n    event: SkyDatepickerCalendarChange | undefined\n  ): void {\n    this.calendarDateRangeChange.next(event);\n  }\n\n  public onCalendarModeChange(event: string): void {\n    this.calendarModeChange.emit(event);\n  }\n\n  public onSelectedDateChange(event: Date): void {\n    this.selectedDateChange.emit(event);\n  }\n\n  public writeValue(value: Date | undefined): void {\n    if (\n      value !== undefined &&\n      this.#formatter.dateIsValid(value) &&\n      this.selectedDate !== undefined &&\n      this.datepicker?.compareHandlerDay &&\n      this.datepicker.compareHandlerDay(value, this.selectedDate) === 0\n    ) {\n      return;\n    }\n\n    if (value && this.#formatter.dateIsValid(value)) {\n      this.selectedDate = value;\n      this.datepicker?.select(value, false);\n    } else {\n      this.selectedDate = new Date();\n      this.datepicker?.select(new Date(), false);\n    }\n  }\n}\n","<div class=\"sky-datepicker-calendar\">\n  <sky-datepicker-inner\n    [customDates]=\"customDates\"\n    [maxDate]=\"maxDate\"\n    [minDate]=\"minDate\"\n    [selectedDate]=\"selectedDate\"\n    [startingDay]=\"startingDay\"\n    (calendarModeChange)=\"onCalendarModeChange($event)\"\n    (selectedDateChange)=\"onSelectedDateChange($event)\"\n  >\n    <sky-daypicker\n      tabindex=\"0\"\n      [customDates]=\"customDates\"\n      [isWaiting]=\"isDaypickerWaiting\"\n      (calendarDateRangeChange)=\"onCalendarDateRangeChange($event)\"\n    ></sky-daypicker>\n    <sky-monthpicker tabindex=\"0\"></sky-monthpicker>\n    <sky-yearpicker tabindex=\"0\"></sky-yearpicker>\n  </sky-datepicker-inner>\n</div>\n"]}