@progressio_resources/gravity-design-system 3.6.6 → 3.6.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (31) hide show
  1. package/esm2022/lib/components/gravity-calendar-next/components/day-calendar/day-calendar.component.mjs +85 -30
  2. package/esm2022/lib/components/gravity-calendar-next/components/day-calendar/range-days-calendar.utils.mjs +197 -46
  3. package/esm2022/lib/components/gravity-calendar-next/components/month-calendar/month-calendar.component.mjs +26 -10
  4. package/esm2022/lib/components/gravity-calendar-next/components/year-calendar/year-calendar.component.mjs +27 -9
  5. package/esm2022/lib/components/gravity-calendar-next/gravity-calendar-next.component.mjs +30 -20
  6. package/esm2022/lib/components/gravity-calendar-next/shared/calendar.constants.mjs +43 -3
  7. package/esm2022/lib/components/gravity-calendar-next/shared/calendar.modal.mjs +1 -1
  8. package/esm2022/lib/components/gravity-calendar-next/shared/calendar.utils.mjs +101 -6
  9. package/esm2022/lib/components/gravity-dropdown-label/gravity-dropdown-label.component.mjs +3 -3
  10. package/esm2022/lib/components/gravity-icon-button/gravity-icon-button.component.mjs +2 -2
  11. package/esm2022/lib/components/gravity-link/gravity-link.component.mjs +2 -2
  12. package/esm2022/lib/components/gravity-text-field/gravity-text-field.component.mjs +12 -6
  13. package/esm2022/lib/gravity-design-system.module.mjs +1 -4
  14. package/esm2022/lib/layout/gravity-header/gravity-header.component.mjs +3 -3
  15. package/esm2022/lib/layout/gravity-menu/gravity-menu.component.mjs +4 -5
  16. package/fesm2022/progressio_resources-gravity-design-system.mjs +506 -222
  17. package/fesm2022/progressio_resources-gravity-design-system.mjs.map +1 -1
  18. package/lib/components/gravity-calendar-next/components/day-calendar/day-calendar.component.d.ts +57 -10
  19. package/lib/components/gravity-calendar-next/components/day-calendar/range-days-calendar.utils.d.ts +4 -1
  20. package/lib/components/gravity-calendar-next/components/month-calendar/month-calendar.component.d.ts +38 -6
  21. package/lib/components/gravity-calendar-next/components/year-calendar/year-calendar.component.d.ts +39 -5
  22. package/lib/components/gravity-calendar-next/gravity-calendar-next.component.d.ts +48 -6
  23. package/lib/components/gravity-calendar-next/shared/calendar.constants.d.ts +33 -3
  24. package/lib/components/gravity-calendar-next/shared/calendar.modal.d.ts +6 -2
  25. package/lib/components/gravity-calendar-next/shared/calendar.utils.d.ts +7 -2
  26. package/lib/components/gravity-text-field/gravity-text-field.component.d.ts +5 -3
  27. package/lib/gravity-design-system.module.d.ts +14 -15
  28. package/lib/layout/gravity-menu/gravity-menu.component.d.ts +2 -2
  29. package/package.json +1 -1
  30. package/esm2022/lib/components/gravity-calendar-next/components/dual-month-calendar/dual-month-calendar.component.mjs +0 -109
  31. package/lib/components/gravity-calendar-next/components/dual-month-calendar/dual-month-calendar.component.d.ts +0 -46
@@ -1,73 +1,224 @@
1
- import { getStartDate, toCalendarDay, toDate } from "../../shared/calendar.utils";
1
+ import { calendarDateToDate, dateToString, getStartDate, stringToCalendarDate, stringToDate, dateToCalendarDay } from "../../shared/calendar.utils";
2
2
  export function isPreview(component, day) {
3
- if (!component.selectedRangeStart || component.selectedRangeEnd || !component.hoveredDay)
4
- return false;
5
- const current = toDate(day);
6
- const hover = toDate(component.hoveredDay);
7
- const start = toDate(component.selectedRangeStart);
8
- if (hover <= start)
9
- return false;
10
- return current > start && current <= hover;
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;
11
19
  }
