@progressio_resources/gravity-design-system 3.0.53 → 3.1.0
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 +86 -88
- package/esm2022/lib/components/gravity-calendar-next/components/day-calendar/range-days-calendar.utils.mjs +70 -0
- package/esm2022/lib/components/gravity-calendar-next/components/dual-month-calendar/dual-month-calendar.component.mjs +113 -0
- package/esm2022/lib/components/gravity-calendar-next/components/month-calendar/month-calendar.component.mjs +100 -0
- package/esm2022/lib/components/gravity-calendar-next/components/year-calendar/year-calendar.component.mjs +10 -6
- package/esm2022/lib/components/gravity-calendar-next/gravity-calendar-next.component.mjs +5 -4
- package/esm2022/lib/components/gravity-calendar-next/shared/calendar.constants.mjs +9 -7
- package/esm2022/lib/components/gravity-calendar-next/shared/calendar.modal.mjs +1 -1
- package/esm2022/lib/components/gravity-calendar-next/shared/calendar.utils.mjs +6 -29
- package/esm2022/lib/components/gravity-calendar-v2/gravity-calendar-v2.component.mjs +1 -1
- package/esm2022/lib/components/gravity-dropdown-label/gravity-dropdown-label.component.mjs +9 -4
- package/esm2022/lib/components/gravity-dropdown-list/gravity-dropdown-list.component.mjs +1 -1
- package/esm2022/lib/gravity-design-system.module.mjs +6 -3
- package/fesm2022/progressio_resources-gravity-design-system.mjs +420 -251
- 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 +35 -19
- package/lib/components/gravity-calendar-next/components/day-calendar/range-days-calendar.utils.d.ts +9 -0
- package/lib/components/gravity-calendar-next/components/dual-month-calendar/dual-month-calendar.component.d.ts +47 -0
- package/lib/components/gravity-calendar-next/components/month-calendar/month-calendar.component.d.ts +40 -0
- package/lib/components/gravity-calendar-next/components/year-calendar/year-calendar.component.d.ts +9 -5
- package/lib/components/gravity-calendar-next/shared/calendar.constants.d.ts +9 -3
- package/lib/components/gravity-calendar-next/shared/calendar.modal.d.ts +4 -4
- package/lib/components/gravity-calendar-next/shared/calendar.utils.d.ts +4 -11
- package/lib/components/gravity-dropdown-label/gravity-dropdown-label.component.d.ts +2 -1
- package/lib/gravity-design-system.module.d.ts +11 -10
- package/package.json +1 -1
- package/src/lib/styles/components/_datepicker-v2.scss +1 -1
- package/esm2022/lib/components/gravity-calendar-next/components/month-calendary/month-calendar.component.mjs +0 -88
- package/lib/components/gravity-calendar-next/components/month-calendary/month-calendar.component.d.ts +0 -34
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { getStartDate, toCalendarDay, toDate } from "../../shared/calendar.utils";
|
|
2
|
+
export function isPreview(component, day) {
|
|
3
|
+
if (!component.selectedRangeStart || component.selectedRangeEnd || !component.hoveredDay)
|
|
4
|
+
return false;
|
|
5
|
+
const current = toDate(day);
|
|
6
|
+
const hover = toDate(component.hoveredDay);
|
|
7
|
+
const start = toDate(component.selectedRangeStart);
|
|
8
|
+
if (hover <= start)
|
|
9
|
+
return false;
|
|
10
|
+
return current > start && current <= hover;
|
|
11
|
+
}
|
|
12
|
+
export function processPreselectedRangeDate(component) {
|
|
13
|
+
const [start, end] = component.preSelectedDate;
|
|
14
|
+
if (start instanceof Date) {
|
|
15
|
+
component.currentDate = getStartDate(start);
|
|
16
|
+
component.selectedRangeStart = toCalendarDay(start);
|
|
17
|
+
}
|
|
18
|
+
if (end instanceof Date) {
|
|
19
|
+
component.selectedRangeEnd = toCalendarDay(end);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
export function getRangeSelectionClass(component, day) {
|
|
23
|
+
if (!component.selectedRangeStart)
|
|
24
|
+
return 'nsl-start';
|
|
25
|
+
const current = toDate(day);
|
|
26
|
+
const start = toDate(component.selectedRangeStart);
|
|
27
|
+
if (!component.selectedRangeEnd) {
|
|
28
|
+
if (current.getTime() === start.getTime())
|
|
29
|
+
return 'sl start';
|
|
30
|
+
if (component.hoveredDay) {
|
|
31
|
+
const hover = toDate(component.hoveredDay);
|
|
32
|
+
if (current.getTime() === hover.getTime() && hover < start)
|
|
33
|
+
return 'nsl-start';
|
|
34
|
+
}
|
|
35
|
+
return 'nsl-end';
|
|
36
|
+
}
|
|
37
|
+
const end = toDate(component.selectedRangeEnd);
|
|
38
|
+
if (current.getTime() === start.getTime())
|
|
39
|
+
return 'sl start';
|
|
40
|
+
if (current.getTime() === end.getTime())
|
|
41
|
+
return 'sl end';
|
|
42
|
+
if (current > start && current < end)
|
|
43
|
+
return 'sl range';
|
|
44
|
+
return 'nsl-start';
|
|
45
|
+
}
|
|
46
|
+
export function onSelectRageDays(component, day) {
|
|
47
|
+
if (!component.selectedRangeStart || component.selectedRangeEnd) {
|
|
48
|
+
component.selectedRangeStart = day;
|
|
49
|
+
component.selectedRangeEnd = null;
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
const selectedDate = toDate(day);
|
|
53
|
+
const startDate = toDate(component.selectedRangeStart);
|
|
54
|
+
selectedDate >= startDate ? component.selectedRangeEnd = day : component.selectedRangeStart = day;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
export function onApplyRageDate(component) {
|
|
58
|
+
const start = toDate(component.selectedRangeStart);
|
|
59
|
+
const end = toDate(component.selectedRangeEnd);
|
|
60
|
+
component.calendarResponse.emit([start, end]);
|
|
61
|
+
}
|
|
62
|
+
export function onHoverDay(component, day) {
|
|
63
|
+
if (component.selectedRangeEnd)
|
|
64
|
+
return;
|
|
65
|
+
component.hoveredDay = day;
|
|
66
|
+
}
|
|
67
|
+
export function onClearHover(component) {
|
|
68
|
+
component.hoveredDay = null;
|
|
69
|
+
}
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZ2UtZGF5cy1jYWxlbmRhci51dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2dyYXZpdHktZGVzaWduLXN5c3RlbS9zcmMvbGliL2NvbXBvbmVudHMvZ3Jhdml0eS1jYWxlbmRhci1uZXh0L2NvbXBvbmVudHMvZGF5LWNhbGVuZGFyL3JhbmdlLWRheXMtY2FsZW5kYXIudXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFDLFlBQVksRUFBRSxhQUFhLEVBQUUsTUFBTSxFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFFaEYsTUFBTSxVQUFVLFNBQVMsQ0FBQyxTQUErQixFQUFFLEdBQWlCO0lBQ3hFLElBQUksQ0FBQyxTQUFTLENBQUMsa0JBQWtCLElBQUksU0FBUyxDQUFDLGdCQUFnQixJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVU7UUFBRSxPQUFPLEtBQUssQ0FBQztJQUV2RyxNQUFNLE9BQU8sR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDNUIsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUMzQyxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLGtCQUFrQixDQUFDLENBQUM7SUFFbkQsSUFBSSxLQUFLLElBQUksS0FBSztRQUFFLE9BQU8sS0FBSyxDQUFDO0lBQ2pDLE9BQU8sT0FBTyxHQUFHLEtBQUssSUFBSSxPQUFPLElBQUksS0FBSyxDQUFDO0FBQy9DLENBQUM7QUFFRCxNQUFNLFVBQVUsMkJBQTJCLENBQUMsU0FBK0I7SUFDdkUsTUFBTSxDQUFDLEtBQUssRUFBRSxHQUFHLENBQUMsR0FBRyxTQUFTLENBQUMsZUFBeUIsQ0FBQztJQUV6RCxJQUFJLEtBQUssWUFBWSxJQUFJLEVBQUU7UUFDdkIsU0FBUyxDQUFDLFdBQVcsR0FBRyxZQUFZLENBQUMsS0FBSyxDQUFDLENB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LFNBQStCO0lBQ3hELFNBQVMsQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDO0FBQ2hDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NhbGVuZGFyRGF0ZX0gZnJvbSBcIi4uLy4uL3NoYXJlZC9jYWxlbmRhci5tb2RhbFwiO1xuaW1wb3J0IHtEYXlDYWxlbmRhckNvbXBvbmVudH0gZnJvbSBcIi4vZGF5LWNhbGVuZGFyLmNvbXBvbmVudFwiO1xuaW1wb3J0IHtnZXRTdGFydERhdGUsIHRvQ2FsZW5kYXJEYXksIHRvRGF0ZX0gZnJvbSBcIi4uLy4uL3NoYXJlZC9jYWxlbmRhci51dGlsc1wiO1xuXG5leHBvcnQgZnVuY3Rpb24gaXNQcmV2aWV3KGNvbXBvbmVudDogRGF5Q2FsZW5kYXJDb21wb25lbnQsIGRheTogQ2FsZW5kYXJEYXRlKTogYm9vbGVhbiB7XG4gICAgaWYgKCFjb21wb25lbnQuc2VsZWN0ZWRSYW5nZVN0YXJ0IHx8IGNvbXBvbmVudC5zZWxlY3RlZFJhbmdlRW5kIHx8ICFjb21wb25lbnQuaG92ZXJlZERheSkgcmV0dXJuIGZhbHNlO1xuXG4gICAgY29uc3QgY3VycmVudCA9IHRvRGF0ZShkYXkpO1xuICAgIGNvbnN0IGhvdmVyID0gdG9EYXRlKGNvbXBvbmVudC5ob3ZlcmVkRGF5KTtcbiAgICBjb25zdCBzdGFydCA9IHRvRGF0ZShjb21wb25lbnQuc2VsZWN0ZWRSYW5nZVN0YXJ0KTtcblxuICAgIGlmIChob3ZlciA8PSBzdGFydCkgcmV0dXJuIGZhbHNlO1xuICAgIHJldHVybiBjdXJyZW50ID4gc3RhcnQgJiYgY3VycmVudCA8PSBob3Zlcjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHByb2Nlc3NQcmVzZWxlY3RlZFJhbmdlRGF0ZShjb21wb25lbnQ6IERheUNhbGVuZGFyQ29tcG9uZW50KSB7XG4gICAgY29uc3QgW3N0YXJ0LCBlbmRdID0gY29tcG9uZW50LnByZVNlbGVjdGVkRGF0ZSBhcyBEYXRlW107XG5cbiAgICBpZiAoc3RhcnQgaW5zdGFuY2VvZiBEYXRlKSB7XG4gICAgICAgIGNvbXBvbmVudC5jdXJyZW50RGF0ZSA9IGdldFN0YXJ0RGF0ZShzdGFydCk7XG4gICAgICAgIGNvbXBvbmVudC5zZWxlY3RlZFJhbmdlU3RhcnQgPSB0b0NhbGVuZGFyRGF5KHN0YXJ0KTtcbiAgICB9XG5cbiAgICBpZiAoZW5kIGluc3RhbmNlb2YgRGF0ZSkgeyBjb21wb25lbnQuc2VsZWN0ZWRSYW5nZUVuZCA9IHRvQ2FsZW5kYXJEYXkoZW5kKTsgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0UmFuZ2VTZWxlY3Rpb25DbGFzcyhjb21wb25lbnQ6IERheUNhbGVuZGFyQ29tcG9uZW50LCBkYXk6IENhbGVuZGFyRGF0ZSk6IHN0cmluZyB7XG4gICAgaWYgKCFjb21wb25lbnQuc2VsZWN0ZWRSYW5nZVN0YXJ0KSByZXR1cm4gJ25zbC1zdGFydCc7XG5cbiAgICBjb25zdCBjdXJyZW50ID0gdG9EYXRlKGRheSk7XG4gICAgY29uc3Qgc3RhcnQgPSB0b0RhdGUoY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VTdGFydCk7XG5cbiAgICBpZiAoIWNvbXBvbmVudC5zZWxlY3RlZFJhbmdlRW5kKSB7XG4gICAgICAgIGlmIChjdXJyZW50LmdldFRpbWUoKSA9PT0gc3RhcnQuZ2V0VGltZSgpKSByZXR1cm4gJ3NsIHN0YXJ0JztcblxuICAgICAgICBpZiAoY29tcG9uZW50LmhvdmVyZWREYXkpIHtcbiAgICAgICAgICAgIGNvbnN0IGhvdmVyID0gdG9EYXRlKGNvbXBvbmVudC5ob3ZlcmVkRGF5KTtcbiAgICAgICAgICAgIGlmIChjdXJyZW50LmdldFRpbWUoKSA9PT0gaG92ZXIuZ2V0VGltZSgpICYmIGhvdmVyIDwgc3RhcnQpIHJldHVybiAnbnNsLXN0YXJ0JztcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiAnbnNsLWVuZCc7XG4gICAgfVxuXG4gICAgY29uc3QgZW5kID0gdG9EYXRlKGNvbXBvbmVudC5zZWxlY3RlZFJhbmdlRW5kKTtcblxuICAgIGlmIChjdXJyZW50LmdldFRpbWUoKSA9PT0gc3RhcnQuZ2V0VGltZSgpKSByZXR1cm4gJ3NsIHN0YXJ0JztcbiAgICBpZiAoY3VycmVudC5nZXRUaW1lKCkgPT09IGVuZC5nZXRUaW1lKCkpIHJldHVybiAnc2wgZW5kJztcbiAgICBpZiAoY3VycmVudCA+IHN0YXJ0ICYmIGN1cnJlbnQgPCBlbmQpIHJldHVybiAnc2wgcmFuZ2UnO1xuXG4gICAgcmV0dXJuICduc2wtc3RhcnQnO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gb25TZWxlY3RSYWdlRGF5cyhjb21wb25lbnQ6IERheUNhbGVuZGFyQ29tcG9uZW50LCBkYXk6IENhbGVuZGFyRGF0ZSkge1xuICAgIGlmICghY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VTdGFydCB8fCBjb21wb25lbnQuc2VsZWN0ZWRSYW5nZUVuZCkge1xuICAgICAgICBjb21wb25lbnQuc2VsZWN0ZWRSYW5nZVN0YXJ0ID0gZGF5O1xuICAgICAgICBjb21wb25lbnQuc2VsZWN0ZWRSYW5nZUVuZCA9IG51bGw7XG4gICAgfSBlbHNlIHtcbiAgICAgICAgY29uc3Qgc2VsZWN0ZWREYXRlID0gdG9EYXRlKGRheSk7XG4gICAgICAgIGNvbnN0IHN0YXJ0RGF0ZSA9IHRvRGF0ZShjb21wb25lbnQuc2VsZWN0ZWRSYW5nZVN0YXJ0KTtcbiAgICAgICAgc2VsZWN0ZWREYXRlID49IHN0YXJ0RGF0ZSA/IGNvbXBvbmVudC5zZWxlY3RlZFJhbmdlRW5kID0gZGF5IDogY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VTdGFydCA9IGRheTtcbiAgICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBvbkFwcGx5UmFnZURhdGUoY29tcG9uZW50OiBEYXlDYWxlbmRhckNvbXBvbmVudCl7XG4gICAgY29uc3Qgc3RhcnQgPSB0b0RhdGUoY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VTdGFydCk7XG4gICAgY29uc3QgZW5kID10b0RhdGUoY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VFbmQpO1xuICAgIGNvbXBvbmVudC5jYWxlbmRhclJlc3BvbnNlLmVtaXQoW3N0YXJ0LCBlbmRdKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG9uSG92ZXJEYXkoY29tcG9uZW50OiBEYXlDYWxlbmRhckNvbXBvbmVudCwgZGF5OiBDYWxlbmRhckRhdGUpOiB2b2lkIHtcbiAgICBpZiAoY29tcG9uZW50LnNlbGVjdGVkUmFuZ2VFbmQpIHJldHVybjtcbiAgICBjb21wb25lbnQuaG92ZXJlZERheSA9IGRheTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG9uQ2xlYXJIb3Zlcihjb21wb25lbnQ6IERheUNhbGVuZGFyQ29tcG9uZW50KTogdm9pZCB7XG4gICAgY29tcG9uZW50LmhvdmVyZWREYXkgPSBudWxsO1xufVxuXG4iXX0=
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { changeDate, getStartDate, toCalendarDay } from "../../shared/calendar.utils";
|
|
2
|
+
import { onClearHover, onHoverDay, onSelectRageDays, } from "../day-calendar/range-days-calendar.utils";
|
|
3
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
4
|
+
import { CALENDAR_I18N, DAYS_EN, DAYS_ES, MONTHS_SHORT_EN, MONTHS_SHORT_ES } from "../../shared/calendar.constants";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "../../../gravity-icon/gravity-icon.component";
|
|
8
|
+
import * as i3 from "../day-calendar/day-calendar.component";
|
|
9
|
+
export class DualMonthCalendarComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.restart = false;
|
|
12
|
+
this.disabled = false;
|
|
13
|
+
this.language = 'en';
|
|
14
|
+
this.clearSelection = new EventEmitter();
|
|
15
|
+
this.calendarResponse = new EventEmitter();
|
|
16
|
+
this.currentDate = new Date();
|
|
17
|
+
this.showLeftCalendar = true;
|
|
18
|
+
this.showRightCalendar = true;
|
|
19
|
+
this.nextMonth = changeDate(1, this.currentDate, true);
|
|
20
|
+
this.Date = Date;
|
|
21
|
+
this.changeDate = changeDate;
|
|
22
|
+
this.onSelectRageDays = onSelectRageDays;
|
|
23
|
+
}
|
|
24
|
+
get i18n() { return CALENDAR_I18N[this.language]; }
|
|
25
|
+
get daysList() { return this.language === 'en' ? DAYS_EN : DAYS_ES; }
|
|
26
|
+
get monthsShortList() { return this.language === 'en' ? MONTHS_SHORT_EN : MONTHS_SHORT_ES; }
|
|
27
|
+
ngOnChanges(changes) {
|
|
28
|
+
const shouldRestart = changes['restart'] && this.restart;
|
|
29
|
+
const shouldProcessPreSelected = changes['preSelectedDate'] && this.preSelectedDate;
|
|
30
|
+
if (shouldRestart || shouldProcessPreSelected) {
|
|
31
|
+
this.processPreselectedDate();
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
processPreselectedDate() {
|
|
35
|
+
this.showLeftCalendar = true;
|
|
36
|
+
this.showRightCalendar = true;
|
|
37
|
+
if (Array.isArray(this.preSelectedDate)) {
|
|
38
|
+
const [start, end] = this.preSelectedDate;
|
|
39
|
+
if (start instanceof Date) {
|
|
40
|
+
this.currentDate = getStartDate(start);
|
|
41
|
+
this.nextMonth = changeDate(1, this.currentDate, true);
|
|
42
|
+
setTimeout(() => {
|
|
43
|
+
this.leftCalendar.selectedRangeStart = toCalendarDay(start);
|
|
44
|
+
this.rightCalendar.selectedRangeStart = toCalendarDay(start);
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
if (end instanceof Date) {
|
|
48
|
+
setTimeout(() => {
|
|
49
|
+
this.leftCalendar.selectedRangeEnd = toCalendarDay(end);
|
|
50
|
+
this.rightCalendar.selectedRangeEnd = toCalendarDay(end);
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
onChangeMonth(calendar, offset) {
|
|
56
|
+
const targetCalendar = calendar === 'left' ? this.rightCalendar : this.leftCalendar;
|
|
57
|
+
targetCalendar.currentDate = changeDate(offset, targetCalendar.currentDate, true);
|
|
58
|
+
}
|
|
59
|
+
getFormattedDate(day) {
|
|
60
|
+
return this.daysList[day.weekDay] + ', ' + day.day + ' ' + this.monthsShortList[day.monthYear.month];
|
|
61
|
+
}
|
|
62
|
+
handleHoverDay(day) {
|
|
63
|
+
onHoverDay(this.leftCalendar, day);
|
|
64
|
+
}
|
|
65
|
+
handleClearHover() {
|
|
66
|
+
onClearHover(this.leftCalendar);
|
|
67
|
+
}
|
|
68
|
+
handleApplyResponse($event) {
|
|
69
|
+
this.calendarResponse.emit($event);
|
|
70
|
+
}
|
|
71
|
+
handleClearSelection() {
|
|
72
|
+
this.clearSelection.emit();
|
|
73
|
+
this.leftCalendar.clearSelectedDate();
|
|
74
|
+
}
|
|
75
|
+
handlerChangeMonthYearResponse($event, origin) {
|
|
76
|
+
if ($event instanceof Date) {
|
|
77
|
+
if (origin === 'left') {
|
|
78
|
+
this.showRightCalendar = true;
|
|
79
|
+
setTimeout(() => { this.rightCalendar.currentDate = changeDate(1, $event, true); });
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
this.showLeftCalendar = true;
|
|
83
|
+
setTimeout(() => { this.leftCalendar.currentDate = changeDate(-1, $event, true); });
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DualMonthCalendarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
88
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DualMonthCalendarComponent, selector: "dual-month-calendar", inputs: { restart: "restart", disabled: "disabled", language: "language", preSelectedDate: "preSelectedDate" }, 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\">\n\n <day-calendar #leftCalendar *ngIf=\"showLeftCalendar\" [range]=\"true\" [language]=\"language\" [disabled]=\"disabled\"\n [navType]=\"'prev'\" [actionsSection]=\"false\" [currentDate]=\"currentDate\"\n (changeMonthYearResponse)=\"handlerChangeMonthYearResponse($event, 'left')\"\n (selectedRage)=\"onSelectRageDays(rightCalendar, $event)\"\n (changeMonth)=\"onChangeMonth('left', $event)\"\n (openIntegratedCalendar)=\"showRightCalendar = false\"> </day-calendar>\n\n <day-calendar #rightCalendar *ngIf=\"showRightCalendar\" [range]=\"true\" [language]=\"language\" [disabled]=\"disabled\"\n [navType]=\"'next'\" [actionsSection]=\"true\" [currentDate]=\"nextMonth\"\n (changeMonthYearResponse)=\"handlerChangeMonthYearResponse($event, 'right')\"\n (selectedRage)=\"onSelectRageDays(leftCalendar, $event)\"\n (changeMonth)=\"onChangeMonth('right', $event)\"\n (openIntegratedCalendar)=\"showLeftCalendar = false\"\n (clearSelection)=\"handleClearSelection()\"\n (response)=\"handleApplyResponse($event)\"\n (hoverDay)=\"handleHoverDay($event)\"\n (clearHover)=\"handleClearHover()\"> </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:center;gap:var(--gravity-spacing-xs);color:var(--bg-calendar-nav-primary)}.dual-calendar-container{display:flex;align-items:center;align-self:stretch;justify-content:center;gap:var(--gravity-spacing-md)}\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: ["preSelectedYear", "preSelectedMonth", "range", "restart", "disabled", "language", "preSelectedDate", "actionsSection", "currentDate", "navType"], outputs: ["clearHover", "clearSelection", "changeMonth", "hoverDay", "openIntegratedCalendar", "selectedRage", "changeMonthYearResponse", "response"] }] }); }
|
|
89
|
+
}
|
|
90
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DualMonthCalendarComponent, decorators: [{
|
|
91
|
+
type: Component,
|
|
92
|
+
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\">\n\n <day-calendar #leftCalendar *ngIf=\"showLeftCalendar\" [range]=\"true\" [language]=\"language\" [disabled]=\"disabled\"\n [navType]=\"'prev'\" [actionsSection]=\"false\" [currentDate]=\"currentDate\"\n (changeMonthYearResponse)=\"handlerChangeMonthYearResponse($event, 'left')\"\n (selectedRage)=\"onSelectRageDays(rightCalendar, $event)\"\n (changeMonth)=\"onChangeMonth('left', $event)\"\n (openIntegratedCalendar)=\"showRightCalendar = false\"> </day-calendar>\n\n <day-calendar #rightCalendar *ngIf=\"showRightCalendar\" [range]=\"true\" [language]=\"language\" [disabled]=\"disabled\"\n [navType]=\"'next'\" [actionsSection]=\"true\" [currentDate]=\"nextMonth\"\n (changeMonthYearResponse)=\"handlerChangeMonthYearResponse($event, 'right')\"\n (selectedRage)=\"onSelectRageDays(leftCalendar, $event)\"\n (changeMonth)=\"onChangeMonth('right', $event)\"\n (openIntegratedCalendar)=\"showLeftCalendar = false\"\n (clearSelection)=\"handleClearSelection()\"\n (response)=\"handleApplyResponse($event)\"\n (hoverDay)=\"handleHoverDay($event)\"\n (clearHover)=\"handleClearHover()\"> </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:center;gap:var(--gravity-spacing-xs);color:var(--bg-calendar-nav-primary)}.dual-calendar-container{display:flex;align-items:center;align-self:stretch;justify-content:center;gap:var(--gravity-spacing-md)}\n"] }]
|
|
93
|
+
}], propDecorators: { restart: [{
|
|
94
|
+
type: Input
|
|
95
|
+
}], disabled: [{
|
|
96
|
+
type: Input
|
|
97
|
+
}], language: [{
|
|
98
|
+
type: Input
|
|
99
|
+
}], preSelectedDate: [{
|
|
100
|
+
type: Input
|
|
101
|
+
}], clearSelection: [{
|
|
102
|
+
type: Output
|
|
103
|
+
}], calendarResponse: [{
|
|
104
|
+
type: Output,
|
|
105
|
+
args: ['response']
|
|
106
|
+
}], leftCalendar: [{
|
|
107
|
+
type: ViewChild,
|
|
108
|
+
args: ['leftCalendar']
|
|
109
|
+
}], rightCalendar: [{
|
|
110
|
+
type: ViewChild,
|
|
111
|
+
args: ['rightCalendar']
|
|
112
|
+
}] } });
|
|
113
|
+
//# 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 {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 restart: boolean = false;\n  @Input() public disabled: boolean = false;\n  @Input() public language: 'es' | 'en' = 'en';\n  @Input() public preSelectedDate: Date | Date[];\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.language]; }\n  public get daysList() { return this.language === 'en' ? DAYS_EN : DAYS_ES; }\n  public get monthsShortList() { return this.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.preSelectedDate;\n    if (shouldRestart || shouldProcessPreSelected) { this.processPreselectedDate(); }\n  }\n\n  private processPreselectedDate(): void {\n    this.showLeftCalendar = true;\n    this.showRightCalendar = true;\n\n    if (Array.isArray(this.preSelectedDate)) {\n      const [start, end] = this.preSelectedDate 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\">\n\n    <day-calendar #leftCalendar *ngIf=\"showLeftCalendar\" [range]=\"true\" [language]=\"language\" [disabled]=\"disabled\"\n                  [navType]=\"'prev'\" [actionsSection]=\"false\" [currentDate]=\"currentDate\"\n                  (changeMonthYearResponse)=\"handlerChangeMonthYearResponse($event, 'left')\"\n                  (selectedRage)=\"onSelectRageDays(rightCalendar, $event)\"\n                  (changeMonth)=\"onChangeMonth('left', $event)\"\n                  (openIntegratedCalendar)=\"showRightCalendar = false\"> </day-calendar>\n\n    <day-calendar #rightCalendar *ngIf=\"showRightCalendar\" [range]=\"true\" [language]=\"language\" [disabled]=\"disabled\"\n                  [navType]=\"'next'\" [actionsSection]=\"true\" [currentDate]=\"nextMonth\"\n                  (changeMonthYearResponse)=\"handlerChangeMonthYearResponse($event, 'right')\"\n                  (selectedRage)=\"onSelectRageDays(leftCalendar, $event)\"\n                  (changeMonth)=\"onChangeMonth('right', $event)\"\n                  (openIntegratedCalendar)=\"showLeftCalendar = false\"\n                  (clearSelection)=\"handleClearSelection()\"\n                  (response)=\"handleApplyResponse($event)\"\n                  (hoverDay)=\"handleHoverDay($event)\"\n                  (clearHover)=\"handleClearHover()\"> </day-calendar>\n</div>"]}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import { changeDate, getStartDate } from "../../shared/calendar.utils";
|
|
2
|
+
import { Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
3
|
+
import { CALENDAR_I18N, MONTHS_EN, MONTHS_SHORT_EN, MONTHS_ES, MONTHS_SHORT_ES } from "../../shared/calendar.constants";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "../../../gravity-button/gravity-button.component";
|
|
7
|
+
import * as i3 from "../../../gravity-icon/gravity-icon.component";
|
|
8
|
+
import * as i4 from "../../../gravity-link/gravity-link.component";
|
|
9
|
+
import * as i5 from "../../../gravity-dropdown-label/gravity-dropdown-label.component";
|
|
10
|
+
export class MonthCalendarComponent {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.restart = false;
|
|
13
|
+
this.disabled = false;
|
|
14
|
+
this.language = 'en';
|
|
15
|
+
this.actionsSection = true;
|
|
16
|
+
this.integratedMode = false;
|
|
17
|
+
this.clearSelection = new EventEmitter();
|
|
18
|
+
this.calendarResponse = new EventEmitter();
|
|
19
|
+
this.currentDate = new Date();
|
|
20
|
+
this.changeDate = changeDate;
|
|
21
|
+
}
|
|
22
|
+
get i18n() { return CALENDAR_I18N[this.language]; }
|
|
23
|
+
get monthsList() { return this.language === 'en' ? MONTHS_EN : MONTHS_ES; }
|
|
24
|
+
get monthsShortList() { return this.language === 'en' ? MONTHS_SHORT_EN : MONTHS_SHORT_ES; }
|
|
25
|
+
ngOnChanges(changes) {
|
|
26
|
+
const shouldRestart = changes['restart'] && this.restart;
|
|
27
|
+
const shouldProcessPreSelected = changes['preSelectedDate'] && this.preSelectedDate;
|
|
28
|
+
if (shouldRestart || shouldProcessPreSelected) {
|
|
29
|
+
this.processPreselectedDate();
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
trackByMonth(_, month) {
|
|
33
|
+
return `${month.year}-${month.month}`;
|
|
34
|
+
}
|
|
35
|
+
processPreselectedDate() {
|
|
36
|
+
if (this.preSelectedDate instanceof Date) {
|
|
37
|
+
this.currentDate = getStartDate(this.preSelectedDate);
|
|
38
|
+
this.selectedMonth = {
|
|
39
|
+
month: this.preSelectedDate.getMonth(),
|
|
40
|
+
year: this.preSelectedDate.getFullYear()
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
onSelectMonth(month) {
|
|
45
|
+
this.selectedMonth = month;
|
|
46
|
+
this.currentDate = new Date(month.year, month.month, 1);
|
|
47
|
+
this.calendarResponse.emit(this.currentDate);
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
getMonthSelectionClass(month) {
|
|
51
|
+
if (this.selectedMonth && this.selectedMonth.month === month.month &&
|
|
52
|
+
this.selectedMonth.year === month.year) {
|
|
53
|
+
return 'selected';
|
|
54
|
+
}
|
|
55
|
+
if (new Date().getMonth() === month.month &&
|
|
56
|
+
new Date().getFullYear() === month.year) {
|
|
57
|
+
return 'current';
|
|
58
|
+
}
|
|
59
|
+
return '';
|
|
60
|
+
}
|
|
61
|
+
clearSelectedMonth() {
|
|
62
|
+
this.selectedMonth = null;
|
|
63
|
+
this.clearSelection.emit();
|
|
64
|
+
}
|
|
65
|
+
applySelectedMonth() {
|
|
66
|
+
const date = new Date(this.selectedMonth.year, this.selectedMonth.month);
|
|
67
|
+
this.calendarResponse.emit(date);
|
|
68
|
+
}
|
|
69
|
+
getYearMonthsList() {
|
|
70
|
+
const months = [];
|
|
71
|
+
for (let i = 0; i < 12; i++) {
|
|
72
|
+
months.push({ month: i, year: this.currentDate.getFullYear() });
|
|
73
|
+
}
|
|
74
|
+
return months;
|
|
75
|
+
}
|
|
76
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MonthCalendarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
77
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MonthCalendarComponent, selector: "month-calendar", inputs: { restart: "restart", disabled: "disabled", language: "language", preSelectedDate: "preSelectedDate", actionsSection: "actionsSection", integratedMode: "integratedMode" }, outputs: { clearSelection: "clearSelection", calendarResponse: "response" }, usesOnChanges: true, ngImport: i0, template: "<section class=\"gravity-calendar-header\">\n <div class=\"header-container\">\n <div *ngIf=\"!integratedMode\" class=\"previous-button\" (click)=\"currentDate = changeDate(-1, currentDate, false)\">\n <gravity-icon [style.--icon-color]=\"'var(--text-highlight-primary)'\" [iconName]=\"'arrow-left'\" [iconSize]=\"'sm-12'\" > </gravity-icon>\n </div>\n\n <div class=\"year-label\">\n <gravity-dropdown-label [state]=\"integratedMode ? 'active' : 'inactive'\" [fontClass]=\"'hr-title sm-bold'\" [size]=\"'sm'\"\n [label]=\"integratedMode ? monthsList[currentDate.getMonth()] : currentDate.getFullYear().toString()\"\n [isOpen]=\"integratedMode\" (onClickLabel)=\"calendarResponse.emit(currentDate)\" > </gravity-dropdown-label>\n </div>\n\n <div *ngIf=\"!integratedMode\" class=\"next-button\" (click)=\"currentDate = changeDate(1, currentDate, false)\">\n <gravity-icon [style.--icon-color]=\"'var(--text-highlight-primary)'\" [iconName]=\"'arrow-right'\" [iconSize]=\"'sm-12'\"> </gravity-icon>\n </div>\n </div>\n\n <div class=\"separator-line\"></div>\n</section>\n\n<section class=\"gravity-calendar-body\">\n <div class=\"items-table\">\n <span class=\"hr-body sm-regular item\" *ngFor=\"let month of getYearMonthsList(), trackBy: trackByMonth\"\n [ngClass]=\"disabled ? 'disabled' : getMonthSelectionClass(month)\" (click)=\"onSelectMonth(month)\">\n {{ monthsShortList[month.month] }} </span>\n </div>\n\n <div *ngIf=\"actionsSection\" class=\"action-section\" >\n <gravity-link [linkText]=\"i18n.clear\" [state]=\"!selectedMonth ? 'disabled' : 'active'\" (click)=\"clearSelectedMonth()\"></gravity-link>\n <gravity-button [size]=\"'sm'\" [type]=\"'tertiary'\" [disabled]=\"!selectedMonth\" (click)=\"applySelectedMonth()\">{{i18n.apply}}</gravity-button>\n </div>\n</section>", styles: [":root{--gravity-spacing-none: 0;--gravity-spacing-xxs: .25rem;--gravity-spacing-xs: .5rem;--gravity-spacing-sm: 1rem;--gravity-spacing-md: 1.5rem;--gravity-spacing-lg: 2rem;--gravity-spacing-xl: 2.5rem;--gravity-spacing-xxl: 3rem;--gravity-spacing-xxxl: 4rem;--gravity-spacing-xxxxl: 6rem;--gravity-spacing-xxxxxl: 12rem}.gravity-padding-none{padding:0!important}.gravity-padding-top-none{padding-top:0!important}.gravity-padding-bottom-none{padding-bottom:0!important}.gravity-padding-left-none{padding-left:0!important}.gravity-padding-right-none{padding-right:0!important}.gravity-padding-block-none{padding-block:0!important}.gravity-padding-inline-none{padding-inline:0!important}.gravity-padding-xxs{padding:.25rem!important}.gravity-padding-top-xxs{padding-top:.25rem!important}.gravity-padding-bottom-xxs{padding-bottom:.25rem!important}.gravity-padding-left-xxs{padding-left:.25rem!important}.gravity-padding-right-xxs{padding-right:.25rem!important}.gravity-padding-block-xxs{padding-block:.25rem!important}.gravity-padding-inline-xxs{padding-inline:.25rem!important}.gravity-padding-xs{padding:.5rem!important}.gravity-padding-top-xs{padding-top:.5rem!important}.gravity-padding-bottom-xs{padding-bottom:.5rem!important}.gravity-padding-left-xs{padding-left:.5rem!important}.gravity-padding-right-xs{padding-right:.5rem!important}.gravity-padding-block-xs{padding-block:.5rem!important}.gravity-padding-inline-xs{padding-inline:.5rem!important}.gravity-padding-sm{padding:1rem!important}.gravity-padding-top-sm{padding-top:1rem!important}.gravity-padding-bottom-sm{padding-bottom:1rem!important}.gravity-padding-left-sm{padding-left:1rem!important}.gravity-padding-right-sm{padding-right:1rem!important}.gravity-padding-block-sm{padding-block:1rem!important}.gravity-padding-inline-sm{padding-inline:1rem!important}.gravity-padding-md{padding:1.5rem!important}.gravity-padding-top-md{padding-top:1.5rem!important}.gravity-padding-bottom-md{padding-bottom:1.5rem!important}.gravity-padding-left-md{padding-left:1.5rem!important}.gravity-padding-right-md{padding-right:1.5rem!important}.gravity-padding-block-md{padding-block:1.5rem!important}.gravity-padding-inline-md{padding-inline:1.5rem!important}.gravity-padding-lg{padding:2rem!important}.gravity-padding-top-lg{padding-top:2rem!important}.gravity-padding-bottom-lg{padding-bottom:2rem!important}.gravity-padding-left-lg{padding-left:2rem!important}.gravity-padding-right-lg{padding-right:2rem!important}.gravity-padding-block-lg{padding-block:2rem!important}.gravity-padding-inline-lg{padding-inline:2rem!important}.gravity-padding-xl{padding:2.5rem!important}.gravity-padding-top-xl{padding-top:2.5rem!important}.gravity-padding-bottom-xl{padding-bottom:2.5rem!important}.gravity-padding-left-xl{padding-left:2.5rem!important}.gravity-padding-right-xl{padding-right:2.5rem!important}.gravity-padding-block-xl{padding-block:2.5rem!important}.gravity-padding-inline-xl{padding-inline:2.5rem!important}.gravity-padding-xxl{padding:3rem!important}.gravity-padding-top-xxl{padding-top:3rem!important}.gravity-padding-bottom-xxl{padding-bottom:3rem!important}.gravity-padding-left-xxl{padding-left:3rem!important}.gravity-padding-right-xxl{padding-right:3rem!important}.gravity-padding-block-xxl{padding-block:3rem!important}.gravity-padding-inline-xxl{padding-inline:3rem!important}.gravity-padding-xxxl{padding:4rem!important}.gravity-padding-top-xxxl{padding-top:4rem!important}.gravity-padding-bottom-xxxl{padding-bottom:4rem!important}.gravity-padding-left-xxxl{padding-left:4rem!important}.gravity-padding-right-xxxl{padding-right:4rem!important}.gravity-padding-block-xxxl{padding-block:4rem!important}.gravity-padding-inline-xxxl{padding-inline:4rem!important}.gravity-padding-xxxxl{padding:6rem!important}.gravity-padding-top-xxxxl{padding-top:6rem!important}.gravity-padding-bottom-xxxxl{padding-bottom:6rem!important}.gravity-padding-left-xxxxl{padding-left:6rem!important}.gravity-padding-right-xxxxl{padding-right:6rem!important}.gravity-padding-block-xxxxl{padding-block:6rem!important}.gravity-padding-inline-xxxxl{padding-inline:6rem!important}.gravity-padding-xxxxxl{padding:12rem!important}.gravity-padding-top-xxxxxl{padding-top:12rem!important}.gravity-padding-bottom-xxxxxl{padding-bottom:12rem!important}.gravity-padding-left-xxxxxl{padding-left:12rem!important}.gravity-padding-right-xxxxxl{padding-right:12rem!important}.gravity-padding-block-xxxxxl{padding-block:12rem!important}.gravity-padding-inline-xxxxxl{padding-inline:12rem!important}.gravity-margin-none{margin:0!important}.gravity-margin-top-none{margin-top:0!important}.gravity-margin-bottom-none{margin-bottom:0!important}.gravity-margin-left-none{margin-left:0!important}.gravity-margin-right-none{margin-right:0!important}.gravity-margin-block-none{margin-block:0!important}.gravity-margin-inline-none{margin-inline:0!important}.gravity-margin-xxs{margin:.25rem!important}.gravity-margin-top-xxs{margin-top:.25rem!important}.gravity-margin-bottom-xxs{margin-bottom:.25rem!important}.gravity-margin-left-xxs{margin-left:.25rem!important}.gravity-margin-right-xxs{margin-right:.25rem!important}.gravity-margin-block-xxs{margin-block:.25rem!important}.gravity-margin-inline-xxs{margin-inline:.25rem!important}.gravity-margin-xs{margin:.5rem!important}.gravity-margin-top-xs{margin-top:.5rem!important}.gravity-margin-bottom-xs{margin-bottom:.5rem!important}.gravity-margin-left-xs{margin-left:.5rem!important}.gravity-margin-right-xs{margin-right:.5rem!important}.gravity-margin-block-xs{margin-block:.5rem!important}.gravity-margin-inline-xs{margin-inline:.5rem!important}.gravity-margin-sm{margin:1rem!important}.gravity-margin-top-sm{margin-top:1rem!important}.gravity-margin-bottom-sm{margin-bottom:1rem!important}.gravity-margin-left-sm{margin-left:1rem!important}.gravity-margin-right-sm{margin-right:1rem!important}.gravity-margin-block-sm{margin-block:1rem!important}.gravity-margin-inline-sm{margin-inline:1rem!important}.gravity-margin-md{margin:1.5rem!important}.gravity-margin-top-md{margin-top:1.5rem!important}.gravity-margin-bottom-md{margin-bottom:1.5rem!important}.gravity-margin-left-md{margin-left:1.5rem!important}.gravity-margin-right-md{margin-right:1.5rem!important}.gravity-margin-block-md{margin-block:1.5rem!important}.gravity-margin-inline-md{margin-inline:1.5rem!important}.gravity-margin-lg{margin:2rem!important}.gravity-margin-top-lg{margin-top:2rem!important}.gravity-margin-bottom-lg{margin-bottom:2rem!important}.gravity-margin-left-lg{margin-left:2rem!important}.gravity-margin-right-lg{margin-right:2rem!important}.gravity-margin-block-lg{margin-block:2rem!important}.gravity-margin-inline-lg{margin-inline:2rem!important}.gravity-margin-xl{margin:2.5rem!important}.gravity-margin-top-xl{margin-top:2.5rem!important}.gravity-margin-bottom-xl{margin-bottom:2.5rem!important}.gravity-margin-left-xl{margin-left:2.5rem!important}.gravity-margin-right-xl{margin-right:2.5rem!important}.gravity-margin-block-xl{margin-block:2.5rem!important}.gravity-margin-inline-xl{margin-inline:2.5rem!important}.gravity-margin-xxl{margin:3rem!important}.gravity-margin-top-xxl{margin-top:3rem!important}.gravity-margin-bottom-xxl{margin-bottom:3rem!important}.gravity-margin-left-xxl{margin-left:3rem!important}.gravity-margin-right-xxl{margin-right:3rem!important}.gravity-margin-block-xxl{margin-block:3rem!important}.gravity-margin-inline-xxl{margin-inline:3rem!important}.gravity-margin-xxxl{margin:4rem!important}.gravity-margin-top-xxxl{margin-top:4rem!important}.gravity-margin-bottom-xxxl{margin-bottom:4rem!important}.gravity-margin-left-xxxl{margin-left:4rem!important}.gravity-margin-right-xxxl{margin-right:4rem!important}.gravity-margin-block-xxxl{margin-block:4rem!important}.gravity-margin-inline-xxxl{margin-inline:4rem!important}.gravity-margin-xxxxl{margin:6rem!important}.gravity-margin-top-xxxxl{margin-top:6rem!important}.gravity-margin-bottom-xxxxl{margin-bottom:6rem!important}.gravity-margin-left-xxxxl{margin-left:6rem!important}.gravity-margin-right-xxxxl{margin-right:6rem!important}.gravity-margin-block-xxxxl{margin-block:6rem!important}.gravity-margin-inline-xxxxl{margin-inline:6rem!important}.gravity-margin-xxxxxl{margin:12rem!important}.gravity-margin-top-xxxxxl{margin-top:12rem!important}.gravity-margin-bottom-xxxxxl{margin-bottom:12rem!important}.gravity-margin-left-xxxxxl{margin-left:12rem!important}.gravity-margin-right-xxxxxl{margin-right:12rem!important}.gravity-margin-block-xxxxxl{margin-block:12rem!important}.gravity-margin-inline-xxxxxl{margin-inline:12rem!important}.border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.next-button,.previous-button{cursor:pointer;padding:var(--gravity-spacing-xs);border-radius:var(--gravity-spacing-xs)}.next-button:hover,.previous-button:hover{background:var(--bg-button-active-tertiary)}.separator-line{border-bottom:2px solid var(--divider-menu-active-primary)}.action-section{height:25px;display:flex;align-items:center;align-self:stretch;justify-content:space-between}.gravity-calendar-header{width:215px;height:40px;display:flex;align-self:stretch;align-items:center;flex-direction:column;justify-content:center;gap:var(--gravity-spacing-sm);padding-top:var(--gravity-spacing-xs)}.gravity-calendar-header .header-container{display:flex;align-items:center;align-self:stretch;justify-content:space-between;padding:0 var(--gravity-spacing-xs)}.gravity-calendar-header .separator-line{width:215px}.gravity-calendar-body{width:215px;display:flex;align-items:center;align-self:stretch;flex-direction:column;justify-content:center;gap:var(--gravity-spacing-sm);margin-top:var(--gravity-spacing-sm)}.gravity-calendar-body .items-table{display:flex;flex-wrap:wrap;justify-content:space-between;gap:0 var(--gravity-spacing-sm)}.gravity-calendar-body .items-table .item{width:37px;height:25px;display:flex;cursor:pointer;align-items:center;justify-content:center;border-radius:var(--gravity-spacing-xs);color:var(--on-bg-button-pressed-tertiary);border:2px solid var(--bg-calender-primary)}.gravity-calendar-body .items-table .item.current{border-color:var(--bg-number-calendar-hover-primary)}.gravity-calendar-body .items-table .item:not(.disabled):not(.selected):hover{color:var(--on-bg-button-pressed-tertiary);background:var(--bg-button-active-tertiary);border-color:var(--bg-button-active-tertiary)}.gravity-calendar-body .items-table .item.selected{color:var(--on-bg-button-pressed-primary);background:var(--bg-button-pressed-primary);border-color:var(--bg-button-pressed-primary)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.GravityButtonComponent, selector: "gravity-button", inputs: ["cypressTag", "disabled", "customState", "iconPosition", "iconName", "isLoading", "showContent", "size", "type"] }, { kind: "component", type: i3.GravityIconComponent, selector: "gravity-icon", inputs: ["customIconColorVariable", "iconName", "iconSize", "hoverIcon", "size", "isCoin"] }, { kind: "component", type: i4.GravityLinkComponent, selector: "gravity-link", inputs: ["linkText", "fontClass", "link", "cypressTag", "iconName", "target", "iconPosition", "iconSize", "state"] }, { kind: "component", type: i5.GravityDropdownLabelComponent, selector: "gravity-dropdown-label", inputs: ["label", "fontClass", "isOpen", "stopPropagation", "size", "state"], outputs: ["onClickLabel"] }] }); }
|
|
78
|
+
}
|
|
79
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MonthCalendarComponent, decorators: [{
|
|
80
|
+
type: Component,
|
|
81
|
+
args: [{ selector: 'month-calendar', template: "<section class=\"gravity-calendar-header\">\n <div class=\"header-container\">\n <div *ngIf=\"!integratedMode\" class=\"previous-button\" (click)=\"currentDate = changeDate(-1, currentDate, false)\">\n <gravity-icon [style.--icon-color]=\"'var(--text-highlight-primary)'\" [iconName]=\"'arrow-left'\" [iconSize]=\"'sm-12'\" > </gravity-icon>\n </div>\n\n <div class=\"year-label\">\n <gravity-dropdown-label [state]=\"integratedMode ? 'active' : 'inactive'\" [fontClass]=\"'hr-title sm-bold'\" [size]=\"'sm'\"\n [label]=\"integratedMode ? monthsList[currentDate.getMonth()] : currentDate.getFullYear().toString()\"\n [isOpen]=\"integratedMode\" (onClickLabel)=\"calendarResponse.emit(currentDate)\" > </gravity-dropdown-label>\n </div>\n\n <div *ngIf=\"!integratedMode\" class=\"next-button\" (click)=\"currentDate = changeDate(1, currentDate, false)\">\n <gravity-icon [style.--icon-color]=\"'var(--text-highlight-primary)'\" [iconName]=\"'arrow-right'\" [iconSize]=\"'sm-12'\"> </gravity-icon>\n </div>\n </div>\n\n <div class=\"separator-line\"></div>\n</section>\n\n<section class=\"gravity-calendar-body\">\n <div class=\"items-table\">\n <span class=\"hr-body sm-regular item\" *ngFor=\"let month of getYearMonthsList(), trackBy: trackByMonth\"\n [ngClass]=\"disabled ? 'disabled' : getMonthSelectionClass(month)\" (click)=\"onSelectMonth(month)\">\n {{ monthsShortList[month.month] }} </span>\n </div>\n\n <div *ngIf=\"actionsSection\" class=\"action-section\" >\n <gravity-link [linkText]=\"i18n.clear\" [state]=\"!selectedMonth ? 'disabled' : 'active'\" (click)=\"clearSelectedMonth()\"></gravity-link>\n <gravity-button [size]=\"'sm'\" [type]=\"'tertiary'\" [disabled]=\"!selectedMonth\" (click)=\"applySelectedMonth()\">{{i18n.apply}}</gravity-button>\n </div>\n</section>", styles: [":root{--gravity-spacing-none: 0;--gravity-spacing-xxs: .25rem;--gravity-spacing-xs: .5rem;--gravity-spacing-sm: 1rem;--gravity-spacing-md: 1.5rem;--gravity-spacing-lg: 2rem;--gravity-spacing-xl: 2.5rem;--gravity-spacing-xxl: 3rem;--gravity-spacing-xxxl: 4rem;--gravity-spacing-xxxxl: 6rem;--gravity-spacing-xxxxxl: 12rem}.gravity-padding-none{padding:0!important}.gravity-padding-top-none{padding-top:0!important}.gravity-padding-bottom-none{padding-bottom:0!important}.gravity-padding-left-none{padding-left:0!important}.gravity-padding-right-none{padding-right:0!important}.gravity-padding-block-none{padding-block:0!important}.gravity-padding-inline-none{padding-inline:0!important}.gravity-padding-xxs{padding:.25rem!important}.gravity-padding-top-xxs{padding-top:.25rem!important}.gravity-padding-bottom-xxs{padding-bottom:.25rem!important}.gravity-padding-left-xxs{padding-left:.25rem!important}.gravity-padding-right-xxs{padding-right:.25rem!important}.gravity-padding-block-xxs{padding-block:.25rem!important}.gravity-padding-inline-xxs{padding-inline:.25rem!important}.gravity-padding-xs{padding:.5rem!important}.gravity-padding-top-xs{padding-top:.5rem!important}.gravity-padding-bottom-xs{padding-bottom:.5rem!important}.gravity-padding-left-xs{padding-left:.5rem!important}.gravity-padding-right-xs{padding-right:.5rem!important}.gravity-padding-block-xs{padding-block:.5rem!important}.gravity-padding-inline-xs{padding-inline:.5rem!important}.gravity-padding-sm{padding:1rem!important}.gravity-padding-top-sm{padding-top:1rem!important}.gravity-padding-bottom-sm{padding-bottom:1rem!important}.gravity-padding-left-sm{padding-left:1rem!important}.gravity-padding-right-sm{padding-right:1rem!important}.gravity-padding-block-sm{padding-block:1rem!important}.gravity-padding-inline-sm{padding-inline:1rem!important}.gravity-padding-md{padding:1.5rem!important}.gravity-padding-top-md{padding-top:1.5rem!important}.gravity-padding-bottom-md{padding-bottom:1.5rem!important}.gravity-padding-left-md{padding-left:1.5rem!important}.gravity-padding-right-md{padding-right:1.5rem!important}.gravity-padding-block-md{padding-block:1.5rem!important}.gravity-padding-inline-md{padding-inline:1.5rem!important}.gravity-padding-lg{padding:2rem!important}.gravity-padding-top-lg{padding-top:2rem!important}.gravity-padding-bottom-lg{padding-bottom:2rem!important}.gravity-padding-left-lg{padding-left:2rem!important}.gravity-padding-right-lg{padding-right:2rem!important}.gravity-padding-block-lg{padding-block:2rem!important}.gravity-padding-inline-lg{padding-inline:2rem!important}.gravity-padding-xl{padding:2.5rem!important}.gravity-padding-top-xl{padding-top:2.5rem!important}.gravity-padding-bottom-xl{padding-bottom:2.5rem!important}.gravity-padding-left-xl{padding-left:2.5rem!important}.gravity-padding-right-xl{padding-right:2.5rem!important}.gravity-padding-block-xl{padding-block:2.5rem!important}.gravity-padding-inline-xl{padding-inline:2.5rem!important}.gravity-padding-xxl{padding:3rem!important}.gravity-padding-top-xxl{padding-top:3rem!important}.gravity-padding-bottom-xxl{padding-bottom:3rem!important}.gravity-padding-left-xxl{padding-left:3rem!important}.gravity-padding-right-xxl{padding-right:3rem!important}.gravity-padding-block-xxl{padding-block:3rem!important}.gravity-padding-inline-xxl{padding-inline:3rem!important}.gravity-padding-xxxl{padding:4rem!important}.gravity-padding-top-xxxl{padding-top:4rem!important}.gravity-padding-bottom-xxxl{padding-bottom:4rem!important}.gravity-padding-left-xxxl{padding-left:4rem!important}.gravity-padding-right-xxxl{padding-right:4rem!important}.gravity-padding-block-xxxl{padding-block:4rem!important}.gravity-padding-inline-xxxl{padding-inline:4rem!important}.gravity-padding-xxxxl{padding:6rem!important}.gravity-padding-top-xxxxl{padding-top:6rem!important}.gravity-padding-bottom-xxxxl{padding-bottom:6rem!important}.gravity-padding-left-xxxxl{padding-left:6rem!important}.gravity-padding-right-xxxxl{padding-right:6rem!important}.gravity-padding-block-xxxxl{padding-block:6rem!important}.gravity-padding-inline-xxxxl{padding-inline:6rem!important}.gravity-padding-xxxxxl{padding:12rem!important}.gravity-padding-top-xxxxxl{padding-top:12rem!important}.gravity-padding-bottom-xxxxxl{padding-bottom:12rem!important}.gravity-padding-left-xxxxxl{padding-left:12rem!important}.gravity-padding-right-xxxxxl{padding-right:12rem!important}.gravity-padding-block-xxxxxl{padding-block:12rem!important}.gravity-padding-inline-xxxxxl{padding-inline:12rem!important}.gravity-margin-none{margin:0!important}.gravity-margin-top-none{margin-top:0!important}.gravity-margin-bottom-none{margin-bottom:0!important}.gravity-margin-left-none{margin-left:0!important}.gravity-margin-right-none{margin-right:0!important}.gravity-margin-block-none{margin-block:0!important}.gravity-margin-inline-none{margin-inline:0!important}.gravity-margin-xxs{margin:.25rem!important}.gravity-margin-top-xxs{margin-top:.25rem!important}.gravity-margin-bottom-xxs{margin-bottom:.25rem!important}.gravity-margin-left-xxs{margin-left:.25rem!important}.gravity-margin-right-xxs{margin-right:.25rem!important}.gravity-margin-block-xxs{margin-block:.25rem!important}.gravity-margin-inline-xxs{margin-inline:.25rem!important}.gravity-margin-xs{margin:.5rem!important}.gravity-margin-top-xs{margin-top:.5rem!important}.gravity-margin-bottom-xs{margin-bottom:.5rem!important}.gravity-margin-left-xs{margin-left:.5rem!important}.gravity-margin-right-xs{margin-right:.5rem!important}.gravity-margin-block-xs{margin-block:.5rem!important}.gravity-margin-inline-xs{margin-inline:.5rem!important}.gravity-margin-sm{margin:1rem!important}.gravity-margin-top-sm{margin-top:1rem!important}.gravity-margin-bottom-sm{margin-bottom:1rem!important}.gravity-margin-left-sm{margin-left:1rem!important}.gravity-margin-right-sm{margin-right:1rem!important}.gravity-margin-block-sm{margin-block:1rem!important}.gravity-margin-inline-sm{margin-inline:1rem!important}.gravity-margin-md{margin:1.5rem!important}.gravity-margin-top-md{margin-top:1.5rem!important}.gravity-margin-bottom-md{margin-bottom:1.5rem!important}.gravity-margin-left-md{margin-left:1.5rem!important}.gravity-margin-right-md{margin-right:1.5rem!important}.gravity-margin-block-md{margin-block:1.5rem!important}.gravity-margin-inline-md{margin-inline:1.5rem!important}.gravity-margin-lg{margin:2rem!important}.gravity-margin-top-lg{margin-top:2rem!important}.gravity-margin-bottom-lg{margin-bottom:2rem!important}.gravity-margin-left-lg{margin-left:2rem!important}.gravity-margin-right-lg{margin-right:2rem!important}.gravity-margin-block-lg{margin-block:2rem!important}.gravity-margin-inline-lg{margin-inline:2rem!important}.gravity-margin-xl{margin:2.5rem!important}.gravity-margin-top-xl{margin-top:2.5rem!important}.gravity-margin-bottom-xl{margin-bottom:2.5rem!important}.gravity-margin-left-xl{margin-left:2.5rem!important}.gravity-margin-right-xl{margin-right:2.5rem!important}.gravity-margin-block-xl{margin-block:2.5rem!important}.gravity-margin-inline-xl{margin-inline:2.5rem!important}.gravity-margin-xxl{margin:3rem!important}.gravity-margin-top-xxl{margin-top:3rem!important}.gravity-margin-bottom-xxl{margin-bottom:3rem!important}.gravity-margin-left-xxl{margin-left:3rem!important}.gravity-margin-right-xxl{margin-right:3rem!important}.gravity-margin-block-xxl{margin-block:3rem!important}.gravity-margin-inline-xxl{margin-inline:3rem!important}.gravity-margin-xxxl{margin:4rem!important}.gravity-margin-top-xxxl{margin-top:4rem!important}.gravity-margin-bottom-xxxl{margin-bottom:4rem!important}.gravity-margin-left-xxxl{margin-left:4rem!important}.gravity-margin-right-xxxl{margin-right:4rem!important}.gravity-margin-block-xxxl{margin-block:4rem!important}.gravity-margin-inline-xxxl{margin-inline:4rem!important}.gravity-margin-xxxxl{margin:6rem!important}.gravity-margin-top-xxxxl{margin-top:6rem!important}.gravity-margin-bottom-xxxxl{margin-bottom:6rem!important}.gravity-margin-left-xxxxl{margin-left:6rem!important}.gravity-margin-right-xxxxl{margin-right:6rem!important}.gravity-margin-block-xxxxl{margin-block:6rem!important}.gravity-margin-inline-xxxxl{margin-inline:6rem!important}.gravity-margin-xxxxxl{margin:12rem!important}.gravity-margin-top-xxxxxl{margin-top:12rem!important}.gravity-margin-bottom-xxxxxl{margin-bottom:12rem!important}.gravity-margin-left-xxxxxl{margin-left:12rem!important}.gravity-margin-right-xxxxxl{margin-right:12rem!important}.gravity-margin-block-xxxxxl{margin-block:12rem!important}.gravity-margin-inline-xxxxxl{margin-inline:12rem!important}.border-radius-none{border-radius:0}.border-radius-xs{border-radius:.0625rem}.border-radius-sm{border-radius:.3125rem}.border-radius-md{border-radius:.625rem}.border-radius-lg{border-radius:.9375rem}.border-radius-xl{border-radius:1.25rem}.border-radius-xxl{border-radius:2rem}.border-radius-rounded{border-radius:6.25rem}.next-button,.previous-button{cursor:pointer;padding:var(--gravity-spacing-xs);border-radius:var(--gravity-spacing-xs)}.next-button:hover,.previous-button:hover{background:var(--bg-button-active-tertiary)}.separator-line{border-bottom:2px solid var(--divider-menu-active-primary)}.action-section{height:25px;display:flex;align-items:center;align-self:stretch;justify-content:space-between}.gravity-calendar-header{width:215px;height:40px;display:flex;align-self:stretch;align-items:center;flex-direction:column;justify-content:center;gap:var(--gravity-spacing-sm);padding-top:var(--gravity-spacing-xs)}.gravity-calendar-header .header-container{display:flex;align-items:center;align-self:stretch;justify-content:space-between;padding:0 var(--gravity-spacing-xs)}.gravity-calendar-header .separator-line{width:215px}.gravity-calendar-body{width:215px;display:flex;align-items:center;align-self:stretch;flex-direction:column;justify-content:center;gap:var(--gravity-spacing-sm);margin-top:var(--gravity-spacing-sm)}.gravity-calendar-body .items-table{display:flex;flex-wrap:wrap;justify-content:space-between;gap:0 var(--gravity-spacing-sm)}.gravity-calendar-body .items-table .item{width:37px;height:25px;display:flex;cursor:pointer;align-items:center;justify-content:center;border-radius:var(--gravity-spacing-xs);color:var(--on-bg-button-pressed-tertiary);border:2px solid var(--bg-calender-primary)}.gravity-calendar-body .items-table .item.current{border-color:var(--bg-number-calendar-hover-primary)}.gravity-calendar-body .items-table .item:not(.disabled):not(.selected):hover{color:var(--on-bg-button-pressed-tertiary);background:var(--bg-button-active-tertiary);border-color:var(--bg-button-active-tertiary)}.gravity-calendar-body .items-table .item.selected{color:var(--on-bg-button-pressed-primary);background:var(--bg-button-pressed-primary);border-color:var(--bg-button-pressed-primary)}\n"] }]
|
|
82
|
+
}], propDecorators: { restart: [{
|
|
83
|
+
type: Input
|
|
84
|
+
}], disabled: [{
|
|
85
|
+
type: Input
|
|
86
|
+
}], language: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}], preSelectedDate: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], actionsSection: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], integratedMode: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], clearSelection: [{
|
|
95
|
+
type: Output
|
|
96
|
+
}], calendarResponse: [{
|
|
97
|
+
type: Output,
|
|
98
|
+
args: ['response']
|
|
99
|
+
}] } });
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"month-calendar.component.js","sourceRoot":"","sources":["../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar-next/components/month-calendar/month-calendar.component.ts","../../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar-next/components/month-calendar/month-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {CalendarPeriod} from \"../../shared/calendar.modal\";\nimport {changeDate, getStartDate} from \"../../shared/calendar.utils\";\nimport {Component, EventEmitter, Input, OnChanges, Output, SimpleChanges,} from '@angular/core';\nimport {CALENDAR_I18N, MONTHS_EN, MONTHS_SHORT_EN, MONTHS_ES, MONTHS_SHORT_ES} from \"../../shared/calendar.constants\";\n\n@Component({\n  selector: 'month-calendar',\n  templateUrl: './month-calendar.component.html',\n  styleUrls: ['./month-calendar.component.scss']\n})\nexport class MonthCalendarComponent implements OnChanges {\n\n    @Input() public restart: boolean = false;\n    @Input() public disabled: boolean = false;\n    @Input() public language: 'es' | 'en' = 'en';\n    @Input() public preSelectedDate: Date | Date[];\n    @Input() public actionsSection: boolean = true;\n    @Input() public integratedMode: boolean = false;\n\n    @Output() public clearSelection: EventEmitter<void> = new EventEmitter<void>();\n    @Output('response') public calendarResponse: EventEmitter<Date[] | Date> = new EventEmitter<Date[] | Date>();\n\n    public currentDate: Date = new Date();\n    public selectedMonth: CalendarPeriod;\n\n    public get i18n() { return CALENDAR_I18N[this.language]; }\n    public get monthsList() { return this.language === 'en' ? MONTHS_EN : MONTHS_ES; }\n    public get monthsShortList() { return this.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.preSelectedDate;\n        if (shouldRestart || shouldProcessPreSelected) { this.processPreselectedDate(); }\n    }\n\n    public trackByMonth(_: number, month: CalendarPeriod): string {\n        return `${month.year}-${month.month}`;\n    }\n\n    private processPreselectedDate(): void {\n        if (this.preSelectedDate instanceof Date) {\n            this.currentDate = getStartDate(this.preSelectedDate);\n            this.selectedMonth = {\n                month: this.preSelectedDate.getMonth(),\n                year: this.preSelectedDate.getFullYear()\n            };\n        }\n    }\n\n    public onSelectMonth(month: CalendarPeriod) {\n        this.selectedMonth = month;\n        this.currentDate = new Date(month.year, month.month, 1);\n        this.calendarResponse.emit(this.currentDate);\n        return;\n    }\n\n    public getMonthSelectionClass(month: CalendarPeriod): string {\n\n       if(this.selectedMonth && this.selectedMonth.month === month.month &&\n           this.selectedMonth.year === month.year) {\n           return 'selected'\n       }\n\n       if(new Date().getMonth() === month.month &&\n          new Date().getFullYear() === month.year) {\n           return 'current'\n       }\n\n       return '';\n    }\n\n    public clearSelectedMonth() {\n        this.selectedMonth = null;\n        this.clearSelection.emit();\n    }\n\n    public applySelectedMonth() {\n        const date = new Date(this.selectedMonth.year, this.selectedMonth.month)\n        this.calendarResponse.emit(date);\n    }\n\n    public getYearMonthsList(): CalendarPeriod[] {\n        const months: CalendarPeriod[] = [];\n\n        for (let i = 0; i < 12; i++) {\n            months.push({month: i, year: this.currentDate.getFullYear()});\n        }\n\n        return months;\n    }\n\n    protected readonly changeDate = changeDate;\n}\n","<section class=\"gravity-calendar-header\">\n    <div class=\"header-container\">\n        <div *ngIf=\"!integratedMode\" class=\"previous-button\" (click)=\"currentDate = changeDate(-1, currentDate, false)\">\n            <gravity-icon [style.--icon-color]=\"'var(--text-highlight-primary)'\" [iconName]=\"'arrow-left'\" [iconSize]=\"'sm-12'\" > </gravity-icon>\n        </div>\n\n        <div class=\"year-label\">\n            <gravity-dropdown-label [state]=\"integratedMode ? 'active' : 'inactive'\" [fontClass]=\"'hr-title sm-bold'\" [size]=\"'sm'\"\n                                    [label]=\"integratedMode ? monthsList[currentDate.getMonth()] : currentDate.getFullYear().toString()\"\n                                    [isOpen]=\"integratedMode\" (onClickLabel)=\"calendarResponse.emit(currentDate)\" > </gravity-dropdown-label>\n        </div>\n\n        <div *ngIf=\"!integratedMode\" class=\"next-button\" (click)=\"currentDate = changeDate(1, currentDate, false)\">\n            <gravity-icon [style.--icon-color]=\"'var(--text-highlight-primary)'\" [iconName]=\"'arrow-right'\" [iconSize]=\"'sm-12'\"> </gravity-icon>\n        </div>\n    </div>\n\n    <div class=\"separator-line\"></div>\n</section>\n\n<section class=\"gravity-calendar-body\">\n    <div class=\"items-table\">\n          <span class=\"hr-body sm-regular item\" *ngFor=\"let month of getYearMonthsList(), trackBy: trackByMonth\"\n                [ngClass]=\"disabled ? 'disabled' : getMonthSelectionClass(month)\" (click)=\"onSelectMonth(month)\">\n              {{ monthsShortList[month.month] }} </span>\n    </div>\n\n    <div *ngIf=\"actionsSection\" class=\"action-section\" >\n        <gravity-link [linkText]=\"i18n.clear\" [state]=\"!selectedMonth ? 'disabled' : 'active'\" (click)=\"clearSelectedMonth()\"></gravity-link>\n        <gravity-button [size]=\"'sm'\" [type]=\"'tertiary'\" [disabled]=\"!selectedMonth\" (click)=\"applySelectedMonth()\">{{i18n.apply}}</gravity-button>\n    </div>\n</section>"]}
|