@fundamental-ngx/core 0.52.2-rc.26 → 0.52.2-rc.28
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/calendar/calendar-views/calendar-day-view/calendar-day-view.component.d.ts +1 -1
- package/calendar/calendar-views/calendar-month-view/calendar-month-view.component.d.ts +71 -7
- package/calendar/calendar-views/calendar-year-view/calendar-year-view.component.d.ts +68 -3
- package/calendar/calendar.component.d.ts +12 -1
- package/calendar/calendar.service.d.ts +4 -1
- package/calendar/models/calendar-month.d.ts +6 -1
- package/calendar/models/calendar-year-grid.d.ts +6 -1
- package/date-picker/date-picker.component.d.ts +6 -1
- package/esm2022/calendar/calendar-header/calendar-header.component.mjs +3 -3
- package/esm2022/calendar/calendar-views/calendar-aggregated-year-view/calendar-aggregated-year-view.component.mjs +2 -2
- package/esm2022/calendar/calendar-views/calendar-day-view/calendar-day-view.component.mjs +4 -3
- package/esm2022/calendar/calendar-views/calendar-month-view/calendar-month-view.component.mjs +210 -21
- package/esm2022/calendar/calendar-views/calendar-year-view/calendar-year-view.component.mjs +196 -9
- package/esm2022/calendar/calendar.component.mjs +40 -8
- package/esm2022/calendar/calendar.service.mjs +2 -2
- package/esm2022/calendar/models/calendar-month.mjs +1 -1
- package/esm2022/calendar/models/calendar-year-grid.mjs +1 -1
- package/esm2022/date-picker/date-picker.component.mjs +18 -4
- package/esm2022/datetime-picker/datetime-picker.component.mjs +2 -2
- package/fesm2022/fundamental-ngx-core-calendar.mjs +448 -41
- package/fesm2022/fundamental-ngx-core-calendar.mjs.map +1 -1
- package/fesm2022/fundamental-ngx-core-date-picker.mjs +17 -3
- package/fesm2022/fundamental-ngx-core-date-picker.mjs.map +1 -1
- package/fesm2022/fundamental-ngx-core-datetime-picker.mjs +1 -1
- package/fesm2022/fundamental-ngx-core-datetime-picker.mjs.map +1 -1
- package/package.json +15 -15
|
@@ -159,7 +159,7 @@ export declare class CalendarDayViewComponent<D> implements OnInit, OnChanges, F
|
|
|
159
159
|
* @param day The calendar day to be selected.
|
|
160
160
|
* @param event Optional mouse event for handling event propagation.
|
|
161
161
|
*/
|
|
162
|
-
selectDate(day: CalendarDay<D>, event?: MouseEvent): void;
|
|
162
|
+
selectDate(day: CalendarDay<D>, event?: MouseEvent | KeyboardEvent): void;
|
|
163
163
|
/**
|
|
164
164
|
* Toggles the selection of a week on the calendar.
|
|
165
165
|
* If the provided week is already fully selected, it will deselect it.
|
|
@@ -3,6 +3,7 @@ import { DateTimeFormats, DatetimeAdapter } from '@fundamental-ngx/core/datetime
|
|
|
3
3
|
import { CalendarService } from '../../calendar.service';
|
|
4
4
|
import { CalendarMonth } from '../../models/calendar-month';
|
|
5
5
|
import { EscapeFocusFunction, FocusableCalendarView } from '../../models/common';
|
|
6
|
+
import { DateRange } from '../../models/date-range';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
/** Component representing the month view of the calendar. */
|
|
8
9
|
export declare class CalendarMonthViewComponent<D> implements OnInit, OnChanges, FocusableCalendarView {
|
|
@@ -19,13 +20,22 @@ export declare class CalendarMonthViewComponent<D> implements OnInit, OnChanges,
|
|
|
19
20
|
focusEscapeFunction: EscapeFocusFunction;
|
|
20
21
|
/** A year the month view is referring to */
|
|
21
22
|
year: number;
|
|
23
|
+
/** Whether to pick the date range in month year format without picking days */
|
|
24
|
+
isDateRangeMonthYearFormat: boolean;
|
|
22
25
|
/** An event fired when a new month is selected */
|
|
23
26
|
readonly monthClicked: EventEmitter<number>;
|
|
27
|
+
/** Event thrown every time selected first or last date in range mode is changed */
|
|
28
|
+
readonly selectedRangeDateChange: EventEmitter<DateRange<D>>;
|
|
29
|
+
/**
|
|
30
|
+
* Whether user wants to mark month cells on hover.
|
|
31
|
+
* Works only on range mode, when start month is selected.
|
|
32
|
+
*/
|
|
33
|
+
rangeHoverEffect: boolean;
|
|
24
34
|
/**
|
|
25
35
|
* @hidden
|
|
26
36
|
* Month grid table
|
|
27
37
|
*/
|
|
28
|
-
_calendarMonthListGrid: CalendarMonth[][];
|
|
38
|
+
_calendarMonthListGrid: CalendarMonth<D>[][];
|
|
29
39
|
/**
|
|
30
40
|
* @hidden
|
|
31
41
|
* A number offset used to achieve the 1-12 representation of the calendar
|
|
@@ -42,6 +52,9 @@ export declare class CalendarMonthViewComponent<D> implements OnInit, OnChanges,
|
|
|
42
52
|
/** @hidden */
|
|
43
53
|
private _initiated;
|
|
44
54
|
/** @hidden */
|
|
55
|
+
private _selectedRangeDate;
|
|
56
|
+
private _isOnRangePick;
|
|
57
|
+
/** @hidden */
|
|
45
58
|
constructor(_eRef: ElementRef, _changeDetectorRef: ChangeDetectorRef, _calendarService: CalendarService, _dateTimeFormats: DateTimeFormats, _dateTimeAdapter: DatetimeAdapter<D>);
|
|
46
59
|
/** @hidden */
|
|
47
60
|
ngOnInit(): void;
|
|
@@ -63,13 +76,17 @@ export declare class CalendarMonthViewComponent<D> implements OnInit, OnChanges,
|
|
|
63
76
|
* Selected date label ID
|
|
64
77
|
*/
|
|
65
78
|
get _selectedDateLabelId(): string;
|
|
66
|
-
/**
|
|
67
|
-
|
|
79
|
+
/** The currently selected FdDates model start and end in range mode. */
|
|
80
|
+
set selectedRangeDate(dateRange: DateRange<D>);
|
|
81
|
+
get selectedRangeDate(): DateRange<D>;
|
|
68
82
|
/**
|
|
69
|
-
*
|
|
70
|
-
*
|
|
83
|
+
* @hidden
|
|
84
|
+
* Amount of selected months
|
|
85
|
+
* 0, when there is no month selected, or start month is invalid,
|
|
86
|
+
* 1, when there is only valid start month, or end month is same as start month,
|
|
87
|
+
* 2, when both dates are valid
|
|
71
88
|
*/
|
|
72
|
-
|
|
89
|
+
get _selectCounter(): number;
|
|
73
90
|
/**
|
|
74
91
|
* @hidden
|
|
75
92
|
* Method for handling the keyboard events (a11y)
|
|
@@ -100,6 +117,53 @@ export declare class CalendarMonthViewComponent<D> implements OnInit, OnChanges,
|
|
|
100
117
|
* Method that check if this is selected month
|
|
101
118
|
*/
|
|
102
119
|
_isSelected(id: number): boolean;
|
|
120
|
+
/** Method for handling the mouse click event when a month is selected */
|
|
121
|
+
selectMonth(monthCell: CalendarMonth<D>, event?: MouseEvent | KeyboardEvent): void;
|
|
122
|
+
/**
|
|
123
|
+
* Set focus on month cell.
|
|
124
|
+
* It can be a selected cell, current month cell or first cell in the list
|
|
125
|
+
*/
|
|
126
|
+
setFocusOnCell(): void;
|
|
127
|
+
/**
|
|
128
|
+
* @hidden
|
|
129
|
+
* Handles hover effect for range selection mode.
|
|
130
|
+
* @param month The calendar month that is hovered.
|
|
131
|
+
*/
|
|
132
|
+
_handleRangeHover(month: CalendarMonth<D>): void;
|
|
133
|
+
/**
|
|
134
|
+
* @hidden
|
|
135
|
+
* Handles the hover effect for range selection.
|
|
136
|
+
* Toggles the hover effect based on the selection state and event.
|
|
137
|
+
* @param event Optional mouse event for handling hover effect.
|
|
138
|
+
*/
|
|
139
|
+
private _handleRangeHoverEffect;
|
|
140
|
+
/**
|
|
141
|
+
* @hidden
|
|
142
|
+
* Selects or updates the range of dates in range mode.
|
|
143
|
+
* Handles the start and end dates and updates the selected range.
|
|
144
|
+
* @param month The calendar month to be selected or updated in the range.
|
|
145
|
+
*/
|
|
146
|
+
private _selectRangeDate;
|
|
147
|
+
/**
|
|
148
|
+
* @hidden
|
|
149
|
+
* Orders the start and end dates for the range selection.
|
|
150
|
+
* Ensures the start date is before or equal to the end date.
|
|
151
|
+
* @param date1 The first date.
|
|
152
|
+
* @param date2 The second date.
|
|
153
|
+
* @returns An object containing the ordered start and end dates.
|
|
154
|
+
*/
|
|
155
|
+
private _getOrderedRange;
|
|
156
|
+
/**
|
|
157
|
+
* @hidden
|
|
158
|
+
* Change properties of range months, this method is called, to not rebuild whole grid from scratch,
|
|
159
|
+
* it just changes properties of newly selected/unselected months.
|
|
160
|
+
*/
|
|
161
|
+
private _changeSelectedRangeMonths;
|
|
162
|
+
/**
|
|
163
|
+
* @hidden
|
|
164
|
+
* Check if dates are equal
|
|
165
|
+
*/
|
|
166
|
+
private _isSameDate;
|
|
103
167
|
/**
|
|
104
168
|
* @hidden
|
|
105
169
|
* Method that create month grid with required meta data
|
|
@@ -118,5 +182,5 @@ export declare class CalendarMonthViewComponent<D> implements OnInit, OnChanges,
|
|
|
118
182
|
/** @hidden */
|
|
119
183
|
private _focusOnCellByIndex;
|
|
120
184
|
static ɵfac: i0.ɵɵFactoryDeclaration<CalendarMonthViewComponent<any>, never>;
|
|
121
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CalendarMonthViewComponent<any>, "fd-calendar-month-view", never, { "id": { "alias": "id"; "required": false; }; "monthSelected": { "alias": "monthSelected"; "required": false; }; "focusEscapeFunction": { "alias": "focusEscapeFunction"; "required": false; }; "year": { "alias": "year"; "required": false; }; }, { "monthClicked": "monthClicked"; }, never, never, true, never>;
|
|
185
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CalendarMonthViewComponent<any>, "fd-calendar-month-view", never, { "id": { "alias": "id"; "required": false; }; "monthSelected": { "alias": "monthSelected"; "required": false; }; "focusEscapeFunction": { "alias": "focusEscapeFunction"; "required": false; }; "year": { "alias": "year"; "required": false; }; "isDateRangeMonthYearFormat": { "alias": "isDateRangeMonthYearFormat"; "required": false; }; "rangeHoverEffect": { "alias": "rangeHoverEffect"; "required": false; }; "selectedRangeDate": { "alias": "selectedRangeDate"; "required": false; }; }, { "monthClicked": "monthClicked"; "selectedRangeDateChange": "selectedRangeDateChange"; }, never, never, true, never>;
|
|
122
186
|
}
|
|
@@ -3,6 +3,7 @@ import { DateTimeFormats, DatetimeAdapter } from '@fundamental-ngx/core/datetime
|
|
|
3
3
|
import { CalendarService } from '../../calendar.service';
|
|
4
4
|
import { CalendarYear, CalendarYearGrid } from '../../models/calendar-year-grid';
|
|
5
5
|
import { EscapeFocusFunction, FocusableCalendarView } from '../../models/common';
|
|
6
|
+
import { DateRange } from '../../models/date-range';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
/** Component representing the YearView of the Calendar Component. */
|
|
8
9
|
export declare class CalendarYearViewComponent<D> implements OnInit, OnChanges, FocusableCalendarView {
|
|
@@ -21,8 +22,17 @@ export declare class CalendarYearViewComponent<D> implements OnInit, OnChanges,
|
|
|
21
22
|
* Object to customize year grid
|
|
22
23
|
*/
|
|
23
24
|
yearViewGrid: CalendarYearGrid;
|
|
25
|
+
/** Whether the date range is year format only excluding month and day */
|
|
26
|
+
isDateRangeYearFormat: boolean;
|
|
27
|
+
/**
|
|
28
|
+
* Whether user wants to mark year cells on hover.
|
|
29
|
+
* Works only on range mode, when start year is selected.
|
|
30
|
+
*/
|
|
31
|
+
rangeHoverEffect: boolean;
|
|
24
32
|
/** Event fired when a year is selected. */
|
|
25
33
|
readonly yearClicked: EventEmitter<number>;
|
|
34
|
+
/** Event thrown every time selected first or last date in range mode is changed */
|
|
35
|
+
readonly selectedRangeDateChange: EventEmitter<DateRange<D>>;
|
|
26
36
|
/**
|
|
27
37
|
* @hidden
|
|
28
38
|
* This variable is used to define which year from calendarYearList should be focusable by tab key
|
|
@@ -32,7 +42,7 @@ export declare class CalendarYearViewComponent<D> implements OnInit, OnChanges,
|
|
|
32
42
|
* @hidden
|
|
33
43
|
* Parameter that stores the dozen of years that are currently being displayed.
|
|
34
44
|
*/
|
|
35
|
-
_calendarYearListGrid: CalendarYear[][];
|
|
45
|
+
_calendarYearListGrid: CalendarYear<D>[][];
|
|
36
46
|
/**
|
|
37
47
|
* @hidden
|
|
38
48
|
* Parameter storing the year of the present day.
|
|
@@ -62,17 +72,32 @@ export declare class CalendarYearViewComponent<D> implements OnInit, OnChanges,
|
|
|
62
72
|
/** @hidden */
|
|
63
73
|
private _initiated;
|
|
64
74
|
/** @hidden */
|
|
75
|
+
private _selectedRangeDate;
|
|
76
|
+
/** @hidden */
|
|
77
|
+
private _isOnRangePick;
|
|
78
|
+
/** @hidden */
|
|
65
79
|
constructor(_eRef: ElementRef, _changeDetectorRef: ChangeDetectorRef, _calendarService: CalendarService, _dateTimeAdapter: DatetimeAdapter<D>, _dateTimeFormats: DateTimeFormats);
|
|
66
80
|
/** @hidden */
|
|
67
81
|
ngOnInit(): void;
|
|
68
82
|
/** @hidden */
|
|
69
83
|
ngOnChanges(changes: SimpleChanges): void;
|
|
84
|
+
/** The currently selected FdDates model start and end in range mode. */
|
|
85
|
+
set selectedRangeDate(dateRange: DateRange<D>);
|
|
86
|
+
get selectedRangeDate(): DateRange<D>;
|
|
87
|
+
/**
|
|
88
|
+
* @hidden
|
|
89
|
+
* Amount of selected years
|
|
90
|
+
* 0, when there is no year selected, or start year is invalid,
|
|
91
|
+
* 1, when there is only valid start year, or end year is same as start year,
|
|
92
|
+
* 2, when both dates are valid
|
|
93
|
+
*/
|
|
94
|
+
get _selectCounter(): number;
|
|
70
95
|
/** Method used to load the previous {{col * row}} years to be displayed. */
|
|
71
96
|
loadNextYearList(): void;
|
|
72
97
|
/** Method used to load the next {{col * row}} years to be displayed. */
|
|
73
98
|
loadPreviousYearList(): void;
|
|
74
99
|
/** Method that sends the year to the parent component when it is clicked. */
|
|
75
|
-
selectYear(selectedYear: CalendarYear
|
|
100
|
+
selectYear(selectedYear: CalendarYear<D>, event?: MouseEvent | KeyboardEvent): void;
|
|
76
101
|
/**
|
|
77
102
|
* Set focus on month cell.
|
|
78
103
|
* It can be a selected cell, current month cell or first cell in the list
|
|
@@ -99,6 +124,12 @@ export declare class CalendarYearViewComponent<D> implements OnInit, OnChanges,
|
|
|
99
124
|
* @param index
|
|
100
125
|
*/
|
|
101
126
|
_getId(index: number): string;
|
|
127
|
+
/**
|
|
128
|
+
* @hidden
|
|
129
|
+
* Handles hover effect for range selection mode.
|
|
130
|
+
* @param year The calendar year that is hovered.
|
|
131
|
+
*/
|
|
132
|
+
_handleRangeHover(year: CalendarYear<D>): void;
|
|
102
133
|
/**
|
|
103
134
|
* @hidden
|
|
104
135
|
* Method that returns active cell, which means:
|
|
@@ -109,6 +140,40 @@ export declare class CalendarYearViewComponent<D> implements OnInit, OnChanges,
|
|
|
109
140
|
private _getActiveYear;
|
|
110
141
|
/** @hidden */
|
|
111
142
|
private _constructYearGrid;
|
|
143
|
+
/**
|
|
144
|
+
* @hidden
|
|
145
|
+
* Handles the hover effect for range selection.
|
|
146
|
+
* Toggles the hover effect based on the selection state and event.
|
|
147
|
+
* @param event Optional mouse event for handling hover effect.
|
|
148
|
+
*/
|
|
149
|
+
private _handleRangeHoverEffect;
|
|
150
|
+
/**
|
|
151
|
+
* @hidden
|
|
152
|
+
* Change properties of range years, this method is called, to not rebuild whole grid from scratch,
|
|
153
|
+
* it just changes properties of newly selected/unselected years.
|
|
154
|
+
*/
|
|
155
|
+
private _changeSelectedRangeYears;
|
|
156
|
+
/**
|
|
157
|
+
* @hidden
|
|
158
|
+
* Check if dates are equal
|
|
159
|
+
*/
|
|
160
|
+
private _isSameDate;
|
|
161
|
+
/**
|
|
162
|
+
* @hidden
|
|
163
|
+
* Selects or updates the range of years in range mode.
|
|
164
|
+
* Handles the start and end years and updates the selected range.
|
|
165
|
+
* @param year The calendar year to be selected or updated in the range.
|
|
166
|
+
*/
|
|
167
|
+
private _selectRangeDate;
|
|
168
|
+
/**
|
|
169
|
+
* @hidden
|
|
170
|
+
* Orders the start and end dates for the range selection.
|
|
171
|
+
* Ensures the start date is before or equal to the end date.
|
|
172
|
+
* @param date1 The first date.
|
|
173
|
+
* @param date2 The second date.
|
|
174
|
+
* @returns An object containing the ordered start and end dates.
|
|
175
|
+
*/
|
|
176
|
+
private _getOrderedRange;
|
|
112
177
|
/**
|
|
113
178
|
* @hidden
|
|
114
179
|
* Returns year name as a string.
|
|
@@ -142,5 +207,5 @@ export declare class CalendarYearViewComponent<D> implements OnInit, OnChanges,
|
|
|
142
207
|
/** @hidden */
|
|
143
208
|
private _focusOnCellByIndex;
|
|
144
209
|
static ɵfac: i0.ɵɵFactoryDeclaration<CalendarYearViewComponent<any>, never>;
|
|
145
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CalendarYearViewComponent<any>, "fd-calendar-year-view", never, { "id": { "alias": "id"; "required": false; }; "focusEscapeFunction": { "alias": "focusEscapeFunction"; "required": false; }; "yearSelected": { "alias": "yearSelected"; "required": false; }; "yearViewGrid": { "alias": "yearViewGrid"; "required": false; }; }, { "yearClicked": "yearClicked"; }, never, never, true, never>;
|
|
210
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CalendarYearViewComponent<any>, "fd-calendar-year-view", never, { "id": { "alias": "id"; "required": false; }; "focusEscapeFunction": { "alias": "focusEscapeFunction"; "required": false; }; "yearSelected": { "alias": "yearSelected"; "required": false; }; "yearViewGrid": { "alias": "yearViewGrid"; "required": false; }; "isDateRangeYearFormat": { "alias": "isDateRangeYearFormat"; "required": false; }; "rangeHoverEffect": { "alias": "rangeHoverEffect"; "required": false; }; "selectedRangeDate": { "alias": "selectedRangeDate"; "required": false; }; }, { "yearClicked": "yearClicked"; "selectedRangeDateChange": "selectedRangeDateChange"; }, never, never, true, never>;
|
|
146
211
|
}
|
|
@@ -94,6 +94,13 @@ export declare class CalendarComponent<D> implements OnInit, OnChanges, ControlV
|
|
|
94
94
|
* Works only on range mode, when start date is selected on Day View.
|
|
95
95
|
*/
|
|
96
96
|
rangeHoverEffect: boolean;
|
|
97
|
+
/** Whether to pick the date range in month or year or days format
|
|
98
|
+
* Day format will have a month and year including day
|
|
99
|
+
* Month format will have year including month
|
|
100
|
+
* Year format will have just year
|
|
101
|
+
* Values can be 'month' for Month format, 'year' for Year format or nothing for day format
|
|
102
|
+
*/
|
|
103
|
+
dateRangeFormat: string;
|
|
97
104
|
/** Event thrown every time active view is changed */
|
|
98
105
|
readonly activeViewChange: EventEmitter<FdCalendarView>;
|
|
99
106
|
/** Event thrown every time selected date in single mode is changed */
|
|
@@ -267,6 +274,10 @@ export declare class CalendarComponent<D> implements OnInit, OnChanges, ControlV
|
|
|
267
274
|
onYearsRangeViewSelected(): void;
|
|
268
275
|
/** Method that provides information if model selected date/dates have properly types and are valid */
|
|
269
276
|
isModelValid(): boolean;
|
|
277
|
+
/** Whether the date range format is month */
|
|
278
|
+
isDateRangeMonthFormat(): boolean;
|
|
279
|
+
/** Whether the date range format is year */
|
|
280
|
+
isDateRangeYearFormat(): boolean;
|
|
270
281
|
/** @hidden */
|
|
271
282
|
private _listenToLocaleChanges;
|
|
272
283
|
/**
|
|
@@ -284,5 +295,5 @@ export declare class CalendarComponent<D> implements OnInit, OnChanges, ControlV
|
|
|
284
295
|
/** @hidden */
|
|
285
296
|
private _isNavigationButtonDisabled;
|
|
286
297
|
static ɵfac: i0.ɵɵFactoryDeclaration<CalendarComponent<any>, [null, null, null, { optional: true; }, { optional: true; }]>;
|
|
287
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CalendarComponent<any>, "fd-calendar", never, { "selectedDate": { "alias": "selectedDate"; "required": false; }; "selectedMultipleDates": { "alias": "selectedMultipleDates"; "required": false; }; "selectedRangeDate": { "alias": "selectedRangeDate"; "required": false; }; "selectedMultipleDateRanges": { "alias": "selectedMultipleDateRanges"; "required": false; }; "markWeekends": { "alias": "markWeekends"; "required": false; }; "showWeekNumbers": { "alias": "showWeekNumbers"; "required": false; }; "allowMultipleSelection": { "alias": "allowMultipleSelection"; "required": false; }; "mobileLandscape": { "alias": "mobileLandscape"; "required": false; }; "mobilePortrait": { "alias": "mobilePortrait"; "required": false; }; "activeView": { "alias": "activeView"; "required": false; }; "startingDayOfWeek": { "alias": "startingDayOfWeek"; "required": false; }; "calType": { "alias": "calType"; "required": false; }; "id": { "alias": "id"; "required": false; }; "specialDaysRules": { "alias": "specialDaysRules"; "required": false; }; "yearGrid": { "alias": "yearGrid"; "required": false; }; "aggregatedYearGrid": { "alias": "aggregatedYearGrid"; "required": false; }; "rangeHoverEffect": { "alias": "rangeHoverEffect"; "required": false; }; "previousButtonDisableFunction": { "alias": "previousButtonDisableFunction"; "required": false; }; "nextButtonDisableFunction": { "alias": "nextButtonDisableFunction"; "required": false; }; "escapeFocusFunction": { "alias": "escapeFocusFunction"; "required": false; }; "disableFunction": { "alias": "disableFunction"; "required": false; }; "disableRangeStartFunction": { "alias": "disableRangeStartFunction"; "required": false; }; "disableRangeEndFunction": { "alias": "disableRangeEndFunction"; "required": false; }; }, { "activeViewChange": "activeViewChange"; "selectedDateChange": "selectedDateChange"; "selectedMultipleDatesChange": "selectedMultipleDatesChange"; "selectedRangeDateChange": "selectedRangeDateChange"; "selectedMultipleDateRangesChange": "selectedMultipleDateRangesChange"; "isValidDateChange": "isValidDateChange"; "closeCalendar": "closeCalendar"; "closeClicked": "closeClicked"; }, never, never, true, never>;
|
|
298
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CalendarComponent<any>, "fd-calendar", never, { "selectedDate": { "alias": "selectedDate"; "required": false; }; "selectedMultipleDates": { "alias": "selectedMultipleDates"; "required": false; }; "selectedRangeDate": { "alias": "selectedRangeDate"; "required": false; }; "selectedMultipleDateRanges": { "alias": "selectedMultipleDateRanges"; "required": false; }; "markWeekends": { "alias": "markWeekends"; "required": false; }; "showWeekNumbers": { "alias": "showWeekNumbers"; "required": false; }; "allowMultipleSelection": { "alias": "allowMultipleSelection"; "required": false; }; "mobileLandscape": { "alias": "mobileLandscape"; "required": false; }; "mobilePortrait": { "alias": "mobilePortrait"; "required": false; }; "activeView": { "alias": "activeView"; "required": false; }; "startingDayOfWeek": { "alias": "startingDayOfWeek"; "required": false; }; "calType": { "alias": "calType"; "required": false; }; "id": { "alias": "id"; "required": false; }; "specialDaysRules": { "alias": "specialDaysRules"; "required": false; }; "yearGrid": { "alias": "yearGrid"; "required": false; }; "aggregatedYearGrid": { "alias": "aggregatedYearGrid"; "required": false; }; "rangeHoverEffect": { "alias": "rangeHoverEffect"; "required": false; }; "dateRangeFormat": { "alias": "dateRangeFormat"; "required": false; }; "previousButtonDisableFunction": { "alias": "previousButtonDisableFunction"; "required": false; }; "nextButtonDisableFunction": { "alias": "nextButtonDisableFunction"; "required": false; }; "escapeFocusFunction": { "alias": "escapeFocusFunction"; "required": false; }; "disableFunction": { "alias": "disableFunction"; "required": false; }; "disableRangeStartFunction": { "alias": "disableRangeStartFunction"; "required": false; }; "disableRangeEndFunction": { "alias": "disableRangeEndFunction"; "required": false; }; }, { "activeViewChange": "activeViewChange"; "selectedDateChange": "selectedDateChange"; "selectedMultipleDatesChange": "selectedMultipleDatesChange"; "selectedRangeDateChange": "selectedRangeDateChange"; "selectedMultipleDateRangesChange": "selectedMultipleDateRangesChange"; "isValidDateChange": "isValidDateChange"; "closeCalendar": "closeCalendar"; "closeClicked": "closeClicked"; }, never, never, true, never>;
|
|
288
299
|
}
|
|
@@ -9,7 +9,10 @@ export declare class CalendarService {
|
|
|
9
9
|
/** Column amount */
|
|
10
10
|
colAmount: number;
|
|
11
11
|
/** Event thrown, when the element is selected by space or enter keys */
|
|
12
|
-
onKeySelect: Subject<
|
|
12
|
+
onKeySelect: Subject<{
|
|
13
|
+
index: number;
|
|
14
|
+
event: KeyboardEvent;
|
|
15
|
+
}>;
|
|
13
16
|
/** Event thrown, when the focus goes after list of elements */
|
|
14
17
|
onListEndApproach: Subject<number>;
|
|
15
18
|
/** Event thrown, when the focus goes before list of elements */
|
|
@@ -1,6 +1,11 @@
|
|
|
1
1
|
import { BaseCalendarCell } from './common';
|
|
2
|
-
export interface CalendarMonth extends BaseCalendarCell {
|
|
2
|
+
export interface CalendarMonth<D> extends BaseCalendarCell {
|
|
3
3
|
/** 1 - 12 */
|
|
4
4
|
month: number;
|
|
5
5
|
index: number;
|
|
6
|
+
date: D;
|
|
7
|
+
selectedFirst?: boolean;
|
|
8
|
+
selectedLast?: boolean;
|
|
9
|
+
selectedRange?: boolean;
|
|
10
|
+
hoverRange?: boolean;
|
|
6
11
|
}
|
|
@@ -9,7 +9,12 @@ export interface CalendarYearGrid {
|
|
|
9
9
|
*/
|
|
10
10
|
yearMapping?: (year: number) => string;
|
|
11
11
|
}
|
|
12
|
-
export interface CalendarYear extends BaseCalendarCell {
|
|
12
|
+
export interface CalendarYear<D> extends BaseCalendarCell {
|
|
13
13
|
year: number;
|
|
14
14
|
index: number;
|
|
15
|
+
date: D;
|
|
16
|
+
selectedFirst?: boolean;
|
|
17
|
+
selectedLast?: boolean;
|
|
18
|
+
selectedRange?: boolean;
|
|
19
|
+
hoverRange?: boolean;
|
|
15
20
|
}
|
|
@@ -155,6 +155,11 @@ export declare class DatePickerComponent<D> implements DatePicker<D>, OnInit, On
|
|
|
155
155
|
mobileLandscape: boolean;
|
|
156
156
|
/** Whether calendar is used inside mobile in portrait mode */
|
|
157
157
|
mobilePortrait: boolean;
|
|
158
|
+
/** Whether to select and display the date range in MM/YYYY or YYYY format
|
|
159
|
+
* For month and year format value is 'month'
|
|
160
|
+
* For year format value is 'year'
|
|
161
|
+
*/
|
|
162
|
+
dateRangeFormat: string;
|
|
158
163
|
/** Event emitted when the state of the isOpen property changes. */
|
|
159
164
|
readonly isOpenChange: EventEmitter<boolean>;
|
|
160
165
|
/** Event thrown every time selected date in single mode is changed */
|
|
@@ -407,6 +412,6 @@ export declare class DatePickerComponent<D> implements DatePicker<D>, OnInit, On
|
|
|
407
412
|
/** Helper method to compare two arrays of date ranges */
|
|
408
413
|
private _areDateRangesEqual;
|
|
409
414
|
static ɵfac: i0.ɵɵFactoryDeclaration<DatePickerComponent<any>, [null, { optional: true; }, { optional: true; }, null]>;
|
|
410
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DatePickerComponent<any>, "fd-date-picker", never, { "type": { "alias": "type"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "inputId": { "alias": "inputId"; "required": false; }; "required": { "alias": "required"; "required": false; }; "customDateTimeFormat": { "alias": "customDateTimeFormat"; "required": false; }; "message": { "alias": "message"; "required": false; }; "messageTriggers": { "alias": "messageTriggers"; "required": false; }; "selectedDate": { "alias": "selectedDate"; "required": false; }; "selectedMultipleDates": { "alias": "selectedMultipleDates"; "required": false; }; "selectedRangeDate": { "alias": "selectedRangeDate"; "required": false; }; "selectedMultipleDateRanges": { "alias": "selectedMultipleDateRanges"; "required": false; }; "startingDayOfWeek": { "alias": "startingDayOfWeek"; "required": false; }; "rangeHoverEffect": { "alias": "rangeHoverEffect"; "required": false; }; "useValidation": { "alias": "useValidation"; "required": false; }; "allowNull": { "alias": "allowNull"; "required": false; }; "activeView": { "alias": "activeView"; "required": false; }; "placement": { "alias": "placement"; "required": false; }; "appendTo": { "alias": "appendTo"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "closeOnDateChoose": { "alias": "closeOnDateChoose"; "required": false; }; "showTodayButton": { "alias": "showTodayButton"; "required": false; }; "todayButtonLabel": { "alias": "todayButtonLabel"; "required": false; }; "previousButtonDisableFunction": { "alias": "previousButtonDisableFunction"; "required": false; }; "nextButtonDisableFunction": { "alias": "nextButtonDisableFunction"; "required": false; }; "state": { "alias": "state"; "required": false; }; "buttonFocusable": { "alias": "buttonFocusable"; "required": false; }; "specialDaysRules": { "alias": "specialDaysRules"; "required": false; }; "yearGrid": { "alias": "yearGrid"; "required": false; }; "aggregatedYearGrid": { "alias": "aggregatedYearGrid"; "required": false; }; "markWeekends": { "alias": "markWeekends"; "required": false; }; "showWeekNumbers": { "alias": "showWeekNumbers"; "required": false; }; "allowMultipleSelection": { "alias": "allowMultipleSelection"; "required": false; }; "isOpen": { "alias": "isOpen"; "required": false; }; "inline": { "alias": "inline"; "required": false; }; "ariaLabelledBy": { "alias": "ariaLabelledBy"; "required": false; }; "processInputOnBlur": { "alias": "processInputOnBlur"; "required": false; }; "preventScrollOnFocus": { "alias": "preventScrollOnFocus"; "required": false; }; "mobile": { "alias": "mobile"; "required": false; }; "mobileConfig": { "alias": "mobileConfig"; "required": false; }; "mobileLandscape": { "alias": "mobileLandscape"; "required": false; }; "mobilePortrait": { "alias": "mobilePortrait"; "required": false; }; "disableFunction": { "alias": "disableFunction"; "required": false; }; "disableRangeStartFunction": { "alias": "disableRangeStartFunction"; "required": false; }; "disableRangeEndFunction": { "alias": "disableRangeEndFunction"; "required": false; }; }, { "isOpenChange": "isOpenChange"; "selectedDateChange": "selectedDateChange"; "selectedMultipleDatesChange": "selectedMultipleDatesChange"; "selectedRangeDateChange": "selectedRangeDateChange"; "selectedMultipleDateRangesChange": "selectedMultipleDateRangesChange"; "activeViewChange": "activeViewChange"; }, never, ["*"], true, never>;
|
|
415
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DatePickerComponent<any>, "fd-date-picker", never, { "type": { "alias": "type"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "inputId": { "alias": "inputId"; "required": false; }; "required": { "alias": "required"; "required": false; }; "customDateTimeFormat": { "alias": "customDateTimeFormat"; "required": false; }; "message": { "alias": "message"; "required": false; }; "messageTriggers": { "alias": "messageTriggers"; "required": false; }; "selectedDate": { "alias": "selectedDate"; "required": false; }; "selectedMultipleDates": { "alias": "selectedMultipleDates"; "required": false; }; "selectedRangeDate": { "alias": "selectedRangeDate"; "required": false; }; "selectedMultipleDateRanges": { "alias": "selectedMultipleDateRanges"; "required": false; }; "startingDayOfWeek": { "alias": "startingDayOfWeek"; "required": false; }; "rangeHoverEffect": { "alias": "rangeHoverEffect"; "required": false; }; "useValidation": { "alias": "useValidation"; "required": false; }; "allowNull": { "alias": "allowNull"; "required": false; }; "activeView": { "alias": "activeView"; "required": false; }; "placement": { "alias": "placement"; "required": false; }; "appendTo": { "alias": "appendTo"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "closeOnDateChoose": { "alias": "closeOnDateChoose"; "required": false; }; "showTodayButton": { "alias": "showTodayButton"; "required": false; }; "todayButtonLabel": { "alias": "todayButtonLabel"; "required": false; }; "previousButtonDisableFunction": { "alias": "previousButtonDisableFunction"; "required": false; }; "nextButtonDisableFunction": { "alias": "nextButtonDisableFunction"; "required": false; }; "state": { "alias": "state"; "required": false; }; "buttonFocusable": { "alias": "buttonFocusable"; "required": false; }; "specialDaysRules": { "alias": "specialDaysRules"; "required": false; }; "yearGrid": { "alias": "yearGrid"; "required": false; }; "aggregatedYearGrid": { "alias": "aggregatedYearGrid"; "required": false; }; "markWeekends": { "alias": "markWeekends"; "required": false; }; "showWeekNumbers": { "alias": "showWeekNumbers"; "required": false; }; "allowMultipleSelection": { "alias": "allowMultipleSelection"; "required": false; }; "isOpen": { "alias": "isOpen"; "required": false; }; "inline": { "alias": "inline"; "required": false; }; "ariaLabelledBy": { "alias": "ariaLabelledBy"; "required": false; }; "processInputOnBlur": { "alias": "processInputOnBlur"; "required": false; }; "preventScrollOnFocus": { "alias": "preventScrollOnFocus"; "required": false; }; "mobile": { "alias": "mobile"; "required": false; }; "mobileConfig": { "alias": "mobileConfig"; "required": false; }; "mobileLandscape": { "alias": "mobileLandscape"; "required": false; }; "mobilePortrait": { "alias": "mobilePortrait"; "required": false; }; "dateRangeFormat": { "alias": "dateRangeFormat"; "required": false; }; "disableFunction": { "alias": "disableFunction"; "required": false; }; "disableRangeStartFunction": { "alias": "disableRangeStartFunction"; "required": false; }; "disableRangeEndFunction": { "alias": "disableRangeEndFunction"; "required": false; }; }, { "isOpenChange": "isOpenChange"; "selectedDateChange": "selectedDateChange"; "selectedMultipleDatesChange": "selectedMultipleDatesChange"; "selectedRangeDateChange": "selectedRangeDateChange"; "selectedMultipleDateRangesChange": "selectedMultipleDateRangesChange"; "activeViewChange": "activeViewChange"; }, never, ["*"], true, never>;
|
|
411
416
|
static ngAcceptInputType_processInputOnBlur: unknown;
|
|
412
417
|
}
|
|
@@ -210,13 +210,13 @@ export class CalendarHeaderComponent {
|
|
|
210
210
|
};
|
|
211
211
|
}
|
|
212
212
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: CalendarHeaderComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.CalendarService }, { token: i2.DatetimeAdapter }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
213
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.3", type: CalendarHeaderComponent, isStandalone: true, selector: "fd-calendar-header", inputs: { activeView: "activeView", currentlyDisplayed: "currentlyDisplayed", previousButtonDisabled: "previousButtonDisabled", nextButtonDisabled: "nextButtonDisabled", calendarYearGrid: "calendarYearGrid", id: "id", mobileLandscape: "mobileLandscape" }, outputs: { activeViewChange: "activeViewChange", previousClicked: "previousClicked", nextClicked: "nextClicked" }, host: { properties: { "attr.id": "viewId" } }, viewQueries: [{ propertyName: "_prevButtonComponent", first: true, predicate: ["prevButton"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<header class=\"fd-calendar__navigation\" [class.fd-calendar__navigation--main]=\"mobileLandscape\">\n <div class=\"fd-calendar__action fd-calendar__action--arrow-left\">\n <button\n #prevButton\n fd-button\n fdType=\"transparent\"\n glyph=\"slim-arrow-left\"\n [attr.id]=\"_prevButtonId\"\n [disabled]=\"previousButtonDisabled\"\n [attr.title]=\"previousAriaLabel | fdTranslate\"\n [ariaLabel]=\"previousAriaLabel | fdTranslate\"\n type=\"button\"\n (click)=\"previousClicked.emit()\"\n ></button>\n </div>\n @if (isOnDayView || isOnMonthView) {\n <div class=\"fd-calendar__action\">\n
|
|
213
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.3", type: CalendarHeaderComponent, isStandalone: true, selector: "fd-calendar-header", inputs: { activeView: "activeView", currentlyDisplayed: "currentlyDisplayed", previousButtonDisabled: "previousButtonDisabled", nextButtonDisabled: "nextButtonDisabled", calendarYearGrid: "calendarYearGrid", id: "id", mobileLandscape: "mobileLandscape" }, outputs: { activeViewChange: "activeViewChange", previousClicked: "previousClicked", nextClicked: "nextClicked" }, host: { properties: { "attr.id": "viewId" } }, viewQueries: [{ propertyName: "_prevButtonComponent", first: true, predicate: ["prevButton"], descendants: true, read: ElementRef }], usesOnChanges: true, ngImport: i0, template: "<header class=\"fd-calendar__navigation\" [class.fd-calendar__navigation--main]=\"mobileLandscape\">\n <div class=\"fd-calendar__action fd-calendar__action--arrow-left\">\n <button\n #prevButton\n fd-button\n fdType=\"transparent\"\n glyph=\"slim-arrow-left\"\n [attr.id]=\"_prevButtonId\"\n [disabled]=\"previousButtonDisabled\"\n [attr.title]=\"previousAriaLabel | fdTranslate\"\n [ariaLabel]=\"previousAriaLabel | fdTranslate\"\n type=\"button\"\n (click)=\"previousClicked.emit()\"\n ></button>\n </div>\n @if (isOnDayView || isOnMonthView) {\n @if (!isOnMonthView) {\n <div class=\"fd-calendar__action\">\n <!-- Select month button -->\n <button\n fd-button\n type=\"button\"\n fdType=\"transparent\"\n [attr.aria-labelledby]=\"_monthButtonLabelId + ' ' + _selectMonthButtonAriaLabelId\"\n [attr.data-fd-calendar-month]=\"currentlyDisplayed.month\"\n (click)=\"_processViewChange('month', $event)\"\n >\n <span [attr.id]=\"_monthButtonLabelId\">{{ selectMonthLabel }}</span>\n </button>\n </div>\n }\n <div class=\"fd-calendar__action\">\n <!-- Select year button -->\n <button\n fd-button\n type=\"button\"\n fdType=\"transparent\"\n [attr.aria-labelledby]=\"_yearButtonLabelId + ' ' + _selectYearButtonAriaLabelId\"\n [attr.data-fd-calendar-year]=\"currentlyDisplayed.year\"\n (click)=\"_processViewChange('year', $event)\"\n >\n <span [attr.id]=\"_yearButtonLabelId\">{{ selectYearLabel }}</span>\n </button>\n </div>\n }\n @if (isOnAggregatedYearsView || isOnYearView) {\n <div class=\"fd-calendar__action\" aria-live=\"polite\">\n <button\n fd-button\n fdType=\"transparent\"\n [attr.aria-labelledby]=\"_yearsRangeButtonLabelId + ' ' + _selectYearsRangeButtonAriaLabelId\"\n (click)=\"_processViewChange('aggregatedYear', $event)\"\n type=\"button\"\n >\n <span [attr.id]=\"_yearsRangeButtonLabelId\">{{ selectAggregatedYearLabel }}</span>\n </button>\n </div>\n }\n <div class=\"fd-calendar__action fd-calendar__action--arrow-right\">\n <button\n fd-button\n fdType=\"transparent\"\n glyph=\"slim-arrow-right\"\n [attr.id]=\"_nextButtonId\"\n [disabled]=\"nextButtonDisabled\"\n [attr.title]=\"nextAriaLabel | fdTranslate\"\n [ariaLabel]=\"nextAriaLabel | fdTranslate\"\n (click)=\"nextClicked.emit()\"\n type=\"button\"\n ></button>\n </div>\n</header>\n<!-- Hidden elements for aria purposes -->\n<div hidden aria-hidden=\"true\">\n <div [attr.id]=\"_selectMonthButtonAriaLabelId\">{{ selectMonthAriaLabel | fdTranslate }}</div>\n <div [attr.id]=\"_selectYearButtonAriaLabelId\">{{ 'coreCalendar.yearSelectionLabel' | fdTranslate }}</div>\n <div [attr.id]=\"_selectYearsRangeButtonAriaLabelId\">{{ selectAggregatedYearAriaLabel | fdTranslate }}</div>\n</div>\n", styles: [""], dependencies: [{ kind: "component", type: ButtonComponent, selector: "button[fd-button], a[fd-button], span[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "pipe", type: FdTranslatePipe, name: "fdTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
214
214
|
}
|
|
215
215
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImport: i0, type: CalendarHeaderComponent, decorators: [{
|
|
216
216
|
type: Component,
|
|
217
217
|
args: [{ selector: 'fd-calendar-header', encapsulation: ViewEncapsulation.None, host: {
|
|
218
218
|
'[attr.id]': 'viewId'
|
|
219
|
-
}, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ButtonComponent, FdTranslatePipe], template: "<header class=\"fd-calendar__navigation\" [class.fd-calendar__navigation--main]=\"mobileLandscape\">\n <div class=\"fd-calendar__action fd-calendar__action--arrow-left\">\n <button\n #prevButton\n fd-button\n fdType=\"transparent\"\n glyph=\"slim-arrow-left\"\n [attr.id]=\"_prevButtonId\"\n [disabled]=\"previousButtonDisabled\"\n [attr.title]=\"previousAriaLabel | fdTranslate\"\n [ariaLabel]=\"previousAriaLabel | fdTranslate\"\n type=\"button\"\n (click)=\"previousClicked.emit()\"\n ></button>\n </div>\n @if (isOnDayView || isOnMonthView) {\n <div class=\"fd-calendar__action\">\n
|
|
219
|
+
}, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ButtonComponent, FdTranslatePipe], template: "<header class=\"fd-calendar__navigation\" [class.fd-calendar__navigation--main]=\"mobileLandscape\">\n <div class=\"fd-calendar__action fd-calendar__action--arrow-left\">\n <button\n #prevButton\n fd-button\n fdType=\"transparent\"\n glyph=\"slim-arrow-left\"\n [attr.id]=\"_prevButtonId\"\n [disabled]=\"previousButtonDisabled\"\n [attr.title]=\"previousAriaLabel | fdTranslate\"\n [ariaLabel]=\"previousAriaLabel | fdTranslate\"\n type=\"button\"\n (click)=\"previousClicked.emit()\"\n ></button>\n </div>\n @if (isOnDayView || isOnMonthView) {\n @if (!isOnMonthView) {\n <div class=\"fd-calendar__action\">\n <!-- Select month button -->\n <button\n fd-button\n type=\"button\"\n fdType=\"transparent\"\n [attr.aria-labelledby]=\"_monthButtonLabelId + ' ' + _selectMonthButtonAriaLabelId\"\n [attr.data-fd-calendar-month]=\"currentlyDisplayed.month\"\n (click)=\"_processViewChange('month', $event)\"\n >\n <span [attr.id]=\"_monthButtonLabelId\">{{ selectMonthLabel }}</span>\n </button>\n </div>\n }\n <div class=\"fd-calendar__action\">\n <!-- Select year button -->\n <button\n fd-button\n type=\"button\"\n fdType=\"transparent\"\n [attr.aria-labelledby]=\"_yearButtonLabelId + ' ' + _selectYearButtonAriaLabelId\"\n [attr.data-fd-calendar-year]=\"currentlyDisplayed.year\"\n (click)=\"_processViewChange('year', $event)\"\n >\n <span [attr.id]=\"_yearButtonLabelId\">{{ selectYearLabel }}</span>\n </button>\n </div>\n }\n @if (isOnAggregatedYearsView || isOnYearView) {\n <div class=\"fd-calendar__action\" aria-live=\"polite\">\n <button\n fd-button\n fdType=\"transparent\"\n [attr.aria-labelledby]=\"_yearsRangeButtonLabelId + ' ' + _selectYearsRangeButtonAriaLabelId\"\n (click)=\"_processViewChange('aggregatedYear', $event)\"\n type=\"button\"\n >\n <span [attr.id]=\"_yearsRangeButtonLabelId\">{{ selectAggregatedYearLabel }}</span>\n </button>\n </div>\n }\n <div class=\"fd-calendar__action fd-calendar__action--arrow-right\">\n <button\n fd-button\n fdType=\"transparent\"\n glyph=\"slim-arrow-right\"\n [attr.id]=\"_nextButtonId\"\n [disabled]=\"nextButtonDisabled\"\n [attr.title]=\"nextAriaLabel | fdTranslate\"\n [ariaLabel]=\"nextAriaLabel | fdTranslate\"\n (click)=\"nextClicked.emit()\"\n type=\"button\"\n ></button>\n </div>\n</header>\n<!-- Hidden elements for aria purposes -->\n<div hidden aria-hidden=\"true\">\n <div [attr.id]=\"_selectMonthButtonAriaLabelId\">{{ selectMonthAriaLabel | fdTranslate }}</div>\n <div [attr.id]=\"_selectYearButtonAriaLabelId\">{{ 'coreCalendar.yearSelectionLabel' | fdTranslate }}</div>\n <div [attr.id]=\"_selectYearsRangeButtonAriaLabelId\">{{ selectAggregatedYearAriaLabel | fdTranslate }}</div>\n</div>\n" }]
|
|
220
220
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.CalendarService }, { type: i2.DatetimeAdapter }], propDecorators: { activeView: [{
|
|
221
221
|
type: Input
|
|
222
222
|
}], currentlyDisplayed: [{
|
|
@@ -241,4 +241,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.3", ngImpor
|
|
|
241
241
|
type: ViewChild,
|
|
242
242
|
args: ['prevButton', { read: ElementRef }]
|
|
243
243
|
}] } });
|
|
244
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-header.component.js","sourceRoot":"","sources":["../../../../../../libs/core/calendar/calendar-header/calendar-header.component.ts","../../../../../../libs/core/calendar/calendar-header/calendar-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    DestroyRef,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n    ViewChild,\n    ViewEncapsulation,\n    inject\n} from '@angular/core';\n\nimport { DatetimeAdapter } from '@fundamental-ngx/core/datetime';\n\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ButtonComponent } from '@fundamental-ngx/core/button';\nimport { FdTranslatePipe } from '@fundamental-ngx/i18n';\nimport { CalendarService } from '../calendar.service';\nimport { CalendarCurrent } from '../models/calendar-current';\nimport { CalendarYearGrid } from '../models/calendar-year-grid';\nimport { FdCalendarView, FdCalendarViewEnum } from '../types';\n\n/**\n * Internal use only.\n * Header of the calendar component.\n */\n@Component({\n    selector: 'fd-calendar-header',\n    templateUrl: './calendar-header.component.html',\n    styleUrl: './calendar-header.component.scss',\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        '[attr.id]': 'viewId'\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [ButtonComponent, FdTranslatePipe]\n})\nexport class CalendarHeaderComponent<D> implements OnInit, OnChanges {\n    /** Currently active view. Needed for a11y labels. */\n    @Input()\n    activeView: FdCalendarView;\n\n    /** Currently displayed date on the calendar. */\n    @Input()\n    currentlyDisplayed: CalendarCurrent;\n\n    /** whether previous navigation button should be disabled in the header. */\n    @Input()\n    previousButtonDisabled: boolean;\n\n    /** whether next navigation button should be disabled in the header. */\n    @Input()\n    nextButtonDisabled: boolean;\n\n    /**\n     * Object to customize year grid\n     */\n    @Input()\n    set calendarYearGrid(yearGrid: CalendarYearGrid) {\n        this._amountOfYearsPerPeriod = yearGrid.cols * yearGrid.rows - 1;\n        this._calculateSelectAggregatedYearLabel();\n    }\n\n    /** Calendar ID */\n    @Input()\n    id: string;\n\n    /** Whether calendar should be rendered in mobile landscape mode. */\n    @Input()\n    mobileLandscape = false;\n\n    /** Event emitted when the active view should change. */\n    @Output()\n    readonly activeViewChange: EventEmitter<FdCalendarView> = new EventEmitter<FdCalendarView>();\n\n    /** Event emitted when the previous button is clicked. */\n    @Output()\n    readonly previousClicked: EventEmitter<void> = new EventEmitter<void>();\n\n    /** Event emitted when the next button is clicked. */\n    @Output()\n    readonly nextClicked: EventEmitter<void> = new EventEmitter<void>();\n\n    /** @hidden */\n    @ViewChild('prevButton', { read: ElementRef })\n    _prevButtonComponent: ElementRef;\n\n    /** Aria label for the previous button. Depends on the active view. */\n    get previousAriaLabel(): 'coreCalendar.previousMonthLabel' | 'coreCalendar.previousYearLabel' {\n        return this.isOnDayView ? 'coreCalendar.previousMonthLabel' : 'coreCalendar.previousYearLabel';\n    }\n\n    /** Aria label for the next button. Depends on the active view. */\n    get nextAriaLabel(): 'coreCalendar.nextMonthLabel' | 'coreCalendar.nextYearLabel' {\n        return this.isOnDayView ? 'coreCalendar.nextMonthLabel' : 'coreCalendar.nextYearLabel';\n    }\n\n    /** Button aria label to open month selection view. */\n    get selectMonthAriaLabel(): 'coreCalendar.monthSelectionLabel' | 'coreCalendar.dateSelectionLabel' {\n        return this.isOnMonthView ? 'coreCalendar.dateSelectionLabel' : 'coreCalendar.monthSelectionLabel';\n    }\n\n    /** Button aria label to open aggregated years selection view. */\n    get selectAggregatedYearAriaLabel(): 'coreCalendar.yearsRangeSelectionLabel' | 'coreCalendar.dateSelectionLabel' {\n        return this.isOnAggregatedYearsView\n            ? 'coreCalendar.dateSelectionLabel'\n            : 'coreCalendar.yearsRangeSelectionLabel';\n    }\n\n    /** Button label to open month selection view. */\n    selectMonthLabel: string;\n\n    /** Button label to open year selection view. */\n    selectYearLabel: string;\n\n    /** Button label to open aggregated years selection view. */\n    selectAggregatedYearLabel: string;\n\n    /** Get information is calendar is on aggregated years view */\n    get isOnAggregatedYearsView(): boolean {\n        return this.activeView === FdCalendarViewEnum.AggregatedYear;\n    }\n\n    /** Get information is calendar is on year view */\n    get isOnYearView(): boolean {\n        return this.activeView === FdCalendarViewEnum.Year;\n    }\n\n    /** Get information is calendar is on month view */\n    get isOnMonthView(): boolean {\n        return this.activeView === FdCalendarViewEnum.Month;\n    }\n\n    /** Get information is calendar is on day view */\n    get isOnDayView(): boolean {\n        return this.activeView === FdCalendarViewEnum.Day;\n    }\n\n    /**\n     * Component id\n     */\n    get viewId(): string {\n        return this.id + '-header';\n    }\n\n    /**\n     * @hidden\n     * Previous button id\n     */\n    get _prevButtonId(): string {\n        return this.viewId + '-left-arrow';\n    }\n\n    /**\n     * @hidden\n     * Next button id\n     */\n    get _nextButtonId(): string {\n        return this.viewId + '-right-arrow';\n    }\n\n    /**\n     * @hidden\n     * Month label id\n     */\n    get _monthButtonLabelId(): string {\n        return this.viewId + '-month-label';\n    }\n\n    /**\n     * @hidden\n     * Select month aria label id\n     */\n    get _selectMonthButtonAriaLabelId(): string {\n        return this.viewId + '-select-month-aria-label';\n    }\n\n    /**\n     * @hidden\n     * Year label id\n     */\n    get _yearButtonLabelId(): string {\n        return this.viewId + '-year-label';\n    }\n\n    /**\n     * @hidden\n     * Select year aria label id\n     */\n    get _selectYearButtonAriaLabelId(): string {\n        return this.viewId + '-select-year-aria-label';\n    }\n\n    /**\n     * @hidden\n     * Years range label id\n     */\n    get _yearsRangeButtonLabelId(): string {\n        return this.viewId + '-years-range-label';\n    }\n\n    /**\n     * @hidden\n     * Select years range aria label id\n     */\n    get _selectYearsRangeButtonAriaLabelId(): string {\n        return this.viewId + '-select-years-range-aria-label';\n    }\n\n    /** @hidden  */\n    private readonly _destroyRef = inject(DestroyRef);\n\n    /** Month names */\n    private _monthNames: string[] = [];\n\n    /** Get information about amount of years displayed at once on year view  */\n    private _amountOfYearsPerPeriod = 1;\n\n    /** @hidden */\n    constructor(\n        private _changeDetRef: ChangeDetectorRef,\n        private _calendarService: CalendarService,\n        private _dateTimeAdapter: DatetimeAdapter<D>\n    ) {}\n\n    /** @hidden */\n    ngOnChanges(changes: SimpleChanges): void {\n        if (\n            (changes.currentlyDisplayed && !changes.currentlyDisplayed.firstChange) ||\n            (changes.activeView && !changes.activeView.firstChange)\n        ) {\n            this._calculateLabels();\n        }\n    }\n\n    /** @hidden */\n    ngOnInit(): void {\n        this._calendarService.leftArrowId = this._prevButtonId;\n\n        this._calculateMonthNames();\n\n        this._calculateLabels();\n\n        this._listenToLocaleChanges();\n    }\n\n    /**\n     * Focus on focusable control within the header\n     */\n    focus(): void {\n        this._prevButtonComponent.nativeElement?.focus();\n    }\n\n    /** @hidden */\n    _processViewChange(type: FdCalendarView, event?: MouseEvent): void {\n        if (event) {\n            event.stopPropagation();\n        }\n\n        this.activeView = type === this.activeView ? FdCalendarViewEnum.Day : type;\n\n        this.activeViewChange.emit(this.activeView);\n    }\n\n    /** @hidden */\n    private _listenToLocaleChanges(): void {\n        this._dateTimeAdapter.localeChanges.pipe(takeUntilDestroyed(this._destroyRef)).subscribe(() => {\n            this._calculateMonthNames();\n            this._calculateLabels();\n            this._changeDetRef.markForCheck();\n        });\n    }\n\n    /** @hidden */\n    private _calculateLabels(): void {\n        this._calculateSelectMonthLabel();\n        this._calculateSelectYearLabel();\n        this._calculateSelectAggregatedYearLabel();\n    }\n\n    /** @hidden */\n    private _calculateSelectMonthLabel(): void {\n        this.selectMonthLabel = this._monthNames[this._getNormalizedDate().month - 1];\n    }\n\n    /** @hidden */\n    private _calculateSelectYearLabel(): void {\n        this.selectYearLabel = this._getYearName(this._getNormalizedDate().year);\n    }\n\n    /** @hidden */\n    private _calculateSelectAggregatedYearLabel(): void {\n        this.selectAggregatedYearLabel = `${this._getYearName(this._getNormalizedDate().year)}-${this._getYearName(\n            this._getNormalizedDate().year + this._amountOfYearsPerPeriod\n        )}`;\n    }\n\n    /** @hidden */\n    private _calculateMonthNames(): void {\n        this._monthNames = this._dateTimeAdapter.getMonthNames('long');\n    }\n\n    /** @hidden */\n    private _getYearName(year: number): string {\n        return this._dateTimeAdapter.getYearName(this._dateTimeAdapter.createDate(year));\n    }\n\n    /** @hidden */\n    private _getNormalizedDate(): CalendarCurrent {\n        return {\n            year: isNaN(this.currentlyDisplayed.year)\n                ? this._dateTimeAdapter.getYear(this._dateTimeAdapter.now())\n                : this.currentlyDisplayed.year,\n            month: isNaN(this.currentlyDisplayed.month)\n                ? this._dateTimeAdapter.getMonth(this._dateTimeAdapter.now())\n                : this.currentlyDisplayed.month\n        };\n    }\n}\n","<header class=\"fd-calendar__navigation\" [class.fd-calendar__navigation--main]=\"mobileLandscape\">\n    <div class=\"fd-calendar__action fd-calendar__action--arrow-left\">\n        <button\n            #prevButton\n            fd-button\n            fdType=\"transparent\"\n            glyph=\"slim-arrow-left\"\n            [attr.id]=\"_prevButtonId\"\n            [disabled]=\"previousButtonDisabled\"\n            [attr.title]=\"previousAriaLabel | fdTranslate\"\n            [ariaLabel]=\"previousAriaLabel | fdTranslate\"\n            type=\"button\"\n            (click)=\"previousClicked.emit()\"\n        ></button>\n    </div>\n    @if (isOnDayView || isOnMonthView) {\n        <div class=\"fd-calendar__action\">\n            <!-- Select month button -->\n            <button\n                fd-button\n                type=\"button\"\n                fdType=\"transparent\"\n                [attr.aria-labelledby]=\"_monthButtonLabelId + ' ' + _selectMonthButtonAriaLabelId\"\n                [attr.data-fd-calendar-month]=\"currentlyDisplayed.month\"\n                (click)=\"_processViewChange('month', $event)\"\n            >\n                <span [attr.id]=\"_monthButtonLabelId\">{{ selectMonthLabel }}</span>\n            </button>\n        </div>\n        <div class=\"fd-calendar__action\">\n            <!-- Select year button -->\n            <button\n                fd-button\n                type=\"button\"\n                fdType=\"transparent\"\n                [attr.aria-labelledby]=\"_yearButtonLabelId + ' ' + _selectYearButtonAriaLabelId\"\n                [attr.data-fd-calendar-year]=\"currentlyDisplayed.year\"\n                (click)=\"_processViewChange('year', $event)\"\n            >\n                <span [attr.id]=\"_yearButtonLabelId\">{{ selectYearLabel }}</span>\n            </button>\n        </div>\n    }\n    @if (isOnAggregatedYearsView || isOnYearView) {\n        <div class=\"fd-calendar__action\" aria-live=\"polite\">\n            <button\n                fd-button\n                fdType=\"transparent\"\n                [attr.aria-labelledby]=\"_yearsRangeButtonLabelId + ' ' + _selectYearsRangeButtonAriaLabelId\"\n                (click)=\"_processViewChange('aggregatedYear', $event)\"\n                type=\"button\"\n            >\n                <span [attr.id]=\"_yearsRangeButtonLabelId\">{{ selectAggregatedYearLabel }}</span>\n            </button>\n        </div>\n    }\n    <div class=\"fd-calendar__action fd-calendar__action--arrow-right\">\n        <button\n            fd-button\n            fdType=\"transparent\"\n            glyph=\"slim-arrow-right\"\n            [attr.id]=\"_nextButtonId\"\n            [disabled]=\"nextButtonDisabled\"\n            [attr.title]=\"nextAriaLabel | fdTranslate\"\n            [ariaLabel]=\"nextAriaLabel | fdTranslate\"\n            (click)=\"nextClicked.emit()\"\n            type=\"button\"\n        ></button>\n    </div>\n</header>\n<!-- Hidden elements for aria purposes -->\n<div hidden aria-hidden=\"true\">\n    <div [attr.id]=\"_selectMonthButtonAriaLabelId\">{{ selectMonthAriaLabel | fdTranslate }}</div>\n    <div [attr.id]=\"_selectYearButtonAriaLabelId\">{{ 'coreCalendar.yearSelectionLabel' | fdTranslate }}</div>\n    <div [attr.id]=\"_selectYearsRangeButtonAriaLabelId\">{{ selectAggregatedYearAriaLabel | fdTranslate }}</div>\n</div>\n"]}
|
|
244
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-header.component.js","sourceRoot":"","sources":["../../../../../../libs/core/calendar/calendar-header/calendar-header.component.ts","../../../../../../libs/core/calendar/calendar-header/calendar-header.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,UAAU,EACV,YAAY,EACZ,KAAK,EAGL,MAAM,EAEN,SAAS,EACT,iBAAiB,EACjB,MAAM,EACT,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,eAAe,EAAE,MAAM,gCAAgC,CAAC;AAEjE,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAGtD,OAAO,EAAkB,kBAAkB,EAAE,MAAM,UAAU,CAAC;;;;AAE9D;;;GAGG;AAaH,MAAM,OAAO,uBAAuB;IAiBhC;;OAEG;IACH,IACI,gBAAgB,CAAC,QAA0B;QAC3C,IAAI,CAAC,uBAAuB,GAAG,QAAQ,CAAC,IAAI,GAAG,QAAQ,CAAC,IAAI,GAAG,CAAC,CAAC;QACjE,IAAI,CAAC,mCAAmC,EAAE,CAAC;IAC/C,CAAC;IA0BD,sEAAsE;IACtE,IAAI,iBAAiB;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,iCAAiC,CAAC,CAAC,CAAC,gCAAgC,CAAC;IACnG,CAAC;IAED,kEAAkE;IAClE,IAAI,aAAa;QACb,OAAO,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,6BAA6B,CAAC,CAAC,CAAC,4BAA4B,CAAC;IAC3F,CAAC;IAED,sDAAsD;IACtD,IAAI,oBAAoB;QACpB,OAAO,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,iCAAiC,CAAC,CAAC,CAAC,kCAAkC,CAAC;IACvG,CAAC;IAED,iEAAiE;IACjE,IAAI,6BAA6B;QAC7B,OAAO,IAAI,CAAC,uBAAuB;YAC/B,CAAC,CAAC,iCAAiC;YACnC,CAAC,CAAC,uCAAuC,CAAC;IAClD,CAAC;IAWD,8DAA8D;IAC9D,IAAI,uBAAuB;QACvB,OAAO,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,cAAc,CAAC;IACjE,CAAC;IAED,kDAAkD;IAClD,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,IAAI,CAAC;IACvD,CAAC;IAED,mDAAmD;IACnD,IAAI,aAAa;QACb,OAAO,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,KAAK,CAAC;IACxD,CAAC;IAED,iDAAiD;IACjD,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,GAAG,CAAC;IACtD,CAAC;IAED;;OAEG;IACH,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,EAAE,GAAG,SAAS,CAAC;IAC/B,CAAC;IAED;;;OAGG;IACH,IAAI,aAAa;QACb,OAAO,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC;IACvC,CAAC;IAED;;;OAGG;IACH,IAAI,aAAa;QACb,OAAO,IAAI,CAAC,MAAM,GAAG,cAAc,CAAC;IACxC,CAAC;IAED;;;OAGG;IACH,IAAI,mBAAmB;QACnB,OAAO,IAAI,CAAC,MAAM,GAAG,cAAc,CAAC;IACxC,CAAC;IAED;;;OAGG;IACH,IAAI,6BAA6B;QAC7B,OAAO,IAAI,CAAC,MAAM,GAAG,0BAA0B,CAAC;IACpD,CAAC;IAED;;;OAGG;IACH,IAAI,kBAAkB;QAClB,OAAO,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC;IACvC,CAAC;IAED;;;OAGG;IACH,IAAI,4BAA4B;QAC5B,OAAO,IAAI,CAAC,MAAM,GAAG,yBAAyB,CAAC;IACnD,CAAC;IAED;;;OAGG;IACH,IAAI,wBAAwB;QACxB,OAAO,IAAI,CAAC,MAAM,GAAG,oBAAoB,CAAC;IAC9C,CAAC;IAED;;;OAGG;IACH,IAAI,kCAAkC;QAClC,OAAO,IAAI,CAAC,MAAM,GAAG,gCAAgC,CAAC;IAC1D,CAAC;IAWD,cAAc;IACd,YACY,aAAgC,EAChC,gBAAiC,EACjC,gBAAoC;QAFpC,kBAAa,GAAb,aAAa,CAAmB;QAChC,qBAAgB,GAAhB,gBAAgB,CAAiB;QACjC,qBAAgB,GAAhB,gBAAgB,CAAoB;QA3JhD,oEAAoE;QAEpE,oBAAe,GAAG,KAAK,CAAC;QAExB,wDAAwD;QAE/C,qBAAgB,GAAiC,IAAI,YAAY,EAAkB,CAAC;QAE7F,yDAAyD;QAEhD,oBAAe,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAExE,qDAAqD;QAE5C,gBAAW,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAgIpE,eAAe;QACE,gBAAW,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAElD,kBAAkB;QACV,gBAAW,GAAa,EAAE,CAAC;QAEnC,4EAA4E;QACpE,4BAAuB,GAAG,CAAC,CAAC;IAOjC,CAAC;IAEJ,cAAc;IACd,WAAW,CAAC,OAAsB;QAC9B,IACI,CAAC,OAAO,CAAC,kBAAkB,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,WAAW,CAAC;YACvE,CAAC,OAAO,CAAC,UAAU,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,WAAW,CAAC,EACzD,CAAC;YACC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC5B,CAAC;IACL,CAAC;IAED,cAAc;IACd,QAAQ;QACJ,IAAI,CAAC,gBAAgB,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC;QAEvD,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAExB,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAClC,CAAC;IAED;;OAEG;IACH,KAAK;QACD,IAAI,CAAC,oBAAoB,CAAC,aAAa,EAAE,KAAK,EAAE,CAAC;IACrD,CAAC;IAED,cAAc;IACd,kBAAkB,CAAC,IAAoB,EAAE,KAAkB;QACvD,IAAI,KAAK,EAAE,CAAC;YACR,KAAK,CAAC,eAAe,EAAE,CAAC;QAC5B,CAAC;QAED,IAAI,CAAC,UAAU,GAAG,IAAI,KAAK,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC;QAE3E,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAChD,CAAC;IAED,cAAc;IACN,sBAAsB;QAC1B,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC1F,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;QACtC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,cAAc;IACN,gBAAgB;QACpB,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAClC,IAAI,CAAC,yBAAyB,EAAE,CAAC;QACjC,IAAI,CAAC,mCAAmC,EAAE,CAAC;IAC/C,CAAC;IAED,cAAc;IACN,0BAA0B;QAC9B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;IAClF,CAAC;IAED,cAAc;IACN,yBAAyB;QAC7B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,IAAI,CAAC,CAAC;IAC7E,CAAC;IAED,cAAc;IACN,mCAAmC;QACvC,IAAI,CAAC,yBAAyB,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,YAAY,CACtG,IAAI,CAAC,kBAAkB,EAAE,CAAC,IAAI,GAAG,IAAI,CAAC,uBAAuB,CAChE,EAAE,CAAC;IACR,CAAC;IAED,cAAc;IACN,oBAAoB;QACxB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;IACnE,CAAC;IAED,cAAc;IACN,YAAY,CAAC,IAAY;QAC7B,OAAO,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;IACrF,CAAC;IAED,cAAc;IACN,kBAAkB;QACtB,OAAO;YACH,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC;gBACrC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC,GAAG,EAAE,CAAC;gBAC5D,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI;YAClC,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC;gBACvC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,GAAG,EAAE,CAAC;gBAC7D,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,KAAK;SACtC,CAAC;IACN,CAAC;8GAxRQ,uBAAuB;kGAAvB,uBAAuB,+kBA+CC,UAAU,kDC1F/C,k5GA8EA,0DDrCc,eAAe,oIAAE,eAAe;;2FAEjC,uBAAuB;kBAZnC,SAAS;+BACI,oBAAoB,iBAGf,iBAAiB,CAAC,IAAI,QAC/B;wBACF,WAAW,EAAE,QAAQ;qBACxB,mBACgB,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP,CAAC,eAAe,EAAE,eAAe,CAAC;kJAK3C,UAAU;sBADT,KAAK;gBAKN,kBAAkB;sBADjB,KAAK;gBAKN,sBAAsB;sBADrB,KAAK;gBAKN,kBAAkB;sBADjB,KAAK;gBAOF,gBAAgB;sBADnB,KAAK;gBAQN,EAAE;sBADD,KAAK;gBAKN,eAAe;sBADd,KAAK;gBAKG,gBAAgB;sBADxB,MAAM;gBAKE,eAAe;sBADvB,MAAM;gBAKE,WAAW;sBADnB,MAAM;gBAKP,oBAAoB;sBADnB,SAAS;uBAAC,YAAY,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    DestroyRef,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n    ViewChild,\n    ViewEncapsulation,\n    inject\n} from '@angular/core';\n\nimport { DatetimeAdapter } from '@fundamental-ngx/core/datetime';\n\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ButtonComponent } from '@fundamental-ngx/core/button';\nimport { FdTranslatePipe } from '@fundamental-ngx/i18n';\nimport { CalendarService } from '../calendar.service';\nimport { CalendarCurrent } from '../models/calendar-current';\nimport { CalendarYearGrid } from '../models/calendar-year-grid';\nimport { FdCalendarView, FdCalendarViewEnum } from '../types';\n\n/**\n * Internal use only.\n * Header of the calendar component.\n */\n@Component({\n    selector: 'fd-calendar-header',\n    templateUrl: './calendar-header.component.html',\n    styleUrl: './calendar-header.component.scss',\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        '[attr.id]': 'viewId'\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [ButtonComponent, FdTranslatePipe]\n})\nexport class CalendarHeaderComponent<D> implements OnInit, OnChanges {\n    /** Currently active view. Needed for a11y labels. */\n    @Input()\n    activeView: FdCalendarView;\n\n    /** Currently displayed date on the calendar. */\n    @Input()\n    currentlyDisplayed: CalendarCurrent;\n\n    /** whether previous navigation button should be disabled in the header. */\n    @Input()\n    previousButtonDisabled: boolean;\n\n    /** whether next navigation button should be disabled in the header. */\n    @Input()\n    nextButtonDisabled: boolean;\n\n    /**\n     * Object to customize year grid\n     */\n    @Input()\n    set calendarYearGrid(yearGrid: CalendarYearGrid) {\n        this._amountOfYearsPerPeriod = yearGrid.cols * yearGrid.rows - 1;\n        this._calculateSelectAggregatedYearLabel();\n    }\n\n    /** Calendar ID */\n    @Input()\n    id: string;\n\n    /** Whether calendar should be rendered in mobile landscape mode. */\n    @Input()\n    mobileLandscape = false;\n\n    /** Event emitted when the active view should change. */\n    @Output()\n    readonly activeViewChange: EventEmitter<FdCalendarView> = new EventEmitter<FdCalendarView>();\n\n    /** Event emitted when the previous button is clicked. */\n    @Output()\n    readonly previousClicked: EventEmitter<void> = new EventEmitter<void>();\n\n    /** Event emitted when the next button is clicked. */\n    @Output()\n    readonly nextClicked: EventEmitter<void> = new EventEmitter<void>();\n\n    /** @hidden */\n    @ViewChild('prevButton', { read: ElementRef })\n    _prevButtonComponent: ElementRef;\n\n    /** Aria label for the previous button. Depends on the active view. */\n    get previousAriaLabel(): 'coreCalendar.previousMonthLabel' | 'coreCalendar.previousYearLabel' {\n        return this.isOnDayView ? 'coreCalendar.previousMonthLabel' : 'coreCalendar.previousYearLabel';\n    }\n\n    /** Aria label for the next button. Depends on the active view. */\n    get nextAriaLabel(): 'coreCalendar.nextMonthLabel' | 'coreCalendar.nextYearLabel' {\n        return this.isOnDayView ? 'coreCalendar.nextMonthLabel' : 'coreCalendar.nextYearLabel';\n    }\n\n    /** Button aria label to open month selection view. */\n    get selectMonthAriaLabel(): 'coreCalendar.monthSelectionLabel' | 'coreCalendar.dateSelectionLabel' {\n        return this.isOnMonthView ? 'coreCalendar.dateSelectionLabel' : 'coreCalendar.monthSelectionLabel';\n    }\n\n    /** Button aria label to open aggregated years selection view. */\n    get selectAggregatedYearAriaLabel(): 'coreCalendar.yearsRangeSelectionLabel' | 'coreCalendar.dateSelectionLabel' {\n        return this.isOnAggregatedYearsView\n            ? 'coreCalendar.dateSelectionLabel'\n            : 'coreCalendar.yearsRangeSelectionLabel';\n    }\n\n    /** Button label to open month selection view. */\n    selectMonthLabel: string;\n\n    /** Button label to open year selection view. */\n    selectYearLabel: string;\n\n    /** Button label to open aggregated years selection view. */\n    selectAggregatedYearLabel: string;\n\n    /** Get information is calendar is on aggregated years view */\n    get isOnAggregatedYearsView(): boolean {\n        return this.activeView === FdCalendarViewEnum.AggregatedYear;\n    }\n\n    /** Get information is calendar is on year view */\n    get isOnYearView(): boolean {\n        return this.activeView === FdCalendarViewEnum.Year;\n    }\n\n    /** Get information is calendar is on month view */\n    get isOnMonthView(): boolean {\n        return this.activeView === FdCalendarViewEnum.Month;\n    }\n\n    /** Get information is calendar is on day view */\n    get isOnDayView(): boolean {\n        return this.activeView === FdCalendarViewEnum.Day;\n    }\n\n    /**\n     * Component id\n     */\n    get viewId(): string {\n        return this.id + '-header';\n    }\n\n    /**\n     * @hidden\n     * Previous button id\n     */\n    get _prevButtonId(): string {\n        return this.viewId + '-left-arrow';\n    }\n\n    /**\n     * @hidden\n     * Next button id\n     */\n    get _nextButtonId(): string {\n        return this.viewId + '-right-arrow';\n    }\n\n    /**\n     * @hidden\n     * Month label id\n     */\n    get _monthButtonLabelId(): string {\n        return this.viewId + '-month-label';\n    }\n\n    /**\n     * @hidden\n     * Select month aria label id\n     */\n    get _selectMonthButtonAriaLabelId(): string {\n        return this.viewId + '-select-month-aria-label';\n    }\n\n    /**\n     * @hidden\n     * Year label id\n     */\n    get _yearButtonLabelId(): string {\n        return this.viewId + '-year-label';\n    }\n\n    /**\n     * @hidden\n     * Select year aria label id\n     */\n    get _selectYearButtonAriaLabelId(): string {\n        return this.viewId + '-select-year-aria-label';\n    }\n\n    /**\n     * @hidden\n     * Years range label id\n     */\n    get _yearsRangeButtonLabelId(): string {\n        return this.viewId + '-years-range-label';\n    }\n\n    /**\n     * @hidden\n     * Select years range aria label id\n     */\n    get _selectYearsRangeButtonAriaLabelId(): string {\n        return this.viewId + '-select-years-range-aria-label';\n    }\n\n    /** @hidden  */\n    private readonly _destroyRef = inject(DestroyRef);\n\n    /** Month names */\n    private _monthNames: string[] = [];\n\n    /** Get information about amount of years displayed at once on year view  */\n    private _amountOfYearsPerPeriod = 1;\n\n    /** @hidden */\n    constructor(\n        private _changeDetRef: ChangeDetectorRef,\n        private _calendarService: CalendarService,\n        private _dateTimeAdapter: DatetimeAdapter<D>\n    ) {}\n\n    /** @hidden */\n    ngOnChanges(changes: SimpleChanges): void {\n        if (\n            (changes.currentlyDisplayed && !changes.currentlyDisplayed.firstChange) ||\n            (changes.activeView && !changes.activeView.firstChange)\n        ) {\n            this._calculateLabels();\n        }\n    }\n\n    /** @hidden */\n    ngOnInit(): void {\n        this._calendarService.leftArrowId = this._prevButtonId;\n\n        this._calculateMonthNames();\n\n        this._calculateLabels();\n\n        this._listenToLocaleChanges();\n    }\n\n    /**\n     * Focus on focusable control within the header\n     */\n    focus(): void {\n        this._prevButtonComponent.nativeElement?.focus();\n    }\n\n    /** @hidden */\n    _processViewChange(type: FdCalendarView, event?: MouseEvent): void {\n        if (event) {\n            event.stopPropagation();\n        }\n\n        this.activeView = type === this.activeView ? FdCalendarViewEnum.Day : type;\n\n        this.activeViewChange.emit(this.activeView);\n    }\n\n    /** @hidden */\n    private _listenToLocaleChanges(): void {\n        this._dateTimeAdapter.localeChanges.pipe(takeUntilDestroyed(this._destroyRef)).subscribe(() => {\n            this._calculateMonthNames();\n            this._calculateLabels();\n            this._changeDetRef.markForCheck();\n        });\n    }\n\n    /** @hidden */\n    private _calculateLabels(): void {\n        this._calculateSelectMonthLabel();\n        this._calculateSelectYearLabel();\n        this._calculateSelectAggregatedYearLabel();\n    }\n\n    /** @hidden */\n    private _calculateSelectMonthLabel(): void {\n        this.selectMonthLabel = this._monthNames[this._getNormalizedDate().month - 1];\n    }\n\n    /** @hidden */\n    private _calculateSelectYearLabel(): void {\n        this.selectYearLabel = this._getYearName(this._getNormalizedDate().year);\n    }\n\n    /** @hidden */\n    private _calculateSelectAggregatedYearLabel(): void {\n        this.selectAggregatedYearLabel = `${this._getYearName(this._getNormalizedDate().year)}-${this._getYearName(\n            this._getNormalizedDate().year + this._amountOfYearsPerPeriod\n        )}`;\n    }\n\n    /** @hidden */\n    private _calculateMonthNames(): void {\n        this._monthNames = this._dateTimeAdapter.getMonthNames('long');\n    }\n\n    /** @hidden */\n    private _getYearName(year: number): string {\n        return this._dateTimeAdapter.getYearName(this._dateTimeAdapter.createDate(year));\n    }\n\n    /** @hidden */\n    private _getNormalizedDate(): CalendarCurrent {\n        return {\n            year: isNaN(this.currentlyDisplayed.year)\n                ? this._dateTimeAdapter.getYear(this._dateTimeAdapter.now())\n                : this.currentlyDisplayed.year,\n            month: isNaN(this.currentlyDisplayed.month)\n                ? this._dateTimeAdapter.getMonth(this._dateTimeAdapter.now())\n                : this.currentlyDisplayed.month\n        };\n    }\n}\n","<header class=\"fd-calendar__navigation\" [class.fd-calendar__navigation--main]=\"mobileLandscape\">\n    <div class=\"fd-calendar__action fd-calendar__action--arrow-left\">\n        <button\n            #prevButton\n            fd-button\n            fdType=\"transparent\"\n            glyph=\"slim-arrow-left\"\n            [attr.id]=\"_prevButtonId\"\n            [disabled]=\"previousButtonDisabled\"\n            [attr.title]=\"previousAriaLabel | fdTranslate\"\n            [ariaLabel]=\"previousAriaLabel | fdTranslate\"\n            type=\"button\"\n            (click)=\"previousClicked.emit()\"\n        ></button>\n    </div>\n    @if (isOnDayView || isOnMonthView) {\n        @if (!isOnMonthView) {\n            <div class=\"fd-calendar__action\">\n                <!-- Select month button -->\n                <button\n                    fd-button\n                    type=\"button\"\n                    fdType=\"transparent\"\n                    [attr.aria-labelledby]=\"_monthButtonLabelId + ' ' + _selectMonthButtonAriaLabelId\"\n                    [attr.data-fd-calendar-month]=\"currentlyDisplayed.month\"\n                    (click)=\"_processViewChange('month', $event)\"\n                >\n                    <span [attr.id]=\"_monthButtonLabelId\">{{ selectMonthLabel }}</span>\n                </button>\n            </div>\n        }\n        <div class=\"fd-calendar__action\">\n            <!-- Select year button -->\n            <button\n                fd-button\n                type=\"button\"\n                fdType=\"transparent\"\n                [attr.aria-labelledby]=\"_yearButtonLabelId + ' ' + _selectYearButtonAriaLabelId\"\n                [attr.data-fd-calendar-year]=\"currentlyDisplayed.year\"\n                (click)=\"_processViewChange('year', $event)\"\n            >\n                <span [attr.id]=\"_yearButtonLabelId\">{{ selectYearLabel }}</span>\n            </button>\n        </div>\n    }\n    @if (isOnAggregatedYearsView || isOnYearView) {\n        <div class=\"fd-calendar__action\" aria-live=\"polite\">\n            <button\n                fd-button\n                fdType=\"transparent\"\n                [attr.aria-labelledby]=\"_yearsRangeButtonLabelId + ' ' + _selectYearsRangeButtonAriaLabelId\"\n                (click)=\"_processViewChange('aggregatedYear', $event)\"\n                type=\"button\"\n            >\n                <span [attr.id]=\"_yearsRangeButtonLabelId\">{{ selectAggregatedYearLabel }}</span>\n            </button>\n        </div>\n    }\n    <div class=\"fd-calendar__action fd-calendar__action--arrow-right\">\n        <button\n            fd-button\n            fdType=\"transparent\"\n            glyph=\"slim-arrow-right\"\n            [attr.id]=\"_nextButtonId\"\n            [disabled]=\"nextButtonDisabled\"\n            [attr.title]=\"nextAriaLabel | fdTranslate\"\n            [ariaLabel]=\"nextAriaLabel | fdTranslate\"\n            (click)=\"nextClicked.emit()\"\n            type=\"button\"\n        ></button>\n    </div>\n</header>\n<!-- Hidden elements for aria purposes -->\n<div hidden aria-hidden=\"true\">\n    <div [attr.id]=\"_selectMonthButtonAriaLabelId\">{{ selectMonthAriaLabel | fdTranslate }}</div>\n    <div [attr.id]=\"_selectYearButtonAriaLabelId\">{{ 'coreCalendar.yearSelectionLabel' | fdTranslate }}</div>\n    <div [attr.id]=\"_selectYearsRangeButtonAriaLabelId\">{{ selectAggregatedYearAriaLabel | fdTranslate }}</div>\n</div>\n"]}
|