12
20
  export function processPreselectedRangeDate(component) {
13
- const [start, end] = component.config.initDate;
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
+ }
14
27
  if (start instanceof Date) {
15
- component.selectedRangeStart = toCalendarDay(start);
28
+ component.selectedRangeStart = dateToCalendarDay(start);
29
+ setTimeout(() => {
30
+ component.endDateField.focus();
31
+ component.startDateField.inputValue = dateToString(start, component.appearance.language);
32
+ }, 0);
16
33
  }
17
34
  if (end instanceof Date) {
18
- component.selectedRangeEnd = toCalendarDay(end);
19
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);
20
41
  }
21
42
  else if (start instanceof Date) {
22
43
  component.currentDate = getStartDate(start);
23
44
  }
24
45
  }
25
46
  export function getRangeSelectionClass(component, day) {
26
- if (!component.selectedRangeStart)
27
- return 'nsl-start';
28
- const current = toDate(day);
29
- const start = toDate(component.selectedRangeStart);
30
- if (!component.selectedRangeEnd) {
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) {
31
54
  if (current.getTime() === start.getTime())
32
55
  return 'sl start';
33
- if (component.hoveredDay) {
34
- const hover = toDate(component.hoveredDay);
35
- if (current.getTime() === hover.getTime() && hover < start)
36
- return 'nsl-start';
37
- }
38
- return 'nsl-end';
39
- }
40
- const end = toDate(component.selectedRangeEnd);
41
- if (current.getTime() === start.getTime())
42
- return 'sl start';
43
- if (current.getTime() === end.getTime())
44
- return 'sl end';
45
- if (current > start && current < end)
46
- return 'sl range';
47
- return 'nsl-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
+ }
48
83
  }
49
- export function onSelectRageDays(component, day) {
50
- if (!component.selectedRangeStart || component.selectedRangeEnd) {
51
- component.selectedRangeStart = day;
52
- component.selectedRangeEnd = null;
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;
53
110
  }
54
- else {
55
- const selectedDate = toDate(day);
56
- const startDate = toDate(component.selectedRangeStart);
57
- selectedDate >= startDate ? component.selectedRangeEnd = day : component.selectedRangeStart = day;
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;
58
122
  }
59
123
  }
60
124
  export function onApplyRageDate(component) {
61
- const start = toDate(component.selectedRangeStart);
62
- const end = toDate(component.selectedRangeEnd);
125
+ const start = calendarDateToDate(component.selectedRangeStart);
126
+ const end = calendarDateToDate(component.selectedRangeEnd);
63
127
  component.calendarResponse.emit([start, end]);
64
128
  }
65
129
  export function onHoverDay(component, day) {
66
- if (component.selectedRangeEnd)
67
- return;
68
- component.hoveredDay = day;
130
+ const startSelected = !!component.selectedRangeStart && !component.selectedRangeEnd;
131
+ const endSelected = !!component.selectedRangeEnd && !component.selectedRangeStart;
132
+ if (startSelected || endSelected) {
133
+ component.hoveredDay = day;
134
+ }
69
135
  }
70
136
  export function onClearHover(component) {
71
137
  component.hoveredDay = null;
72
138
  }
