@progressio_resources/gravity-design-system 3.6.1 → 3.6.2
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 +56 -14
- package/esm2022/lib/components/gravity-calendar-next/components/day-calendar/range-days-calendar.utils.mjs +122 -37
- 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 +9 -3
- package/esm2022/lib/components/gravity-calendar-next/shared/calendar.modal.mjs +1 -1
- package/esm2022/lib/components/gravity-calendar-next/shared/calendar.utils.mjs +7 -1
- package/esm2022/lib/components/gravity-link/gravity-link.component.mjs +2 -2
- package/esm2022/lib/components/gravity-text-field/gravity-text-field.component.mjs +60 -4
- package/esm2022/lib/layout/gravity-menu/gravity-menu.component.mjs +4 -5
- package/fesm2022/progressio_resources-gravity-design-system.mjs +249 -56
- 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 +17 -2
- package/lib/components/gravity-calendar-next/components/day-calendar/range-days-calendar.utils.d.ts +2 -1
- package/lib/components/gravity-calendar-next/components/dual-month-calendar/dual-month-calendar.component.d.ts +11 -3
- package/lib/components/gravity-calendar-next/components/month-calendar/month-calendar.component.d.ts +8 -0
- package/lib/components/gravity-calendar-next/components/year-calendar/year-calendar.component.d.ts +8 -0
- package/lib/components/gravity-calendar-next/shared/calendar.constants.d.ts +8 -0
- package/lib/components/gravity-calendar-next/shared/calendar.modal.d.ts +1 -1
- package/lib/components/gravity-calendar-next/shared/calendar.utils.d.ts +1 -0
- package/lib/components/gravity-text-field/gravity-text-field.component.d.ts +2 -1
- package/lib/layout/gravity-menu/gravity-menu.component.d.ts +2 -2
- package/package.json +1 -1
|
@@ -1,13 +1,24 @@
|
|
|
1
|
-
import { getStartDate, toCalendarDay, toDate } from "../../shared/calendar.utils";
|
|
1
|
+
import { dateToString, 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;
|
|
5
3
|
const current = toDate(day);
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
4
|
+
// Caso 1: solo start seleccionado → hover hacia adelante
|
|
5
|
+
if (component.selectedRangeStart && !component.selectedRangeEnd && component.hoveredDay) {
|
|
6
|
+
const start = toDate(component.selectedRangeStart);
|
|
7
|
+
const hover = toDate(component.hoveredDay);
|
|
8
|
+
if (hover <= start)
|
|
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;
|
|
11
22
|
}
|
|
12
23
|
export function processPreselectedRangeDate(component) {
|
|
13
24
|
const [start, end] = component.config.initDate;
|
|
@@ -23,38 +34,87 @@ export function processPreselectedRangeDate(component) {
|
|
|
23
34
|
}
|
|
24
35
|
}
|
|
25
36
|
export function getRangeSelectionClass(component, day) {
|
|
26
|
-
if (!component.selectedRangeStart)
|
|
27
|
-
return 'nsl-start';
|
|
28
37
|
const current = toDate(day);
|
|
29
|
-
const start = toDate(component.selectedRangeStart);
|
|
30
|
-
|
|
38
|
+
const start = component.selectedRangeStart ? toDate(component.selectedRangeStart) : null;
|
|
39
|
+
const end = component.selectedRangeEnd ? toDate(component.selectedRangeEnd) : null;
|
|
40
|
+
if (!start && !end)
|
|
41
|
+
return 'nsl-start';
|
|
42
|
+
if (start && !end) {
|
|
31
43
|
if (current.getTime() === start.getTime())
|
|
32
44
|
return 'sl start';
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
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';
|
|
59
|
+
if (current.getTime() === start.getTime())
|
|
60
|
+
return 'sl start';
|
|
61
|
+
if (current.getTime() === end.getTime())
|
|
62
|
+
return 'sl end';
|
|
63
|
+
if (current > start && current < end)
|
|
64
|
+
return 'sl range';
|
|
65
|
+
return 'all-sld';
|
|
39
66
|
}
|
|
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';
|
|
48
67
|
}
|
|
49
|
-
export function
|
|
50
|
-
|
|
68
|
+
export function onSelectDaysRange(component, day) {
|
|
69
|
+
const selected = toDate(day);
|
|
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) {
|
|
51
74
|
component.selectedRangeStart = day;
|
|
52
|
-
component.
|
|
75
|
+
component.startDateField.inputValue = dateToString(selected);
|
|
76
|
+
return;
|
|
53
77
|
}
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
78
|
+
// Solo start → asignar end si es posterior, o intercambiar
|
|
79
|
+
if (startDate && !endDate) {
|
|
80
|
+
if (selected >= startDate) {
|
|
81
|
+
component.selectedRangeEnd = day;
|
|
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
|
+
}
|
|
58
118
|
}
|
|
59
119
|
}
|
|
60
120
|
export function onApplyRageDate(component) {
|
|
@@ -63,11 +123,36 @@ export function onApplyRageDate(component) {
|
|
|
63
123
|
component.calendarResponse.emit([start, end]);
|
|
64
124
|
}
|
|
65
125
|
export function onHoverDay(component, day) {
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
126
|
+
const startSelected = !!component.selectedRangeStart && !component.selectedRangeEnd;
|
|
127
|
+
const endSelected = !!component.selectedRangeEnd && !component.selectedRangeStart;
|
|
128
|
+
if (startSelected || endSelected) {
|
|
129
|
+
component.hoveredDay = day;
|
|
130
|
+
}
|
|
69
131
|
}
|
|
70
132
|
export function onClearHover(component) {
|
|
71
133
|
component.hoveredDay = null;
|
|
72
134
|
}
|
|
73
|
-
|
|
135
|
+
export function stringToDate(value) {
|
|
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"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { changeDate, getStartDate, toCalendarDay } from "../../shared/calendar.utils";
|
|
2
|
-
import { onClearHover, onHoverDay,
|
|
2
|
+
import { onClearHover, onHoverDay, onSelectDaysRange } 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.onSelectDaysRange = onSelectDaysRange;
|
|
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('all');
|
|
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)=\"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>", 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)=\"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>", 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 {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>"]}
|
|
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>"]}
|
|
@@ -15,7 +15,13 @@ 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
|
-
|
|
18
|
+
en: { apply: 'Apply', clear: 'Clear selection', start_date: 'Start date', end_date: 'End date',
|
|
19
|
+
select_range: 'Select a date range', select_date: 'Select a date',
|
|
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
|
+
}
|
|
20
26
|
};
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZ3Jhdml0eS1kZXNpZ24tc3lzdGVtL3NyYy9saWIvY29tcG9uZW50cy9ncmF2aXR5LWNhbGVuZGFyLW5leHQvc2hhcmVkL2NhbGVuZGFyLmNvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQWEsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztBQUVuRixNQUFNLENBQUMsTUFBTSxPQUFPLEdBQWEsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQztBQUVuRixNQUFNLENBQUMsTUFBTSxhQUFhLEdBQWEsQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztBQUVsRixNQUFNLENBQUMsTUFBTSxhQUFhLEdBQWEsQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztBQUVsRixNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsQ0FBQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE9BQU87SUFDM0UsT0FBTyxFQUFFLFFBQVEsRUFBRSxZQUFZLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxXQUFXO0NBQ3ZFLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsQ0FBQyxTQUFTLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU07SUFDNUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxVQUFVO0NBQ25FLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUs7SUFDcEUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLO0NBQzNDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxlQUFlLEdBQUcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUs7SUFDcEUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLO0NBQzNDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUc7SUFDekIsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsVUFBVSxFQUFFLFlBQVksRUFBRSxRQUFRLEVBQUUsVUFBVTtRQUN6RixZQUFZLEVBQUUscUJBQXFCLEVBQUUsV0FBVyxFQUFFLGVBQWU7UUFDakUsYUFBYSxFQUFFLGVBQWUsRUFBRSxVQUFVLEVBQUUsWUFBWTtLQUM1RDtJQUVELEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLG1CQUFtQixFQUFFLFVBQVUsRUFBRSxlQUFlLEVBQUUsUUFBUSxFQUFFLGFBQWE7UUFDbkcsWUFBWSxFQUFFLCtCQUErQixFQUFFLFdBQVcsRUFBRSxzQkFBc0I7UUFDbEYsYUFBYSxFQUFFLGNBQWMsRUFBRSxVQUFVLEVBQUUsZUFBZTtLQUNoRTtDQUNPLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgREFZU19FTjogc3RyaW5nW10gPSBbJ01vbicsICdUdWUnLCAnV2VkJywgJ1RodScsICdGcmknLCAnU2F0JywgJ1N1biddO1xuXG5leHBvcnQgY29uc3QgREFZU19FUzogc3RyaW5nW10gPSBbJ0x1bicsICdNYXInLCAnTWnDqScsICdKdWUnLCAnVmllJywgJ1PDoWInLCAnRG9tJ107XG5cbmV4cG9ydCBjb25zdCBEQVlTX1NIT1JUX0VTOiBzdHJpbmdbXSA9IFsnTHUnLCAnTWEnLCAnTWknLCAnSnUnLCAnVmknLCAnU2EnLCAnRG8nXTtcblxuZXhwb3J0IGNvbnN0IERBWVNfU0hPUlRfRU46IHN0cmluZ1tdID0gWydNbycsICdUdScsICdXZScsICdUaCcsICdGcicsICdTYScsICdTdSddO1xuXG5leHBvcnQgY29uc3QgTU9OVEhTX0VTID0gWydFbmVybycsICdGZWJyZXJvJywgJ01hcnpvJywgJ0FicmlsJywgJ01heW8nLCAnSnVuaW8nLFxuICAgICdKdWxpbycsICdBZ29zdG8nLCAnU2VwdGllbWJyZScsICdPY3R1YnJlJywgJ05vdmllbWJyZScsICdEaWNpZW1icmUnXG5dO1xuXG5leHBvcnQgY29uc3QgTU9OVEhTX0VOID0gWydKYW51YXJ5JywgJ0ZlYnJ1YXJ5JywgJ01hcmNoJywgJ0FwcmlsJywgJ01heScsICdKdW5lJyxcbiAgICAnSnVseScsICdBdWd1c3QnLCAnU2VwdGVtYmVyJywgJ09jdG9iZXInLCAnTm92ZW1iZXInLCAnRGVjZW1iZXInXG5dO1xuXG5leHBvcnQgY29uc3QgTU9OVEhTX1NIT1JUX0VTID0gWydFbmUnLCAnRmViJywgJ01hcicsICdBYnInLCAnTWF5JywgJ0p1bicsXG4gICAgJ0p1bCcsICdBZ28nLCAnU2VwJywgJ09jdCcsICdOb3YnLCAnRGljJ1xuXTtcblxuZXhwb3J0IGNvbnN0IE1PTlRIU19TSE9SVF9FTiA9IFsnSmFuJywgJ0ZlYicsICdNYXInLCAnQXByJywgJ01heScsICdKdW4nLFxuICAgICdKdWwnLCAnQXVnJywgJ1NlcCcsICdPY3QnLCAnTm92JywgJ0RlYydcbl07XG5cbmV4cG9ydCBjb25zdCBDQUxFTkRBUl9JMThOID0ge1xuICAgIGVuOiB7IGFwcGx5OiAnQXBwbHknLCBjbGVhcjogJ0NsZWFyIHNlbGVjdGlvbicsIHN0YXJ0X2RhdGU6ICdTdGFydCBkYXRlJywgZW5kX2RhdGU6ICdFbmQgZGF0ZScsXG5cdCAgICAgICAgc2VsZWN0X3JhbmdlOiAnU2VsZWN0IGEgZGF0ZSByYW5nZScsIHNlbGVjdF9kYXRlOiAnU2VsZWN0IGEgZGF0ZScsXG5cdCAgICAgICAgcHJldmlld19tb250aDogJ1ByZXZpZXcgbW9udGgnLCBuZXh0X21vbnRoOiAnTmV4dCBtb250aCdcbiAgICB9LFxuXG4gICAgZXM6IHsgYXBwbHk6ICdBcGxpY2FyJywgY2xlYXI6ICdMaW1waWFyIHNlbGVjY2nDs24nLCBzdGFydF9kYXRlOiAnRmVjaGEgaW5pY2lhbCcsIGVuZF9kYXRlOiAnRmVjaGEgZmluYWwnLFxuXHQgICAgICAgIHNlbGVjdF9yYW5nZTogJ1NlbGVjY2lvbmEgdW4gcmFuZ28gZGUgZmVjaGFzJywgc2VsZWN0X2RhdGU6ICdTZWxlY2Npb25hIHVuYSBmZWNoYScsXG5cdCAgICAgICAgcHJldmlld19tb250aDogJ01lcyBhbnRlcmlvcicsIG5leHRfbW9udGg6ICdNZXMgc2lndWllbnRlJ1xuXHRcdH1cbn0gYXMgY29uc3Q7Il19
|
|
@@ -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/OiBib29sZWFuO1xuICAgIGlzTW9iaWxlPzogYm9vbGVhbjtcbiAgICBsYW5ndWFnZT86ICdlcycgfCAnZW4nO1xuICAgIHN0YXRlPzogJ2FjdGl2ZScgfCAnaGlkZGVuJyB8ICdkaXNhYmxlZCc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FsZW5kYXJEYXRlIHtcbiAgICBkYXk6IG51bWJlcjtcbiAgICB3ZWVrRGF5OiBudW1iZXI7XG4gICAgaXNUb2RheT86IGJvb2xlYW47XG4gICAgaW5DdXJyZW50TW9udGg6IGJvb2xlYW47XG4gICAgbW9udGhZZWFyOiBDYWxlbmRhclBlcmlvZFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIENhbGVuZGFyUGVyaW9kIHtcbiAgICB5ZWFyOiBudW1iZXI7XG4gICAgbW9udGg6IG51bWJlcjtcbn1cbiJdfQ==
|
|
@@ -13,4 +13,10 @@ 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
|
-
|
|
16
|
+
export function dateToString(date) {
|
|
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
|
|
@@ -12,11 +12,11 @@ export class GravityLinkComponent {
|
|
|
12
12
|
this.state = 'active';
|
|
13
13
|
}
|
|
14
14
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityLinkComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
15
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GravityLinkComponent, selector: "gravity-link", inputs: { linkText: "linkText", fontClass: "fontClass", link: "link", cypressTag: "cypressTag", iconName: "iconName", target: "target", iconPosition: "iconPosition", iconSize: "iconSize", state: "state" }, ngImport: i0, template: "<div class=\"gravity-link-container {{iconPosition}} {{state}}\">\n\n <a *ngIf=\"!link || !(link.startsWith('http') || link.startsWith('https'))\"\n [attr.data-cy]=\"cypressTag\" [routerLink]=\"!link || state === 'disabled' ? null : link\"\n class=\"{{ fontClass ? (fontClass !== '' ? fontClass : 'hr-body sm-regular') : 'hr-body sm-regular' }}\"> \n {{linkText}}\n </a>\n\n <a *ngIf=\"link && (link.startsWith('http') || link.startsWith('https'))\"\n [attr.data-cy]=\"cypressTag\" [href]=\"state === 'disabled' || link === '' ? null : link\" [target]=\"target\"\n class=\"{{ fontClass ? (fontClass !== '' ? fontClass : 'hr-body sm-regular') : 'hr-body sm-regular' }}\">\n {{linkText}}\n </a>\n\n <gravity-icon [style.--icon-color]=\"'var(--link-text-color)'\" [size]=\"'md'\"\n [hoverIcon]=\"false\" [iconName]=\"iconName\" *ngIf=\"iconName\"\n [iconSize]=\"iconSize\" class=\"icon-{{iconPosition}}\">\n </gravity-icon>\n</div>", styles: [".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}.gravity-link-container{display:flex;cursor:pointer;width:-moz-fit-content;width:fit-content;align-items:center;justify-content:flex-start;gap:var(--gravity-spacing-xxs);padding:var(--gravity-spacing-xxs)}.gravity-link-container.right{flex-direction:row}.gravity-link-container.left{flex-direction:row-reverse}.gravity-link-container.pressed{border:1px solid var(--bg-link-hover-primary);--link-text-color: var(--bg-link-hover-primary)}.gravity-link-container.active{--link-text-color: var(--link-active-primary)}.gravity-link-container.visited{font-weight:650;--link-text-color: var(--link-visited-primary)}.gravity-link-container.disabled{cursor:
|
|
15
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GravityLinkComponent, selector: "gravity-link", inputs: { linkText: "linkText", fontClass: "fontClass", link: "link", cypressTag: "cypressTag", iconName: "iconName", target: "target", iconPosition: "iconPosition", iconSize: "iconSize", state: "state" }, ngImport: i0, template: "<div class=\"gravity-link-container {{iconPosition}} {{state}}\">\n\n <a *ngIf=\"!link || !(link.startsWith('http') || link.startsWith('https'))\"\n [attr.data-cy]=\"cypressTag\" [routerLink]=\"!link || state === 'disabled' ? null : link\"\n class=\"{{ fontClass ? (fontClass !== '' ? fontClass : 'hr-body sm-regular') : 'hr-body sm-regular' }}\"> \n {{linkText}}\n </a>\n\n <a *ngIf=\"link && (link.startsWith('http') || link.startsWith('https'))\"\n [attr.data-cy]=\"cypressTag\" [href]=\"state === 'disabled' || link === '' ? null : link\" [target]=\"target\"\n class=\"{{ fontClass ? (fontClass !== '' ? fontClass : 'hr-body sm-regular') : 'hr-body sm-regular' }}\">\n {{linkText}}\n </a>\n\n <gravity-icon [style.--icon-color]=\"'var(--link-text-color)'\" [size]=\"'md'\"\n [hoverIcon]=\"false\" [iconName]=\"iconName\" *ngIf=\"iconName\"\n [iconSize]=\"iconSize\" class=\"icon-{{iconPosition}}\">\n </gravity-icon>\n</div>", styles: [".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}.gravity-link-container{display:flex;cursor:pointer;width:-moz-fit-content;width:fit-content;align-items:center;justify-content:flex-start;gap:var(--gravity-spacing-xxs);padding:var(--gravity-spacing-xxs)}.gravity-link-container.right{flex-direction:row}.gravity-link-container.left{flex-direction:row-reverse}.gravity-link-container.pressed{border:1px solid var(--bg-link-hover-primary);--link-text-color: var(--bg-link-hover-primary)}.gravity-link-container.active{--link-text-color: var(--link-active-primary)}.gravity-link-container.visited{font-weight:650;--link-text-color: var(--link-visited-primary)}.gravity-link-container.disabled{cursor:default;pointer-events:none;--link-text-color: var(--link-disabled-primary)}.gravity-link-container.disabled a{cursor:default;pointer-events:none}.gravity-link-container:hover:not(.disabled){background-color:var(--link-hover-primary);--link-text-color: var(--bg-link-hover-primary)}.gravity-link-container a{border:none;width:max-content;align-items:center;display:inline-flex;justify-content:center;text-decoration:underline;color:var(--link-text-color);gap:var(--gravity-spacing-xxs);border-radius:.0625rem}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i3.GravityIconComponent, selector: "gravity-icon", inputs: ["customIconColorVariable", "iconName", "iconSize", "hoverIcon", "size", "isCoin"] }] }); }
|
|
16
16
|
}
|
|
17
17
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityLinkComponent, decorators: [{
|
|
18
18
|
type: Component,
|
|
19
|
-
args: [{ selector: 'gravity-link', template: "<div class=\"gravity-link-container {{iconPosition}} {{state}}\">\n\n <a *ngIf=\"!link || !(link.startsWith('http') || link.startsWith('https'))\"\n [attr.data-cy]=\"cypressTag\" [routerLink]=\"!link || state === 'disabled' ? null : link\"\n class=\"{{ fontClass ? (fontClass !== '' ? fontClass : 'hr-body sm-regular') : 'hr-body sm-regular' }}\"> \n {{linkText}}\n </a>\n\n <a *ngIf=\"link && (link.startsWith('http') || link.startsWith('https'))\"\n [attr.data-cy]=\"cypressTag\" [href]=\"state === 'disabled' || link === '' ? null : link\" [target]=\"target\"\n class=\"{{ fontClass ? (fontClass !== '' ? fontClass : 'hr-body sm-regular') : 'hr-body sm-regular' }}\">\n {{linkText}}\n </a>\n\n <gravity-icon [style.--icon-color]=\"'var(--link-text-color)'\" [size]=\"'md'\"\n [hoverIcon]=\"false\" [iconName]=\"iconName\" *ngIf=\"iconName\"\n [iconSize]=\"iconSize\" class=\"icon-{{iconPosition}}\">\n </gravity-icon>\n</div>", styles: [".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}.gravity-link-container{display:flex;cursor:pointer;width:-moz-fit-content;width:fit-content;align-items:center;justify-content:flex-start;gap:var(--gravity-spacing-xxs);padding:var(--gravity-spacing-xxs)}.gravity-link-container.right{flex-direction:row}.gravity-link-container.left{flex-direction:row-reverse}.gravity-link-container.pressed{border:1px solid var(--bg-link-hover-primary);--link-text-color: var(--bg-link-hover-primary)}.gravity-link-container.active{--link-text-color: var(--link-active-primary)}.gravity-link-container.visited{font-weight:650;--link-text-color: var(--link-visited-primary)}.gravity-link-container.disabled{cursor:
|
|
19
|
+
args: [{ selector: 'gravity-link', template: "<div class=\"gravity-link-container {{iconPosition}} {{state}}\">\n\n <a *ngIf=\"!link || !(link.startsWith('http') || link.startsWith('https'))\"\n [attr.data-cy]=\"cypressTag\" [routerLink]=\"!link || state === 'disabled' ? null : link\"\n class=\"{{ fontClass ? (fontClass !== '' ? fontClass : 'hr-body sm-regular') : 'hr-body sm-regular' }}\"> \n {{linkText}}\n </a>\n\n <a *ngIf=\"link && (link.startsWith('http') || link.startsWith('https'))\"\n [attr.data-cy]=\"cypressTag\" [href]=\"state === 'disabled' || link === '' ? null : link\" [target]=\"target\"\n class=\"{{ fontClass ? (fontClass !== '' ? fontClass : 'hr-body sm-regular') : 'hr-body sm-regular' }}\">\n {{linkText}}\n </a>\n\n <gravity-icon [style.--icon-color]=\"'var(--link-text-color)'\" [size]=\"'md'\"\n [hoverIcon]=\"false\" [iconName]=\"iconName\" *ngIf=\"iconName\"\n [iconSize]=\"iconSize\" class=\"icon-{{iconPosition}}\">\n </gravity-icon>\n</div>", styles: [".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}.gravity-link-container{display:flex;cursor:pointer;width:-moz-fit-content;width:fit-content;align-items:center;justify-content:flex-start;gap:var(--gravity-spacing-xxs);padding:var(--gravity-spacing-xxs)}.gravity-link-container.right{flex-direction:row}.gravity-link-container.left{flex-direction:row-reverse}.gravity-link-container.pressed{border:1px solid var(--bg-link-hover-primary);--link-text-color: var(--bg-link-hover-primary)}.gravity-link-container.active{--link-text-color: var(--link-active-primary)}.gravity-link-container.visited{font-weight:650;--link-text-color: var(--link-visited-primary)}.gravity-link-container.disabled{cursor:default;pointer-events:none;--link-text-color: var(--link-disabled-primary)}.gravity-link-container.disabled a{cursor:default;pointer-events:none}.gravity-link-container:hover:not(.disabled){background-color:var(--link-hover-primary);--link-text-color: var(--bg-link-hover-primary)}.gravity-link-container a{border:none;width:max-content;align-items:center;display:inline-flex;justify-content:center;text-decoration:underline;color:var(--link-text-color);gap:var(--gravity-spacing-xxs);border-radius:.0625rem}\n"] }]
|
|
20
20
|
}], propDecorators: { linkText: [{
|
|
21
21
|
type: Input
|
|
22
22
|
}], fontClass: [{
|