@progressio_resources/gravity-design-system 3.6.6 → 3.6.8
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/esm2022/lib/components/gravity-date-picker/components/day-calendar/day-calendar.component.mjs +271 -0
- package/esm2022/lib/components/gravity-date-picker/components/day-calendar/range-days-calendar.utils.mjs +224 -0
- package/esm2022/lib/components/gravity-date-picker/components/month-calendar/month-calendar.component.mjs +110 -0
- package/esm2022/lib/components/gravity-date-picker/components/year-calendar/year-calendar.component.mjs +111 -0
- package/esm2022/lib/components/gravity-date-picker/gravity-date-picker.component.mjs +85 -0
- package/esm2022/lib/components/gravity-date-picker/shared/date-picker.constants.mjs +61 -0
- package/esm2022/lib/components/gravity-date-picker/shared/date-picker.modal.mjs +2 -0
- package/esm2022/lib/components/gravity-date-picker/shared/date-picker.utils.mjs +111 -0
- package/esm2022/lib/components/gravity-dropdown-label/gravity-dropdown-label.component.mjs +3 -3
- package/esm2022/lib/components/gravity-icon-button/gravity-icon-button.component.mjs +2 -2
- package/esm2022/lib/components/gravity-link/gravity-link.component.mjs +2 -2
- package/esm2022/lib/components/gravity-text-field/gravity-text-field.component.mjs +12 -6
- package/esm2022/lib/gravity-design-system.module.mjs +9 -12
- package/esm2022/lib/layout/gravity-header/gravity-header.component.mjs +3 -3
- package/esm2022/lib/layout/gravity-menu/gravity-menu.component.mjs +4 -5
- package/esm2022/public-api.mjs +2 -2
- package/fesm2022/progressio_resources-gravity-design-system.mjs +527 -245
- package/fesm2022/progressio_resources-gravity-design-system.mjs.map +1 -1
- package/lib/components/gravity-date-picker/components/day-calendar/day-calendar.component.d.ts +108 -0
- package/lib/components/{gravity-calendar-next → gravity-date-picker}/components/day-calendar/range-days-calendar.utils.d.ts +5 -2
- package/lib/components/gravity-date-picker/components/month-calendar/month-calendar.component.d.ts +71 -0
- package/lib/components/gravity-date-picker/components/year-calendar/year-calendar.component.d.ts +72 -0
- package/lib/components/gravity-date-picker/gravity-date-picker.component.d.ts +63 -0
- package/lib/components/gravity-date-picker/shared/date-picker.constants.d.ts +52 -0
- package/lib/components/{gravity-calendar-next/shared/calendar.modal.d.ts → gravity-date-picker/shared/date-picker.modal.d.ts} +8 -4
- package/lib/components/gravity-date-picker/shared/date-picker.utils.d.ts +10 -0
- package/lib/components/gravity-text-field/gravity-text-field.component.d.ts +5 -3
- package/lib/gravity-design-system.module.d.ts +18 -19
- package/lib/layout/gravity-menu/gravity-menu.component.d.ts +2 -2
- package/package.json +1 -1
- package/public-api.d.ts +1 -1
- package/esm2022/lib/components/gravity-calendar-next/components/day-calendar/day-calendar.component.mjs +0 -216
- package/esm2022/lib/components/gravity-calendar-next/components/day-calendar/range-days-calendar.utils.mjs +0 -73
- package/esm2022/lib/components/gravity-calendar-next/components/dual-month-calendar/dual-month-calendar.component.mjs +0 -109
- package/esm2022/lib/components/gravity-calendar-next/components/month-calendar/month-calendar.component.mjs +0 -95
- package/esm2022/lib/components/gravity-calendar-next/components/year-calendar/year-calendar.component.mjs +0 -94
- package/esm2022/lib/components/gravity-calendar-next/gravity-calendar-next.component.mjs +0 -75
- package/esm2022/lib/components/gravity-calendar-next/shared/calendar.constants.mjs +0 -21
- package/esm2022/lib/components/gravity-calendar-next/shared/calendar.modal.mjs +0 -2
- package/esm2022/lib/components/gravity-calendar-next/shared/calendar.utils.mjs +0 -16
- package/lib/components/gravity-calendar-next/components/day-calendar/day-calendar.component.d.ts +0 -61
- package/lib/components/gravity-calendar-next/components/dual-month-calendar/dual-month-calendar.component.d.ts +0 -46
- package/lib/components/gravity-calendar-next/components/month-calendar/month-calendar.component.d.ts +0 -39
- package/lib/components/gravity-calendar-next/components/year-calendar/year-calendar.component.d.ts +0 -38
- package/lib/components/gravity-calendar-next/gravity-calendar-next.component.d.ts +0 -21
- package/lib/components/gravity-calendar-next/shared/calendar.constants.d.ts +0 -22
- package/lib/components/gravity-calendar-next/shared/calendar.utils.d.ts +0 -5
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
import { calendarDateToDate, dateToString, getStartDate, stringToCalendarDate, stringToDate, dateToCalendarDay } from "../../shared/date-picker.utils";
|
|
2
|
+
export function isPreview(component, day) {
|
|
3
|
+
const current = calendarDateToDate(day);
|
|
4
|
+
if (component.selectedRangeStart && !component.selectedRangeEnd && component.hoveredDay) {
|
|
5
|
+
const start = calendarDateToDate(component.selectedRangeStart);
|
|
6
|
+
const hover = calendarDateToDate(component.hoveredDay);
|
|
7
|
+
if (hover <= start)
|
|
8
|
+
return false;
|
|
9
|
+
return current > start && current <= hover;
|
|
10
|
+
}
|
|
11
|
+
if (!component.selectedRangeStart && component.selectedRangeEnd && component.hoveredDay) {
|
|
12
|
+
const end = calendarDateToDate(component.selectedRangeEnd);
|
|
13
|
+
const hover = calendarDateToDate(component.hoveredDay);
|
|
14
|
+
if (hover >= end)
|
|
15
|
+
return false;
|
|
16
|
+
return current < end && current >= hover;
|
|
17
|
+
}
|
|
18
|
+
return false;
|
|
19
|
+
}
|
|
20
|
+
export function processPreselectedRangeDate(component) {
|
|
21
|
+
let end = null;
|
|
22
|
+
let start = null;
|
|
23
|
+
component.startDateField.focus();
|
|
24
|
+
if (Array.isArray(component.config.initDate)) {
|
|
25
|
+
[start, end] = component.config.initDate;
|
|
26
|
+
}
|
|
27
|
+
if (start instanceof Date) {
|
|
28
|
+
component.selectedRangeStart = dateToCalendarDay(start);
|
|
29
|
+
setTimeout(() => {
|
|
30
|
+
component.endDateField.focus();
|
|
31
|
+
component.startDateField.inputValue = dateToString(start, component.appearance.language);
|
|
32
|
+
}, 0);
|
|
33
|
+
}
|
|
34
|
+
if (end instanceof Date) {
|
|
35
|
+
component.currentDate = getStartDate(end);
|
|
36
|
+
component.selectedRangeEnd = dateToCalendarDay(end);
|
|
37
|
+
setTimeout(() => {
|
|
38
|
+
component.startDateField.focus();
|
|
39
|
+
component.endDateField.inputValue = dateToString(end, component.appearance.language);
|
|
40
|
+
}, 0);
|
|
41
|
+
}
|
|
42
|
+
else if (start instanceof Date) {
|
|
43
|
+
component.currentDate = getStartDate(start);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
export function getRangeSelectionClass(component, day) {
|
|
47
|
+
const current = calendarDateToDate(day);
|
|
48
|
+
const start = component.selectedRangeStart ? calendarDateToDate(component.selectedRangeStart) : null;
|
|
49
|
+
const end = component.selectedRangeEnd ? calendarDateToDate(component.selectedRangeEnd) : null;
|
|
50
|
+
if (!start && !end) {
|
|
51
|
+
return component.focused === 'start' ? 'nsl-start' : 'nsl-end';
|
|
52
|
+
}
|
|
53
|
+
if (start && !end) {
|
|
54
|
+
if (current.getTime() === start.getTime())
|
|
55
|
+
return 'sl start';
|
|
56
|
+
if (current.getTime() < start.getTime())
|
|
57
|
+
return 'nsl-start';
|
|
58
|
+
return 'in-slt nsl-end';
|
|
59
|
+
}
|
|
60
|
+
if (!start && end) {
|
|
61
|
+
if (current.getTime() === end.getTime())
|
|
62
|
+
return 'sl end';
|
|
63
|
+
if (current.getTime() > end.getTime())
|
|
64
|
+
return 'nsl-end';
|
|
65
|
+
return 'in-slt nsl-start';
|
|
66
|
+
}
|
|
67
|
+
if (start && end) {
|
|
68
|
+
if (current.getTime() === start.getTime() &&
|
|
69
|
+
start.getTime() === end.getTime())
|
|
70
|
+
return 'start sl same-sln';
|
|
71
|
+
if (current.getTime() === start.getTime())
|
|
72
|
+
return 'sl start';
|
|
73
|
+
if (current.getTime() < start.getTime())
|
|
74
|
+
return 'nsl-start';
|
|
75
|
+
if (current.getTime() === end.getTime())
|
|
76
|
+
return 'sl end';
|
|
77
|
+
if (current.getTime() > end.getTime())
|
|
78
|
+
return 'nsl-end';
|
|
79
|
+
if (current > start && current < end)
|
|
80
|
+
return 'sl range';
|
|
81
|
+
return 'default';
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
export function onSelectDaysRange(component, day) {
|
|
85
|
+
const selected = calendarDateToDate(day);
|
|
86
|
+
const hasEnd = !!component.selectedRangeEnd;
|
|
87
|
+
const hasStart = !!component.selectedRangeStart;
|
|
88
|
+
const language = component.appearance.language;
|
|
89
|
+
const endDate = hasEnd ? calendarDateToDate(component.selectedRangeEnd) : null;
|
|
90
|
+
const startDate = hasStart ? calendarDateToDate(component.selectedRangeStart) : null;
|
|
91
|
+
Object.assign(component, {
|
|
92
|
+
notification: null,
|
|
93
|
+
endDateError: '', startDateError: '',
|
|
94
|
+
endFieldDisabled: false, startFieldDisabled: false,
|
|
95
|
+
});
|
|
96
|
+
const updateField = (field) => {
|
|
97
|
+
component[`selectedRange${field === 'start' ? 'Start' : 'End'}`] = day;
|
|
98
|
+
component[`${field}DateField`].inputValue = dateToString(selected, language);
|
|
99
|
+
setTimeout(() => {
|
|
100
|
+
const focusField = field === 'start' ?
|
|
101
|
+
(component.selectedRangeEnd ? 'start' : 'end') :
|
|
102
|
+
(component.selectedRangeStart ? 'end' : 'start');
|
|
103
|
+
component[`${focusField}DateField`].focus();
|
|
104
|
+
component[`${focusField}DateField`].inputElement.nativeElement.setSelectionRange(10, 10);
|
|
105
|
+
}, 100);
|
|
106
|
+
};
|
|
107
|
+
if (!hasStart && !hasEnd) {
|
|
108
|
+
updateField(component.focused);
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
if (hasStart && !hasEnd) {
|
|
112
|
+
selected >= startDate ? updateField('end') : updateField('start');
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
if (!hasStart && hasEnd) {
|
|
116
|
+
selected < endDate ? updateField('start') : updateField('end');
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
119
|
+
if (hasStart && hasEnd) {
|
|
120
|
+
selected < startDate ? updateField('start') : updateField('end');
|
|
121
|
+
return;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
export function onApplyRageDate(component) {
|
|
125
|
+
const start = calendarDateToDate(component.selectedRangeStart);
|
|
126
|
+
const end = calendarDateToDate(component.selectedRangeEnd);
|
|
127
|
+
component.calendarResponse.emit([start, end]);
|
|
128
|
+
}
|
|
129
|
+
export function onHoverDay(component, day) {
|
|
130
|
+
const startSelected = !!component.selectedRangeStart && !component.selectedRangeEnd;
|
|
131
|
+
const endSelected = !!component.selectedRangeEnd && !component.selectedRangeStart;
|
|
132
|
+
if (startSelected || endSelected) {
|
|
133
|
+
component.hoveredDay = day;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
export function onClearHover(component) {
|
|
137
|
+
component.hoveredDay = null;
|
|
138
|
+
}
|
|
139
|
+
export function searchDate(component, dateStr, target) {
|
|
140
|
+
const i18n = component.i18n;
|
|
141
|
+
const date = stringToDate(dateStr, component.appearance.language);
|
|
142
|
+
const calendarDate = stringToCalendarDate(dateStr, component.appearance.language);
|
|
143
|
+
const errorProp = target === 'start' ? 'startDateError' : 'endDateError';
|
|
144
|
+
const field = target === 'start' ? component.startDateField : component.endDateField;
|
|
145
|
+
const oppositeDisabled = target === 'start' ? 'endFieldDisabled' : 'startFieldDisabled';
|
|
146
|
+
if (!dateStr) {
|
|
147
|
+
component[oppositeDisabled] = false;
|
|
148
|
+
return;
|
|
149
|
+
}
|
|
150
|
+
if (!calendarDate) {
|
|
151
|
+
field.focus();
|
|
152
|
+
component[oppositeDisabled] = true;
|
|
153
|
+
component[errorProp] = i18n.invalid_date;
|
|
154
|
+
component.notification = { text: i18n.select_valid_date, error: true };
|
|
155
|
+
return;
|
|
156
|
+
}
|
|
157
|
+
if (!validateDateLimits(component, date, target)) {
|
|
158
|
+
component[oppositeDisabled] = true;
|
|
159
|
+
return;
|
|
160
|
+
}
|
|
161
|
+
const otherCalendarDate = target === 'start' ? component.selectedRangeEnd : component.selectedRangeStart;
|
|
162
|
+
const otherDate = otherCalendarDate ? calendarDateToDate(otherCalendarDate) : null;
|
|
163
|
+
if ((target === 'start' && otherDate && date > otherDate) ||
|
|
164
|
+
(target === 'end' && otherDate && date < otherDate)) {
|
|
165
|
+
field.focus();
|
|
166
|
+
component[oppositeDisabled] = true;
|
|
167
|
+
component[errorProp] = i18n.invalid_date;
|
|
168
|
+
component.notification = { text: target === 'start' ? i18n.start_before_end : i18n.end_after_start, error: true };
|
|
169
|
+
return;
|
|
170
|
+
}
|
|
171
|
+
if (target === 'start') {
|
|
172
|
+
component.selectedRangeStart = calendarDate;
|
|
173
|
+
if (!component.selectedRangeEnd)
|
|
174
|
+
setTimeout(() => component.endDateField.focus(), 100);
|
|
175
|
+
}
|
|
176
|
+
else {
|
|
177
|
+
component.selectedRangeEnd = calendarDate;
|
|
178
|
+
if (!component.selectedRangeStart)
|
|
179
|
+
setTimeout(() => component.startDateField.focus(), 100);
|
|
180
|
+
}
|
|
181
|
+
component[errorProp] = null;
|
|
182
|
+
component.currentDate = date;
|
|
183
|
+
component.notification = null;
|
|
184
|
+
component[oppositeDisabled] = false;
|
|
185
|
+
}
|
|
186
|
+
export function validateDateLimits(component, date, target) {
|
|
187
|
+
if (component.config.minDate && date < component.config.minDate) {
|
|
188
|
+
component.notification = { text: component.i18n.date_unavailable, error: true };
|
|
189
|
+
target === 'start' ? component.startDateError = component.i18n.invalid_date : component.endDateError = component.i18n.invalid_date;
|
|
190
|
+
return false;
|
|
191
|
+
}
|
|
192
|
+
if (component.config.maxDate && date > component.config.maxDate) {
|
|
193
|
+
component.notification = { text: component.i18n.date_unavailable, error: true };
|
|
194
|
+
target === 'start' ? component.startDateError = component.i18n.invalid_date : component.endDateError = component.i18n.invalid_date;
|
|
195
|
+
return false;
|
|
196
|
+
}
|
|
197
|
+
return true;
|
|
198
|
+
}
|
|
199
|
+
export function onDateKeyup(component, event, target) {
|
|
200
|
+
const ignoredKeys = ['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight', 'Enter', ' ', 'Spacebar'];
|
|
201
|
+
if (ignoredKeys.includes(event.key)) {
|
|
202
|
+
return;
|
|
203
|
+
}
|
|
204
|
+
const errorProp = target === 'start' ? 'startDateError' : 'endDateError';
|
|
205
|
+
const disabled = target === 'start' ? 'endFieldDisabled' : 'startFieldDisabled';
|
|
206
|
+
const dateInput = target === 'start' ? component.startDateField : component.endDateField;
|
|
207
|
+
const selectedRangeProp = target === 'start' ? 'selectedRangeStart' : 'selectedRangeEnd';
|
|
208
|
+
const value = dateInput?.inputValue ?? '';
|
|
209
|
+
if (value.length < 10) {
|
|
210
|
+
component[selectedRangeProp] = null;
|
|
211
|
+
if (!component.notification?.error) {
|
|
212
|
+
component.notification = null;
|
|
213
|
+
}
|
|
214
|
+
if (value.length < 1) {
|
|
215
|
+
component[errorProp] = '';
|
|
216
|
+
component[disabled] = false;
|
|
217
|
+
component.notification = null;
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
if (value.length > 9) {
|
|
221
|
+
searchDate(this, value, target);
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range-days-calendar.utils.js","sourceRoot":"","sources":["../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-date-picker/components/day-calendar/range-days-calendar.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import {CalendarDate} from \"../../shared/date-picker.modal\";\nimport {DayCalendarComponent} from \"./day-calendar.component\";\nimport {calendarDateToDate, dateToString, getStartDate, stringToCalendarDate, stringToDate, dateToCalendarDay} from \"../../shared/date-picker.utils\";\n\nexport function isPreview(component: DayCalendarComponent, day: CalendarDate): boolean {\n\tconst current = calendarDateToDate(day);\n\n\tif (component.selectedRangeStart && !component.selectedRangeEnd && component.hoveredDay) {\n\t\tconst start = calendarDateToDate(component.selectedRangeStart);\n\t\tconst hover = calendarDateToDate(component.hoveredDay);\n\t\tif (hover <= start) return false;\n\t\treturn current > start && current <= hover;\n\t}\n\n\tif (!component.selectedRangeStart && component.selectedRangeEnd && component.hoveredDay) {\n\t\tconst end = calendarDateToDate(component.selectedRangeEnd);\n\t\tconst hover = calendarDateToDate(component.hoveredDay);\n\t\tif (hover >= end) return false;\n\t\treturn current < end && current >= hover;\n\t}\n\n\treturn false;\n}\n\nexport function processPreselectedRangeDate(component: DayCalendarComponent) {\n\tlet end: Date | null = null;\n\tlet start: Date | null = null;\n\n\tcomponent.startDateField.focus();\n\n\tif (Array.isArray(component.config.initDate)) {[start, end] = component.config.initDate;}\n\n  if (start instanceof Date) {\n    component.selectedRangeStart = dateToCalendarDay(start);\n    setTimeout(() => {\n\t    component.endDateField.focus();\n\t\t\tcomponent.startDateField.inputValue = dateToString(start, component.appearance.language);\n\t\t}, 0);\n  }\n\n  if (end instanceof Date) {\n    component.currentDate = getStartDate(end);\n    component.selectedRangeEnd = dateToCalendarDay(end);\n\t\tsetTimeout(() => {\n\t\t\tcomponent.startDateField.focus();\n\t\t\tcomponent.endDateField.inputValue = dateToString(end, component.appearance.language);\n\t\t}, 0);\n\n  } else if (start instanceof Date) {\n    component.currentDate = getStartDate(start);\n  }\n}\n\nexport function getRangeSelectionClass(component: DayCalendarComponent, day: CalendarDate): string {\n\tconst current = calendarDateToDate(day);\n\tconst start = component.selectedRangeStart ? calendarDateToDate(component.selectedRangeStart) : null;\n\tconst end = component.selectedRangeEnd ? calendarDateToDate(component.selectedRangeEnd) : null;\n\n\tif (!start && !end) {\n\t\treturn component.focused === 'start' ? 'nsl-start' : 'nsl-end';\n\t}\n\n\tif (start && !end) {\n\t\tif (current.getTime() === start.getTime()) return 'sl start';\n\t\tif (current.getTime() < start.getTime()) return 'nsl-start';\n\t\treturn 'in-slt nsl-end';\n\t}\n\n\tif (!start && end) {\n\t\tif (current.getTime() === end.getTime()) return 'sl end';\n\t\tif (current.getTime() > end.getTime()) return 'nsl-end';\n\t\treturn 'in-slt nsl-start';\n\t}\n\n\tif (start && end) {\n\t\tif(current.getTime() === start.getTime() &&\n\t\t\t start.getTime() === end.getTime())\n\t\t\t\treturn 'start sl same-sln';\n\n\t\tif (current.getTime() === start.getTime()) return 'sl start';\n\t\tif (current.getTime() < start.getTime()) return 'nsl-start';\n\t\tif (current.getTime() === end.getTime()) return 'sl end';\n\t\tif (current.getTime() > end.getTime()) return 'nsl-end';\n\t\tif (current > start && current < end) return 'sl range';\n\t\treturn 'default';\n\t}\n}\n\nexport function onSelectDaysRange(component: DayCalendarComponent, day: CalendarDate): void {\n\tconst selected = calendarDateToDate(day);\n\tconst hasEnd = !!component.selectedRangeEnd;\n\tconst hasStart = !!component.selectedRangeStart;\n\tconst language = component.appearance.language;\n\tconst endDate = hasEnd ? calendarDateToDate(component.selectedRangeEnd) : null;\n\tconst startDate = hasStart ? calendarDateToDate(component.selectedRangeStart) : null;\n\n\tObject.assign(component, {\n\t\tnotification: null,\n\t\tendDateError: '', startDateError: '',\n\t\tendFieldDisabled: false, startFieldDisabled: false,\n\t});\n\n\tconst updateField = (field: 'start' | 'end') => {\n\t\tcomponent[`selectedRange${field === 'start' ? 'Start' : 'End'}`] = day;\n\t\tcomponent[`${field}DateField`].inputValue = dateToString(selected, language);\n\n\t\tsetTimeout(() => {\n\t\t\tconst focusField = field === 'start' ?\n\t\t\t\t(component.selectedRangeEnd ? 'start' : 'end') :\n\t\t\t\t(component.selectedRangeStart ? 'end' : 'start');\n\n\t\t\tcomponent[`${focusField}DateField`].focus();\n\t\t\tcomponent[`${focusField}DateField`].inputElement.nativeElement.setSelectionRange(10, 10);\n\t\t}, 100);\n\t};\n\n\tif (!hasStart && !hasEnd) {\n\t\tupdateField(component.focused);\n\t\treturn;\n\t}\n\n\tif (hasStart && !hasEnd) {\n\t\tselected >= startDate! ? updateField('end') : updateField('start');\n\t\treturn;\n\t}\n\n\tif (!hasStart && hasEnd) {\n\t\tselected < endDate! ? updateField('start') : updateField('end');\n\t\treturn;\n\t}\n\n\tif (hasStart && hasEnd) {\n\t\tselected < startDate! ? updateField('start') : updateField('end');\n\t\treturn;\n\t}\n}\n\nexport function onApplyRageDate(component: DayCalendarComponent){\n    const start = calendarDateToDate(component.selectedRangeStart);\n    const end = calendarDateToDate(component.selectedRangeEnd);\n    component.calendarResponse.emit([start, end]);\n}\n\nexport function onHoverDay(component: DayCalendarComponent, day: CalendarDate): void {\n\tconst startSelected = !!component.selectedRangeStart && !component.selectedRangeEnd;\n\tconst endSelected = !!component.selectedRangeEnd && !component.selectedRangeStart;\n\tif (startSelected || endSelected) { component.hoveredDay = day; }\n}\n\nexport function onClearHover(component: DayCalendarComponent): void {\n\tcomponent.hoveredDay = null;\n}\n\nexport function searchDate(component: DayCalendarComponent, dateStr: string, target: 'start' | 'end'): void {\n\tconst i18n = component.i18n;\n\tconst date = stringToDate(dateStr, component.appearance.language);\n\tconst calendarDate = stringToCalendarDate(dateStr, component.appearance.language);\n\tconst errorProp = target === 'start' ? 'startDateError' : 'endDateError';\n\tconst field = target === 'start' ? component.startDateField : component.endDateField;\n\tconst oppositeDisabled = target === 'start' ? 'endFieldDisabled' : 'startFieldDisabled';\n\n\tif (!dateStr) { component[oppositeDisabled] = false; return; }\n\n\tif (!calendarDate) {\n\t\tfield.focus();\n\t\tcomponent[oppositeDisabled] = true;\n\t\tcomponent[errorProp] = i18n.invalid_date;\n\t\tcomponent.notification = { text: i18n.select_valid_date, error: true };\n\t\treturn;\n\t}\n\n\tif (!validateDateLimits(component, date, target)) {\n\t\tcomponent[oppositeDisabled] = true;\n\t\treturn;\n\t}\n\n\tconst otherCalendarDate = target === 'start' ? component.selectedRangeEnd : component.selectedRangeStart;\n\tconst otherDate = otherCalendarDate ? calendarDateToDate(otherCalendarDate) : null;\n\n\tif ((target === 'start' && otherDate && date > otherDate) ||\n\t\t(target === 'end' && otherDate && date < otherDate)) {\n\t\tfield.focus();\n\t\tcomponent[oppositeDisabled] = true;\n\t\tcomponent[errorProp] = i18n.invalid_date;\n\t\tcomponent.notification = { text: target === 'start' ? i18n.start_before_end : i18n.end_after_start, error: true };\n\t\treturn;\n\t}\n\n\tif (target === 'start') {\n\t\tcomponent.selectedRangeStart = calendarDate;\n\t\tif (!component.selectedRangeEnd) setTimeout(() => component.endDateField.focus(), 100);\n\t} else {\n\t\tcomponent.selectedRangeEnd = calendarDate;\n\t\tif (!component.selectedRangeStart) setTimeout(() => component.startDateField.focus(), 100);\n\t}\n\n\tcomponent[errorProp] = null;\n\tcomponent.currentDate = date;\n\tcomponent.notification = null;\n\tcomponent[oppositeDisabled] = false;\n}\n\nexport function validateDateLimits(component: DayCalendarComponent, date: Date, target: 'start' | 'end') : boolean {\n\tif (component.config.minDate && date < component.config.minDate) {\n\t\tcomponent.notification = { text: component.i18n.date_unavailable, error: true };\n\t\ttarget === 'start' ? component.startDateError = component.i18n.invalid_date : component.endDateError = component.i18n.invalid_date;\n\t\treturn false;\n\t}\n\n\tif (component.config.maxDate && date > component.config.maxDate) {\n\t\tcomponent.notification = { text: component.i18n.date_unavailable, error: true };\n\t\ttarget === 'start' ? component.startDateError = component.i18n.invalid_date : component.endDateError = component.i18n.invalid_date;\n\t\treturn false;\n\t}\n\n\treturn true;\n}\n\nexport function onDateKeyup(component: DayCalendarComponent, event: KeyboardEvent, target: 'start' | 'end'): void {\n\tconst ignoredKeys = ['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight', 'Enter', ' ', 'Spacebar'];\n\tif (ignoredKeys.includes(event.key)) { return; }\n\n\tconst errorProp = target === 'start' ? 'startDateError' : 'endDateError';\n\tconst disabled = target === 'start' ? 'endFieldDisabled' : 'startFieldDisabled';\n\tconst dateInput = target === 'start' ? component.startDateField : component.endDateField;\n\tconst selectedRangeProp = target === 'start' ? 'selectedRangeStart' : 'selectedRangeEnd';\n\n\tconst value = dateInput?.inputValue ?? '';\n\n\tif (value.length < 10) {\n\t\tcomponent[selectedRangeProp] = null;\n\n\t\tif(!component.notification?.error) {\n\t\t\tcomponent.notification = null;\n\t\t}\n\n\t\tif (value.length < 1) {\n\t\t\tcomponent[errorProp] = '';\n\t\t\tcomponent[disabled] = false;\n\t\t\tcomponent.notification = null;\n\t\t}\n\t}\n\n\tif (value.length > 9) {\n\t\tsearchDate(this, value, target);\n\t}\n\n}\n"]}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { changeDate, getStartDate, isPeriodAvailable } from "../../shared/date-picker.utils";
|
|
2
|
+
import { Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
3
|
+
import { CALENDAR_I18N, MONTHS_EN, MONTHS_SHORT_EN, MONTHS_ES, MONTHS_SHORT_ES } from "../../shared/date-picker.constants";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "../../../gravity-button/gravity-button.component";
|
|
7
|
+
import * as i3 from "../../../gravity-icon-button/gravity-icon-button.component";
|
|
8
|
+
import * as i4 from "../../../gravity-link/gravity-link.component";
|
|
9
|
+
import * as i5 from "../../../gravity-dropdown-label/gravity-dropdown-label.component";
|
|
10
|
+
export class MonthCalendarComponent {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.restart = false;
|
|
13
|
+
this.integratedMode = false;
|
|
14
|
+
this.clearSelection = new EventEmitter();
|
|
15
|
+
this.response = new EventEmitter();
|
|
16
|
+
this.currentDate = new Date();
|
|
17
|
+
this.changeDate = changeDate;
|
|
18
|
+
this.isPeriodAvailable = isPeriodAvailable;
|
|
19
|
+
}
|
|
20
|
+
get i18n() { return CALENDAR_I18N[this.appearance.language]; }
|
|
21
|
+
get monthsList() { return this.appearance.language === 'en' ? MONTHS_EN : MONTHS_ES; }
|
|
22
|
+
get monthsShortList() { return this.appearance.language === 'en' ? MONTHS_SHORT_EN : MONTHS_SHORT_ES; }
|
|
23
|
+
ngOnChanges(changes) {
|
|
24
|
+
const shouldRestart = changes['restart'] && this.restart;
|
|
25
|
+
const shouldProcessPreSelected = changes['preSelectedDate'] && this.initDate;
|
|
26
|
+
if (shouldRestart || shouldProcessPreSelected) {
|
|
27
|
+
this.processInitDate();
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
trackByMonth(_, month) {
|
|
31
|
+
return `${month.year}-${month.month}`;
|
|
32
|
+
}
|
|
33
|
+
processInitDate() {
|
|
34
|
+
if (this.initDate instanceof Date) {
|
|
35
|
+
this.currentDate = getStartDate(this.initDate);
|
|
36
|
+
this.selectedMonth = {
|
|
37
|
+
month: this.initDate.getMonth(),
|
|
38
|
+
year: this.initDate.getFullYear()
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
onSelectMonth(month) {
|
|
43
|
+
this.selectedMonth = month;
|
|
44
|
+
this.currentDate = new Date(month.year, month.month, 1);
|
|
45
|
+
this.response.emit(this.currentDate);
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
getMonthSelectionClass(month) {
|
|
49
|
+
const classes = [];
|
|
50
|
+
const { minDate, maxDate } = this.config ?? {};
|
|
51
|
+
const firstDay = new Date(month.year, month.month, 1);
|
|
52
|
+
const lastDay = new Date(month.year, month.month + 1, 0);
|
|
53
|
+
let isDisabled = false;
|
|
54
|
+
if (minDate && lastDay < minDate) {
|
|
55
|
+
isDisabled = true;
|
|
56
|
+
}
|
|
57
|
+
if (maxDate && firstDay > maxDate) {
|
|
58
|
+
isDisabled = true;
|
|
59
|
+
}
|
|
60
|
+
if (isDisabled) {
|
|
61
|
+
classes.push('disabled');
|
|
62
|
+
}
|
|
63
|
+
if (this.selectedMonth && this.selectedMonth.month === month.month && this.selectedMonth.year === month.year) {
|
|
64
|
+
classes.push('selected');
|
|
65
|
+
}
|
|
66
|
+
return classes.join(' ');
|
|
67
|
+
}
|
|
68
|
+
isCurrentMonth(month) {
|
|
69
|
+
if (new Date().getMonth() === month.month &&
|
|
70
|
+
new Date().getFullYear() === month.year) {
|
|
71
|
+
return true;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
clearSelectedMonth() {
|
|
75
|
+
this.selectedMonth = null;
|
|
76
|
+
this.clearSelection.emit();
|
|
77
|
+
}
|
|
78
|
+
applySelectedMonth() {
|
|
79
|
+
const date = new Date(this.selectedMonth.year, this.selectedMonth.month);
|
|
80
|
+
this.response.emit(date);
|
|
81
|
+
}
|
|
82
|
+
getYearMonthsList() {
|
|
83
|
+
const months = [];
|
|
84
|
+
for (let i = 0; i < 12; i++) {
|
|
85
|
+
months.push({ month: i, year: this.currentDate.getFullYear() });
|
|
86
|
+
}
|
|
87
|
+
return months;
|
|
88
|
+
}
|
|
89
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MonthCalendarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
90
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MonthCalendarComponent, selector: "month-calendar", inputs: { config: "config", initDate: "initDate", restart: "restart", appearance: "appearance", integratedMode: "integratedMode" }, outputs: { clearSelection: "clearSelection", response: "response" }, usesOnChanges: true, ngImport: i0, template: "<section class=\"gravity-calendar-header\" [class.mobile]=\"appearance.isMobile\">\n <div class=\"header-container\">\n\n <gravity-icon-button *ngIf=\"!integratedMode\"\n [size]=\"'sm'\"\n [type]=\"'primary'\"\n [icon]=\"'arrow-left'\"\n [supportText]=\"i18n.preview_year\"\n (clickOnIcon)=\"currentDate = changeDate(-1, currentDate, false)\"\n [state]=\"(appearance.state !== 'disabled') && isPeriodAvailable(currentDate, config.minDate, 'month', 'prev') ? 'active' : 'disabled'\"/>\n\n <div class=\"year-label\">\n <gravity-dropdown-label\n [size]=\"'sm'\"\n [fontClass]=\"'hr-title sm-bold'\"\n [state]=\"integratedMode && appearance.state !== 'disabled' ? 'active' : 'inactive'\"\n [label]=\"integratedMode ? monthsList[currentDate.getMonth()] : currentDate.getFullYear().toString()\"\n [isOpen]=\"integratedMode\" (onClickLabel)=\"response.emit(currentDate)\" > </gravity-dropdown-label>\n </div>\n\n <gravity-icon-button *ngIf=\"!integratedMode\"\n [size]=\"'sm'\"\n [type]=\"'primary'\"\n [icon]=\"'arrow-right'\"\n [supportText]=\"i18n.next_year\"\n (clickOnIcon)=\"currentDate = changeDate(1, currentDate, false)\"\n [state]=\"(appearance.state !== 'disabled') && isPeriodAvailable(currentDate, config.maxDate, 'month', 'next') ? 'active' : 'disabled'\"/>\n </div>\n\n <div class=\"separator-line\"></div>\n</section>\n\n<section class=\"gravity-calendar-body\" [class.mobile]=\"appearance.isMobile\">\n <div class=\"items-table\">\n <span class=\"hr-body sm-regular item\" *ngFor=\"let month of getYearMonthsList(), trackBy: trackByMonth\"\n [ngClass]=\"appearance.state === 'disabled' ? 'disabled' : getMonthSelectionClass(month)\" (click)=\"onSelectMonth(month)\"\n [class.current]=\"isCurrentMonth(month)\"> {{ monthsShortList[month.month] }} </span>\n </div>\n\n <div *ngIf=\"appearance.actions\" class=\"action-section\" >\n <gravity-link [linkText]=\"i18n.clear\" [state]=\"!selectedMonth ? 'disabled' : 'active'\" (click)=\"clearSelectedMonth()\"/>\n <gravity-button [size]=\"'sm'\" [type]=\"'tertiary'\" [disabled]=\"!selectedMonth\" (click)=\"applySelectedMonth()\">{{i18n.apply}}</gravity-button>\n </div>\n</section>", styles: [":root{--gravity-spacing-none: 0;--gravity-spacing-xxxs: .125rem;--gravity-spacing-xxs: .25rem;--gravity-spacing-xs: .5rem;--gravity-spacing-sm: 1rem;--gravity-spacing-md: 1.5rem;--gravity-spacing-lg: 2rem;--gravity-spacing-xl: 2.5rem;--gravity-spacing-xxl: 3rem;--gravity-spacing-xxxl: 4rem;--gravity-spacing-xxxxl: 6rem;--gravity-spacing-xxxxxl: 12rem}.gravity-padding-none{padding:0!important}.gravity-padding-top-none{padding-top:0!important}.gravity-padding-bottom-none{padding-bottom:0!important}.gravity-padding-left-none{padding-left:0!important}.gravity-padding-right-none{padding-right:0!important}.gravity-padding-block-none{padding-block:0!important}.gravity-padding-inline-none{padding-inline:0!important}.gravity-padding-xxs{padding:.25rem!important}.gravity-padding-top-xxs{padding-top:.25rem!important}.gravity-padding-bottom-xxs{padding-bottom:.25rem!important}.gravity-padding-left-xxs{padding-left:.25rem!important}.gravity-padding-right-xxs{padding-right:.25rem!important}.gravity-padding-block-xxs{padding-block:.25rem!important}.gravity-padding-inline-xxs{padding-inline:.25rem!important}.gravity-padding-xs{padding:.5rem!important}.gravity-padding-top-xs{padding-top:.5rem!important}.gravity-padding-bottom-xs{padding-bottom:.5rem!important}.gravity-padding-left-xs{padding-left:.5rem!important}.gravity-padding-right-xs{padding-right:.5rem!important}.gravity-padding-block-xs{padding-block:.5rem!important}.gravity-padding-inline-xs{padding-inline:.5rem!important}.gravity-padding-sm{padding:1rem!important}.gravity-padding-top-sm{padding-top:1rem!important}.gravity-padding-bottom-sm{padding-bottom:1rem!important}.gravity-padding-left-sm{padding-left:1rem!important}.gravity-padding-right-sm{padding-right:1rem!important}.gravity-padding-block-sm{padding-block:1rem!important}.gravity-padding-inline-sm{padding-inline:1rem!important}.gravity-padding-md{padding:1.5rem!important}.gravity-padding-top-md{padding-top:1.5rem!important}.gravity-padding-bottom-md{padding-bottom:1.5rem!important}.gravity-padding-left-md{padding-left:1.5rem!important}.gravity-padding-right-md{padding-right:1.5rem!important}.gravity-padding-block-md{padding-block:1.5rem!important}.gravity-padding-inline-md{padding-inline:1.5rem!important}.gravity-padding-lg{padding:2rem!important}.gravity-padding-top-lg{padding-top:2rem!important}.gravity-padding-bottom-lg{padding-bottom:2rem!important}.gravity-padding-left-lg{padding-left:2rem!important}.gravity-padding-right-lg{padding-right:2rem!important}.gravity-padding-block-lg{padding-block:2rem!important}.gravity-padding-inline-lg{padding-inline:2rem!important}.gravity-padding-xl{padding:2.5rem!important}.gravity-padding-top-xl{padding-top:2.5rem!important}.gravity-padding-bottom-xl{padding-bottom:2.5rem!important}.gravity-padding-left-xl{padding-left:2.5rem!important}.gravity-padding-right-xl{padding-right:2.5rem!important}.gravity-padding-block-xl{padding-block:2.5rem!important}.gravity-padding-inline-xl{padding-inline:2.5rem!important}.gravity-padding-xxl{padding:3rem!important}.gravity-padding-top-xxl{padding-top:3rem!important}.gravity-padding-bottom-xxl{padding-bottom:3rem!important}.gravity-padding-left-xxl{padding-left:3rem!important}.gravity-padding-right-xxl{padding-right:3rem!important}.gravity-padding-block-xxl{padding-block:3rem!important}.gravity-padding-inline-xxl{padding-inline:3rem!important}.gravity-padding-xxxl{padding:4rem!important}.gravity-padding-top-xxxl{padding-top:4rem!important}.gravity-padding-bottom-xxxl{padding-bottom:4rem!important}.gravity-padding-left-xxxl{padding-left:4rem!important}.gravity-padding-right-xxxl{padding-right:4rem!important}.gravity-padding-block-xxxl{padding-block:4rem!important}.gravity-padding-inline-xxxl{padding-inline:4rem!important}.gravity-padding-xxxxl{padding:6rem!important}.gravity-padding-top-xxxxl{padding-top:6rem!important}.gravity-padding-bottom-xxxxl{padding-bottom:6rem!important}.gravity-padding-left-xxxxl{padding-left:6rem!important}.gravity-padding-right-xxxxl{padding-right:6rem!important}.gravity-padding-block-xxxxl{padding-block:6rem!important}.gravity-padding-inline-xxxxl{padding-inline:6rem!important}.gravity-padding-xxxxxl{padding:12rem!important}.gravity-padding-top-xxxxxl{padding-top:12rem!important}.gravity-padding-bottom-xxxxxl{padding-bottom:12rem!important}.gravity-padding-left-xxxxxl{padding-left:12rem!important}.gravity-padding-right-xxxxxl{padding-right:12rem!important}.gravity-padding-block-xxxxxl{padding-block:12rem!important}.gravity-padding-inline-xxxxxl{padding-inline:12rem!important}.gravity-margin-none{margin:0!important}.gravity-margin-top-none{margin-top:0!important}.gravity-margin-bottom-none{margin-bottom:0!important}.gravity-margin-left-none{margin-left:0!important}.gravity-margin-right-none{margin-right:0!important}.gravity-margin-block-none{margin-block:0!important}.gravity-margin-inline-none{margin-inline:0!important}.gravity-margin-xxs{margin:.25rem!important}.gravity-margin-top-xxs{margin-top:.25rem!important}.gravity-margin-bottom-xxs{margin-bottom:.25rem!important}.gravity-margin-left-xxs{margin-left:.25rem!important}.gravity-margin-right-xxs{margin-right:.25rem!important}.gravity-margin-block-xxs{margin-block:.25rem!important}.gravity-margin-inline-xxs{margin-inline:.25rem!important}.gravity-margin-xs{margin:.5rem!important}.gravity-margin-top-xs{margin-top:.5rem!important}.gravity-margin-bottom-xs{margin-bottom:.5rem!important}.gravity-margin-left-xs{margin-left:.5rem!important}.gravity-margin-right-xs{margin-right:.5rem!important}.gravity-margin-block-xs{margin-block:.5rem!important}.gravity-margin-inline-xs{margin-inline:.5rem!important}.gravity-margin-sm{margin:1rem!important}.gravity-margin-top-sm{margin-top:1rem!important}.gravity-margin-bottom-sm{margin-bottom:1rem!important}.gravity-margin-left-sm{margin-left:1rem!important}.gravity-margin-right-sm{margin-right:1rem!important}.gravity-margin-block-sm{margin-block:1rem!important}.gravity-margin-inline-sm{margin-inline:1rem!important}.gravity-margin-md{margin:1.5rem!important}.gravity-margin-top-md{margin-top:1.5rem!important}.gravity-margin-bottom-md{margin-bottom:1.5rem!important}.gravity-margin-left-md{margin-left:1.5rem!important}.gravity-margin-right-md{margin-right:1.5rem!important}.gravity-margin-block-md{margin-block:1.5rem!important}.gravity-margin-inline-md{margin-inline:1.5rem!important}.gravity-margin-lg{margin:2rem!important}.gravity-margin-top-lg{margin-top:2rem!important}.gravity-margin-bottom-lg{margin-bottom:2rem!important}.gravity-margin-left-lg{margin-left:2rem!important}.gravity-margin-right-lg{margin-right:2rem!important}.gravity-margin-block-lg{margin-block:2rem!important}.gravity-margin-inline-lg{margin-inline:2rem!important}.gravity-margin-xl{margin:2.5rem!important}.gravity-margin-top-xl{margin-top:2.5rem!important}.gravity-margin-bottom-xl{margin-bottom:2.5rem!important}.gravity-margin-left-xl{margin-left:2.5rem!important}.gravity-margin-right-xl{margin-right:2.5rem!important}.gravity-margin-block-xl{margin-block:2.5rem!important}.gravity-margin-inline-xl{margin-inline:2.5rem!important}.gravity-margin-xxl{margin:3rem!important}.gravity-margin-top-xxl{margin-top:3rem!important}.gravity-margin-bottom-xxl{margin-bottom:3rem!important}.gravity-margin-left-xxl{margin-left:3rem!important}.gravity-margin-right-xxl{margin-right:3rem!important}.gravity-margin-block-xxl{margin-block:3rem!important}.gravity-margin-inline-xxl{margin-inline:3rem!important}.gravity-margin-xxxl{margin:4rem!important}.gravity-margin-top-xxxl{margin-top:4rem!important}.gravity-margin-bottom-xxxl{margin-bottom:4rem!important}.gravity-margin-left-xxxl{margin-left:4rem!important}.gravity-margin-right-xxxl{margin-right:4rem!important}.gravity-margin-block-xxxl{margin-block:4rem!important}.gravity-margin-inline-xxxl{margin-inline:4rem!important}.gravity-margin-xxxxl{margin:6rem!important}.gravity-margin-top-xxxxl{margin-top:6rem!important}.gravity-margin-bottom-xxxxl{margin-bottom:6rem!important}.gravity-margin-left-xxxxl{margin-left:6rem!important}.gravity-margin-right-xxxxl{margin-right:6rem!important}.gravity-margin-block-xxxxl{margin-block:6rem!important}.gravity-margin-inline-xxxxl{margin-inline:6rem!important}.gravity-margin-xxxxxl{margin:12rem!important}.gravity-margin-top-xxxxxl{margin-top:12rem!important}.gravity-margin-bottom-xxxxxl{margin-bottom:12rem!important}.gravity-margin-left-xxxxxl{margin-left:12rem!important}.gravity-margin-right-xxxxxl{margin-right:12rem!important}.gravity-margin-block-xxxxxl{margin-block:12rem!important}.gravity-margin-inline-xxxxxl{margin-inline:12rem!important}.border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.next-button,.previous-button{cursor:pointer;padding:var(--gravity-spacing-xs);border-radius:var(--gravity-spacing-xs)}.next-button:not(.disabled):hover,.previous-button:not(.disabled):hover{background:var(--bg-button-active-tertiary)}.next-button.disabled,.previous-button.disabled{cursor:default;pointer-events:none;--icon-color: var(--on-bg-disabled)}.separator-line{border-bottom:2px solid var(--divider-menu-active-primary)}.action-section{height:25px;display:flex;align-self:stretch;align-items:center;justify-content:space-between}.gravity-calendar-header{width:215px;height:40px;display:flex;align-self:stretch;align-items:center;flex-direction:column;justify-content:center;gap:var(--gravity-spacing-sm);padding-top:var(--gravity-spacing-xs)}.gravity-calendar-header .header-container{display:flex;align-items:center;align-self:stretch;justify-content:space-between}.gravity-calendar-header .separator-line{width:215px}.gravity-calendar-header.mobile,.gravity-calendar-header.mobile .separator-line{width:100%}.gravity-calendar-body{width:215px;display:flex;align-items:center;align-self:stretch;flex-direction:column;justify-content:center;gap:var(--gravity-spacing-sm);margin-top:var(--gravity-spacing-sm)}.gravity-calendar-body .items-table{display:flex;flex-wrap:wrap;justify-content:space-between;gap:0 var(--gravity-spacing-sm)}.gravity-calendar-body .items-table .item{width:37px;height:25px;display:flex;cursor:pointer;align-items:center;justify-content:center;border-radius:var(--gravity-spacing-xs);color:var(--on-bg-button-pressed-tertiary);border:2px solid var(--bg-calender-primary)}.gravity-calendar-body .items-table .item.current{border-color:var(--bg-number-calendar-hover-primary)}.gravity-calendar-body .items-table .item:not(.disabled):not(.selected):hover{color:var(--on-bg-button-pressed-tertiary);background:var(--bg-button-active-tertiary);border-color:var(--bg-button-active-tertiary)}.gravity-calendar-body .items-table .item.selected{color:var(--on-bg-button-pressed-primary);background:var(--bg-button-pressed-primary);border-color:var(--bg-button-pressed-primary)}.gravity-calendar-body .items-table .item.disabled{cursor:default;pointer-events:none;color:var(--on-bg-disabled)}.gravity-calendar-body.mobile{width:100%}.gravity-calendar-body.mobile .items-table{gap:var(--gravity-spacing-md) var(--gravity-spacing-sm)}.gravity-calendar-body.mobile .items-table .item{width:70px;height:43px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.GravityButtonComponent, selector: "gravity-button", inputs: ["cypressTag", "disabled", "iconName", "isLoading", "showContent", "size", "iconPosition", "customState", "type"] }, { kind: "component", type: i3.GravityIconButtonComponent, selector: "gravity-icon-button", inputs: ["cypressTag", "icon", "supportText", "variant", "size", "type", "state", "badge"], outputs: ["clickOnIcon"] }, { kind: "component", type: i4.GravityLinkComponent, selector: "gravity-link", inputs: ["linkText", "fontClass", "link", "cypressTag", "iconName", "target", "iconPosition", "iconSize", "state"] }, { kind: "component", type: i5.GravityDropdownLabelComponent, selector: "gravity-dropdown-label", inputs: ["label", "fontClass", "isOpen", "stopPropagation", "size", "state"], outputs: ["onClickLabel"] }] }); }
|
|
91
|
+
}
|
|
92
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MonthCalendarComponent, decorators: [{
|
|
93
|
+
type: Component,
|
|
94
|
+
args: [{ selector: 'month-calendar', template: "<section class=\"gravity-calendar-header\" [class.mobile]=\"appearance.isMobile\">\n <div class=\"header-container\">\n\n <gravity-icon-button *ngIf=\"!integratedMode\"\n [size]=\"'sm'\"\n [type]=\"'primary'\"\n [icon]=\"'arrow-left'\"\n [supportText]=\"i18n.preview_year\"\n (clickOnIcon)=\"currentDate = changeDate(-1, currentDate, false)\"\n [state]=\"(appearance.state !== 'disabled') && isPeriodAvailable(currentDate, config.minDate, 'month', 'prev') ? 'active' : 'disabled'\"/>\n\n <div class=\"year-label\">\n <gravity-dropdown-label\n [size]=\"'sm'\"\n [fontClass]=\"'hr-title sm-bold'\"\n [state]=\"integratedMode && appearance.state !== 'disabled' ? 'active' : 'inactive'\"\n [label]=\"integratedMode ? monthsList[currentDate.getMonth()] : currentDate.getFullYear().toString()\"\n [isOpen]=\"integratedMode\" (onClickLabel)=\"response.emit(currentDate)\" > </gravity-dropdown-label>\n </div>\n\n <gravity-icon-button *ngIf=\"!integratedMode\"\n [size]=\"'sm'\"\n [type]=\"'primary'\"\n [icon]=\"'arrow-right'\"\n [supportText]=\"i18n.next_year\"\n (clickOnIcon)=\"currentDate = changeDate(1, currentDate, false)\"\n [state]=\"(appearance.state !== 'disabled') && isPeriodAvailable(currentDate, config.maxDate, 'month', 'next') ? 'active' : 'disabled'\"/>\n </div>\n\n <div class=\"separator-line\"></div>\n</section>\n\n<section class=\"gravity-calendar-body\" [class.mobile]=\"appearance.isMobile\">\n <div class=\"items-table\">\n <span class=\"hr-body sm-regular item\" *ngFor=\"let month of getYearMonthsList(), trackBy: trackByMonth\"\n [ngClass]=\"appearance.state === 'disabled' ? 'disabled' : getMonthSelectionClass(month)\" (click)=\"onSelectMonth(month)\"\n [class.current]=\"isCurrentMonth(month)\"> {{ monthsShortList[month.month] }} </span>\n </div>\n\n <div *ngIf=\"appearance.actions\" class=\"action-section\" >\n <gravity-link [linkText]=\"i18n.clear\" [state]=\"!selectedMonth ? 'disabled' : 'active'\" (click)=\"clearSelectedMonth()\"/>\n <gravity-button [size]=\"'sm'\" [type]=\"'tertiary'\" [disabled]=\"!selectedMonth\" (click)=\"applySelectedMonth()\">{{i18n.apply}}</gravity-button>\n </div>\n</section>", styles: [":root{--gravity-spacing-none: 0;--gravity-spacing-xxxs: .125rem;--gravity-spacing-xxs: .25rem;--gravity-spacing-xs: .5rem;--gravity-spacing-sm: 1rem;--gravity-spacing-md: 1.5rem;--gravity-spacing-lg: 2rem;--gravity-spacing-xl: 2.5rem;--gravity-spacing-xxl: 3rem;--gravity-spacing-xxxl: 4rem;--gravity-spacing-xxxxl: 6rem;--gravity-spacing-xxxxxl: 12rem}.gravity-padding-none{padding:0!important}.gravity-padding-top-none{padding-top:0!important}.gravity-padding-bottom-none{padding-bottom:0!important}.gravity-padding-left-none{padding-left:0!important}.gravity-padding-right-none{padding-right:0!important}.gravity-padding-block-none{padding-block:0!important}.gravity-padding-inline-none{padding-inline:0!important}.gravity-padding-xxs{padding:.25rem!important}.gravity-padding-top-xxs{padding-top:.25rem!important}.gravity-padding-bottom-xxs{padding-bottom:.25rem!important}.gravity-padding-left-xxs{padding-left:.25rem!important}.gravity-padding-right-xxs{padding-right:.25rem!important}.gravity-padding-block-xxs{padding-block:.25rem!important}.gravity-padding-inline-xxs{padding-inline:.25rem!important}.gravity-padding-xs{padding:.5rem!important}.gravity-padding-top-xs{padding-top:.5rem!important}.gravity-padding-bottom-xs{padding-bottom:.5rem!important}.gravity-padding-left-xs{padding-left:.5rem!important}.gravity-padding-right-xs{padding-right:.5rem!important}.gravity-padding-block-xs{padding-block:.5rem!important}.gravity-padding-inline-xs{padding-inline:.5rem!important}.gravity-padding-sm{padding:1rem!important}.gravity-padding-top-sm{padding-top:1rem!important}.gravity-padding-bottom-sm{padding-bottom:1rem!important}.gravity-padding-left-sm{padding-left:1rem!important}.gravity-padding-right-sm{padding-right:1rem!important}.gravity-padding-block-sm{padding-block:1rem!important}.gravity-padding-inline-sm{padding-inline:1rem!important}.gravity-padding-md{padding:1.5rem!important}.gravity-padding-top-md{padding-top:1.5rem!important}.gravity-padding-bottom-md{padding-bottom:1.5rem!important}.gravity-padding-left-md{padding-left:1.5rem!important}.gravity-padding-right-md{padding-right:1.5rem!important}.gravity-padding-block-md{padding-block:1.5rem!important}.gravity-padding-inline-md{padding-inline:1.5rem!important}.gravity-padding-lg{padding:2rem!important}.gravity-padding-top-lg{padding-top:2rem!important}.gravity-padding-bottom-lg{padding-bottom:2rem!important}.gravity-padding-left-lg{padding-left:2rem!important}.gravity-padding-right-lg{padding-right:2rem!important}.gravity-padding-block-lg{padding-block:2rem!important}.gravity-padding-inline-lg{padding-inline:2rem!important}.gravity-padding-xl{padding:2.5rem!important}.gravity-padding-top-xl{padding-top:2.5rem!important}.gravity-padding-bottom-xl{padding-bottom:2.5rem!important}.gravity-padding-left-xl{padding-left:2.5rem!important}.gravity-padding-right-xl{padding-right:2.5rem!important}.gravity-padding-block-xl{padding-block:2.5rem!important}.gravity-padding-inline-xl{padding-inline:2.5rem!important}.gravity-padding-xxl{padding:3rem!important}.gravity-padding-top-xxl{padding-top:3rem!important}.gravity-padding-bottom-xxl{padding-bottom:3rem!important}.gravity-padding-left-xxl{padding-left:3rem!important}.gravity-padding-right-xxl{padding-right:3rem!important}.gravity-padding-block-xxl{padding-block:3rem!important}.gravity-padding-inline-xxl{padding-inline:3rem!important}.gravity-padding-xxxl{padding:4rem!important}.gravity-padding-top-xxxl{padding-top:4rem!important}.gravity-padding-bottom-xxxl{padding-bottom:4rem!important}.gravity-padding-left-xxxl{padding-left:4rem!important}.gravity-padding-right-xxxl{padding-right:4rem!important}.gravity-padding-block-xxxl{padding-block:4rem!important}.gravity-padding-inline-xxxl{padding-inline:4rem!important}.gravity-padding-xxxxl{padding:6rem!important}.gravity-padding-top-xxxxl{padding-top:6rem!important}.gravity-padding-bottom-xxxxl{padding-bottom:6rem!important}.gravity-padding-left-xxxxl{padding-left:6rem!important}.gravity-padding-right-xxxxl{padding-right:6rem!important}.gravity-padding-block-xxxxl{padding-block:6rem!important}.gravity-padding-inline-xxxxl{padding-inline:6rem!important}.gravity-padding-xxxxxl{padding:12rem!important}.gravity-padding-top-xxxxxl{padding-top:12rem!important}.gravity-padding-bottom-xxxxxl{padding-bottom:12rem!important}.gravity-padding-left-xxxxxl{padding-left:12rem!important}.gravity-padding-right-xxxxxl{padding-right:12rem!important}.gravity-padding-block-xxxxxl{padding-block:12rem!important}.gravity-padding-inline-xxxxxl{padding-inline:12rem!important}.gravity-margin-none{margin:0!important}.gravity-margin-top-none{margin-top:0!important}.gravity-margin-bottom-none{margin-bottom:0!important}.gravity-margin-left-none{margin-left:0!important}.gravity-margin-right-none{margin-right:0!important}.gravity-margin-block-none{margin-block:0!important}.gravity-margin-inline-none{margin-inline:0!important}.gravity-margin-xxs{margin:.25rem!important}.gravity-margin-top-xxs{margin-top:.25rem!important}.gravity-margin-bottom-xxs{margin-bottom:.25rem!important}.gravity-margin-left-xxs{margin-left:.25rem!important}.gravity-margin-right-xxs{margin-right:.25rem!important}.gravity-margin-block-xxs{margin-block:.25rem!important}.gravity-margin-inline-xxs{margin-inline:.25rem!important}.gravity-margin-xs{margin:.5rem!important}.gravity-margin-top-xs{margin-top:.5rem!important}.gravity-margin-bottom-xs{margin-bottom:.5rem!important}.gravity-margin-left-xs{margin-left:.5rem!important}.gravity-margin-right-xs{margin-right:.5rem!important}.gravity-margin-block-xs{margin-block:.5rem!important}.gravity-margin-inline-xs{margin-inline:.5rem!important}.gravity-margin-sm{margin:1rem!important}.gravity-margin-top-sm{margin-top:1rem!important}.gravity-margin-bottom-sm{margin-bottom:1rem!important}.gravity-margin-left-sm{margin-left:1rem!important}.gravity-margin-right-sm{margin-right:1rem!important}.gravity-margin-block-sm{margin-block:1rem!important}.gravity-margin-inline-sm{margin-inline:1rem!important}.gravity-margin-md{margin:1.5rem!important}.gravity-margin-top-md{margin-top:1.5rem!important}.gravity-margin-bottom-md{margin-bottom:1.5rem!important}.gravity-margin-left-md{margin-left:1.5rem!important}.gravity-margin-right-md{margin-right:1.5rem!important}.gravity-margin-block-md{margin-block:1.5rem!important}.gravity-margin-inline-md{margin-inline:1.5rem!important}.gravity-margin-lg{margin:2rem!important}.gravity-margin-top-lg{margin-top:2rem!important}.gravity-margin-bottom-lg{margin-bottom:2rem!important}.gravity-margin-left-lg{margin-left:2rem!important}.gravity-margin-right-lg{margin-right:2rem!important}.gravity-margin-block-lg{margin-block:2rem!important}.gravity-margin-inline-lg{margin-inline:2rem!important}.gravity-margin-xl{margin:2.5rem!important}.gravity-margin-top-xl{margin-top:2.5rem!important}.gravity-margin-bottom-xl{margin-bottom:2.5rem!important}.gravity-margin-left-xl{margin-left:2.5rem!important}.gravity-margin-right-xl{margin-right:2.5rem!important}.gravity-margin-block-xl{margin-block:2.5rem!important}.gravity-margin-inline-xl{margin-inline:2.5rem!important}.gravity-margin-xxl{margin:3rem!important}.gravity-margin-top-xxl{margin-top:3rem!important}.gravity-margin-bottom-xxl{margin-bottom:3rem!important}.gravity-margin-left-xxl{margin-left:3rem!important}.gravity-margin-right-xxl{margin-right:3rem!important}.gravity-margin-block-xxl{margin-block:3rem!important}.gravity-margin-inline-xxl{margin-inline:3rem!important}.gravity-margin-xxxl{margin:4rem!important}.gravity-margin-top-xxxl{margin-top:4rem!important}.gravity-margin-bottom-xxxl{margin-bottom:4rem!important}.gravity-margin-left-xxxl{margin-left:4rem!important}.gravity-margin-right-xxxl{margin-right:4rem!important}.gravity-margin-block-xxxl{margin-block:4rem!important}.gravity-margin-inline-xxxl{margin-inline:4rem!important}.gravity-margin-xxxxl{margin:6rem!important}.gravity-margin-top-xxxxl{margin-top:6rem!important}.gravity-margin-bottom-xxxxl{margin-bottom:6rem!important}.gravity-margin-left-xxxxl{margin-left:6rem!important}.gravity-margin-right-xxxxl{margin-right:6rem!important}.gravity-margin-block-xxxxl{margin-block:6rem!important}.gravity-margin-inline-xxxxl{margin-inline:6rem!important}.gravity-margin-xxxxxl{margin:12rem!important}.gravity-margin-top-xxxxxl{margin-top:12rem!important}.gravity-margin-bottom-xxxxxl{margin-bottom:12rem!important}.gravity-margin-left-xxxxxl{margin-left:12rem!important}.gravity-margin-right-xxxxxl{margin-right:12rem!important}.gravity-margin-block-xxxxxl{margin-block:12rem!important}.gravity-margin-inline-xxxxxl{margin-inline:12rem!important}.border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.next-button,.previous-button{cursor:pointer;padding:var(--gravity-spacing-xs);border-radius:var(--gravity-spacing-xs)}.next-button:not(.disabled):hover,.previous-button:not(.disabled):hover{background:var(--bg-button-active-tertiary)}.next-button.disabled,.previous-button.disabled{cursor:default;pointer-events:none;--icon-color: var(--on-bg-disabled)}.separator-line{border-bottom:2px solid var(--divider-menu-active-primary)}.action-section{height:25px;display:flex;align-self:stretch;align-items:center;justify-content:space-between}.gravity-calendar-header{width:215px;height:40px;display:flex;align-self:stretch;align-items:center;flex-direction:column;justify-content:center;gap:var(--gravity-spacing-sm);padding-top:var(--gravity-spacing-xs)}.gravity-calendar-header .header-container{display:flex;align-items:center;align-self:stretch;justify-content:space-between}.gravity-calendar-header .separator-line{width:215px}.gravity-calendar-header.mobile,.gravity-calendar-header.mobile .separator-line{width:100%}.gravity-calendar-body{width:215px;display:flex;align-items:center;align-self:stretch;flex-direction:column;justify-content:center;gap:var(--gravity-spacing-sm);margin-top:var(--gravity-spacing-sm)}.gravity-calendar-body .items-table{display:flex;flex-wrap:wrap;justify-content:space-between;gap:0 var(--gravity-spacing-sm)}.gravity-calendar-body .items-table .item{width:37px;height:25px;display:flex;cursor:pointer;align-items:center;justify-content:center;border-radius:var(--gravity-spacing-xs);color:var(--on-bg-button-pressed-tertiary);border:2px solid var(--bg-calender-primary)}.gravity-calendar-body .items-table .item.current{border-color:var(--bg-number-calendar-hover-primary)}.gravity-calendar-body .items-table .item:not(.disabled):not(.selected):hover{color:var(--on-bg-button-pressed-tertiary);background:var(--bg-button-active-tertiary);border-color:var(--bg-button-active-tertiary)}.gravity-calendar-body .items-table .item.selected{color:var(--on-bg-button-pressed-primary);background:var(--bg-button-pressed-primary);border-color:var(--bg-button-pressed-primary)}.gravity-calendar-body .items-table .item.disabled{cursor:default;pointer-events:none;color:var(--on-bg-disabled)}.gravity-calendar-body.mobile{width:100%}.gravity-calendar-body.mobile .items-table{gap:var(--gravity-spacing-md) var(--gravity-spacing-sm)}.gravity-calendar-body.mobile .items-table .item{width:70px;height:43px}\n"] }]
|
|
95
|
+
}], propDecorators: { config: [{
|
|
96
|
+
type: Input
|
|
97
|
+
}], initDate: [{
|
|
98
|
+
type: Input
|
|
99
|
+
}], restart: [{
|
|
100
|
+
type: Input
|
|
101
|
+
}], appearance: [{
|
|
102
|
+
type: Input
|
|
103
|
+
}], integratedMode: [{
|
|
104
|
+
type: Input
|
|
105
|
+
}], clearSelection: [{
|
|
106
|
+
type: Output
|
|
107
|
+
}], response: [{
|
|
108
|
+
type: Output
|
|
109
|
+
}] } });
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"month-calendar.component.js","sourceRoot":"","sources":["../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-date-picker/components/month-calendar/month-calendar.component.ts","../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-date-picker/components/month-calendar/month-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {DatePickerAppearance, DatePickerConfig, CalendarPeriod} from \"../../shared/date-picker.modal\";\nimport {changeDate, getStartDate, isPeriodAvailable} from \"../../shared/date-picker.utils\";\nimport {Component, EventEmitter, Input, OnChanges, Output, SimpleChanges,} from '@angular/core';\nimport {CALENDAR_I18N, MONTHS_EN, MONTHS_SHORT_EN, MONTHS_ES, MONTHS_SHORT_ES} from \"../../shared/date-picker.constants\";\n\n@Component({\n  selector: 'month-calendar',\n  templateUrl: './month-calendar.component.html',\n  styleUrls: ['./month-calendar.component.scss']\n})\nexport class MonthCalendarComponent implements OnChanges {\n\t@Input() public config: DatePickerConfig;\n  @Input() public initDate: Date | Date[];\n  @Input() public restart: boolean = false;\n  @Input() public appearance: DatePickerAppearance;\n  @Input() public integratedMode: boolean = false;\n\n  @Output() public clearSelection: EventEmitter<void> = new EventEmitter<void>();\n  @Output() public response: EventEmitter<Date[] | Date> = new EventEmitter<Date[] | Date>();\n\n  public currentDate: Date = new Date();\n  public selectedMonth: CalendarPeriod;\n\n  public get i18n() { return CALENDAR_I18N[this.appearance.language]; }\n  public get monthsList() { return this.appearance.language === 'en' ? MONTHS_EN : MONTHS_ES; }\n  public get monthsShortList() { return this.appearance.language === 'en' ? MONTHS_SHORT_EN : MONTHS_SHORT_ES; }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const shouldRestart = changes['restart'] && this.restart;\n    const shouldProcessPreSelected = changes['preSelectedDate'] && this.initDate;\n    if (shouldRestart || shouldProcessPreSelected) { this.processInitDate(); }\n  }\n\n  public trackByMonth(_: number, month: CalendarPeriod): string {\n    return `${month.year}-${month.month}`;\n  }\n\n  private processInitDate(): void {\n    if (this.initDate instanceof Date) {\n      this.currentDate = getStartDate(this.initDate);\n      this.selectedMonth = {\n        month: this.initDate.getMonth(),\n        year: this.initDate.getFullYear()\n      };\n    }\n  }\n\n  public onSelectMonth(month: CalendarPeriod) {\n    this.selectedMonth = month;\n    this.currentDate = new Date(month.year, month.month, 1);\n    this.response.emit(this.currentDate);\n    return;\n  }\n\n\tpublic getMonthSelectionClass(month: CalendarPeriod): string {\n\t\tconst classes: string[] = [];\n\t\tconst { minDate, maxDate } = this.config ?? {};\n\t\tconst firstDay = new Date(month.year, month.month, 1);\n\t\tconst lastDay = new Date(month.year, month.month + 1, 0);\n\n\t\tlet isDisabled = false;\n\t\tif (minDate && lastDay < minDate) { isDisabled = true; }\n\t\tif (maxDate && firstDay > maxDate) { isDisabled = true; }\n\t\tif (isDisabled) { classes.push('disabled'); }\n\n\t\tif (this.selectedMonth && this.selectedMonth.month === month.month && this.selectedMonth.year === month.year) {\n\t\t\tclasses.push('selected');\n\t\t}\n\n\t\treturn classes.join(' ');\n\t}\n\n\tpublic isCurrentMonth(month: CalendarPeriod) {\n    if(new Date().getMonth() === month.month &&\n      new Date().getFullYear() === month.year) {\n      return true;\n    }\n  }\n\n  public clearSelectedMonth() {\n    this.selectedMonth = null;\n    this.clearSelection.emit();\n  }\n\n  public applySelectedMonth() {\n    const date = new Date(this.selectedMonth.year, this.selectedMonth.month)\n    this.response.emit(date);\n  }\n\n  public getYearMonthsList(): CalendarPeriod[] {\n    const months: CalendarPeriod[] = [];\n\n    for (let i = 0; i < 12; i++) {\n      months.push({month: i, year: this.currentDate.getFullYear()});\n    }\n\n    return months;\n  }\n\n  protected readonly changeDate = changeDate;\n\tprotected readonly isPeriodAvailable = isPeriodAvailable;\n}\n","<section class=\"gravity-calendar-header\" [class.mobile]=\"appearance.isMobile\">\n  <div class=\"header-container\">\n\n    <gravity-icon-button *ngIf=\"!integratedMode\"\n     [size]=\"'sm'\"\n     [type]=\"'primary'\"\n     [icon]=\"'arrow-left'\"\n     [supportText]=\"i18n.preview_year\"\n     (clickOnIcon)=\"currentDate = changeDate(-1, currentDate, false)\"\n     [state]=\"(appearance.state !== 'disabled') && isPeriodAvailable(currentDate, config.minDate, 'month', 'prev') ? 'active' : 'disabled'\"/>\n\n    <div class=\"year-label\">\n      <gravity-dropdown-label\n        [size]=\"'sm'\"\n        [fontClass]=\"'hr-title sm-bold'\"\n        [state]=\"integratedMode && appearance.state !== 'disabled' ? 'active' : 'inactive'\"\n        [label]=\"integratedMode ? monthsList[currentDate.getMonth()] : currentDate.getFullYear().toString()\"\n        [isOpen]=\"integratedMode\" (onClickLabel)=\"response.emit(currentDate)\" > </gravity-dropdown-label>\n    </div>\n\n    <gravity-icon-button *ngIf=\"!integratedMode\"\n     [size]=\"'sm'\"\n     [type]=\"'primary'\"\n     [icon]=\"'arrow-right'\"\n     [supportText]=\"i18n.next_year\"\n     (clickOnIcon)=\"currentDate = changeDate(1, currentDate, false)\"\n     [state]=\"(appearance.state !== 'disabled') && isPeriodAvailable(currentDate, config.maxDate, 'month', 'next') ? 'active' : 'disabled'\"/>\n  </div>\n\n    <div class=\"separator-line\"></div>\n</section>\n\n<section class=\"gravity-calendar-body\" [class.mobile]=\"appearance.isMobile\">\n    <div class=\"items-table\">\n          <span class=\"hr-body sm-regular item\" *ngFor=\"let month of getYearMonthsList(), trackBy: trackByMonth\"\n                [ngClass]=\"appearance.state === 'disabled' ? 'disabled' : getMonthSelectionClass(month)\" (click)=\"onSelectMonth(month)\"\n                [class.current]=\"isCurrentMonth(month)\"> {{ monthsShortList[month.month] }} </span>\n    </div>\n\n    <div *ngIf=\"appearance.actions\" class=\"action-section\" >\n        <gravity-link [linkText]=\"i18n.clear\" [state]=\"!selectedMonth ? 'disabled' : 'active'\" (click)=\"clearSelectedMonth()\"/>\n        <gravity-button [size]=\"'sm'\" [type]=\"'tertiary'\" [disabled]=\"!selectedMonth\" (click)=\"applySelectedMonth()\">{{i18n.apply}}</gravity-button>\n    </div>\n</section>"]}
|