73
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZ2UtZGF5cy1jYWxlbmRhci51dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2dyYXZpdHktZGVzaWduLXN5c3RlbS9zcmMvbGliL2NvbXBvbmVudHMvZ3Jhdml0eS1jYWxlbmRhci1uZXh0L2NvbXBvbmVudHMvZGF5LWNhbGVuZGFyL3JhbmdlLWRheXMtY2FsZW5kYXIudXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFDLFlBQVksRUFBRSxhQUFhLEVBQUUsTUFBTSxFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFFaEYsTUFBTSxVQUFVLFNBQVMsQ0FBQyxTQUErQixFQUFFLEdBQWlCO0lBQ3hFLElBQUksQ0FBQyxTQUFTLENBQUMsa0JBQWtCLElBQUksU0FBUyxDQUFDLGdCQUFnQixJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVU7UUFBRSxPQUFPLEtBQUssQ0FBQztJQUV2RyxNQUFNLE9BQU8sR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDNUIsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUMzQyxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLGtCQUFrQixDQUFDLENBQUM7SUFFbkQsSUFBSSxLQUFLLElBQUksS0FBSztRQUFFLE9BQU8sS0FBSyxDQUFDO0lBQ2pDLE9BQU8sT0FBTyxHQUFHLEtBQUssSUFBSSxPQUFPLElBQUksS0FBSyxDQUFDO0FBQy9DLENBQUM7QUFFRCxNQUFNLFVBQVUsMkJBQTJCLENBQUMsU0FBK0I7SUFDdkUsTUFBTSxDQUFDLEtBQUssRUFBRSxHQUFHLENBQUMsR0FBRyxTQUFTLENBQUMsTUFBTSxDQUFDLFFBQWtCLENBQUM7SUFFekQsSUFBSSxLQUFLLFlBQVksSUFBSSxFQUFFO1FBQ3ZCLFNBQVMsQ0FBQyxrQkFBa0IsR0FBRyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7S0FDdkQ7SUFFRCxJQUFJLEdBQUcsWUFBWSxJQUFJLEVBQUU7UUFDckIsU0FBUyxDQUFDLGdCQUFnQixHQUFHLGFBQWEsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNoRCxTQUFTLENBQUMsV0FBVyxHQUFHLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQztLQUM3QztTQUFNLElBQUksS0FBSyxZQUFZLElBQUksRUFBRTtRQUM5QixTQUFTLENBQUMsV0FBVyxHQUFHLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQztLQUMvQztBQUNMLENBQUM7QUFHRCxNQUFNLFVBQVUsc0JBQXNCLENBQUMsU0FBK0IsRUFBRSxHQUFpQjtJQUNyRixJQUFJLENBQUMsU0FBUyxDQUFDLGtCQUFrQjtRQUFFLE9BQU8sV0FBVyxDQUFDO0lBRXRELE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUM1QixNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLGtCQUFrQixDQUFDLENBQUM7SUFFbkQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxnQkFBZ0IsRUFBRTtRQUM3QixJQUFJLE9BQU8sQ0FBQyxPQUFPLEVBQUUsS0FBSyxLQUFLLENBQUMsT0FBTyxFQUFFO1lBQUUsT0FBTyxVQUFVLENBQUM7UUFFN0QsSUFBSSxTQUFTLENBQUMsVUFBVSxFQUFFO1lBQ3RCLE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDM0MsSUFBSSxPQUFPLENBQUMsT0FBTyxFQUFFLEtBQUssS0FBSyxDQUFDLE9BQU8sRUFBRSxJQUFJLEtBQUssR0FBRyxLQUFLO2dCQUFFLE9BQU8sV0FBVyxDQUFDO1NBQ2xGO1FBRUQsT0FBTyxTQUFTLENBQUM7S0FDcEI7SUFFRCxNQUFNLEdBQUcsR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFFL0MsSUFBSSxPQUFPLENBQUMsT0FBTyxFQUFFLEtBQUssS0FBSyxDQUFDLE9BQU8sRUFBRTtRQUFFLE9BQU8sVUFBVSxDQUFDO0lBQzdELElBQUksT0FBTyxDQUFDLE9BQU8sRUFBRSxLQUFLLEdBQUcsQ0FBQyxPQUFPLEVBQUU7UUFBRSxPQUFPLFFBQVEsQ0FBQztJQUN6RCxJQUFJLE9BQU8sR0FBRyxLQUFLLElBQUksT0FBTyxHQUFHLEdBQUc7UUFBRSxPQUFPLFVBQVUsQ0FBQztJQUV4RCxPQUFPLFdBQVcsQ0FBQztBQUN2QixDQUFDO0FBRUQsTUFBTSxVQUFVLGdCQUFnQixDQUFDLFNBQStCLEVBQUUsR0FBaUI7SUFDL0UsSUFBSSxDQUFDLFNBQVMsQ0FBQyxrQkFBa0IsSUFBSSxTQUFTLENBQUMsZ0JBQWdCLEVBQUU7UUFDN0QsU0FBUyxDQUFDLGtCQUFrQixHQUFHLEdBQUcsQ0FBQztRQUNuQyxTQUFTLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDO0tBQ3JDO1NBQU07UUFDSCxNQUFNLFlBQVksR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDakMsTUFBTSxTQUFTLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQ3ZELFlBQVksSUFBSSxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxnQkFBZ0IsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxrQkFBa0IsR0FBRyxHQUFHLENBQUM7S0FDckc7QUFDTCxDQUFDO0FBRUQsTUFBTSxVQUFVLGVBQWUsQ0FBQyxTQUErQjtJQUMzRCxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLGtCQUFrQixDQUFDLENBQUM7SUFDbkQsTUFBTSxHQUFHLEdBQUUsTUFBTSxDQUFDLFNBQVMsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBQzlDLFNBQVMsQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsQ0FBQyxLQUFLLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQztBQUNsRCxDQUFDO0FBRUQsTUFBTSxVQUFVLFVBQVUsQ0FBQyxTQUErQixFQUFFLEdBQWlCO0lBQ3pFLElBQUksU0FBUyxDQUFDLGdCQUFnQjtRQUFFLE9BQU87SUFDdkMsU0FBUyxDQUFDLFVBQVUsR0FBRyxHQUFHLENBQUM7QUFDL0IsQ0FBQztBQUVELE1BQU0sVUFBVSxZQUFZLENBQUMsU0FBK0I7SUFDeEQsU0FBUyxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUM7QUFDaEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2FsZW5kYXJEYXRlfSBmcm9tIFwiLi4vLi4vc2hhcmVkL2NhbGVuZGFyLm1vZGFsXCI7XG5pbXBvcnQge0RheUNhbGVuZGFyQ29tcG9uZW50fSBmcm9tIFwiLi9kYXktY2FsZW5kYXIuY29tcG9uZW50XCI7XG5pbXBvcnQge2dldFN0YXJ0RGF0ZSwgdG9DYWxlbmRhckRheSwgdG9EYXRlfSBmcm9tIFwiLi4vLi4vc2hhcmVkL2NhbGVuZGFyLnV0aWxzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1ByZXZpZXcoY29tcG9uZW50OiBEYXlDYWxlbmRhckNvbXBvbmVudCwgZGF5OiBDYWxlbmRhckRhdGUpOiBib29sZWFuIHtcbiAgICBpZiAoIWNvbXBvbmVudC5zZWxlY3RlZFJhbmdlU3RhcnQgfHwgY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VFbmQgfHwgIWNvbXBvbmVudC5ob3ZlcmVkRGF5KSByZXR1cm4gZmFsc2U7XG5cbiAgICBjb25zdCBjdXJyZW50ID0gdG9EYXRlKGRheSk7XG4gICAgY29uc3QgaG92ZXIgPSB0b0RhdGUoY29tcG9uZW50LmhvdmVyZWREYXkpO1xuICAgIGNvbnN0IHN0YXJ0ID0gdG9EYXRlKGNvbXBvbmVudC5zZWxlY3RlZFJhbmdlU3RhcnQpO1xuXG4gICAgaWYgKGhvdmVyIDw9IHN0YXJ0KSByZXR1cm4gZmFsc2U7XG4gICAgcmV0dXJuIGN1cnJlbnQgPiBzdGFydCAmJiBjdXJyZW50IDw9IGhvdmVyO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcHJvY2Vzc1ByZXNlbGVjdGVkUmFuZ2VEYXRlKGNvbXBvbmVudDogRGF5Q2FsZW5kYXJDb21wb25lbnQpIHtcbiAgICBjb25zdCBbc3RhcnQsIGVuZF0gPSBjb21wb25lbnQuY29uZmlnLmluaXREYXRlIGFzIERhdGVbXTtcblxuICAgIGlmIChzdGFydCBpbnN0YW5jZW9mIERhdGUpIHtcbiAgICAgICAgY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VTdGFydCA9IHRvQ2FsZW5kYXJEYXkoc3RhcnQpO1xuICAgIH1cblxuICAgIGlmIChlbmQgaW5zdGFuY2VvZiBEYXRlKSB7XG4gICAgICAgIGNvbXBvbmVudC5zZWxlY3RlZFJhbmdlRW5kID0gdG9DYWxlbmRhckRheShlbmQpO1xuICAgICAgICBjb21wb25lbnQuY3VycmVudERhdGUgPSBnZXRTdGFydERhdGUoZW5kKTtcbiAgICB9IGVsc2UgaWYgKHN0YXJ0IGluc3RhbmNlb2YgRGF0ZSkge1xuICAgICAgICBjb21wb25lbnQuY3VycmVudERhdGUgPSBnZXRTdGFydERhdGUoc3RhcnQpO1xuICAgIH1cbn1cblxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0UmFuZ2VTZWxlY3Rpb25DbGFzcyhjb21wb25lbnQ6IERheUNhbGVuZGFyQ29tcG9uZW50LCBkYXk6IENhbGVuZGFyRGF0ZSk6IHN0cmluZyB7XG4gICAgaWYgKCFjb21wb25lbnQuc2VsZWN0ZWRSYW5nZVN0YXJ0KSByZXR1cm4gJ25zbC1zdGFydCc7XG5cbiAgICBjb25zdCBjdXJyZW50ID0gdG9EYXRlKGRheSk7XG4gICAgY29uc3Qgc3RhcnQgPSB0b0RhdGUoY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VTdGFydCk7XG5cbiAgICBpZiAoIWNvbXBvbmVudC5zZWxlY3RlZFJhbmdlRW5kKSB7XG4gICAgICAgIGlmIChjdXJyZW50LmdldFRpbWUoKSA9PT0gc3RhcnQuZ2V0VGltZSgpKSByZXR1cm4gJ3NsIHN0YXJ0JztcblxuICAgICAgICBpZiAoY29tcG9uZW50LmhvdmVyZWREYXkpIHtcbiAgICAgICAgICAgIGNvbnN0IGhvdmVyID0gdG9EYXRlKGNvbXBvbmVudC5ob3ZlcmVkRGF5KTtcbiAgICAgICAgICAgIGlmIChjdXJyZW50LmdldFRpbWUoKSA9PT0gaG92ZXIuZ2V0VGltZSgpICYmIGhvdmVyIDwgc3RhcnQpIHJldHVybiAnbnNsLXN0YXJ0JztcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiAnbnNsLWVuZCc7XG4gICAgfVxuXG4gICAgY29uc3QgZW5kID0gdG9EYXRlKGNvbXBvbmVudC5zZWxlY3RlZFJhbmdlRW5kKTtcblxuICAgIGlmIChjdXJyZW50LmdldFRpbWUoKSA9PT0gc3RhcnQuZ2V0VGltZSgpKSByZXR1cm4gJ3NsIHN0YXJ0JztcbiAgICBpZiAoY3VycmVudC5nZXRUaW1lKCkgPT09IGVuZC5nZXRUaW1lKCkpIHJldHVybiAnc2wgZW5kJztcbiAgICBpZiAoY3VycmVudCA+IHN0YXJ0ICYmIGN1cnJlbnQgPCBlbmQpIHJldHVybiAnc2wgcmFuZ2UnO1xuXG4gICAgcmV0dXJuICduc2wtc3RhcnQnO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gb25TZWxlY3RSYWdlRGF5cyhjb21wb25lbnQ6IERheUNhbGVuZGFyQ29tcG9uZW50LCBkYXk6IENhbGVuZGFyRGF0ZSkge1xuICAgIGlmICghY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VTdGFydCB8fCBjb21wb25lbnQuc2VsZWN0ZWRSYW5nZUVuZCkge1xuICAgICAgICBjb21wb25lbnQuc2VsZWN0ZWRSYW5nZVN0YXJ0ID0gZGF5O1xuICAgICAgICBjb21wb25lbnQuc2VsZWN0ZWRSYW5nZUVuZCA9IG51bGw7XG4gICAgfSBlbHNlIHtcbiAgICAgICAgY29uc3Qgc2VsZWN0ZWREYXRlID0gdG9EYXRlKGRheSk7XG4gICAgICAgIGNvbnN0IHN0YXJ0RGF0ZSA9IHRvRGF0ZShjb21wb25lbnQuc2VsZWN0ZWRSYW5nZVN0YXJ0KTtcbiAgICAgICAgc2VsZWN0ZWREYXRlID49IHN0YXJ0RGF0ZSA/IGNvbXBvbmVudC5zZWxlY3RlZFJhbmdlRW5kID0gZGF5IDogY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VTdGFydCA9IGRheTtcbiAgICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBvbkFwcGx5UmFnZURhdGUoY29tcG9uZW50OiBEYXlDYWxlbmRhckNvbXBvbmVudCl7XG4gICAgY29uc3Qgc3RhcnQgPSB0b0RhdGUoY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VTdGFydCk7XG4gICAgY29uc3QgZW5kID10b0RhdGUoY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VFbmQpO1xuICAgIGNvbXBvbmVudC5jYWxlbmRhclJlc3BvbnNlLmVtaXQoW3N0YXJ0LCBlbmRdKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG9uSG92ZXJEYXkoY29tcG9uZW50OiBEYXlDYWxlbmRhckNvbXBvbmVudCwgZGF5OiBDYWxlbmRhckRhdGUpOiB2b2lkIHtcbiAgICBpZiAoY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VFbmQpIHJldHVybjtcbiAgICBjb21wb25lbnQuaG92ZXJlZERheSA9IGRheTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG9uQ2xlYXJIb3Zlcihjb21wb25lbnQ6IERheUNhbGVuZGFyQ29tcG9uZW50KTogdm9pZCB7XG4gICAgY29tcG9uZW50LmhvdmVyZWREYXkgPSBudWxsO1xufVxuXG4iXX0=
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-calendar-next/components/day-calendar/range-days-calendar.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import {CalendarDate} from \"../../shared/calendar.modal\";\nimport {DayCalendarComponent} from \"./day-calendar.component\";\nimport {calendarDateToDate, dateToString, getStartDate, stringToCalendarDate, stringToDate, dateToCalendarDay} from \"../../shared/calendar.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"]}
@@ -1,10 +1,10 @@
1
- import { changeDate, getStartDate } from "../../shared/calendar.utils";
1
+ import { changeDate, getStartDate, isPeriodAvailable } from "../../shared/calendar.utils";
2
2
  import { Component, EventEmitter, Input, Output, } from '@angular/core';
