@ardium-ui/ui 3.4.3 → 3.5.0

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 (56) hide show
  1. package/esm2022/lib/_internal/disablable-component.mjs +1 -1
  2. package/esm2022/lib/_internal/item-storages/simple-item-storage.mjs +8 -3
  3. package/esm2022/lib/buttons/icon-button/icon-button.module.mjs +2 -2
  4. package/esm2022/lib/calendar/calendar.component.mjs +437 -0
  5. package/esm2022/lib/calendar/calendar.defaults.mjs +26 -0
  6. package/esm2022/lib/calendar/calendar.internal-types.mjs +2 -0
  7. package/esm2022/lib/calendar/calendar.module.mjs +24 -0
  8. package/esm2022/lib/calendar/calendar.types.mjs +6 -0
  9. package/esm2022/lib/calendar/index.mjs +5 -0
  10. package/esm2022/lib/calendar/views/days-view/days-view.component.mjs +282 -0
  11. package/esm2022/lib/calendar/views/days-view/days-view.helpers.mjs +65 -0
  12. package/esm2022/lib/calendar/views/months-view/months-view.component.mjs +245 -0
  13. package/esm2022/lib/calendar/views/months-view/months-view.helpers.mjs +22 -0
  14. package/esm2022/lib/calendar/views/years-view/years-view.component.mjs +244 -0
  15. package/esm2022/lib/calendar/views/years-view/years-view.helpers.mjs +14 -0
  16. package/esm2022/lib/inputs/date-input/date-input.component.mjs +357 -0
  17. package/esm2022/lib/inputs/date-input/date-input.defaults.mjs +38 -0
  18. package/esm2022/lib/inputs/date-input/date-input.directive.mjs +59 -0
  19. package/esm2022/lib/inputs/date-input/date-input.module.mjs +50 -0
  20. package/esm2022/lib/inputs/date-input/date-input.serializers.mjs +49 -0
  21. package/esm2022/lib/inputs/date-input/date-input.types.mjs +5 -0
  22. package/esm2022/lib/inputs/date-input/index.mjs +6 -0
  23. package/esm2022/public-api.mjs +3 -2
  24. package/fesm2022/ardium-ui-ui.mjs +1885 -54
  25. package/fesm2022/ardium-ui-ui.mjs.map +1 -1
  26. package/lib/_internal/disablable-component.d.ts +1 -1
  27. package/lib/calendar/calendar.component.d.ts +94 -0
  28. package/lib/calendar/calendar.defaults.d.ts +18 -0
  29. package/lib/calendar/calendar.internal-types.d.ts +4 -0
  30. package/lib/calendar/calendar.module.d.ts +14 -0
  31. package/lib/calendar/calendar.types.d.ts +83 -0
  32. package/lib/calendar/index.d.ts +4 -0
  33. package/lib/calendar/views/days-view/days-view.component.d.ts +68 -0
  34. package/lib/calendar/views/days-view/days-view.helpers.d.ts +20 -0
  35. package/lib/calendar/views/months-view/months-view.component.d.ts +61 -0
  36. package/lib/calendar/views/months-view/months-view.helpers.d.ts +3 -0
  37. package/lib/calendar/views/years-view/years-view.component.d.ts +59 -0
  38. package/lib/calendar/views/years-view/years-view.helpers.d.ts +3 -0
  39. package/lib/inputs/date-input/date-input.component.d.ts +95 -0
  40. package/lib/inputs/date-input/date-input.defaults.d.ts +30 -0
  41. package/lib/inputs/date-input/date-input.directive.d.ts +33 -0
  42. package/lib/inputs/date-input/date-input.module.d.ts +14 -0
  43. package/lib/inputs/date-input/date-input.serializers.d.ts +3 -0
  44. package/lib/inputs/date-input/date-input.types.d.ts +16 -0
  45. package/lib/inputs/date-input/index.d.ts +5 -0
  46. package/package.json +1 -1
  47. package/prebuilt-themes/default/calendar-OLD.css +294 -0
  48. package/prebuilt-themes/default/calendar-OLD.css.map +1 -0
  49. package/prebuilt-themes/default/calendar.css +100 -80
  50. package/prebuilt-themes/default/calendar.css.map +1 -1
  51. package/prebuilt-themes/default/inputs/date-input.css +68 -0
  52. package/prebuilt-themes/default/inputs/date-input.css.map +1 -0
  53. package/public-api.d.ts +2 -0
  54. package/themes/default/calendar-OLD.scss +183 -0
  55. package/themes/default/calendar.scss +120 -98
  56. package/themes/default/inputs/date-input.scss +32 -0
