@progressio_resources/gravity-design-system 3.6.3 → 3.6.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/gravity-calendar-next/components/day-calendar/day-calendar.component.mjs +14 -56
- package/esm2022/lib/components/gravity-calendar-next/components/day-calendar/range-days-calendar.utils.mjs +37 -122
- package/esm2022/lib/components/gravity-calendar-next/components/dual-month-calendar/dual-month-calendar.component.mjs +6 -6
- package/esm2022/lib/components/gravity-calendar-next/shared/calendar.constants.mjs +3 -9
- package/esm2022/lib/components/gravity-calendar-next/shared/calendar.modal.mjs +1 -1
- package/esm2022/lib/components/gravity-calendar-next/shared/calendar.utils.mjs +1 -7
- package/esm2022/lib/components/gravity-data-views-v2/gravity-data-views-v2.component.mjs +2 -2
- package/esm2022/lib/components/gravity-dropdown-list/gravity-dropdown-list.component.mjs +32 -2
- package/esm2022/lib/components/gravity-dropdown-list-display/gravity-dropdown-list-display.component.mjs +27 -4
- package/esm2022/lib/components/gravity-link/gravity-link.component.mjs +2 -2
- package/esm2022/lib/components/gravity-status-indicator/gravity-status-indicator.component.mjs +11 -3
- package/esm2022/lib/components/gravity-tree-view/node/node-checkbox/node-checkbox.component.mjs +3 -3
- package/esm2022/lib/layout/gravity-menu/gravity-menu.component.mjs +5 -4
- package/fesm2022/progressio_resources-gravity-design-system.mjs +125 -201
- package/fesm2022/progressio_resources-gravity-design-system.mjs.map +1 -1
- package/lib/components/gravity-calendar-next/components/day-calendar/day-calendar.component.d.ts +2 -17
- package/lib/components/gravity-calendar-next/components/day-calendar/range-days-calendar.utils.d.ts +1 -2
- package/lib/components/gravity-calendar-next/components/dual-month-calendar/dual-month-calendar.component.d.ts +3 -11
- package/lib/components/gravity-calendar-next/components/month-calendar/month-calendar.component.d.ts +0 -8
- package/lib/components/gravity-calendar-next/components/year-calendar/year-calendar.component.d.ts +0 -8
- package/lib/components/gravity-calendar-next/shared/calendar.constants.d.ts +0 -8
- package/lib/components/gravity-calendar-next/shared/calendar.modal.d.ts +1 -1
- package/lib/components/gravity-calendar-next/shared/calendar.utils.d.ts +0 -1
- package/lib/components/gravity-dropdown-list/gravity-dropdown-list.component.d.ts +3 -0
- package/lib/components/gravity-dropdown-list-display/gravity-dropdown-list-display.component.d.ts +2 -0
- package/lib/components/gravity-status-indicator/gravity-status-indicator.component.d.ts +4 -1
- package/lib/layout/gravity-menu/gravity-menu.component.d.ts +2 -2
- package/package.json +1 -1
|
@@ -1,24 +1,13 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { getStartDate, toCalendarDay, toDate } from "../../shared/calendar.utils";
|
|
2
2
|
export function isPreview(component, day) {
|
|
3
|
+
if (!component.selectedRangeStart || component.selectedRangeEnd || !component.hoveredDay)
|
|
4
|
+
return false;
|
|
3
5
|
const current = toDate(day);
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
return false;
|
|
10
|
-
return current > start && current <= hover;
|
|
11
|
-
}
|
|
12
|
-
// Caso 2: solo end seleccionado → hover hacia atrás
|
|
13
|
-
if (!component.selectedRangeStart && component.selectedRangeEnd && component.hoveredDay) {
|
|
14
|
-
const end = toDate(component.selectedRangeEnd);
|
|
15
|
-
const hover = toDate(component.hoveredDay);
|
|
16
|
-
if (hover >= end)
|
|
17
|
-
return false;
|
|
18
|
-
return current < end && current >= hover;
|
|
19
|
-
}
|
|
20
|
-
// Cualquier otro caso → no preview
|
|
21
|
-
return false;
|
|
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;
|
|
22
11
|
}
|
|
23
12
|
export function processPreselectedRangeDate(component) {
|
|
24
13
|
const [start, end] = component.config.initDate;
|
|
@@ -34,87 +23,38 @@ export function processPreselectedRangeDate(component) {
|
|
|
34
23
|
}
|
|
35
24
|
}
|
|
36
25
|
export function getRangeSelectionClass(component, day) {
|
|
37
|
-
|
|
38
|
-
const start = component.selectedRangeStart ? toDate(component.selectedRangeStart) : null;
|
|
39
|
-
const end = component.selectedRangeEnd ? toDate(component.selectedRangeEnd) : null;
|
|
40
|
-
if (!start && !end)
|
|
26
|
+
if (!component.selectedRangeStart)
|
|
41
27
|
return 'nsl-start';
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
return 'in-slt nsl-end';
|
|
46
|
-
}
|
|
47
|
-
if (!start && end) {
|
|
48
|
-
if (current.getTime() === end.getTime())
|
|
49
|
-
return 'sl end';
|
|
50
|
-
if (current > end)
|
|
51
|
-
return 'sl';
|
|
52
|
-
if (current < end)
|
|
53
|
-
return 'in-slt nsl-start';
|
|
54
|
-
}
|
|
55
|
-
if (start && end) {
|
|
56
|
-
if (current.getTime() === start.getTime() &&
|
|
57
|
-
start.getTime() === end.getTime())
|
|
58
|
-
return 'start sl same-sln';
|
|
28
|
+
const current = toDate(day);
|
|
29
|
+
const start = toDate(component.selectedRangeStart);
|
|
30
|
+
if (!component.selectedRangeEnd) {
|
|
59
31
|
if (current.getTime() === start.getTime())
|
|
60
32
|
return 'sl start';
|
|
61
|
-
if (
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
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';
|
|
66
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';
|
|
67
48
|
}
|
|
68
|
-
export function
|
|
69
|
-
|
|
70
|
-
const startDate = component.selectedRangeStart ? toDate(component.selectedRangeStart) : null;
|
|
71
|
-
const endDate = component.selectedRangeEnd ? toDate(component.selectedRangeEnd) : null;
|
|
72
|
-
// No hay fechas → establecer start
|
|
73
|
-
if (!startDate && !endDate) {
|
|
49
|
+
export function onSelectRageDays(component, day) {
|
|
50
|
+
if (!component.selectedRangeStart || component.selectedRangeEnd) {
|
|
74
51
|
component.selectedRangeStart = day;
|
|
75
|
-
component.
|
|
76
|
-
return;
|
|
52
|
+
component.selectedRangeEnd = null;
|
|
77
53
|
}
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
component.endDateField.inputValue = dateToString(selected);
|
|
83
|
-
}
|
|
84
|
-
else {
|
|
85
|
-
component.selectedRangeEnd = component.selectedRangeStart;
|
|
86
|
-
component.endDateField.inputValue = dateToString(startDate);
|
|
87
|
-
component.selectedRangeStart = day;
|
|
88
|
-
component.startDateField.inputValue = dateToString(selected);
|
|
89
|
-
}
|
|
90
|
-
return;
|
|
91
|
-
}
|
|
92
|
-
// Solo end seleccionado
|
|
93
|
-
if (!startDate && endDate) {
|
|
94
|
-
if (selected < endDate) {
|
|
95
|
-
// Fecha anterior al end → asignar start
|
|
96
|
-
component.selectedRangeStart = day;
|
|
97
|
-
component.startDateField.inputValue = dateToString(selected);
|
|
98
|
-
}
|
|
99
|
-
else {
|
|
100
|
-
// Fecha igual o posterior al end → actualizar end
|
|
101
|
-
component.selectedRangeEnd = day;
|
|
102
|
-
component.endDateField.inputValue = dateToString(selected);
|
|
103
|
-
}
|
|
104
|
-
return;
|
|
105
|
-
}
|
|
106
|
-
// Start y end ya seleccionados
|
|
107
|
-
if (startDate && endDate) {
|
|
108
|
-
if (selected < startDate) {
|
|
109
|
-
// Fecha anterior al start → actualizar start
|
|
110
|
-
component.selectedRangeStart = day;
|
|
111
|
-
component.startDateField.inputValue = dateToString(selected);
|
|
112
|
-
}
|
|
113
|
-
else {
|
|
114
|
-
// Cualquier otra fecha → actualizar end
|
|
115
|
-
component.selectedRangeEnd = day;
|
|
116
|
-
component.endDateField.inputValue = dateToString(selected);
|
|
117
|
-
}
|
|
54
|
+
else {
|
|
55
|
+
const selectedDate = toDate(day);
|
|
56
|
+
const startDate = toDate(component.selectedRangeStart);
|
|
57
|
+
selectedDate >= startDate ? component.selectedRangeEnd = day : component.selectedRangeStart = day;
|
|
118
58
|
}
|
|
119
59
|
}
|
|
120
60
|
export function onApplyRageDate(component) {
|
|
@@ -123,36 +63,11 @@ export function onApplyRageDate(component) {
|
|
|
123
63
|
component.calendarResponse.emit([start, end]);
|
|
124
64
|
}
|
|
125
65
|
export function onHoverDay(component, day) {
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
component.hoveredDay = day;
|
|
130
|
-
}
|
|
66
|
+
if (component.selectedRangeEnd)
|
|
67
|
+
return;
|
|
68
|
+
component.hoveredDay = day;
|
|
131
69
|
}
|
|
132
70
|
export function onClearHover(component) {
|
|
133
71
|
component.hoveredDay = null;
|
|
134
72
|
}
|
|
135
|
-
|
|
136
|
-
if (!value)
|
|
137
|
-
return null;
|
|
138
|
-
const parts = value.split('/');
|
|
139
|
-
if (parts.length !== 3)
|
|
140
|
-
return null;
|
|
141
|
-
const day = parseInt(parts[0], 10);
|
|
142
|
-
const year = parseInt(parts[2], 10);
|
|
143
|
-
const month = parseInt(parts[1], 10) - 1;
|
|
144
|
-
if (isNaN(day) || isNaN(month) || isNaN(year))
|
|
145
|
-
return null;
|
|
146
|
-
if (month < 0 || month > 11 || day < 1)
|
|
147
|
-
return null;
|
|
148
|
-
if (year < 1000 || year > 9999)
|
|
149
|
-
return null;
|
|
150
|
-
const date = new Date(year, month, day);
|
|
151
|
-
if (date.getFullYear() !== year || date.getMonth() !== month || date.getDate() !== day) {
|
|
152
|
-
return null;
|
|
153
|
-
}
|
|
154
|
-
return { day, weekDay: date.getDay(), inCurrentMonth: true,
|
|
155
|
-
monthYear: { year, month }
|
|
156
|
-
};
|
|
157
|
-
}
|
|
158
|
-
//# 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 {dateToString, getStartDate, toCalendarDay, toDate} from \"../../shared/calendar.utils\";\n\nexport function isPreview(component: DayCalendarComponent, day: CalendarDate): boolean {\n\tconst current = toDate(day);\n\n\t// Caso 1: solo start seleccionado → hover hacia adelante\n\tif (component.selectedRangeStart && !component.selectedRangeEnd && component.hoveredDay) {\n\t\tconst start = toDate(component.selectedRangeStart);\n\t\tconst hover = toDate(component.hoveredDay);\n\t\tif (hover <= start) return false;\n\t\treturn current > start && current <= hover;\n\t}\n\n\t// Caso 2: solo end seleccionado → hover hacia atrás\n\tif (!component.selectedRangeStart && component.selectedRangeEnd && component.hoveredDay) {\n\t\tconst end = toDate(component.selectedRangeEnd);\n\t\tconst hover = toDate(component.hoveredDay);\n\t\tif (hover >= end) return false;\n\t\treturn current < end && current >= hover;\n\t}\n\n\t// Cualquier otro caso → no preview\n\treturn false;\n}\n\n\nexport function processPreselectedRangeDate(component: DayCalendarComponent) {\n    const [start, end] = component.config.initDate as Date[];\n\n    if (start instanceof Date) {\n        component.selectedRangeStart = toCalendarDay(start);\n    }\n\n    if (end instanceof Date) {\n        component.selectedRangeEnd = toCalendarDay(end);\n        component.currentDate = getStartDate(end);\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 = toDate(day);\n\tconst start = component.selectedRangeStart ? toDate(component.selectedRangeStart) : null;\n\tconst end = component.selectedRangeEnd ? toDate(component.selectedRangeEnd) : null;\n\n\tif (!start && !end) return 'nsl-start';\n\n\tif (start && !end) {\n\t\tif (current.getTime() === start.getTime()) return 'sl 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 > end) return 'sl';\n\t\tif (current < end) return '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() === end.getTime()) return 'sl end';\n\t\tif (current > start && current < end) return 'sl range';\n\t\treturn 'all-sld';\n\t}\n}\n\nexport function onSelectDaysRange(component: DayCalendarComponent, day: CalendarDate): void {\n\tconst selected = toDate(day);\n\tconst startDate = component.selectedRangeStart ? toDate(component.selectedRangeStart) : null;\n\tconst endDate = component.selectedRangeEnd ? toDate(component.selectedRangeEnd) : null;\n\n\t// No hay fechas → establecer start\n\tif (!startDate && !endDate) {\n\t\tcomponent.selectedRangeStart = day;\n\t\tcomponent.startDateField.inputValue = dateToString(selected);\n\t\treturn;\n\t}\n\n\t// Solo start → asignar end si es posterior, o intercambiar\n\tif (startDate && !endDate) {\n\t\tif (selected >= startDate) {\n\t\t\tcomponent.selectedRangeEnd = day;\n\t\t\tcomponent.endDateField.inputValue = dateToString(selected);\n\t\t} else {\n\t\t\tcomponent.selectedRangeEnd = component.selectedRangeStart;\n\t\t\tcomponent.endDateField.inputValue = dateToString(startDate);\n\n\t\t\tcomponent.selectedRangeStart = day;\n\t\t\tcomponent.startDateField.inputValue = dateToString(selected);\n\t\t}\n\t\treturn;\n\t}\n\n\t// Solo end seleccionado\n\tif (!startDate && endDate) {\n\t\tif (selected < endDate) {\n\t\t\t// Fecha anterior al end → asignar start\n\t\t\tcomponent.selectedRangeStart = day;\n\t\t\tcomponent.startDateField.inputValue = dateToString(selected);\n\t\t} else {\n\t\t\t// Fecha igual o posterior al end → actualizar end\n\t\t\tcomponent.selectedRangeEnd = day;\n\t\t\tcomponent.endDateField.inputValue = dateToString(selected);\n\t\t}\n\t\treturn;\n\t}\n\n\t// Start y end ya seleccionados\n\tif (startDate && endDate) {\n\t\tif (selected < startDate) {\n\t\t\t// Fecha anterior al start → actualizar start\n\t\t\tcomponent.selectedRangeStart = day;\n\t\t\tcomponent.startDateField.inputValue = dateToString(selected);\n\t\t} else {\n\t\t\t// Cualquier otra fecha → actualizar end\n\t\t\tcomponent.selectedRangeEnd = day;\n\t\t\tcomponent.endDateField.inputValue = dateToString(selected);\n\t\t}\n\t}\n}\n\nexport function onApplyRageDate(component: DayCalendarComponent){\n    const start = toDate(component.selectedRangeStart);\n    const end =toDate(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 stringToDate(value: string): CalendarDate | null {\n\tif (!value) return null;\n\n\tconst parts = value.split('/');\n\tif (parts.length !== 3) return null;\n\n\tconst day = parseInt(parts[0], 10);\n\tconst year = parseInt(parts[2], 10);\n\tconst month = parseInt(parts[1], 10) - 1;\n\n\tif (isNaN(day) || isNaN(month) || isNaN(year)) return null;\n\tif (month < 0 || month > 11 || day < 1) return null;\n\tif (year < 1000 || year > 9999) return null;\n\n\tconst date = new Date(year, month, day);\n\n\tif (date.getFullYear() !== year || date.getMonth() !== month || date.getDate() !== day) {\n\t\treturn null;\n\t}\n\n\treturn {day, weekDay: date.getDay(), inCurrentMonth: true,\n\t\tmonthYear: { year, month }\n\t};\n}\n\n"]}
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZ2UtZGF5cy1jYWxlbmRhci51dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2dyYXZpdHktZGVzaWduLXN5c3RlbS9zcmMvbGliL2NvbXBvbmVudHMvZ3Jhdml0eS1jYWxlbmRhci1uZXh0L2NvbXBvbmVudHMvZGF5LWNhbGVuZGFyL3JhbmdlLWRheXMtY2FsZW5kYXIudXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFDLFlBQVksRUFBRSxhQUFhLEVBQUUsTUFBTSxFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFFaEYsTUFBTSxVQUFVLFNBQVMsQ0FBQyxTQUErQixFQUFFLEdBQWlCO0lBQ3hFLElBQUksQ0FBQyxTQUFTLENBQUMsa0JBQWtCLElBQUksU0FBUyxDQUFDLGdCQUFnQixJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVU7UUFBRSxPQUFPLEtBQUssQ0FBQztJQUV2RyxNQUFNLE9BQU8sR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDNUIsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUMzQyxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLGtCQUFrQixDQUFDLENBQUM7SUFFbkQsSUFBSSxLQUFLLElBQUksS0FBSztRQUFFLE9BQU8sS0FBSyxDQUFDO0lBQ2pDLE9BQU8sT0FBTyxHQUFHLEtBQUssSUFBSSxPQUFPLElBQUksS0FBSyxDQUFDO0FBQy9DLENBQUM7QUFFRCxNQUFNLFVBQVUsMkJBQTJCLENBQUMsU0FBK0I7SUFDdkUsTUFBTSxDQUFDLEtBQUssRUFBRSxHQUFHLENBQUMsR0FBRyxTQUFTLENBQUMsTUFBTSxDQUFDLFFBQWtCLENBQUM7SUFFekQsSUFBSSxLQUFLLFlBQVksSUFBSSxFQUFFO1FBQ3ZCLFNBQVMsQ0FBQyxrQkFBa0IsR0FBRyxhQUFhLENBQUMs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U0FBUyxDQUFDLGdCQUFnQjtRQUFFLE9BQU87SUFDdkMsU0FBUyxDQUFDLFVBQVUsR0FBRyxHQUFHLENBQUM7QUFDL0IsQ0FBQztBQUVELE1BQU0sVUFBVSxZQUFZLENBQUMsU0FBK0I7SUFDeEQsU0FBUyxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUM7QUFDaEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2FsZW5kYXJEYXRlfSBmcm9tIFwiLi4vLi4vc2hhcmVkL2NhbGVuZGFyLm1vZGFsXCI7XG5pbXBvcnQge0RheUNhbGVuZGFyQ29tcG9uZW50fSBmcm9tIFwiLi9kYXktY2FsZW5kYXIuY29tcG9uZW50XCI7XG5pbXBvcnQge2dldFN0YXJ0RGF0ZSwgdG9DYWxlbmRhckRheSwgdG9EYXRlfSBmcm9tIFwiLi4vLi4vc2hhcmVkL2NhbGVuZGFyLnV0aWxzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1ByZXZpZXcoY29tcG9uZW50OiBEYXlDYWxlbmRhckNvbXBvbmVudCwgZGF5OiBDYWxlbmRhckRhdGUpOiBib29sZWFuIHtcbiAgICBpZiAoIWNvbXBvbmVudC5zZWxlY3RlZFJhbmdlU3RhcnQgfHwgY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VFbmQgfHwgIWNvbXBvbmVudC5ob3ZlcmVkRGF5KSByZXR1cm4gZmFsc2U7XG5cbiAgICBjb25zdCBjdXJyZW50ID0gdG9EYXRlKGRheSk7XG4gICAgY29uc3QgaG92ZXIgPSB0b0RhdGUoY29tcG9uZW50LmhvdmVyZWREYXkpO1xuICAgIGNvbnN0IHN0YXJ0ID0gdG9EYXRlKGNvbXBvbmVudC5zZWxlY3RlZFJhbmdlU3RhcnQpO1xuXG4gICAgaWYgKGhvdmVyIDw9IHN0YXJ0KSByZXR1cm4gZmFsc2U7XG4gICAgcmV0dXJuIGN1cnJlbnQgPiBzdGFydCAmJiBjdXJyZW50IDw9IGhvdmVyO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcHJvY2Vzc1ByZXNlbGVjdGVkUmFuZ2VEYXRlKGNvbXBvbmVudDogRGF5Q2FsZW5kYXJDb21wb25lbnQpIHtcbiAgICBjb25zdCBbc3RhcnQsIGVuZF0gPSBjb21wb25lbnQuY29uZmlnLmluaXREYXRlIGFzIERhdGVbXTtcblxuICAgIGlmIChzdGFydCBpbnN0YW5jZW9mIERhdGUpIHtcbiAgICAgICAgY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VTdGFydCA9IHRvQ2FsZW5kYXJEYXkoc3RhcnQpO1xuICAgIH1cblxuICAgIGlmIChlbmQgaW5zdGFuY2VvZiBEYXRlKSB7XG4gICAgICAgIGNvbXBvbmVudC5zZWxlY3RlZFJhbmdlRW5kID0gdG9DYWxlbmRhckRheShlbmQpO1xuICAgICAgICBjb21wb25lbnQuY3VycmVudERhdGUgPSBnZXRTdGFydERhdGUoZW5kKTtcbiAgICB9IGVsc2UgaWYgKHN0YXJ0IGluc3RhbmNlb2YgRGF0ZSkge1xuICAgICAgICBjb21wb25lbnQuY3VycmVudERhdGUgPSBnZXRTdGFydERhdGUoc3RhcnQpO1xuICAgIH1cbn1cblxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0UmFuZ2VTZWxlY3Rpb25DbGFzcyhjb21wb25lbnQ6IERheUNhbGVuZGFyQ29tcG9uZW50LCBkYXk6IENhbGVuZGFyRGF0ZSk6IHN0cmluZyB7XG4gICAgaWYgKCFjb21wb25lbnQuc2VsZWN0ZWRSYW5nZVN0YXJ0KSByZXR1cm4gJ25zbC1zdGFydCc7XG5cbiAgICBjb25zdCBjdXJyZW50ID0gdG9EYXRlKGRheSk7XG4gICAgY29uc3Qgc3RhcnQgPSB0b0RhdGUoY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VTdGFydCk7XG5cbiAgICBpZiAoIWNvbXBvbmVudC5zZWxlY3RlZFJhbmdlRW5kKSB7XG4gICAgICAgIGlmIChjdXJyZW50LmdldFRpbWUoKSA9PT0gc3RhcnQuZ2V0VGltZSgpKSByZXR1cm4gJ3NsIHN0YXJ0JztcblxuICAgICAgICBpZiAoY29tcG9uZW50LmhvdmVyZWREYXkpIHtcbiAgICAgICAgICAgIGNvbnN0IGhvdmVyID0gdG9EYXRlKGNvbXBvbmVudC5ob3ZlcmVkRGF5KTtcbiAgICAgICAgICAgIGlmIChjdXJyZW50LmdldFRpbWUoKSA9PT0gaG92ZXIuZ2V0VGltZSgpICYmIGhvdmVyIDwgc3RhcnQpIHJldHVybiAnbnNsLXN0YXJ0JztcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiAnbnNsLWVuZCc7XG4gICAgfVxuXG4gICAgY29uc3QgZW5kID0gdG9EYXRlKGNvbXBvbmVudC5zZWxlY3RlZFJhbmdlRW5kKTtcblxuICAgIGlmIChjdXJyZW50LmdldFRpbWUoKSA9PT0gc3RhcnQuZ2V0VGltZSgpKSByZXR1cm4gJ3NsIHN0YXJ0JztcbiAgICBpZiAoY3VycmVudC5nZXRUaW1lKCkgPT09IGVuZC5nZXRUaW1lKCkpIHJldHVybiAnc2wgZW5kJztcbiAgICBpZiAoY3VycmVudCA+IHN0YXJ0ICYmIGN1cnJlbnQgPCBlbmQpIHJldHVybiAnc2wgcmFuZ2UnO1xuXG4gICAgcmV0dXJuICduc2wtc3RhcnQnO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gb25TZWxlY3RSYWdlRGF5cyhjb21wb25lbnQ6IERheUNhbGVuZGFyQ29tcG9uZW50LCBkYXk6IENhbGVuZGFyRGF0ZSkge1xuICAgIGlmICghY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VTdGFydCB8fCBjb21wb25lbnQuc2VsZWN0ZWRSYW5nZUVuZCkge1xuICAgICAgICBjb21wb25lbnQuc2VsZWN0ZWRSYW5nZVN0YXJ0ID0gZGF5O1xuICAgICAgICBjb21wb25lbnQuc2VsZWN0ZWRSYW5nZUVuZCA9IG51bGw7XG4gICAgfSBlbHNlIHtcbiAgICAgICAgY29uc3Qgc2VsZWN0ZWREYXRlID0gdG9EYXRlKGRheSk7XG4gICAgICAgIGNvbnN0IHN0YXJ0RGF0ZSA9IHRvRGF0ZShjb21wb25lbnQuc2VsZWN0ZWRSYW5nZVN0YXJ0KTtcbiAgICAgICAgc2VsZWN0ZWREYXRlID49IHN0YXJ0RGF0ZSA/IGNvbXBvbmVudC5zZWxlY3RlZFJhbmdlRW5kID0gZGF5IDogY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VTdGFydCA9IGRheTtcbiAgICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBvbkFwcGx5UmFnZURhdGUoY29tcG9uZW50OiBEYXlDYWxlbmRhckNvbXBvbmVudCl7XG4gICAgY29uc3Qgc3RhcnQgPSB0b0RhdGUoY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VTdGFydCk7XG4gICAgY29uc3QgZW5kID10b0RhdGUoY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VFbmQpO1xuICAgIGNvbXBvbmVudC5jYWxlbmRhclJlc3BvbnNlLmVtaXQoW3N0YXJ0LCBlbmRdKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG9uSG92ZXJEYXkoY29tcG9uZW50OiBEYXlDYWxlbmRhckNvbXBvbmVudCwgZGF5OiBDYWxlbmRhckRhdGUpOiB2b2lkIHtcbiAgICBpZiAoY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VFbmQpIHJldHVybjtcbiAgICBjb21wb25lbnQuaG92ZXJlZERheSA9IGRheTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG9uQ2xlYXJIb3Zlcihjb21wb25lbnQ6IERheUNhbGVuZGFyQ29tcG9uZW50KTogdm9pZCB7XG4gICAgY29tcG9uZW50LmhvdmVyZWREYXkgPSBudWxsO1xufVxuXG4iXX0=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { changeDate, getStartDate, toCalendarDay } from "../../shared/calendar.utils";
|
|
2
|
-
import { onClearHover, onHoverDay,
|
|
2
|
+
import { onClearHover, onHoverDay, onSelectRageDays, } from "../day-calendar/range-days-calendar.utils";
|
|
3
3
|
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
4
4
|
import { CALENDAR_I18N, DAYS_EN, DAYS_ES, MONTHS_SHORT_EN, MONTHS_SHORT_ES } from "../../shared/calendar.constants";
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
@@ -17,7 +17,7 @@ export class DualMonthCalendarComponent {
|
|
|
17
17
|
this.nextMonth = changeDate(1, this.currentDate, true);
|
|
18
18
|
this.Date = Date;
|
|
19
19
|
this.changeDate = changeDate;
|
|
20
|
-
this.
|
|
20
|
+
this.onSelectRageDays = onSelectRageDays;
|
|
21
21
|
}
|
|
22
22
|
get i18n() { return CALENDAR_I18N[this.appearance.language]; }
|
|
23
23
|
get daysList() { return this.appearance.language === 'en' ? DAYS_EN : DAYS_ES; }
|
|
@@ -68,7 +68,7 @@ export class DualMonthCalendarComponent {
|
|
|
68
68
|
}
|
|
69
69
|
handleClearSelection() {
|
|
70
70
|
this.clearSelection.emit();
|
|
71
|
-
this.leftCalendar.clearSelectedDate(
|
|
71
|
+
this.leftCalendar.clearSelectedDate();
|
|
72
72
|
}
|
|
73
73
|
handlerChangeMonthYearResponse($event, origin) {
|
|
74
74
|
if ($event instanceof Date) {
|
|
@@ -83,11 +83,11 @@ export class DualMonthCalendarComponent {
|
|
|
83
83
|
}
|
|
84
84
|
}
|
|
85
85
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DualMonthCalendarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
86
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DualMonthCalendarComponent, selector: "dual-month-calendar", inputs: { initDate: "initDate", restart: "restart", appearance: "appearance" }, outputs: { clearSelection: "clearSelection", calendarResponse: "response" }, viewQueries: [{ propertyName: "leftCalendar", first: true, predicate: ["leftCalendar"], descendants: true }, { propertyName: "rightCalendar", first: true, predicate: ["rightCalendar"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"showRightCalendar && showLeftCalendar\" class=\"date-select-indicator\">\n <p>\n <span class=\"hr-title\" [ngClass]=\"leftCalendar?.selectedRangeStart ? 'sm-regular' : 'sm-bold'\">\n {{leftCalendar?.selectedRangeStart ? getFormattedDate(leftCalendar.selectedRangeStart) : i18n.start_date}} </span>\n\n <gravity-icon [iconSize]=\"'md-16'\" [size]=\"'md'\" [iconName]=\"'swaps-arrow-right'\"></gravity-icon>\n\n <span class=\"hr-title\" [ngClass]=\"leftCalendar?.selectedRangeStart && !leftCalendar.selectedRangeEnd ? 'sm-bold' : 'sm-regular'\">\n {{leftCalendar?.selectedRangeEnd ? getFormattedDate(leftCalendar.selectedRangeEnd) : i18n.end_date}} </span>\n </p>\n</div>\n\n<div class=\"dual-calendar-container\" [class.mobile]=\"appearance.isMobile\">\n\n <day-calendar #leftCalendar *ngIf=\"showLeftCalendar\"\n [range]=\"true\"\n (openIntegratedCalendar)=\"showRightCalendar = false\"\n (changeMonth)=\"onChangeMonth('left', $event)\"\n (selectedRage)=\"
|
|
86
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DualMonthCalendarComponent, selector: "dual-month-calendar", inputs: { initDate: "initDate", restart: "restart", appearance: "appearance" }, outputs: { clearSelection: "clearSelection", calendarResponse: "response" }, viewQueries: [{ propertyName: "leftCalendar", first: true, predicate: ["leftCalendar"], descendants: true }, { propertyName: "rightCalendar", first: true, predicate: ["rightCalendar"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"showRightCalendar && showLeftCalendar\" class=\"date-select-indicator\">\n <p>\n <span class=\"hr-title\" [ngClass]=\"leftCalendar?.selectedRangeStart ? 'sm-regular' : 'sm-bold'\">\n {{leftCalendar?.selectedRangeStart ? getFormattedDate(leftCalendar.selectedRangeStart) : i18n.start_date}} </span>\n\n <gravity-icon [iconSize]=\"'md-16'\" [size]=\"'md'\" [iconName]=\"'swaps-arrow-right'\"></gravity-icon>\n\n <span class=\"hr-title\" [ngClass]=\"leftCalendar?.selectedRangeStart && !leftCalendar.selectedRangeEnd ? 'sm-bold' : 'sm-regular'\">\n {{leftCalendar?.selectedRangeEnd ? getFormattedDate(leftCalendar.selectedRangeEnd) : i18n.end_date}} </span>\n </p>\n</div>\n\n<div class=\"dual-calendar-container\" [class.mobile]=\"appearance.isMobile\">\n\n <day-calendar #leftCalendar *ngIf=\"showLeftCalendar\"\n [range]=\"true\"\n (openIntegratedCalendar)=\"showRightCalendar = false\"\n (changeMonth)=\"onChangeMonth('left', $event)\"\n (selectedRage)=\"onSelectRageDays(rightCalendar, $event)\"\n [navType]=\"appearance.isMobile ? 'none' : 'prev'\" [currentDate]=\"currentDate\"\n (changeMonthYearResponse)=\"handlerChangeMonthYearResponse($event, 'left')\"\n [appearance]=\"{language: appearance.language, actions: false, isMobile: appearance.isMobile, state: appearance.state}\">\n </day-calendar>\n\n <day-calendar #rightCalendar *ngIf=\"showRightCalendar\"\n [range]=\"true\"\n (clearHover)=\"handleClearHover()\"\n (hoverDay)=\"handleHoverDay($event)\"\n (response)=\"handleApplyResponse($event)\"\n (clearSelection)=\"handleClearSelection()\"\n (openIntegratedCalendar)=\"showLeftCalendar = false\"\n (changeMonth)=\"onChangeMonth('right', $event)\"\n (selectedRage)=\"onSelectRageDays(leftCalendar, $event)\"\n [navType]=\"appearance.isMobile ? 'none' : 'next'\" [currentDate]=\"nextMonth\"\n (changeMonthYearResponse)=\"handlerChangeMonthYearResponse($event, 'right')\"\n [appearance]=\"{language: appearance.language, actions: true, isMobile: appearance.isMobile, state: appearance.state}\">\n </day-calendar>\n</div>", styles: [".date-select-indicator{height:27px;display:flex;align-self:stretch;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:var(--gravity-spacing-sm);margin-bottom:var(--gravity-spacing-md);border-bottom:2px solid var(--divider-menu-active-primary)}.date-select-indicator p{display:flex;align-items:flex-start;gap:var(--gravity-spacing-xs);color:var(--bg-calendar-nav-primary)}.dual-calendar-container{display:flex;align-self:stretch;align-items:flex-start;justify-content:center;gap:var(--gravity-spacing-md)}.dual-calendar-container.mobile{flex-direction:column;gap:var(--gravity-spacing-sm)}.dual-calendar-container.mobile day-calendar{width:100%}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.GravityIconComponent, selector: "gravity-icon", inputs: ["customIconColorVariable", "iconName", "iconSize", "hoverIcon", "size", "isCoin"] }, { kind: "component", type: i3.DayCalendarComponent, selector: "day-calendar", inputs: ["initYear", "initMonth", "config", "range", "restart", "currentDate", "appearance", "navType"], outputs: ["clearHover", "clearSelection", "changeMonth", "hoverDay", "openIntegratedCalendar", "selectedRage", "changeMonthYearResponse", "response"] }] }); }
|
|
87
87
|
}
|
|
88
88
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DualMonthCalendarComponent, decorators: [{
|
|
89
89
|
type: Component,
|
|
90
|
-
args: [{ selector: 'dual-month-calendar', template: "<div *ngIf=\"showRightCalendar && showLeftCalendar\" class=\"date-select-indicator\">\n <p>\n <span class=\"hr-title\" [ngClass]=\"leftCalendar?.selectedRangeStart ? 'sm-regular' : 'sm-bold'\">\n {{leftCalendar?.selectedRangeStart ? getFormattedDate(leftCalendar.selectedRangeStart) : i18n.start_date}} </span>\n\n <gravity-icon [iconSize]=\"'md-16'\" [size]=\"'md'\" [iconName]=\"'swaps-arrow-right'\"></gravity-icon>\n\n <span class=\"hr-title\" [ngClass]=\"leftCalendar?.selectedRangeStart && !leftCalendar.selectedRangeEnd ? 'sm-bold' : 'sm-regular'\">\n {{leftCalendar?.selectedRangeEnd ? getFormattedDate(leftCalendar.selectedRangeEnd) : i18n.end_date}} </span>\n </p>\n</div>\n\n<div class=\"dual-calendar-container\" [class.mobile]=\"appearance.isMobile\">\n\n <day-calendar #leftCalendar *ngIf=\"showLeftCalendar\"\n [range]=\"true\"\n (openIntegratedCalendar)=\"showRightCalendar = false\"\n (changeMonth)=\"onChangeMonth('left', $event)\"\n (selectedRage)=\"
|
|
90
|
+
args: [{ selector: 'dual-month-calendar', template: "<div *ngIf=\"showRightCalendar && showLeftCalendar\" class=\"date-select-indicator\">\n <p>\n <span class=\"hr-title\" [ngClass]=\"leftCalendar?.selectedRangeStart ? 'sm-regular' : 'sm-bold'\">\n {{leftCalendar?.selectedRangeStart ? getFormattedDate(leftCalendar.selectedRangeStart) : i18n.start_date}} </span>\n\n <gravity-icon [iconSize]=\"'md-16'\" [size]=\"'md'\" [iconName]=\"'swaps-arrow-right'\"></gravity-icon>\n\n <span class=\"hr-title\" [ngClass]=\"leftCalendar?.selectedRangeStart && !leftCalendar.selectedRangeEnd ? 'sm-bold' : 'sm-regular'\">\n {{leftCalendar?.selectedRangeEnd ? getFormattedDate(leftCalendar.selectedRangeEnd) : i18n.end_date}} </span>\n </p>\n</div>\n\n<div class=\"dual-calendar-container\" [class.mobile]=\"appearance.isMobile\">\n\n <day-calendar #leftCalendar *ngIf=\"showLeftCalendar\"\n [range]=\"true\"\n (openIntegratedCalendar)=\"showRightCalendar = false\"\n (changeMonth)=\"onChangeMonth('left', $event)\"\n (selectedRage)=\"onSelectRageDays(rightCalendar, $event)\"\n [navType]=\"appearance.isMobile ? 'none' : 'prev'\" [currentDate]=\"currentDate\"\n (changeMonthYearResponse)=\"handlerChangeMonthYearResponse($event, 'left')\"\n [appearance]=\"{language: appearance.language, actions: false, isMobile: appearance.isMobile, state: appearance.state}\">\n </day-calendar>\n\n <day-calendar #rightCalendar *ngIf=\"showRightCalendar\"\n [range]=\"true\"\n (clearHover)=\"handleClearHover()\"\n (hoverDay)=\"handleHoverDay($event)\"\n (response)=\"handleApplyResponse($event)\"\n (clearSelection)=\"handleClearSelection()\"\n (openIntegratedCalendar)=\"showLeftCalendar = false\"\n (changeMonth)=\"onChangeMonth('right', $event)\"\n (selectedRage)=\"onSelectRageDays(leftCalendar, $event)\"\n [navType]=\"appearance.isMobile ? 'none' : 'next'\" [currentDate]=\"nextMonth\"\n (changeMonthYearResponse)=\"handlerChangeMonthYearResponse($event, 'right')\"\n [appearance]=\"{language: appearance.language, actions: true, isMobile: appearance.isMobile, state: appearance.state}\">\n </day-calendar>\n</div>", styles: [".date-select-indicator{height:27px;display:flex;align-self:stretch;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:var(--gravity-spacing-sm);margin-bottom:var(--gravity-spacing-md);border-bottom:2px solid var(--divider-menu-active-primary)}.date-select-indicator p{display:flex;align-items:flex-start;gap:var(--gravity-spacing-xs);color:var(--bg-calendar-nav-primary)}.dual-calendar-container{display:flex;align-self:stretch;align-items:flex-start;justify-content:center;gap:var(--gravity-spacing-md)}.dual-calendar-container.mobile{flex-direction:column;gap:var(--gravity-spacing-sm)}.dual-calendar-container.mobile day-calendar{width:100%}\n"] }]
|
|
91
91
|
}], propDecorators: { initDate: [{
|
|
92
92
|
type: Input
|
|
93
93
|
}], restart: [{
|
|
@@ -106,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
106
106
|
type: ViewChild,
|
|
107
107
|
args: ['rightCalendar']
|
|
108
108
|
}] } });
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dual-month-calendar.component.js","sourceRoot":"","sources":["../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar-next/components/dual-month-calendar/dual-month-calendar.component.ts","../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar-next/components/dual-month-calendar/dual-month-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {DayCalendarComponent} from \"../day-calendar/day-calendar.component\";\nimport {CalendarAppearance, CalendarDate} from \"../../shared/calendar.modal\";\nimport {changeDate, getStartDate, toCalendarDay} from \"../../shared/calendar.utils\";\nimport {onClearHover, onHoverDay, onSelectDaysRange} from \"../day-calendar/range-days-calendar.utils\";\nimport {Component, EventEmitter, Input, OnChanges, Output, SimpleChanges, ViewChild} from '@angular/core';\nimport {CALENDAR_I18N, DAYS_EN, DAYS_ES, MONTHS_SHORT_EN, MONTHS_SHORT_ES} from \"../../shared/calendar.constants\";\n\n@Component({\n  selector: 'dual-month-calendar',\n  templateUrl: './dual-month-calendar.component.html',\n  styleUrls: ['./dual-month-calendar.component.scss']\n})\nexport class DualMonthCalendarComponent implements OnChanges {\n  @Input() public initDate: Date | Date[];\n  @Input() public restart: boolean = false;\n  @Input() public appearance: CalendarAppearance\n\n  @Output() public clearSelection: EventEmitter<void> = new EventEmitter<void>();\n  @Output('response') public calendarResponse: EventEmitter<Date[] | Date> = new EventEmitter<Date[] | Date>();\n\n  @ViewChild('leftCalendar') leftCalendar: DayCalendarComponent;\n  @ViewChild('rightCalendar') rightCalendar: DayCalendarComponent;\n\n  public currentDate = new Date();\n  public showLeftCalendar: boolean = true;\n  public showRightCalendar: boolean = true;\n  public nextMonth = changeDate(1, this.currentDate, true);\n\n  public get i18n() { return CALENDAR_I18N[this.appearance.language]; }\n  public get daysList() { return this.appearance.language === 'en' ? DAYS_EN : DAYS_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  private processInitDate(): void {\n    this.showLeftCalendar = true;\n    this.showRightCalendar = true;\n\n    if (Array.isArray(this.initDate)) {\n      const [start, end] = this.initDate as Date[];\n\n      if (start instanceof Date) {\n        this.currentDate = getStartDate(start);\n        this.nextMonth = changeDate(1, this.currentDate, true);\n        setTimeout(() => {\n          this.leftCalendar.selectedRangeStart = toCalendarDay(start);\n          this.rightCalendar.selectedRangeStart = toCalendarDay(start);\n        });\n      }\n\n      if (end instanceof Date) {\n        setTimeout(() => {\n          this.leftCalendar.selectedRangeEnd = toCalendarDay(end);\n          this.rightCalendar.selectedRangeEnd = toCalendarDay(end);\n        });\n      }\n    }\n  }\n\n  public onChangeMonth(calendar: 'left' | 'right', offset: number): void {\n    const targetCalendar = calendar === 'left' ? this.rightCalendar : this.leftCalendar;\n    targetCalendar.currentDate = changeDate(offset, targetCalendar.currentDate, true);\n  }\n\n  public getFormattedDate(day: CalendarDate) {\n    return this.daysList[day.weekDay] + ', ' + day.day + ' ' + this.monthsShortList[day.monthYear.month];\n  }\n\n  public handleHoverDay(day: CalendarDate) {\n    onHoverDay(this.leftCalendar, day);\n  }\n\n  public handleClearHover(){\n    onClearHover(this.leftCalendar);\n  }\n\n  public handleApplyResponse($event: Date | Date[]): void {\n    this.calendarResponse.emit($event);\n  }\n\n  public handleClearSelection(){\n    this.clearSelection.emit();\n    this.leftCalendar.clearSelectedDate('all');\n  }\n\n  public handlerChangeMonthYearResponse($event: Date | Date[], origin: 'left' | 'right'){\n    if($event instanceof Date) {\n      if(origin === 'left') {\n        this.showRightCalendar = true;\n        setTimeout(() => {this.rightCalendar.currentDate = changeDate(1, $event, true)})\n      } else {\n        this.showLeftCalendar = true;\n        setTimeout(() => {this.leftCalendar.currentDate = changeDate(-1, $event, true)})\n      }\n    }\n  }\n\n  protected readonly Date = Date;\n  protected readonly changeDate = changeDate;\n  protected readonly onSelectDaysRange = onSelectDaysRange;\n}\n","<div *ngIf=\"showRightCalendar && showLeftCalendar\" class=\"date-select-indicator\">\n    <p>\n        <span class=\"hr-title\"  [ngClass]=\"leftCalendar?.selectedRangeStart ? 'sm-regular' : 'sm-bold'\">\n            {{leftCalendar?.selectedRangeStart ? getFormattedDate(leftCalendar.selectedRangeStart) : i18n.start_date}} </span>\n\n        <gravity-icon [iconSize]=\"'md-16'\" [size]=\"'md'\" [iconName]=\"'swaps-arrow-right'\"></gravity-icon>\n\n        <span class=\"hr-title\"  [ngClass]=\"leftCalendar?.selectedRangeStart && !leftCalendar.selectedRangeEnd ? 'sm-bold' : 'sm-regular'\">\n            {{leftCalendar?.selectedRangeEnd ? getFormattedDate(leftCalendar.selectedRangeEnd) : i18n.end_date}} </span>\n    </p>\n</div>\n\n<div class=\"dual-calendar-container\" [class.mobile]=\"appearance.isMobile\">\n\n    <day-calendar #leftCalendar *ngIf=\"showLeftCalendar\"\n      [range]=\"true\"\n      (openIntegratedCalendar)=\"showRightCalendar = false\"\n      (changeMonth)=\"onChangeMonth('left', $event)\"\n      (selectedRage)=\"onSelectDaysRange(rightCalendar, $event)\"\n      [navType]=\"appearance.isMobile ? 'none' : 'prev'\" [currentDate]=\"currentDate\"\n      (changeMonthYearResponse)=\"handlerChangeMonthYearResponse($event, 'left')\"\n      [appearance]=\"{language: appearance.language, actions: false, isMobile: appearance.isMobile, state: appearance.state}\">\n    </day-calendar>\n\n    <day-calendar #rightCalendar *ngIf=\"showRightCalendar\"\n      [range]=\"true\"\n      (clearHover)=\"handleClearHover()\"\n      (hoverDay)=\"handleHoverDay($event)\"\n      (response)=\"handleApplyResponse($event)\"\n      (clearSelection)=\"handleClearSelection()\"\n      (openIntegratedCalendar)=\"showLeftCalendar = false\"\n      (changeMonth)=\"onChangeMonth('right', $event)\"\n      (selectedRage)=\"onSelectDaysRange(leftCalendar, $event)\"\n      [navType]=\"appearance.isMobile ? 'none' : 'next'\"  [currentDate]=\"nextMonth\"\n      (changeMonthYearResponse)=\"handlerChangeMonthYearResponse($event, 'right')\"\n      [appearance]=\"{language: appearance.language, actions: true, isMobile: appearance.isMobile, state: appearance.state}\">\n    </day-calendar>\n</div>"]}
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dual-month-calendar.component.js","sourceRoot":"","sources":["../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar-next/components/dual-month-calendar/dual-month-calendar.component.ts","../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar-next/components/dual-month-calendar/dual-month-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {CalendarAppearance, CalendarDate} from \"../../shared/calendar.modal\";\nimport {DayCalendarComponent} from \"../day-calendar/day-calendar.component\";\nimport {changeDate, getStartDate, toCalendarDay} from \"../../shared/calendar.utils\";\nimport {onClearHover, onHoverDay, onSelectRageDays,} from \"../day-calendar/range-days-calendar.utils\";\nimport {Component, EventEmitter, Input, OnChanges, Output, SimpleChanges, ViewChild} from '@angular/core';\nimport {CALENDAR_I18N, DAYS_EN, DAYS_ES, MONTHS_SHORT_EN, MONTHS_SHORT_ES} from \"../../shared/calendar.constants\";\n\n@Component({\n  selector: 'dual-month-calendar',\n  templateUrl: './dual-month-calendar.component.html',\n  styleUrls: ['./dual-month-calendar.component.scss']\n})\nexport class DualMonthCalendarComponent implements OnChanges {\n  @Input() public initDate: Date | Date[];\n  @Input() public restart: boolean = false;\n  @Input() public appearance: CalendarAppearance\n\n  @Output() public clearSelection: EventEmitter<void> = new EventEmitter<void>();\n  @Output('response') public calendarResponse: EventEmitter<Date[] | Date> = new EventEmitter<Date[] | Date>();\n\n  @ViewChild('leftCalendar') leftCalendar: DayCalendarComponent;\n  @ViewChild('rightCalendar') rightCalendar: DayCalendarComponent;\n\n  public currentDate = new Date();\n  public showLeftCalendar: boolean = true;\n  public showRightCalendar: boolean = true;\n  public nextMonth = changeDate(1, this.currentDate, true);\n\n  public get i18n() { return CALENDAR_I18N[this.appearance.language]; }\n  public get daysList() { return this.appearance.language === 'en' ? DAYS_EN : DAYS_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  private processInitDate(): void {\n    this.showLeftCalendar = true;\n    this.showRightCalendar = true;\n\n    if (Array.isArray(this.initDate)) {\n      const [start, end] = this.initDate as Date[];\n\n      if (start instanceof Date) {\n        this.currentDate = getStartDate(start);\n        this.nextMonth = changeDate(1, this.currentDate, true);\n        setTimeout(() => {\n          this.leftCalendar.selectedRangeStart = toCalendarDay(start);\n          this.rightCalendar.selectedRangeStart = toCalendarDay(start);\n        });\n      }\n\n      if (end instanceof Date) {\n        setTimeout(() => {\n          this.leftCalendar.selectedRangeEnd = toCalendarDay(end);\n          this.rightCalendar.selectedRangeEnd = toCalendarDay(end);\n        });\n      }\n    }\n  }\n\n  public onChangeMonth(calendar: 'left' | 'right', offset: number): void {\n    const targetCalendar = calendar === 'left' ? this.rightCalendar : this.leftCalendar;\n    targetCalendar.currentDate = changeDate(offset, targetCalendar.currentDate, true);\n  }\n\n  public getFormattedDate(day: CalendarDate) {\n    return this.daysList[day.weekDay] + ', ' + day.day + ' ' + this.monthsShortList[day.monthYear.month];\n  }\n\n  public handleHoverDay(day: CalendarDate) {\n    onHoverDay(this.leftCalendar, day);\n  }\n\n  public handleClearHover(){\n    onClearHover(this.leftCalendar);\n  }\n\n  public handleApplyResponse($event: Date | Date[]): void {\n    this.calendarResponse.emit($event);\n  }\n\n  public handleClearSelection(){\n    this.clearSelection.emit();\n    this.leftCalendar.clearSelectedDate();\n  }\n\n  public handlerChangeMonthYearResponse($event: Date | Date[], origin: 'left' | 'right'){\n    if($event instanceof Date) {\n      if(origin === 'left') {\n        this.showRightCalendar = true;\n        setTimeout(() => {this.rightCalendar.currentDate = changeDate(1, $event, true)})\n      } else {\n        this.showLeftCalendar = true;\n        setTimeout(() => {this.leftCalendar.currentDate = changeDate(-1, $event, true)})\n      }\n    }\n  }\n\n  protected readonly Date = Date;\n  protected readonly changeDate = changeDate;\n  protected readonly onSelectRageDays = onSelectRageDays;\n}\n","<div *ngIf=\"showRightCalendar && showLeftCalendar\" class=\"date-select-indicator\">\n    <p>\n        <span class=\"hr-title\"  [ngClass]=\"leftCalendar?.selectedRangeStart ? 'sm-regular' : 'sm-bold'\">\n            {{leftCalendar?.selectedRangeStart ? getFormattedDate(leftCalendar.selectedRangeStart) : i18n.start_date}} </span>\n\n        <gravity-icon [iconSize]=\"'md-16'\" [size]=\"'md'\" [iconName]=\"'swaps-arrow-right'\"></gravity-icon>\n\n        <span class=\"hr-title\"  [ngClass]=\"leftCalendar?.selectedRangeStart && !leftCalendar.selectedRangeEnd ? 'sm-bold' : 'sm-regular'\">\n            {{leftCalendar?.selectedRangeEnd ? getFormattedDate(leftCalendar.selectedRangeEnd) : i18n.end_date}} </span>\n    </p>\n</div>\n\n<div class=\"dual-calendar-container\" [class.mobile]=\"appearance.isMobile\">\n\n    <day-calendar #leftCalendar *ngIf=\"showLeftCalendar\"\n      [range]=\"true\"\n      (openIntegratedCalendar)=\"showRightCalendar = false\"\n      (changeMonth)=\"onChangeMonth('left', $event)\"\n      (selectedRage)=\"onSelectRageDays(rightCalendar, $event)\"\n      [navType]=\"appearance.isMobile ? 'none' : 'prev'\" [currentDate]=\"currentDate\"\n      (changeMonthYearResponse)=\"handlerChangeMonthYearResponse($event, 'left')\"\n      [appearance]=\"{language: appearance.language, actions: false, isMobile: appearance.isMobile, state: appearance.state}\">\n    </day-calendar>\n\n    <day-calendar #rightCalendar *ngIf=\"showRightCalendar\"\n      [range]=\"true\"\n      (clearHover)=\"handleClearHover()\"\n      (hoverDay)=\"handleHoverDay($event)\"\n      (response)=\"handleApplyResponse($event)\"\n      (clearSelection)=\"handleClearSelection()\"\n      (openIntegratedCalendar)=\"showLeftCalendar = false\"\n      (changeMonth)=\"onChangeMonth('right', $event)\"\n      (selectedRage)=\"onSelectRageDays(leftCalendar, $event)\"\n      [navType]=\"appearance.isMobile ? 'none' : 'next'\"  [currentDate]=\"nextMonth\"\n      (changeMonthYearResponse)=\"handlerChangeMonthYearResponse($event, 'right')\"\n      [appearance]=\"{language: appearance.language, actions: true, isMobile: appearance.isMobile, state: appearance.state}\">\n    </day-calendar>\n</div>"]}
|
|
@@ -15,13 +15,7 @@ export const MONTHS_SHORT_EN = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',
|
|
|
15
15
|
'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'
|
|
16
16
|
];
|
|
17
17
|
export const CALENDAR_I18N = {
|
|
18
|
-
en: { apply: 'Apply', clear: 'Clear selection', start_date: 'Start date', end_date: 'End date',
|
|
19
|
-
|
|
20
|
-
preview_month: 'Preview month', next_month: 'Next month'
|
|
21
|
-
},
|
|
22
|
-
es: { apply: 'Aplicar', clear: 'Limpiar selección', start_date: 'Fecha inicial', end_date: 'Fecha final',
|
|
23
|
-
select_range: 'Selecciona un rango de fechas', select_date: 'Selecciona una fecha',
|
|
24
|
-
preview_month: 'Mes anterior', next_month: 'Mes siguiente'
|
|
25
|
-
}
|
|
18
|
+
en: { apply: 'Apply', clear: 'Clear selection', start_date: 'Start date', end_date: 'End date' },
|
|
19
|
+
es: { apply: 'Aplicar', clear: 'Limpiar selección', start_date: 'Fecha inicial', end_date: 'Fecha final' }
|
|
26
20
|
};
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZ3Jhdml0eS1kZXNpZ24tc3lzdGVtL3NyYy9saWIvY29tcG9uZW50cy9ncmF2aXR5LWNhbGVuZGFyLW5leHQvc2hhcmVkL2NhbGVuZGFyLmNvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQWEsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztBQUVuRixNQUFNLENBQUMsTUFBTSxPQUFPLEdBQWEsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztBQUVuRixNQUFNLENBQUMsTUFBTSxhQUFhLEdBQWEsQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztBQUVsRixNQUFNLENBQUMsTUFBTSxhQUFhLEdBQWEsQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztBQUVsRixNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsQ0FBQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE9BQU87SUFDM0UsT0FBTyxFQUFFLFFBQVEsRUFBRSxZQUFZLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxXQUFXO0NBQ3ZFLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsQ0FBQyxTQUFTLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU07SUFDNUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxVQUFVO0NBQ25FLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUs7SUFDcEUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLO0NBQzNDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUs7SUFDcEUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLO0NBQzNDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUc7SUFDekIsRUFBRSxFQUFFLEVBQUMsS0FBSyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsVUFBVSxFQUFFLFlBQVksRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFDO0lBQzlGLEVBQUUsRUFBRSxFQUFDLEtBQUssRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLG1CQUFtQixFQUFFLFVBQVUsRUFBRSxlQUFlLEVBQUUsUUFBUSxFQUFFLGFBQWEsRUFBQztDQUNsRyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IERBWVNfRU46IHN0cmluZ1tdID0gWydNb24nLCAnVHVlJywgJ1dlZCcsICdUaHUnLCAnRnJpJywgJ1NhdCcsICdTdW4nXTtcblxuZXhwb3J0IGNvbnN0IERBWVNfRVM6IHN0cmluZ1tdID0gWydMdW4nLCAnTWFyJywgJ01pw6knLCAnSnVlJywgJ1ZpZScsICdTw6FiJywgJ0RvbSddO1xuXG5leHBvcnQgY29uc3QgREFZU19TSE9SVF9FUzogc3RyaW5nW10gPSBbJ0x1JywgJ01hJywgJ01pJywgJ0p1JywgJ1ZpJywgJ1NhJywgJ0RvJ107XG5cbmV4cG9ydCBjb25zdCBEQVlTX1NIT1JUX0VOOiBzdHJpbmdbXSA9IFsnTW8nLCAnVHUnLCAnV2UnLCAnVGgnLCAnRnInLCAnU2EnLCAnU3UnXTtcblxuZXhwb3J0IGNvbnN0IE1PTlRIU19FUyA9IFsnRW5lcm8nLCAnRmVicmVybycsICdNYXJ6bycsICdBYnJpbCcsICdNYXlvJywgJ0p1bmlvJyxcbiAgICAnSnVsaW8nLCAnQWdvc3RvJywgJ1NlcHRpZW1icmUnLCAnT2N0dWJyZScsICdOb3ZpZW1icmUnLCAnRGljaWVtYnJlJ1xuXTtcblxuZXhwb3J0IGNvbnN0IE1PTlRIU19FTiA9IFsnSmFudWFyeScsICdGZWJydWFyeScsICdNYXJjaCcsICdBcHJpbCcsICdNYXknLCAnSnVuZScsXG4gICAgJ0p1bHknLCAnQXVndXN0JywgJ1NlcHRlbWJlcicsICdPY3RvYmVyJywgJ05vdmVtYmVyJywgJ0RlY2VtYmVyJ1xuXTtcblxuZXhwb3J0IGNvbnN0IE1PTlRIU19TSE9SVF9FUyA9IFsnRW5lJywgJ0ZlYicsICdNYXInLCAnQWJyJywgJ01heScsICdKdW4nLFxuICAgICdKdWwnLCAnQWdvJywgJ1NlcCcsICdPY3QnLCAnTm92JywgJ0RpYydcbl07XG5cbmV4cG9ydCBjb25zdCBNT05USFNfU0hPUlRfRU4gPSBbJ0phbicsICdGZWInLCAnTWFyJywgJ0FwcicsICdNYXknLCAnSnVuJyxcbiAgICAnSnVsJywgJ0F1ZycsICdTZXAnLCAnT2N0JywgJ05vdicsICdEZWMnXG5dO1xuXG5leHBvcnQgY29uc3QgQ0FMRU5EQVJfSTE4TiA9IHtcbiAgICBlbjoge2FwcGx5OiAnQXBwbHknLCBjbGVhcjogJ0NsZWFyIHNlbGVjdGlvbicsIHN0YXJ0X2RhdGU6ICdTdGFydCBkYXRlJywgZW5kX2RhdGU6ICdFbmQgZGF0ZSd9LFxuICAgIGVzOiB7YXBwbHk6ICdBcGxpY2FyJywgY2xlYXI6ICdMaW1waWFyIHNlbGVjY2nDs24nLCBzdGFydF9kYXRlOiAnRmVjaGEgaW5pY2lhbCcsIGVuZF9kYXRlOiAnRmVjaGEgZmluYWwnfVxufSBhcyBjb25zdDsiXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIubW9kYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ncmF2aXR5LWRlc2lnbi1zeXN0ZW0vc3JjL2xpYi9jb21wb25lbnRzL2dyYXZpdHktY2FsZW5kYXItbmV4dC9zaGFyZWQvY2FsZW5kYXIubW9kYWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQ2FsZW5kYXJDb25maWcge1xuICAgIG1heERhdGU/OiBEYXRlIHwgbnVsbDtcbiAgICBtaW5EYXRlPzogRGF0ZSB8IG51bGw7XG4gICAgaW5pdERhdGU/OiBEYXRlIHwgRGF0ZVtdIHwgbnVsbDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDYWxlbmRhckFwcGVhcmFuY2Uge1xuICAgIGFjdGlvbnM/
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIubW9kYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ncmF2aXR5LWRlc2lnbi1zeXN0ZW0vc3JjL2xpYi9jb21wb25lbnRzL2dyYXZpdHktY2FsZW5kYXItbmV4dC9zaGFyZWQvY2FsZW5kYXIubW9kYWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQ2FsZW5kYXJDb25maWcge1xuICAgIG1heERhdGU/OiBEYXRlIHwgbnVsbDtcbiAgICBtaW5EYXRlPzogRGF0ZSB8IG51bGw7XG4gICAgaW5pdERhdGU/OiBEYXRlIHwgRGF0ZVtdIHwgbnVsbDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDYWxlbmRhckFwcGVhcmFuY2Uge1xuICAgIGFjdGlvbnM/OiBib29sZWFuO1xuICAgIGlzTW9iaWxlPzogYm9vbGVhbjtcbiAgICBsYW5ndWFnZT86ICdlcycgfCAnZW4nO1xuICAgIHN0YXRlPzogJ2FjdGl2ZScgfCAnaGlkZGVuJyB8ICdkaXNhYmxlZCc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FsZW5kYXJEYXRlIHtcbiAgICBkYXk6IG51bWJlcjtcbiAgICB3ZWVrRGF5OiBudW1iZXI7XG4gICAgaXNUb2RheTogYm9vbGVhbjtcbiAgICBpbkN1cnJlbnRNb250aDogYm9vbGVhbjtcbiAgICBtb250aFllYXI6IENhbGVuZGFyUGVyaW9kXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FsZW5kYXJQZXJpb2Qge1xuICAgIHllYXI6IG51bWJlcjtcbiAgICBtb250aDogbnVtYmVyO1xufVxuIl19
|
|
@@ -13,10 +13,4 @@ export function toCalendarDay(date) {
|
|
|
13
13
|
return { inCurrentMonth: true, isToday: false, day: date.getDate(),
|
|
14
14
|
monthYear: { month: date.getMonth(), year: date.getFullYear() }, weekDay: date.getDay() };
|
|
15
15
|
}
|
|
16
|
-
|
|
17
|
-
const day = date.getDate().toString().padStart(2, '0'); // día con 2 dígitos
|
|
18
|
-
const month = (date.getMonth() + 1).toString().padStart(2, '0'); // mes con 2 dígitos (JS: 0-11)
|
|
19
|
-
const year = date.getFullYear().toString(); // año completo
|
|
20
|
-
return `${day}/${month}/${year}`;
|
|
21
|
-
}
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIudXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ncmF2aXR5LWRlc2lnbi1zeXN0ZW0vc3JjL2xpYi9jb21wb25lbnRzL2dyYXZpdHktY2FsZW5kYXItbmV4dC9zaGFyZWQvY2FsZW5kYXIudXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxVQUFVLE1BQU0sQ0FBQyxHQUFpQjtJQUNwQyxPQUFPLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLEdBQUcsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztBQUN0RSxDQUFDO0FBRUQsTUFBTSxVQUFVLFlBQVksQ0FBQyxJQUFVO0lBQ25DLE9BQU8sSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUM1RCxDQUFDO0FBRUQsTUFBTSxVQUFVLFVBQVUsQ0FBQyxNQUFjLEVBQUUsV0FBaUIsRUFBRSxPQUFnQjtJQUMxRSxNQUFNLEtBQUssR0FBRyxXQUFXLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDckMsTUFBTSxJQUFJLEdBQUcsV0FBVyxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBRXZDLE9BQU8sT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLElBQUksQ0FBQyxJQUFJLEVBQUUsS0FBSyxHQUFHLE1BQU0sRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUMsSUFBSSxHQUFHLE1BQU0sRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDM0YsQ0FBQztBQUVELE1BQU0sVUFBVSxhQUFhLENBQUMsSUFBVTtJQUNwQyxPQUFPLEVBQUUsY0FBYyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLEdBQUcsRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFO1FBQzlELFNBQVMsRUFBRSxFQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxXQUFXLEVBQUUsRUFBQyxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQztBQUNoRyxDQUFDO0FBRUQsTUFBTSxVQUFVLFlBQVksQ0FBQyxJQUFVO0lBQ3RDLE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQU0sb0JBQW9CO0lBQ2pGLE1BQU0sS0FBSyxHQUFHLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQywrQkFBK0I7SUFDaEcsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQWtCLGVBQWU7SUFFNUUsT0FBTyxHQUFHLEdBQUcsSUFBSSxLQUFLLElBQUksSUFBSSxFQUFFLENBQUM7QUFDbEMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2FsZW5kYXJEYXRlfSBmcm9tIFwiLi9jYWxlbmRhci5tb2RhbFwiO1xuXG5leHBvcnQgZnVuY3Rpb24gdG9EYXRlKGRheTogQ2FsZW5kYXJEYXRlKTogRGF0ZSB7XG4gICAgcmV0dXJuIG5ldyBEYXRlKGRheS5tb250aFllYXIueWVhciwgZGF5Lm1vbnRoWWVhci5tb250aCwgZGF5LmRheSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRTdGFydERhdGUoZGF0ZTogRGF0ZSk6IERhdGUge1xuICAgIHJldHVybiBuZXcgRGF0ZShkYXRlLmdldEZ1bGxZZWFyKCksIGRhdGUuZ2V0TW9udGgoKSwgMSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjaGFuZ2VEYXRlKG9mZnNldDogbnVtYmVyLCBjdXJyZW50RGF0ZTogRGF0ZSwgaXNNb250aDogYm9vbGVhbik6IERhdGUge1xuICAgIGNvbnN0IG1vbnRoID0gY3VycmVudERhdGUuZ2V0TW9udGgoKTtcbiAgICBjb25zdCB5ZWFyID0gY3VycmVudERhdGUuZ2V0RnVsbFllYXIoKTtcblxuICAgIHJldHVybiBpc01vbnRoID8gbmV3IERhdGUoeWVhciwgbW9udGggKyBvZmZzZXQsIDEpIDogbmV3IERhdGUoeWVhciArIG9mZnNldCwgbW9udGgsIDEpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdG9DYWxlbmRhckRheShkYXRlOiBEYXRlKTogQ2FsZW5kYXJEYXRlIHtcbiAgICByZXR1cm4geyBpbkN1cnJlbnRNb250aDogdHJ1ZSwgaXNUb2RheTogZmFsc2UsIGRheTogZGF0ZS5nZXREYXRlKCksXG4gICAgICAgIG1vbnRoWWVhcjoge21vbnRoOiBkYXRlLmdldE1vbnRoKCksIHllYXI6IGRhdGUuZ2V0RnVsbFllYXIoKX0sIHdlZWtEYXk6IGRhdGUuZ2V0RGF5KCkgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGRhdGVUb1N0cmluZyhkYXRlOiBEYXRlKTogc3RyaW5nIHtcblx0Y29uc3QgZGF5ID0gZGF0ZS5nZXREYXRlKCkudG9TdHJpbmcoKS5wYWRTdGFydCgyLCAnMCcpOyAgICAgIC8vIGTDrWEgY29uIDIgZMOtZ2l0b3Ncblx0Y29uc3QgbW9udGggPSAoZGF0ZS5nZXRNb250aCgpICsgMSkudG9TdHJpbmcoKS5wYWRTdGFydCgyLCAnMCcpOyAvLyBtZXMgY29uIDIgZMOtZ2l0b3MgKEpTOiAwLTExKVxuXHRjb25zdCB5ZWFyID0gZGF0ZS5nZXRGdWxsWWVhcigpLnRvU3RyaW5nKCk7ICAgICAgICAgICAgICAgICAgLy8gYcOxbyBjb21wbGV0b1xuXG5cdHJldHVybiBgJHtkYXl9LyR7bW9udGh9LyR7eWVhcn1gO1xufVxuIl19
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIudXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ncmF2aXR5LWRlc2lnbi1zeXN0ZW0vc3JjL2xpYi9jb21wb25lbnRzL2dyYXZpdHktY2FsZW5kYXItbmV4dC9zaGFyZWQvY2FsZW5kYXIudXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxVQUFVLE1BQU0sQ0FBQyxHQUFpQjtJQUNwQyxPQUFPLElBQUksSUFBSSxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLEdBQUcsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztBQUN0RSxDQUFDO0FBRUQsTUFBTSxVQUFVLFlBQVksQ0FBQyxJQUFVO0lBQ25DLE9BQU8sSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUM1RCxDQUFDO0FBRUQsTUFBTSxVQUFVLFVBQVUsQ0FBQyxNQUFjLEVBQUUsV0FBaUIsRUFBRSxPQUFnQjtJQUMxRSxNQUFNLEtBQUssR0FBRyxXQUFXLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDckMsTUFBTSxJQUFJLEdBQUcsV0FBVyxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBRXZDLE9BQU8sT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLElBQUksQ0FBQyxJQUFJLEVBQUUsS0FBSyxHQUFHLE1BQU0sRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUMsSUFBSSxHQUFHLE1BQU0sRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDM0YsQ0FBQztBQUVELE1BQU0sVUFBVSxhQUFhLENBQUMsSUFBVTtJQUNwQyxPQUFPLEVBQUUsY0FBYyxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLEdBQUcsRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFO1FBQzlELFNBQVMsRUFBRSxFQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxXQUFXLEVBQUUsRUFBQyxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQztBQUNoRyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDYWxlbmRhckRhdGV9IGZyb20gXCIuL2NhbGVuZGFyLm1vZGFsXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiB0b0RhdGUoZGF5OiBDYWxlbmRhckRhdGUpOiBEYXRlIHtcbiAgICByZXR1cm4gbmV3IERhdGUoZGF5Lm1vbnRoWWVhci55ZWFyLCBkYXkubW9udGhZZWFyLm1vbnRoLCBkYXkuZGF5KTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldFN0YXJ0RGF0ZShkYXRlOiBEYXRlKTogRGF0ZSB7XG4gICAgcmV0dXJuIG5ldyBEYXRlKGRhdGUuZ2V0RnVsbFllYXIoKSwgZGF0ZS5nZXRNb250aCgpLCAxKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNoYW5nZURhdGUob2Zmc2V0OiBudW1iZXIsIGN1cnJlbnREYXRlOiBEYXRlLCBpc01vbnRoOiBib29sZWFuKTogRGF0ZSB7XG4gICAgY29uc3QgbW9udGggPSBjdXJyZW50RGF0ZS5nZXRNb250aCgpO1xuICAgIGNvbnN0IHllYXIgPSBjdXJyZW50RGF0ZS5nZXRGdWxsWWVhcigpO1xuXG4gICAgcmV0dXJuIGlzTW9udGggPyBuZXcgRGF0ZSh5ZWFyLCBtb250aCArIG9mZnNldCwgMSkgOiBuZXcgRGF0ZSh5ZWFyICsgb2Zmc2V0LCBtb250aCwgMSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0b0NhbGVuZGFyRGF5KGRhdGU6IERhdGUpOiBDYWxlbmRhckRhdGUge1xuICAgIHJldHVybiB7IGluQ3VycmVudE1vbnRoOiB0cnVlLCBpc1RvZGF5OiBmYWxzZSwgZGF5OiBkYXRlLmdldERhdGUoKSxcbiAgICAgICAgbW9udGhZZWFyOiB7bW9udGg6IGRhdGUuZ2V0TW9udGgoKSwgeWVhcjogZGF0ZS5nZXRGdWxsWWVhcigpfSwgd2Vla0RheTogZGF0ZS5nZXREYXkoKSB9O1xufVxuIl19
|