3
3
  import { CALENDAR_I18N, MONTHS_EN, MONTHS_SHORT_EN, MONTHS_ES, MONTHS_SHORT_ES } from "../../shared/calendar.constants";
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/common";
6
6
  import * as i2 from "../../../gravity-button/gravity-button.component";
7
- import * as i3 from "../../../gravity-icon/gravity-icon.component";
7
+ import * as i3 from "../../../gravity-icon-button/gravity-icon-button.component";
8
8
  import * as i4 from "../../../gravity-link/gravity-link.component";
9
9
  import * as i5 from "../../../gravity-dropdown-label/gravity-dropdown-label.component";
10
10
  export class MonthCalendarComponent {
@@ -15,6 +15,7 @@ export class MonthCalendarComponent {
15
15
  this.calendarResponse = new EventEmitter();
16
16
  this.currentDate = new Date();
17
17
  this.changeDate = changeDate;
18
+ this.isPeriodAvailable = isPeriodAvailable;
18
19
  }
19
20
  get i18n() { return CALENDAR_I18N[this.appearance.language]; }
20
21
  get monthsList() { return this.appearance.language === 'en' ? MONTHS_EN : MONTHS_ES; }
@@ -45,11 +46,24 @@ export class MonthCalendarComponent {
45
46
  return;
46
47
  }
47
48
  getMonthSelectionClass(month) {
48
- if (this.selectedMonth && this.selectedMonth.month === month.month &&
49
- this.selectedMonth.year === month.year) {
50
- return 'selected';
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;
51
56
  }
52
- return '';
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(' ');
53
67
  }
54
68
  isCurrentMonth(month) {
55
69
  if (new Date().getMonth() === month.month &&
@@ -73,12 +87,14 @@ export class MonthCalendarComponent {
73
87
  return months;
74
88
  }
75
89
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MonthCalendarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
76
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MonthCalendarComponent, selector: "month-calendar", inputs: { initDate: "initDate", restart: "restart", appearance: "appearance", integratedMode: "integratedMode" }, outputs: { clearSelection: "clearSelection", calendarResponse: "response" }, usesOnChanges: true, ngImport: i0, template: "<section class=\"gravity-calendar-header\" [class.mobile]=\"appearance.isMobile\">\n <div class=\"header-container\">\n <div *ngIf=\"!integratedMode\" class=\"previous-button\" (click)=\"currentDate = changeDate(-1, currentDate, false)\">\n <gravity-icon *ngIf=\"appearance.state !== 'disabled'\" [style.--icon-color]=\"'var(--text-highlight-primary)'\"\n [iconName]=\"'arrow-left'\" [iconSize]=\"'sm-12'\" > </gravity-icon>\n </div>\n\n <div class=\"year-label\">\n <gravity-dropdown-label [state]=\"integratedMode && appearance.state !== 'disabled' ? 'active' : 'inactive'\" [fontClass]=\"'hr-title sm-bold'\" [size]=\"'sm'\"\n [label]=\"integratedMode ? monthsList[currentDate.getMonth()] : currentDate.getFullYear().toString()\"\n [isOpen]=\"integratedMode\" (onClickLabel)=\"calendarResponse.emit(currentDate)\" > </gravity-dropdown-label>\n </div>\n\n <div *ngIf=\"!integratedMode\" class=\"next-button\" (click)=\"currentDate = changeDate(1, currentDate, false)\">\n <gravity-icon *ngIf=\"appearance.state !== 'disabled'\" [style.--icon-color]=\"'var(--text-highlight-primary)'\"\n [iconName]=\"'arrow-right'\" [iconSize]=\"'sm-12'\"> </gravity-icon>\n </div>\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()\"></gravity-link>\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.GravityIconComponent, selector: "gravity-icon", inputs: ["customIconColorVariable", "iconName", "iconSize", "hoverIcon", "size", "isCoin"] }, { 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"] }] }); }
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", calendarResponse: "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)=\"calendarResponse.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"] }] }); }
77
91
  }