@@ -0,0 +1,244 @@
1
+ import { ChangeDetectionStrategy, Component, computed, HostListener, input, output, viewChild, } from '@angular/core';
2
+ import { isNull } from 'simple-bool';
3
+ import { getCalendarYearsArray, isYearOutOfRange } from './years-view.helpers';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "../../../buttons/icon-button/icon-button.component";
7
+ import * as i3 from "../../../icon/icon.component";
8
+ import * as i4 from "../../../buttons/button/button.component";
9
+ const TODAY = new Date();
10
+ export class YearsViewComponent {
11
+ constructor() {
12
+ this.tabIndex = input.required();
13
+ this.readOnly = input.required();
14
+ this.disabled = input.required();
15
+ this.autoFocus = input.required();
16
+ this._isUsingKeyboard = input.required();
17
+ this.activeYear = input.required();
18
+ this.selectedDate = input.required();
19
+ this.min = input.required();
20
+ this.max = input.required();
21
+ this.currentYearRangeStart = input.required();
22
+ this.yearsArray = computed(() => getCalendarYearsArray(this.currentYearRangeStart(), 24, this.min(), this.max()));
23
+ this.currentAriaLabel = computed(() => {
24
+ return this.highlightedYear()?.toString() ?? '';
25
+ });
26
+ //! outputs
27
+ this.triggerOpenMonthsView = output();
28
+ this.triggerOpenDaysView = output();
29
+ this.focusEvent = output({ alias: 'focus' });
30
+ this.blurEvent = output({ alias: 'blur' });
31
+ this.triggerSelectYear = output();
32
+ this.triggerChangeYearsViewPage = output();
33
+ this.triggerHighlightYear = output();
34
+ this.triggerHighlightNextYear = output();
35
+ this.triggerHighlightPreviousYear = output();
36
+ this.triggerHighlightFirstYear = output();
37
+ this.triggerHighlightLastYear = output();
38
+ this.triggerHighlightSameYearPreviousPage = output();
39
+ this.triggerHighlightSameYearNextPage = output();
40
+ //! calendar entry hover & click
41
+ this.highlightedYear = input.required();
42
+ //! focusing
43
+ this.focusableElement = viewChild.required('focusableElement');
44
+ //! templates
45
+ this.yearsViewHeaderTemplate = input.required();
46
+ this.yearTemplate = input.required();
47
+ //! template contexts
48
+ this.yearsViewHeaderContext = computed(() => {
49
+ const yearRangeStart = this.currentYearRangeStart();
50
+ const yearRangeEnd = yearRangeStart + 23;
51
+ const dateRange = {
52
+ low: new Date(yearRangeStart, 0, 1),
53
+ high: new Date(yearRangeEnd, 0, 1),
54
+ };
55
+ const yearRange = {
56
+ low: yearRangeStart,
57
+ high: yearRangeEnd,
58
+ };
59
+ return {
60
+ nextPage: () => {
61
+ this.triggerChangeYearsViewPage.emit(1);
62
+ },
63
+ prevPage: () => {
64
+ this.triggerChangeYearsViewPage.emit(-1);
65
+ },
66
+ openMonthsView: () => {
67
+ this.triggerOpenMonthsView.emit();
68
+ },
69
+ openDaysView: () => {
70
+ this.triggerOpenDaysView.emit();
71
+ },
72
+ canGoToNextPage: !this.isYearOutOfRange(yearRangeEnd + 1),
73
+ canGoToPreviousPage: !this.isYearOutOfRange(yearRangeStart - 1),
74
+ yearRange: yearRange,
75
+ dateRange,
76
+ $implicit: dateRange,
77
+ };
78
+ });
79
+ this.yearContext = computed(() => {
80
+ return (year) => {
81
+ const date = new Date(year, 1, 1);
82
+ return {
83
+ value: year,
84
+ date,
85
+ $implicit: date,
86
+ select: (year) => {
87
+ this.triggerSelectYear.emit(year);
88
+ },
89
+ };
90
+ };
91
+ });
92
+ }
93
+ onMouseMove() {
94
+ if (this._isUsingKeyboard())
95
+ return;
96
+ if (this.highlightedYear())
97
+ this.triggerHighlightYear.emit(null);
98
+ }
99
+ ngAfterViewInit() {
100
+ if (!this.autoFocus())
101
+ return;
102
+ this.focus();
103
+ this.triggerHighlightYear.emit(this.currentYearRangeStart());
104
+ }
105
+ onCalendarYearMouseover(year) {
106
+ if (this._isUsingKeyboard() || this.disabled() || this.readOnly())
107
+ return;
108
+ this.triggerHighlightYear.emit(year);
109
+ }
110
+ onCalendarYearClick(year) {
111
+ if (this.disabled() || this.readOnly())
112
+ return;
113
+ this.triggerSelectYear.emit(year);
114
+ }
115
+ onYearGridFocus() {
116
+ if (this.disabled() || this.readOnly())
117
+ return;
118
+ this.triggerHighlightFirstYear.emit();
119
+ }
120
+ onYearGridBlur() {
121
+ if (this.disabled() || this.readOnly())
122
+ return;
123
+ this.triggerHighlightYear.emit(null);
124
+ }
125
+ onYearGridClick() {
126
+ if (this.disabled() || this.readOnly())
127
+ return;
128
+ if (this.highlightedYear() !== null)
129
+ return;
130
+ this.triggerHighlightFirstYear.emit();
131
+ }
132
+ //! helpers
133
+ isYearToday(year) {
134
+ return year === TODAY.getFullYear();
135
+ }
136
+ isYearSelected(year) {
137
+ if (year instanceof Date)
138
+ year = year.getFullYear();
139
+ return this.selectedDate() !== null && year === this.selectedDate()?.getFullYear();
140
+ }
141
+ isYearOutOfRange(year) {
142
+ return isYearOutOfRange(year, this.min(), this.max());
143
+ }
144
+ focus() {
145
+ this.focusableElement().nativeElement.focus();
146
+ }
147
+ //! keyboard controls
148
+ onMainGridKeydown(event) {
149
+ if (this.disabled() || this.readOnly())
150
+ return;
151
+ switch (event.code) {
152
+ case 'Space':
153
+ case 'Enter':
154
+ this._onEnterPress(event);
155
+ break;
156
+ case 'ArrowUp':
157
+ this._onArrowUpPress(event);
158
+ break;
159
+ case 'ArrowDown':
160
+ this._onArrowDownPress(event);
161
+ break;
162
+ case 'ArrowLeft':
163
+ this._onArrowLeftPress(event);
164
+ break;
165
+ case 'ArrowRight':
166
+ this._onArrowRightPress(event);
167
+ break;
168
+ case 'Home':
169
+ this._onHomePress(event);
170
+ break;
171
+ case 'End':
172
+ this._onEndPress(event);
173
+ break;
174
+ case 'PageUp':
175
+ this._onPageUpPress(event);
176
+ break;
177
+ case 'PageDown':
178
+ this._onPageDownPress(event);
179
+ break;
180
+ default:
181
+ return;
182
+ }
183
+ }
184
+ //select currently selected entry
185
+ _onEnterPress(event) {
186
+ event.preventDefault();
187
+ const year = this.highlightedYear();
188
+ if (isNull(year))
189
+ return;
190
+ this.triggerSelectYear.emit(year);
191
+ }
192
+ //highlight the entry one line below
193
+ _onArrowDownPress(event) {
194
+ event.preventDefault();
195
+ this.triggerHighlightNextYear.emit(4); //4 years per line
196
+ }
197
+ //highlight the entry one line above
198
+ _onArrowUpPress(event) {
199
+ event.preventDefault();
200
+ this.triggerHighlightPreviousYear.emit(4); //4 years per line
201
+ }
202
+ //highlight next entry
203
+ _onArrowRightPress(event) {
204
+ event.preventDefault();
205
+ this.triggerHighlightNextYear.emit(1);
206
+ }
207
+ //highlight previous entry
208
+ _onArrowLeftPress(event) {
209
+ event.preventDefault();
210
+ this.triggerHighlightPreviousYear.emit(1);
211
+ }
212
+ //highlight first entry on the page
213
+ _onHomePress(event) {
214
+ event.preventDefault();
215
+ this.triggerHighlightFirstYear.emit();
216
+ }
217
+ //highlight last entry on the page
218
+ _onEndPress(event) {
219
+ event.preventDefault();
220
+ this.triggerHighlightLastYear.emit();
221
+ }
222
+ //alone: highlight same entry on the previous page
223
+ //with alt: highlight same entry multiple pages before
224
+ _onPageUpPress(event) {
225
+ event.preventDefault();
226
+ this.triggerHighlightSameYearPreviousPage.emit(event.altKey);
227
+ }
228
+ //alone: highlight same entry on the next page
229
+ //with alt: highlight same entry multiple pages after
230
+ _onPageDownPress(event) {
231
+ event.preventDefault();
232
+ this.triggerHighlightSameYearNextPage.emit(event.altKey);
233
+ }
234
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: YearsViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
235
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: YearsViewComponent, selector: "ard-years-view", inputs: { tabIndex: { classPropertyName: "tabIndex", publicName: "tabIndex", isSignal: true, isRequired: true, transformFunction: null }, readOnly: { classPropertyName: "readOnly", publicName: "readOnly", isSignal: true, isRequired: true, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: true, transformFunction: null }, autoFocus: { classPropertyName: "autoFocus", publicName: "autoFocus", isSignal: true, isRequired: true, transformFunction: null }, _isUsingKeyboard: { classPropertyName: "_isUsingKeyboard", publicName: "_isUsingKeyboard", isSignal: true, isRequired: true, transformFunction: null }, activeYear: { classPropertyName: "activeYear", publicName: "activeYear", isSignal: true, isRequired: true, transformFunction: null }, selectedDate: { classPropertyName: "selectedDate", publicName: "selectedDate", isSignal: true, isRequired: true, transformFunction: null }, min: { classPropertyName: "min", publicName: "min", isSignal: true, isRequired: true, transformFunction: null }, max: { classPropertyName: "max", publicName: "max", isSignal: true, isRequired: true, transformFunction: null }, currentYearRangeStart: { classPropertyName: "currentYearRangeStart", publicName: "currentYearRangeStart", isSignal: true, isRequired: true, transformFunction: null }, highlightedYear: { classPropertyName: "highlightedYear", publicName: "highlightedYear", isSignal: true, isRequired: true, transformFunction: null }, yearsViewHeaderTemplate: { classPropertyName: "yearsViewHeaderTemplate", publicName: "yearsViewHeaderTemplate", isSignal: true, isRequired: true, transformFunction: null }, yearTemplate: { classPropertyName: "yearTemplate", publicName: "yearTemplate", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { triggerOpenMonthsView: "triggerOpenMonthsView", triggerOpenDaysView: "triggerOpenDaysView", focusEvent: "focus", blurEvent: "blur", triggerSelectYear: "triggerSelectYear", triggerChangeYearsViewPage: "triggerChangeYearsViewPage", triggerHighlightYear: "triggerHighlightYear", triggerHighlightNextYear: "triggerHighlightNextYear", triggerHighlightPreviousYear: "triggerHighlightPreviousYear", triggerHighlightFirstYear: "triggerHighlightFirstYear", triggerHighlightLastYear: "triggerHighlightLastYear", triggerHighlightSameYearPreviousPage: "triggerHighlightSameYearPreviousPage", triggerHighlightSameYearNextPage: "triggerHighlightSameYearNextPage" }, host: { listeners: { "mousemove": "onMouseMove()" } }, viewQueries: [{ propertyName: "focusableElement", first: true, predicate: ["focusableElement"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"ard-years-view\">\r\n @if (!readOnly()) {\r\n <div class=\"ard-calendar__top-toolbar\">\r\n <ng-template\r\n #defaultYearsViewHeaderTemplate\r\n let-dateRange=\"dateRange\"\r\n let-nextPage=\"nextPage\"\r\n let-prevPage=\"prevPage\"\r\n let-canGoToNextPage=\"canGoToNextPage\"\r\n let-canGoToPreviousPage=\"canGoToPreviousPage\"\r\n let-openDaysView=\"openDaysView\"\r\n >\r\n <div class=\"ard-calendar__calendar-header\">\r\n <ard-button\r\n class=\"ard-calendar__header-button\"\r\n appearance=\"transparent\"\r\n color=\"none\"\r\n [tabIndex]=\"tabIndex()\"\r\n (click)=\"openDaysView()\"\r\n variant=\"pill\"\r\n >\r\n {{ dateRange.low | date : 'YYYY' }}\r\n &mdash;\r\n {{ dateRange.high | date : 'YYYY' }}\r\n <div class=\"ard-dropdown-arrow\"></div>\r\n </ard-button>\r\n <div class=\"ard-calendar-arrows\">\r\n <ard-icon-button\r\n size=\"small\"\r\n appearance=\"transparent\"\r\n color=\"none\"\r\n (click)=\"prevPage()\"\r\n [tabIndex]=\"tabIndex()\"\r\n [disabled]=\"!canGoToPreviousPage\"\r\n >\r\n <ard-icon>chevron_left</ard-icon>\r\n </ard-icon-button>\r\n <ard-icon-button\r\n size=\"small\"\r\n appearance=\"transparent\"\r\n color=\"none\"\r\n (click)=\"nextPage()\"\r\n [tabIndex]=\"tabIndex()\"\r\n [disabled]=\"!canGoToNextPage\"\r\n >\r\n <ard-icon>chevron_right</ard-icon>\r\n </ard-icon-button>\r\n </div>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template\r\n [ngTemplateOutlet]=\"yearsViewHeaderTemplate() || defaultYearsViewHeaderTemplate\"\r\n [ngTemplateOutletContext]=\"yearsViewHeaderContext()\"\r\n />\r\n </div>\r\n }\r\n <div\r\n #focusableElement\r\n class=\"ard-calendar__simple-grid\"\r\n [tabindex]=\"tabIndex()\"\r\n [ariaLabel]=\"currentAriaLabel()\"\r\n (focus)=\"focusEvent.emit($event)\"\r\n (focus)=\"onYearGridFocus()\"\r\n (blur)=\"blurEvent.emit($event)\"\r\n (blur)=\"onYearGridBlur()\"\r\n (click)=\"onYearGridClick()\"\r\n (keydown)=\"onMainGridKeydown($event)\"\r\n role=\"grid\"\r\n >\r\n @for (year of yearsArray(); track year) {\r\n <div\r\n class=\"ard-calendar__entry\"\r\n [class.ard-calendar__entry-highlighted]=\"highlightedYear() === year.value\"\r\n [class.ard-calendar__entry-disabled]=\"year.disabled\"\r\n [class.ard-calendar__entry-selected]=\"isYearSelected(year.value)\"\r\n [class.ard-calendar-today]=\"isYearToday(year.value)\"\r\n (click)=\"onCalendarYearClick(year.value)\"\r\n (mousemove)=\"$event.stopPropagation()\"\r\n (mouseover)=\"onCalendarYearMouseover(year.value)\"\r\n role=\"gridcell\"\r\n >\r\n <button\r\n type=\"button\"\r\n class=\"ard-calendar__entry-button\"\r\n tabindex=\"-1\"\r\n aria-hidden=\"true\"\r\n >\r\n <div class=\"ard-focus-overlay\"></div>\r\n <div class=\"ard-button-content\">\r\n <ng-template\r\n #defaultYearTemplate\r\n let-year\r\n >\r\n {{ year | date : 'YYYY' }}\r\n </ng-template>\r\n <ng-template\r\n [ngTemplateOutlet]=\"yearTemplate() || defaultYearTemplate\"\r\n [ngTemplateOutletContext]=\"yearContext()(year.value)\"\r\n />\r\n </div>\r\n </button>\r\n </div>\r\n }\r\n </div>\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.ArdiumIconButtonComponent, selector: "ard-icon-button", inputs: ["wrapperClasses", "type", "color", "lightColoring", "compact"] }, { kind: "component", type: i3.ArdiumIconComponent, selector: "ard-icon", inputs: ["ariaLabel", "icon", "filled", "weight", "grade", "opticalSize"] }, { kind: "component", type: i4.ArdiumButtonComponent, selector: "ard-button", inputs: ["icon", "variant", "alignIcon", "vertical"] }, { kind: "pipe", type: i1.DatePipe, name: "date" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
236
+ }
237
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: YearsViewComponent, decorators: [{
238
+ type: Component,
239
+ args: [{ selector: 'ard-years-view', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"ard-years-view\">\r\n @if (!readOnly()) {\r\n <div class=\"ard-calendar__top-toolbar\">\r\n <ng-template\r\n #defaultYearsViewHeaderTemplate\r\n let-dateRange=\"dateRange\"\r\n let-nextPage=\"nextPage\"\r\n let-prevPage=\"prevPage\"\r\n let-canGoToNextPage=\"canGoToNextPage\"\r\n let-canGoToPreviousPage=\"canGoToPreviousPage\"\r\n let-openDaysView=\"openDaysView\"\r\n >\r\n <div class=\"ard-calendar__calendar-header\">\r\n <ard-button\r\n class=\"ard-calendar__header-button\"\r\n appearance=\"transparent\"\r\n color=\"none\"\r\n [tabIndex]=\"tabIndex()\"\r\n (click)=\"openDaysView()\"\r\n variant=\"pill\"\r\n >\r\n {{ dateRange.low | date : 'YYYY' }}\r\n &mdash;\r\n {{ dateRange.high | date : 'YYYY' }}\r\n <div class=\"ard-dropdown-arrow\"></div>\r\n </ard-button>\r\n <div class=\"ard-calendar-arrows\">\r\n <ard-icon-button\r\n size=\"small\"\r\n appearance=\"transparent\"\r\n color=\"none\"\r\n (click)=\"prevPage()\"\r\n [tabIndex]=\"tabIndex()\"\r\n [disabled]=\"!canGoToPreviousPage\"\r\n >\r\n <ard-icon>chevron_left</ard-icon>\r\n </ard-icon-button>\r\n <ard-icon-button\r\n size=\"small\"\r\n appearance=\"transparent\"\r\n color=\"none\"\r\n (click)=\"nextPage()\"\r\n [tabIndex]=\"tabIndex()\"\r\n [disabled]=\"!canGoToNextPage\"\r\n >\r\n <ard-icon>chevron_right</ard-icon>\r\n </ard-icon-button>\r\n </div>\r\n </div>\r\n </ng-template>\r\n\r\n <ng-template\r\n [ngTemplateOutlet]=\"yearsViewHeaderTemplate() || defaultYearsViewHeaderTemplate\"\r\n [ngTemplateOutletContext]=\"yearsViewHeaderContext()\"\r\n />\r\n </div>\r\n }\r\n <div\r\n #focusableElement\r\n class=\"ard-calendar__simple-grid\"\r\n [tabindex]=\"tabIndex()\"\r\n [ariaLabel]=\"currentAriaLabel()\"\r\n (focus)=\"focusEvent.emit($event)\"\r\n (focus)=\"onYearGridFocus()\"\r\n (blur)=\"blurEvent.emit($event)\"\r\n (blur)=\"onYearGridBlur()\"\r\n (click)=\"onYearGridClick()\"\r\n (keydown)=\"onMainGridKeydown($event)\"\r\n role=\"grid\"\r\n >\r\n @for (year of yearsArray(); track year) {\r\n <div\r\n class=\"ard-calendar__entry\"\r\n [class.ard-calendar__entry-highlighted]=\"highlightedYear() === year.value\"\r\n [class.ard-calendar__entry-disabled]=\"year.disabled\"\r\n [class.ard-calendar__entry-selected]=\"isYearSelected(year.value)\"\r\n [class.ard-calendar-today]=\"isYearToday(year.value)\"\r\n (click)=\"onCalendarYearClick(year.value)\"\r\n (mousemove)=\"$event.stopPropagation()\"\r\n (mouseover)=\"onCalendarYearMouseover(year.value)\"\r\n role=\"gridcell\"\r\n >\r\n <button\r\n type=\"button\"\r\n class=\"ard-calendar__entry-button\"\r\n tabindex=\"-1\"\r\n aria-hidden=\"true\"\r\n >\r\n <div class=\"ard-focus-overlay\"></div>\r\n <div class=\"ard-button-content\">\r\n <ng-template\r\n #defaultYearTemplate\r\n let-year\r\n >\r\n {{ year | date : 'YYYY' }}\r\n </ng-template>\r\n <ng-template\r\n [ngTemplateOutlet]=\"yearTemplate() || defaultYearTemplate\"\r\n [ngTemplateOutletContext]=\"yearContext()(year.value)\"\r\n />\r\n </div>\r\n </button>\r\n </div>\r\n }\r\n </div>\r\n</div>\r\n" }]
240
+ }], propDecorators: { onMouseMove: [{
241
+ type: HostListener,
242
+ args: ['mousemove']
243
+ }] } });
244
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"years-view.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui/src/lib/calendar/views/years-view/years-view.component.ts","../../../../../../../projects/ui/src/lib/calendar/views/years-view/years-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  computed,\r\n  ElementRef,\r\n  HostListener,\r\n  input,\r\n  output,\r\n  TemplateRef,\r\n  viewChild,\r\n} from '@angular/core';\r\nimport { isNull } from 'simple-bool';\r\nimport { CalendarYearContext, CalendarYearsViewHeaderContext, DateRange, YearRange } from '../../calendar.types';\r\nimport { getCalendarYearsArray, isYearOutOfRange } from './years-view.helpers';\r\n\r\nconst TODAY = new Date();\r\n\r\n@Component({\r\n  selector: 'ard-years-view',\r\n  templateUrl: './years-view.component.html',\r\n  styleUrl: './years-view.component.scss',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class YearsViewComponent implements AfterViewInit {\r\n  readonly tabIndex = input.required<number>();\r\n  readonly readOnly = input.required<boolean>();\r\n  readonly disabled = input.required<boolean>();\r\n\r\n  readonly autoFocus = input.required<boolean>();\r\n\r\n  readonly _isUsingKeyboard = input.required<boolean>();\r\n\r\n  @HostListener('mousemove')\r\n  onMouseMove(): void {\r\n    if (this._isUsingKeyboard()) return;\r\n    if (this.highlightedYear()) this.triggerHighlightYear.emit(null);\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (!this.autoFocus()) return;\r\n    this.focus();\r\n    this.triggerHighlightYear.emit(this.currentYearRangeStart());\r\n  }\r\n\r\n  readonly activeYear = input.required<number>();\r\n\r\n  readonly selectedDate = input.required<Date | null>();\r\n\r\n  readonly min = input.required<Date | null>();\r\n  readonly max = input.required<Date | null>();\r\n\r\n  readonly currentYearRangeStart = input.required<number>();\r\n  readonly yearsArray = computed(() => getCalendarYearsArray(this.currentYearRangeStart(), 24, this.min(), this.max()));\r\n\r\n  readonly currentAriaLabel = computed(() => {\r\n    return this.highlightedYear()?.toString() ?? '';\r\n  });\r\n\r\n  //! outputs\r\n  readonly triggerOpenMonthsView = output<void>();\r\n  readonly triggerOpenDaysView = output<void>();\r\n\r\n  readonly focusEvent = output<FocusEvent>({ alias: 'focus' });\r\n  readonly blurEvent = output<FocusEvent>({ alias: 'blur' });\r\n\r\n  readonly triggerSelectYear = output<number>();\r\n  readonly triggerChangeYearsViewPage = output<number>();\r\n\r\n  readonly triggerHighlightYear = output<number | null>();\r\n  readonly triggerHighlightNextYear = output<number>();\r\n  readonly triggerHighlightPreviousYear = output<number>();\r\n  readonly triggerHighlightFirstYear = output<void>();\r\n  readonly triggerHighlightLastYear = output<void>();\r\n  readonly triggerHighlightSameYearPreviousPage = output<boolean>();\r\n  readonly triggerHighlightSameYearNextPage = output<boolean>();\r\n\r\n  //! calendar entry hover & click\r\n  readonly highlightedYear = input.required<number | null>();\r\n\r\n  onCalendarYearMouseover(year: number): void {\r\n    if (this._isUsingKeyboard() || this.disabled() || this.readOnly()) return;\r\n\r\n    this.triggerHighlightYear.emit(year);\r\n  }\r\n  onCalendarYearClick(year: number): void {\r\n    if (this.disabled() || this.readOnly()) return;\r\n    this.triggerSelectYear.emit(year);\r\n  }\r\n  onYearGridFocus(): void {\r\n    if (this.disabled() || this.readOnly()) return;\r\n    this.triggerHighlightFirstYear.emit();\r\n  }\r\n  onYearGridBlur(): void {\r\n    if (this.disabled() || this.readOnly()) return;\r\n    this.triggerHighlightYear.emit(null);\r\n  }\r\n  onYearGridClick(): void {\r\n    if (this.disabled() || this.readOnly()) return;\r\n    if (this.highlightedYear() !== null) return;\r\n    this.triggerHighlightFirstYear.emit();\r\n  }\r\n\r\n  //! helpers\r\n  isYearToday(year: number): boolean {\r\n    return year === TODAY.getFullYear();\r\n  }\r\n  isYearSelected(year: number | Date): boolean {\r\n    if (year instanceof Date) year = year.getFullYear();\r\n    return this.selectedDate() !== null && year === this.selectedDate()?.getFullYear();\r\n  }\r\n  isYearOutOfRange(year: number): number {\r\n    return isYearOutOfRange(year, this.min(), this.max());\r\n  }\r\n\r\n  //! focusing\r\n  readonly focusableElement = viewChild.required<ElementRef<HTMLElement>>('focusableElement');\r\n\r\n  focus(): void {\r\n    this.focusableElement().nativeElement.focus();\r\n  }\r\n\r\n  //! keyboard controls\r\n  onMainGridKeydown(event: KeyboardEvent): void {\r\n    if (this.disabled() || this.readOnly()) return;\r\n    switch (event.code) {\r\n      case 'Space':\r\n      case 'Enter':\r\n        this._onEnterPress(event);\r\n        break;\r\n      case 'ArrowUp':\r\n        this._onArrowUpPress(event);\r\n        break;\r\n      case 'ArrowDown':\r\n        this._onArrowDownPress(event);\r\n        break;\r\n      case 'ArrowLeft':\r\n        this._onArrowLeftPress(event);\r\n        break;\r\n      case 'ArrowRight':\r\n        this._onArrowRightPress(event);\r\n        break;\r\n      case 'Home':\r\n        this._onHomePress(event);\r\n        break;\r\n      case 'End':\r\n        this._onEndPress(event);\r\n        break;\r\n      case 'PageUp':\r\n        this._onPageUpPress(event);\r\n        break;\r\n      case 'PageDown':\r\n        this._onPageDownPress(event);\r\n        break;\r\n\r\n      default:\r\n        return;\r\n    }\r\n  }\r\n  //select currently selected entry\r\n  private _onEnterPress(event: KeyboardEvent): void {\r\n    event.preventDefault();\r\n\r\n    const year = this.highlightedYear();\r\n    if (isNull(year)) return;\r\n\r\n    this.triggerSelectYear.emit(year);\r\n  }\r\n  //highlight the entry one line below\r\n  private _onArrowDownPress(event: KeyboardEvent): void {\r\n    event.preventDefault();\r\n\r\n    this.triggerHighlightNextYear.emit(4); //4 years per line\r\n  }\r\n  //highlight the entry one line above\r\n  private _onArrowUpPress(event: KeyboardEvent): void {\r\n    event.preventDefault();\r\n\r\n    this.triggerHighlightPreviousYear.emit(4); //4 years per line\r\n  }\r\n  //highlight next entry\r\n  private _onArrowRightPress(event: KeyboardEvent): void {\r\n    event.preventDefault();\r\n\r\n    this.triggerHighlightNextYear.emit(1);\r\n  }\r\n  //highlight previous entry\r\n  private _onArrowLeftPress(event: KeyboardEvent): void {\r\n    event.preventDefault();\r\n\r\n    this.triggerHighlightPreviousYear.emit(1);\r\n  }\r\n  //highlight first entry on the page\r\n  private _onHomePress(event: KeyboardEvent): void {\r\n    event.preventDefault();\r\n\r\n    this.triggerHighlightFirstYear.emit();\r\n  }\r\n  //highlight last entry on the page\r\n  private _onEndPress(event: KeyboardEvent): void {\r\n    event.preventDefault();\r\n\r\n    this.triggerHighlightLastYear.emit();\r\n  }\r\n  //alone: highlight same entry on the previous page\r\n  //with alt: highlight same entry multiple pages before\r\n  private _onPageUpPress(event: KeyboardEvent): void {\r\n    event.preventDefault();\r\n\r\n    this.triggerHighlightSameYearPreviousPage.emit(event.altKey);\r\n  }\r\n  //alone: highlight same entry on the next page\r\n  //with alt: highlight same entry multiple pages after\r\n  private _onPageDownPress(event: KeyboardEvent): void {\r\n    event.preventDefault();\r\n\r\n    this.triggerHighlightSameYearNextPage.emit(event.altKey);\r\n  }\r\n\r\n  //! templates\r\n  readonly yearsViewHeaderTemplate = input.required<TemplateRef<CalendarYearsViewHeaderContext> | undefined>();\r\n  readonly yearTemplate = input.required<TemplateRef<CalendarYearContext> | undefined>();\r\n\r\n  //! template contexts\r\n  readonly yearsViewHeaderContext = computed<CalendarYearsViewHeaderContext>(() => {\r\n    const yearRangeStart = this.currentYearRangeStart();\r\n    const yearRangeEnd = yearRangeStart + 23;\r\n    const dateRange: DateRange = {\r\n      low: new Date(yearRangeStart, 0, 1),\r\n      high: new Date(yearRangeEnd, 0, 1),\r\n    };\r\n    const yearRange: YearRange = {\r\n      low: yearRangeStart,\r\n      high: yearRangeEnd,\r\n    };\r\n    return {\r\n      nextPage: () => {\r\n        this.triggerChangeYearsViewPage.emit(1);\r\n      },\r\n      prevPage: () => {\r\n        this.triggerChangeYearsViewPage.emit(-1);\r\n      },\r\n      openMonthsView: () => {\r\n        this.triggerOpenMonthsView.emit();\r\n      },\r\n      openDaysView: () => {\r\n        this.triggerOpenDaysView.emit();\r\n      },\r\n      canGoToNextPage: !this.isYearOutOfRange(yearRangeEnd + 1),\r\n      canGoToPreviousPage: !this.isYearOutOfRange(yearRangeStart - 1),\r\n      yearRange: yearRange,\r\n      dateRange,\r\n      $implicit: dateRange,\r\n    };\r\n  });\r\n  readonly yearContext = computed<(year: number) => CalendarYearContext>(() => {\r\n    return (year: number) => {\r\n      const date = new Date(year, 1, 1);\r\n      return {\r\n        value: year,\r\n        date,\r\n        $implicit: date,\r\n        select: (year: number) => {\r\n          this.triggerSelectYear.emit(year);\r\n        },\r\n      };\r\n    };\r\n  });\r\n}\r\n","<div class=\"ard-years-view\">\r\n  @if (!readOnly()) {\r\n  <div class=\"ard-calendar__top-toolbar\">\r\n    <ng-template\r\n      #defaultYearsViewHeaderTemplate\r\n      let-dateRange=\"dateRange\"\r\n      let-nextPage=\"nextPage\"\r\n      let-prevPage=\"prevPage\"\r\n      let-canGoToNextPage=\"canGoToNextPage\"\r\n      let-canGoToPreviousPage=\"canGoToPreviousPage\"\r\n      let-openDaysView=\"openDaysView\"\r\n    >\r\n      <div class=\"ard-calendar__calendar-header\">\r\n        <ard-button\r\n          class=\"ard-calendar__header-button\"\r\n          appearance=\"transparent\"\r\n          color=\"none\"\r\n          [tabIndex]=\"tabIndex()\"\r\n          (click)=\"openDaysView()\"\r\n          variant=\"pill\"\r\n        >\r\n          {{ dateRange.low | date : 'YYYY' }}\r\n          &mdash;\r\n          {{ dateRange.high | date : 'YYYY' }}\r\n          <div class=\"ard-dropdown-arrow\"></div>\r\n        </ard-button>\r\n        <div class=\"ard-calendar-arrows\">\r\n          <ard-icon-button\r\n            size=\"small\"\r\n            appearance=\"transparent\"\r\n            color=\"none\"\r\n            (click)=\"prevPage()\"\r\n            [tabIndex]=\"tabIndex()\"\r\n            [disabled]=\"!canGoToPreviousPage\"\r\n          >\r\n            <ard-icon>chevron_left</ard-icon>\r\n          </ard-icon-button>\r\n          <ard-icon-button\r\n            size=\"small\"\r\n            appearance=\"transparent\"\r\n            color=\"none\"\r\n            (click)=\"nextPage()\"\r\n            [tabIndex]=\"tabIndex()\"\r\n            [disabled]=\"!canGoToNextPage\"\r\n          >\r\n            <ard-icon>chevron_right</ard-icon>\r\n          </ard-icon-button>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n\r\n    <ng-template\r\n      [ngTemplateOutlet]=\"yearsViewHeaderTemplate() || defaultYearsViewHeaderTemplate\"\r\n      [ngTemplateOutletContext]=\"yearsViewHeaderContext()\"\r\n    />\r\n  </div>\r\n  }\r\n  <div\r\n    #focusableElement\r\n    class=\"ard-calendar__simple-grid\"\r\n    [tabindex]=\"tabIndex()\"\r\n    [ariaLabel]=\"currentAriaLabel()\"\r\n    (focus)=\"focusEvent.emit($event)\"\r\n    (focus)=\"onYearGridFocus()\"\r\n    (blur)=\"blurEvent.emit($event)\"\r\n    (blur)=\"onYearGridBlur()\"\r\n    (click)=\"onYearGridClick()\"\r\n    (keydown)=\"onMainGridKeydown($event)\"\r\n    role=\"grid\"\r\n  >\r\n    @for (year of yearsArray(); track year) {\r\n    <div\r\n      class=\"ard-calendar__entry\"\r\n      [class.ard-calendar__entry-highlighted]=\"highlightedYear() === year.value\"\r\n      [class.ard-calendar__entry-disabled]=\"year.disabled\"\r\n      [class.ard-calendar__entry-selected]=\"isYearSelected(year.value)\"\r\n      [class.ard-calendar-today]=\"isYearToday(year.value)\"\r\n      (click)=\"onCalendarYearClick(year.value)\"\r\n      (mousemove)=\"$event.stopPropagation()\"\r\n      (mouseover)=\"onCalendarYearMouseover(year.value)\"\r\n      role=\"gridcell\"\r\n    >\r\n      <button\r\n        type=\"button\"\r\n        class=\"ard-calendar__entry-button\"\r\n        tabindex=\"-1\"\r\n        aria-hidden=\"true\"\r\n      >\r\n        <div class=\"ard-focus-overlay\"></div>\r\n        <div class=\"ard-button-content\">\r\n          <ng-template\r\n            #defaultYearTemplate\r\n            let-year\r\n          >\r\n            {{ year | date : 'YYYY' }}\r\n          </ng-template>\r\n          <ng-template\r\n            [ngTemplateOutlet]=\"yearTemplate() || defaultYearTemplate\"\r\n            [ngTemplateOutletContext]=\"yearContext()(year.value)\"\r\n          />\r\n        </div>\r\n      </button>\r\n    </div>\r\n    }\r\n  </div>\r\n</div>\r\n"]}
@@ -0,0 +1,14 @@
1
+ import { isDefined } from 'simple-bool';
2
+ export function getCalendarYearsArray(startYear, yearCount, min, max) {
3
+ return new Array(yearCount).fill(startYear).map((v, i) => ({ value: v + i, disabled: !!isYearOutOfRange(v + i, min, max) }));
4
+ }
5
+ export function isYearOutOfRange(year, min, max) {
6
+ const dateForMinComparison = new Date(year, 11, 31);
7
+ if (isDefined(min) && dateForMinComparison < min)
8
+ return -1;
9
+ const dateForMaxComparison = new Date(year, 0, 1);
10
+ if (isDefined(max) && dateForMaxComparison > max)
11
+ return 1;
12
+ return 0;
13
+ }
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieWVhcnMtdmlldy5oZWxwZXJzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvc3JjL2xpYi9jYWxlbmRhci92aWV3cy95ZWFycy12aWV3L3llYXJzLXZpZXcuaGVscGVycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBR3hDLE1BQU0sVUFBVSxxQkFBcUIsQ0FDbkMsU0FBaUIsRUFDakIsU0FBaUIsRUFDakIsR0FBZ0IsRUFDaEIsR0FBZ0I7SUFFaEIsT0FBTyxJQUFJLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxDQUFDLEdBQUcsQ0FBQyxFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDL0gsQ0FBQztBQUNELE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxJQUFZLEVBQUUsR0FBZ0IsRUFBRSxHQUFnQjtJQUMvRSxNQUFNLG9CQUFvQixHQUFHLElBQUksSUFBSSxDQUFDLElBQUksRUFBRSxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDcEQsSUFBSSxTQUFTLENBQUMsR0FBRyxDQUFDLElBQUksb0JBQW9CLEdBQUcsR0FBRztRQUFFLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFFNUQsTUFBTSxvQkFBb0IsR0FBRyxJQUFJLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ2xELElBQUksU0FBUyxDQUFDLEdBQUcsQ0FBQyxJQUFJLG9CQUFvQixHQUFHLEdBQUc7UUFBRSxPQUFPLENBQUMsQ0FBQztJQUUzRCxPQUFPLENBQUMsQ0FBQztBQUNYLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc0RlZmluZWQgfSBmcm9tICdzaW1wbGUtYm9vbCc7XHJcbmltcG9ydCB7IENhbGVuZGFyQXJyYXlJdGVtIH0gZnJvbSAnLi4vLi4vY2FsZW5kYXIuaW50ZXJuYWwtdHlwZXMnO1xyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGdldENhbGVuZGFyWWVhcnNBcnJheShcclxuICBzdGFydFllYXI6IG51bWJlcixcclxuICB5ZWFyQ291bnQ6IG51bWJlcixcclxuICBtaW46IERhdGUgfCBudWxsLFxyXG4gIG1heDogRGF0ZSB8IG51bGxcclxuKTogQ2FsZW5kYXJBcnJheUl0ZW1bXSB7XHJcbiAgcmV0dXJuIG5ldyBBcnJheSh5ZWFyQ291bnQpLmZpbGwoc3RhcnRZZWFyKS5tYXAoKHYsIGkpID0+ICh7IHZhbHVlOiB2ICsgaSwgZGlzYWJsZWQ6ICEhaXNZZWFyT3V0T2ZSYW5nZSh2ICsgaSwgbWluLCBtYXgpIH0pKTtcclxufVxyXG5leHBvcnQgZnVuY3Rpb24gaXNZZWFyT3V0T2ZSYW5nZSh5ZWFyOiBudW1iZXIsIG1pbjogRGF0ZSB8IG51bGwsIG1heDogRGF0ZSB8IG51bGwpOiBudW1iZXIge1xyXG4gIGNvbnN0IGRhdGVGb3JNaW5Db21wYXJpc29uID0gbmV3IERhdGUoeWVhciwgMTEsIDMxKTtcclxuICBpZiAoaXNEZWZpbmVkKG1pbikgJiYgZGF0ZUZvck1pbkNvbXBhcmlzb24gPCBtaW4pIHJldHVybiAtMTtcclxuXHJcbiAgY29uc3QgZGF0ZUZvck1heENvbXBhcmlzb24gPSBuZXcgRGF0ZSh5ZWFyLCAwLCAxKTtcclxuICBpZiAoaXNEZWZpbmVkKG1heCkgJiYgZGF0ZUZvck1heENvbXBhcmlzb24gPiBtYXgpIHJldHVybiAxO1xyXG5cclxuICByZXR1cm4gMDtcclxufVxyXG4iXX0=