78
92
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MonthCalendarComponent, decorators: [{
79
93
  type: Component,
80
- args: [{ selector: 'month-calendar', template: "<section class=\"gravity-calendar-header\" [class.mobile]=\"appearance.isMobile\">\n <div class=\"header-container\">\n <div *ngIf=\"!integratedMode\" class=\"previous-button\" (click)=\"currentDate = changeDate(-1, currentDate, false)\">\n <gravity-icon *ngIf=\"appearance.state !== 'disabled'\" [style.--icon-color]=\"'var(--text-highlight-primary)'\"\n [iconName]=\"'arrow-left'\" [iconSize]=\"'sm-12'\" > </gravity-icon>\n </div>\n\n <div class=\"year-label\">\n <gravity-dropdown-label [state]=\"integratedMode && appearance.state !== 'disabled' ? 'active' : 'inactive'\" [fontClass]=\"'hr-title sm-bold'\" [size]=\"'sm'\"\n [label]=\"integratedMode ? monthsList[currentDate.getMonth()] : currentDate.getFullYear().toString()\"\n [isOpen]=\"integratedMode\" (onClickLabel)=\"calendarResponse.emit(currentDate)\" > </gravity-dropdown-label>\n </div>\n\n <div *ngIf=\"!integratedMode\" class=\"next-button\" (click)=\"currentDate = changeDate(1, currentDate, false)\">\n <gravity-icon *ngIf=\"appearance.state !== 'disabled'\" [style.--icon-color]=\"'var(--text-highlight-primary)'\"\n [iconName]=\"'arrow-right'\" [iconSize]=\"'sm-12'\"> </gravity-icon>\n </div>\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()\"></gravity-link>\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"] }]
81
- }], propDecorators: { initDate: [{
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)=\"calendarResponse.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: [{
82
98
  type: Input
83
99
  }], restart: [{
84
100
  type: Input
@@ -92,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
92
108
  type: Output,
93
109
  args: ['response']
94
110
  }] } });
95
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"month-calendar.component.js","sourceRoot":"","sources":["../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar-next/components/month-calendar/month-calendar.component.ts","../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar-next/components/month-calendar/month-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {CalendarAppearance, CalendarPeriod} from \"../../shared/calendar.modal\";\nimport {changeDate, getStartDate} from \"../../shared/calendar.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/calendar.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    @Input() public initDate: Date | Date[];\n    @Input() public restart: boolean = false;\n    @Input() public appearance: CalendarAppearance;\n    @Input() public integratedMode: boolean = false;\n\n    @Output() public clearSelection: EventEmitter<void> = new EventEmitter<void>();\n    @Output('response') public calendarResponse: 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.calendarResponse.emit(this.currentDate);\n        return;\n    }\n\n    public getMonthSelectionClass(month: CalendarPeriod): string {\n\n       if(this.selectedMonth && this.selectedMonth.month === month.month &&\n           this.selectedMonth.year === month.year) {\n           return 'selected'\n       }\n\n       return '';\n    }\n\n    public 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.calendarResponse.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}\n","<section class=\"gravity-calendar-header\" [class.mobile]=\"appearance.isMobile\">\n    <div class=\"header-container\">\n        <div *ngIf=\"!integratedMode\" class=\"previous-button\" (click)=\"currentDate = changeDate(-1, currentDate, false)\">\n            <gravity-icon *ngIf=\"appearance.state !== 'disabled'\" [style.--icon-color]=\"'var(--text-highlight-primary)'\"\n                          [iconName]=\"'arrow-left'\" [iconSize]=\"'sm-12'\" > </gravity-icon>\n        </div>\n\n        <div class=\"year-label\">\n            <gravity-dropdown-label [state]=\"integratedMode && appearance.state !== 'disabled' ? 'active' : 'inactive'\" [fontClass]=\"'hr-title sm-bold'\" [size]=\"'sm'\"\n                                    [label]=\"integratedMode ? monthsList[currentDate.getMonth()] : currentDate.getFullYear().toString()\"\n                                    [isOpen]=\"integratedMode\" (onClickLabel)=\"calendarResponse.emit(currentDate)\" > </gravity-dropdown-label>\n        </div>\n\n        <div *ngIf=\"!integratedMode\" class=\"next-button\" (click)=\"currentDate = changeDate(1, currentDate, false)\">\n            <gravity-icon *ngIf=\"appearance.state !== 'disabled'\" [style.--icon-color]=\"'var(--text-highlight-primary)'\"\n                          [iconName]=\"'arrow-right'\" [iconSize]=\"'sm-12'\"> </gravity-icon>\n        </div>\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()\"></gravity-link>\n        <gravity-button [size]=\"'sm'\" [type]=\"'tertiary'\" [disabled]=\"!selectedMonth\" (click)=\"applySelectedMonth()\">{{i18n.apply}}</gravity-button>\n    </div>\n</section>"]}
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"month-calendar.component.js","sourceRoot":"","sources":["../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar-next/components/month-calendar/month-calendar.component.ts","../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar-next/components/month-calendar/month-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {CalendarAppearance, CalendarConfig, CalendarPeriod} from \"../../shared/calendar.modal\";\nimport {changeDate, getStartDate, isPeriodAvailable} from \"../../shared/calendar.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/calendar.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: CalendarConfig;\n  @Input() public initDate: Date | Date[];\n  @Input() public restart: boolean = false;\n  @Input() public appearance: CalendarAppearance;\n  @Input() public integratedMode: boolean = false;\n\n  @Output() public clearSelection: EventEmitter<void> = new EventEmitter<void>();\n  @Output('response') public calendarResponse: 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.calendarResponse.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\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.calendarResponse.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)=\"calendarResponse.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>"]}