@progressio_resources/gravity-design-system 2.3.2 → 2.4.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.
Files changed (30) hide show
  1. package/esm2022/lib/components/gravity-calendar/gravity-calendar.component.mjs +31 -103
  2. package/esm2022/lib/components/gravity-checkbox/gravity-checkbox.component.mjs +20 -10
  3. package/esm2022/lib/components/gravity-stepper/gravity-stepper.component.mjs +2 -2
  4. package/esm2022/lib/components/gravity-switch/gravity-switch.component.mjs +13 -6
  5. package/esm2022/lib/gravity-design-system.module.mjs +6 -5
  6. package/esm2022/lib/services/gravity-dialog-manager.service.mjs +4 -3
  7. package/fesm2022/progressio_resources-gravity-design-system.mjs +70 -252
  8. package/fesm2022/progressio_resources-gravity-design-system.mjs.map +1 -1
  9. package/lib/components/gravity-calendar/gravity-calendar.component.d.ts +16 -30
  10. package/lib/components/gravity-checkbox/gravity-checkbox.component.d.ts +13 -8
  11. package/lib/components/gravity-switch/gravity-switch.component.d.ts +5 -4
  12. package/lib/gravity-design-system.module.d.ts +16 -16
  13. package/lib/services/gravity-dialog-manager.service.d.ts +1 -1
  14. package/package.json +2 -1
  15. package/src/lib/assets/icons/coins/binance_coin.svg +22 -0
  16. package/src/lib/assets/icons/coins/binance_usd.svg +13 -0
  17. package/src/lib/assets/icons/coins/bitcoin.svg +8 -0
  18. package/src/lib/assets/icons/coins/bitcoin_cash.svg +15 -0
  19. package/src/lib/assets/icons/coins/ethereum.svg +18 -0
  20. package/src/lib/assets/icons/coins/euro_coin.svg +26 -0
  21. package/src/lib/assets/icons/coins/litecoin.svg +15 -0
  22. package/src/lib/assets/icons/coins/tether.svg +15 -0
  23. package/src/lib/assets/icons/coins/tron.svg +12 -0
  24. package/src/lib/assets/icons/coins/usd_coin.svg +16 -0
  25. package/src/lib/assets/icons/coins/wrapped_bitcoin.svg +27 -0
  26. package/src/lib/assets/json/icons.json +98 -2
  27. package/src/lib/styles/components/_datepicker.scss +122 -70
  28. package/esm2022/lib/components/gravity-calendar/gravity-month-picker/gravity-month-picker.component.mjs +0 -136
  29. package/lib/components/gravity-calendar/gravity-month-picker/gravity-month-picker.component.d.ts +0 -40
  30. /package/src/lib/assets/icons/{settings.svg → sections/settings.svg} +0 -0
@@ -1,117 +1,169 @@
1
1
  @import "../foundations/typography/hero.typography";
2
+ @import "../foundations/spacing/spacing";
2
3
  @import "../foundations/border-radius/hero.border-radius";
3
4
  @import "../shared";
4
5
 
5
- ngb-datepicker.gravity-datepicker-dialog {
6
+ $datepicker-min-width: 15rem;
7
+
8
+ bs-datepicker-container {
9
+ z-index: 1;
10
+ }
11
+
12
+ .gravity-datepicker-dialog {
6
13
  background-color: var(--bg-calender-primary);
7
14
  border-radius: $border-radius-md;
8
15
  box-shadow: 0 0 10px #AAA;
9
16
  color: var(--on-bg-calender-primary);
10
17
 
11
- .ngb-dp-header {
18
+ .bs-datepicker-head {
12
19
  background-color: var(--bg-calendar-nav-primary);
13
20
  border-top-left-radius: $border-radius-md;
14
21
  border-top-right-radius: $border-radius-md;
15
22
  color: var(--on-bg-calendar-nav-primary);
16
23
  height: 3.125rem;
17
- min-width: 17.75rem;
24
+ min-width: $datepicker-min-width;
18
25
  padding: 0.625rem;
19
26
 
20
- ngb-datepicker-navigation {
21
- .ngb-dp-arrow {
22
- button {
23
- @extend .hr-label, .sm-regular;
27
+ bs-datepicker-navigation-view {
28
+ align-items: center;
29
+ display: flex;
30
+ justify-content: space-between;
24
31
 
25
- border-radius: 50%;
26
- color: var(--arrow-calendar-active-primary);
27
- cursor: pointer;
28
- height: 2rem;
29
- margin: 0;
30
- outline: none;
31
- padding: 0;
32
- width: 2rem;
33
-
34
- span {
35
- border: none;
36
- display: inline-block;
37
- font-size: 1.75rem;
38
- height: 100%;
39
- line-height: 1;
40
- margin: 0;
41
- position: relative;
42
- transform: none;
43
- width: 100%;
44
- }
45
-
46
- &:not([disabled]):hover {
47
- background-color: var(--bg-arrow-calendar-hover-primary);
48
- color: var(--arrow-calendar-hover-primary);
49
- }
50
-
51
- &[disabled] {
52
- color: var(--arrow-calendar-disabled-primary);
53
- cursor: not-allowed;
54
- }
32
+ .previous,
33
+ .next {
34
+ @extend .hr-label, .sm-regular;
35
+
36
+ background-color: var(--bg-calendar-nav-primary);
37
+ border: none;
38
+ border-radius: $border-radius-rounded;
39
+ color: var(--arrow-calendar-active-primary);
40
+ cursor: pointer;
41
+ height: 2rem;
42
+ outline: none;
43
+ width: 2rem;
44
+
45
+ span {
46
+ border: none;
47
+ display: inline-block;
48
+ font-size: 1.75rem;
49
+ height: 100%;
50
+ line-height: 1;
51
+ width: 100%;
55
52
  }
56
53
 
57
- &.ngb-dp-arrow-prev button span:before {
58
- content: "‹";
54
+ &:not([disabled]):hover {
55
+ background-color: var(--bg-arrow-calendar-hover-primary);
56
+ color: var(--arrow-calendar-hover-primary);
59
57
  }
60
58
 
61
- &.ngb-dp-arrow-next button span:after {
62
- content: "›";
59
+ &[disabled] {
60
+ color: var(--arrow-calendar-disabled-primary);
61
+ cursor: not-allowed;
63
62
  }
64
63
  }
65
64
 
66
- .ngb-dp-month-name {
65
+ .current {
67
66
  @extend .hr-label, .md-regular;
67
+
68
68
  background-color: var(--bg-calendar-nav-primary);
69
+ border: none;
70
+ border-radius: $border-radius-rounded;
71
+ color: var(--on-bg-calendar-nav-primary);
72
+ cursor: pointer;
73
+ height: 2rem;
74
+ outline: none;
75
+ padding-inline: map-get($spacing-values, sm);
76
+
77
+ &:not([disabled]):hover {
78
+ background-color: var(--bg-arrow-calendar-hover-primary);
79
+ color: var(--arrow-calendar-hover-primary);
80
+ }
81
+
82
+ &[disabled] {
83
+ color: var(--arrow-calendar-disabled-primary);
84
+ cursor: not-allowed;
85
+ }
69
86
  }
70
87
  }
71
88
  }
72
89
 
73
- .ngb-dp-content {
90
+ .bs-datepicker-body {
74
91
  @extend .hr-label, .sm-regular;
75
92
 
76
- min-width: 16.5rem;
93
+ min-width: $datepicker-min-width;
77
94
  padding: 0.625rem;
78
95
 
79
- .ngb-dp-weekdays {
80
- background-color: var(--bg-calender-primary);
81
- border: none;
96
+ table {
97
+ width: 100%;
82
98
 
83
- .ngb-dp-weekday {
84
- @extend .hr-label, .sm-regular;
85
- color: var(--on-bg-calender-primary);
99
+ td {
100
+ border-radius: $border-radius-rounded;
101
+ color: var(--number-calender-active-primary);
102
+ cursor: pointer;
103
+ height: 2rem;
104
+ outline: none;
105
+ text-align: center;
106
+
107
+ span {
108
+ display: block;
109
+ height: 2rem;
110
+ line-height: 2rem;
111
+ }
86
112
  }
87
113
  }
114
+ }
88
115
 
89
- .ngb-dp-week-number {
90
- @extend .hr-label, .sm-regular;
116
+ bs-days-calendar-view .bs-datepicker-body table {
117
+ th {
118
+ font-style: italic;
119
+ height: 2rem;
120
+ width: 2rem;
91
121
  }
92
122
 
93
- .ngb-dp-day {
94
- border-radius: 50%;
95
- color: var(--number-calender-active-primary);
96
- outline: none;
123
+ td {
124
+ width: 2rem;
97
125
 
98
- .btn-light {
99
- border-radius: 50%;
100
- outline: none;
126
+ &:not(:has(span.is-other-month)):not(:has(span.selected)):not(:has(span.disabled)):hover {
127
+ background-color: var(--bg-number-calendar-hover-primary);
128
+ color: var(--number-calendar-hover-primary);
129
+ }
101
130
 
102
- &:not(.text-muted):hover {
103
- background-color: var(--bg-number-calendar-hover-primary);
104
- color: var(--number-calendar-hover-primary);
105
- }
131
+ &:has(span.selected) {
132
+ background-color: var(--bg-number-calendar-pressed-primary);
133
+ color: var(--number-calendar-pressed-primary);
134
+ }
106
135
 
107
- &.text-muted {
108
- color: var(--number-calendar-disabled-primary);
109
- }
136
+ &:has(span.is-other-month) {
137
+ color: var(--number-calendar-disabled-primary);
138
+ }
110
139
 
111
- &.bg-primary.text-white {
112
- background-color: var(--bg-number-calendar-pressed-primary) !important;
113
- color: var(--number-calendar-pressed-primary) !important;
114
- }
140
+ &:has(span.disabled) {
141
+ color: var(--number-calendar-disabled-primary);
142
+ cursor: not-allowed;
143
+ }
144
+
145
+ span {
146
+ width: 2rem;
147
+ }
148
+ }
149
+ }
150
+
151
+ bs-month-calendar-view,
152
+ bs-years-calendar-view {
153
+ .bs-datepicker-body table td {
154
+ &:not(.disabled):hover {
155
+ background-color: var(--bg-number-calendar-hover-primary);
156
+ color: var(--number-calendar-hover-primary);
157
+ }
158
+
159
+ &.disabled {
160
+ color: var(--number-calendar-disabled-primary);
161
+ cursor: not-allowed;
162
+ }
163
+
164
+ &.selected {
165
+ background-color: var(--bg-number-calendar-pressed-primary);
166
+ color: var(--number-calendar-pressed-primary);
115
167
  }
116
168
  }
117
169
  }
@@ -1,136 +0,0 @@
1
- import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/common";
4
- export class GravityMonthPickerComponent {
5
- constructor() {
6
- this.closeCalendar = new EventEmitter();
7
- this.monthSelected = new EventEmitter();
8
- this.currentLang = 'en';
9
- this.monthsEn = ["Jan", "Feb", "Mar", "Apr", "May", "June", "July", "Aug", "Sept", "Oct", "Nov", "Dec"];
10
- this.monthsEs = ["En", "Feb", "Mar", "Abr", "May", "Jun", "Jul", "Ag", "Set", "Oct", "Nov", "Dic"];
11
- this.isShowingCalendar = false;
12
- this.isShowingMonths = true;
13
- this.monthPickerData = {};
14
- this.monthIndex = new Date().getUTCMonth();
15
- this.yearDisplayed = new Date().getUTCFullYear();
16
- this.yearBase = GravityMonthPickerComponent.getYearsRangeBase(this.yearDisplayed);
17
- }
18
- ngOnInit() {
19
- if (this.monthConfig?.customMonthDate) {
20
- this.monthPickerData.month = this.monthConfig.customMonthDate.month;
21
- this.monthPickerData.year = this.monthConfig.customMonthDate.year;
22
- }
23
- }
24
- showCalendar() {
25
- this.isShowingCalendar = true;
26
- }
27
- hideCalendar() {
28
- this.isShowingCalendar = false;
29
- }
30
- updateYear(changeRange, newYear) {
31
- if (changeRange) {
32
- this.yearDisplayed += changeRange;
33
- }
34
- else if (newYear) {
35
- this.yearDisplayed = newYear;
36
- }
37
- this.yearBase = GravityMonthPickerComponent.getYearsRangeBase(this.yearDisplayed);
38
- }
39
- addYear() {
40
- this.updateYear(this.isShowingMonths ? 1 : 10);
41
- }
42
- subtractYear() {
43
- this.updateYear(this.isShowingMonths ? -1 : -10);
44
- }
45
- changeYear(newYear, disabled) {
46
- if (!disabled) {
47
- this.updateYear(null, newYear);
48
- this.isShowingMonths = true;
49
- }
50
- }
51
- static getYearsRangeBase(year) {
52
- return (year - year % 10) - 1;
53
- }
54
- changeMonth(monthIndex, disabled) {
55
- if (!disabled) {
56
- this.monthPickerData.month = monthIndex + 1;
57
- this.monthPickerData.year = this.yearDisplayed;
58
- this.isShowingCalendar = false;
59
- this.closeCalendar.emit(false);
60
- this.monthSelected.emit(this.monthPickerData);
61
- }
62
- }
63
- getMonths() {
64
- switch (this.currentLang) {
65
- case 'es':
66
- return this.monthsEs;
67
- default:
68
- return this.monthsEn;
69
- }
70
- }
71
- getDisabled(currentIndex) {
72
- let minMonthDisabled = false;
73
- if (this.monthConfig?.minMonthDate) {
74
- if (this.isShowingMonths) {
75
- minMonthDisabled = this.yearDisplayed < this.monthConfig.minMonthDate.year || (this.yearDisplayed == this.monthConfig.minMonthDate.year && currentIndex + 1 < this.monthConfig.minMonthDate.month);
76
- }
77
- else {
78
- minMonthDisabled = this.yearBase + currentIndex < this.monthConfig.minMonthDate.year;
79
- }
80
- }
81
- let maxMonthDisabled = false;
82
- if (this.monthConfig?.maxMonthDate) {
83
- if (this.isShowingMonths) {
84
- maxMonthDisabled = this.yearDisplayed > this.monthConfig.maxMonthDate.year || (this.yearDisplayed == this.monthConfig.maxMonthDate.year && currentIndex + 1 > this.monthConfig.maxMonthDate.month);
85
- }
86
- else {
87
- maxMonthDisabled = this.yearBase + currentIndex > this.monthConfig.maxMonthDate.year;
88
- }
89
- }
90
- return minMonthDisabled || maxMonthDisabled;
91
- }
92
- getArrowDisabled(arrow) {
93
- if (arrow == 'left' && this.monthConfig?.minMonthDate) {
94
- if (this.isShowingMonths) {
95
- return this.yearDisplayed <= this.monthConfig.minMonthDate.year;
96
- }
97
- else {
98
- return this.yearBase < this.monthConfig.minMonthDate.year;
99
- }
100
- }
101
- if (arrow == 'right' && this.monthConfig?.maxMonthDate) {
102
- if (this.isShowingMonths) {
103
- return this.yearDisplayed >= this.monthConfig.maxMonthDate.year;
104
- }
105
- else {
106
- return this.yearBase + 12 > this.monthConfig.maxMonthDate.year;
107
- }
108
- }
109
- }
110
- onDocumentClick() {
111
- if (this.isShowingCalendar) {
112
- this.isShowingCalendar = false;
113
- this.closeCalendar.emit(false);
114
- }
115
- }
116
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityMonthPickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
117
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GravityMonthPickerComponent, selector: "gravity-month-picker", inputs: { currentLang: "currentLang", monthConfig: "monthConfig" }, outputs: { closeCalendar: "closeCalendar", monthSelected: "monthSelected" }, host: { listeners: { "document:click": "onDocumentClick($event)" } }, ngImport: i0, template: "<ng-container *ngIf=\"isShowingCalendar\">\n <div class=\"calendar-header\">\n <div class=\"month-picker-arrow month-picker-arrow-previous\">\n <button class=\"hr-label sm-regular\" [disabled]=\"getArrowDisabled('left')\" (click)=\"subtractYear()\">\n <span></span>\n </button>\n </div>\n <div class=\"hr-label md-regular month-picker-year\">\n <span (click)=\"$event.stopPropagation(); isShowingMonths = false\" *ngIf=\"isShowingMonths\">\n {{yearDisplayed}}\n </span>\n <span (click)=\"$event.stopPropagation(); isShowingMonths = true\" *ngIf=\"!isShowingMonths\">\n {{yearBase + 1}} - {{yearBase + 10}}\n </span>\n </div>\n <div class=\"month-picker-arrow month-picker-arrow-next\">\n <button class=\"hr-label sm-regular\" [disabled]=\"getArrowDisabled('right')\" (click)=\"addYear()\">\n <span></span>\n </button>\n </div>\n </div>\n <div class=\"calendar-body hr-label sm-regular\">\n <article [class.active]=\"(isShowingMonths && monthPickerData.month == i + 1 && monthPickerData.year == yearDisplayed) || (!isShowingMonths && monthPickerData.year == i + yearBase)\"\n [class.disabled]=\"getDisabled(i)\"\n (click)=\"isShowingMonths ? changeMonth(i, getDisabled(i)) : changeYear(i + yearBase, getDisabled(i))\"\n *ngFor=\"let month of getMonths(); let i = index\">\n <span *ngIf=\"isShowingMonths\">{{month}}</span>\n <span *ngIf=\"!isShowingMonths\">{{i + yearBase}}</span>\n </article>\n </div>\n</ng-container>\n", styles: ["@charset \"UTF-8\";.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}:host{background-color:var(--bg-calender-primary);border-radius:.625rem;box-shadow:0 0 10px #aaa;color:var(--on-bg-calender-primary);left:2.6rem;position:absolute;top:77%;width:15rem;z-index:1055}.calendar-header{align-items:center;background-color:var(--bg-calendar-nav-primary);border-top-left-radius:.625rem;border-top-right-radius:.625rem;color:var(--on-bg-calendar-nav-primary);display:flex;height:3.125rem;min-width:15rem;padding:.625rem}.month-picker-arrow{display:flex;flex:1 1 auto;height:2rem;margin:0;padding-left:0;padding-right:0;width:2rem}.month-picker-arrow button{background-color:var(--bg-calendar-nav-primary);border:none;border-radius:50%;color:var(--arrow-calendar-active-primary);cursor:pointer;height:2rem;margin:0;outline:none;padding:0;width:2rem}.month-picker-arrow button span{border:none;display:inline-block;font-size:1.75rem;height:100%;line-height:1;margin:0;position:relative;transform:none;width:100%}.month-picker-arrow button:not([disabled]):hover{background-color:var(--bg-arrow-calendar-hover-primary);color:var(--arrow-calendar-hover-primary)}.month-picker-arrow button[disabled]{color:var(--arrow-calendar-disabled-primary);cursor:not-allowed}.month-picker-arrow.month-picker-arrow-previous button span:before{content:\"\\2039\"}.month-picker-arrow.month-picker-arrow-next button span:after{content:\"\\203a\"}.month-picker-year{cursor:pointer}.month-picker-arrow-next{justify-content:flex-end}.calendar-body{display:flex;flex-wrap:wrap;justify-content:space-between;min-width:15rem;padding:.625rem;text-align:center}.calendar-body article{align-items:center;border-radius:50%;cursor:pointer;display:flex;height:2.5rem;justify-content:center;margin-inline:.25rem;width:2.5rem}.calendar-body article:not(.disabled):hover{background-color:var(--bg-number-calendar-hover-primary);color:var(--number-calendar-hover-primary)}.calendar-body article.active{background-color:var(--bg-number-calendar-pressed-primary)!important;color:var(--number-calendar-pressed-primary)!important}.calendar-body article.disabled{color:var(--number-calendar-disabled-primary);cursor:default}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
118
- }
119
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityMonthPickerComponent, decorators: [{
120
- type: Component,
121
- args: [{ selector: 'gravity-month-picker', template: "<ng-container *ngIf=\"isShowingCalendar\">\n <div class=\"calendar-header\">\n <div class=\"month-picker-arrow month-picker-arrow-previous\">\n <button class=\"hr-label sm-regular\" [disabled]=\"getArrowDisabled('left')\" (click)=\"subtractYear()\">\n <span></span>\n </button>\n </div>\n <div class=\"hr-label md-regular month-picker-year\">\n <span (click)=\"$event.stopPropagation(); isShowingMonths = false\" *ngIf=\"isShowingMonths\">\n {{yearDisplayed}}\n </span>\n <span (click)=\"$event.stopPropagation(); isShowingMonths = true\" *ngIf=\"!isShowingMonths\">\n {{yearBase + 1}} - {{yearBase + 10}}\n </span>\n </div>\n <div class=\"month-picker-arrow month-picker-arrow-next\">\n <button class=\"hr-label sm-regular\" [disabled]=\"getArrowDisabled('right')\" (click)=\"addYear()\">\n <span></span>\n </button>\n </div>\n </div>\n <div class=\"calendar-body hr-label sm-regular\">\n <article [class.active]=\"(isShowingMonths && monthPickerData.month == i + 1 && monthPickerData.year == yearDisplayed) || (!isShowingMonths && monthPickerData.year == i + yearBase)\"\n [class.disabled]=\"getDisabled(i)\"\n (click)=\"isShowingMonths ? changeMonth(i, getDisabled(i)) : changeYear(i + yearBase, getDisabled(i))\"\n *ngFor=\"let month of getMonths(); let i = index\">\n <span *ngIf=\"isShowingMonths\">{{month}}</span>\n <span *ngIf=\"!isShowingMonths\">{{i + yearBase}}</span>\n </article>\n </div>\n</ng-container>\n", styles: ["@charset \"UTF-8\";.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}:host{background-color:var(--bg-calender-primary);border-radius:.625rem;box-shadow:0 0 10px #aaa;color:var(--on-bg-calender-primary);left:2.6rem;position:absolute;top:77%;width:15rem;z-index:1055}.calendar-header{align-items:center;background-color:var(--bg-calendar-nav-primary);border-top-left-radius:.625rem;border-top-right-radius:.625rem;color:var(--on-bg-calendar-nav-primary);display:flex;height:3.125rem;min-width:15rem;padding:.625rem}.month-picker-arrow{display:flex;flex:1 1 auto;height:2rem;margin:0;padding-left:0;padding-right:0;width:2rem}.month-picker-arrow button{background-color:var(--bg-calendar-nav-primary);border:none;border-radius:50%;color:var(--arrow-calendar-active-primary);cursor:pointer;height:2rem;margin:0;outline:none;padding:0;width:2rem}.month-picker-arrow button span{border:none;display:inline-block;font-size:1.75rem;height:100%;line-height:1;margin:0;position:relative;transform:none;width:100%}.month-picker-arrow button:not([disabled]):hover{background-color:var(--bg-arrow-calendar-hover-primary);color:var(--arrow-calendar-hover-primary)}.month-picker-arrow button[disabled]{color:var(--arrow-calendar-disabled-primary);cursor:not-allowed}.month-picker-arrow.month-picker-arrow-previous button span:before{content:\"\\2039\"}.month-picker-arrow.month-picker-arrow-next button span:after{content:\"\\203a\"}.month-picker-year{cursor:pointer}.month-picker-arrow-next{justify-content:flex-end}.calendar-body{display:flex;flex-wrap:wrap;justify-content:space-between;min-width:15rem;padding:.625rem;text-align:center}.calendar-body article{align-items:center;border-radius:50%;cursor:pointer;display:flex;height:2.5rem;justify-content:center;margin-inline:.25rem;width:2.5rem}.calendar-body article:not(.disabled):hover{background-color:var(--bg-number-calendar-hover-primary);color:var(--number-calendar-hover-primary)}.calendar-body article.active{background-color:var(--bg-number-calendar-pressed-primary)!important;color:var(--number-calendar-pressed-primary)!important}.calendar-body article.disabled{color:var(--number-calendar-disabled-primary);cursor:default}\n"] }]
122
- }], ctorParameters: function () { return []; }, propDecorators: { closeCalendar: [{
123
- type: Output,
124
- args: ['closeCalendar']
125
- }], monthSelected: [{
126
- type: Output,
127
- args: ['monthSelected']
128
- }], currentLang: [{
129
- type: Input
130
- }], monthConfig: [{
131
- type: Input
132
- }], onDocumentClick: [{
133
- type: HostListener,
134
- args: ['document:click', ['$event']]
135
- }] } });
136
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-month-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar/gravity-month-picker/gravity-month-picker.component.ts","../../../../../../../projects/gravity-design-system/src/lib/components/gravity-calendar/gravity-month-picker/gravity-month-picker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAC,MAAM,eAAe,CAAC;;;AAO3F,MAAM,OAAO,2BAA2B;IAqBtC;QApBgC,kBAAa,GAA0B,IAAI,YAAY,EAAE,CAAC;QAC1D,kBAAa,GAAyC,IAAI,YAAY,EAAE,CAAC;QAEzF,gBAAW,GAAW,IAAI,CAAC;QAO3B,aAAQ,GAAa,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAC7G,aAAQ,GAAa,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAEjH,sBAAiB,GAAY,KAAK,CAAC;QACnC,oBAAe,GAAY,IAAI,CAAC;QAChC,oBAAe,GAA2B,EAA4B,CAAC;QAM5E,IAAI,CAAC,UAAU,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QAC3C,IAAI,CAAC,aAAa,GAAG,IAAI,IAAI,EAAE,CAAC,cAAc,EAAE,CAAC;QACjD,IAAI,CAAC,QAAQ,GAAG,2BAA2B,CAAC,iBAAiB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACpF,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,WAAW,EAAE,eAAe,EAAE;YACrC,IAAI,CAAC,eAAe,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,KAAK,CAAC;YACpE,IAAI,CAAC,eAAe,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,IAAI,CAAC;SACnE;IACH,CAAC;IAEM,YAAY;QACjB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;IAChC,CAAC;IAEM,YAAY;QACjB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACjC,CAAC;IAEO,UAAU,CAAC,WAAoB,EAAE,OAAgB;QACvD,IAAI,WAAW,EAAE;YACf,IAAI,CAAC,aAAa,IAAI,WAAW,CAAC;SACnC;aAAM,IAAI,OAAO,EAAE;YAClB,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC;SAC9B;QAED,IAAI,CAAC,QAAQ,GAAG,2BAA2B,CAAC,iBAAiB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IACpF,CAAC;IAEM,OAAO;QACZ,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IACjD,CAAC;IAEM,YAAY;QACjB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IACnD,CAAC;IAEM,UAAU,CAAC,OAAe,EAAE,QAAiB;QAClD,IAAI,CAAC,QAAQ,EAAE;YACb,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;YAC/B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC7B;IACH,CAAC;IAEO,MAAM,CAAC,iBAAiB,CAAC,IAAY;QAC3C,OAAO,CAAC,IAAI,GAAG,IAAI,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC;IAChC,CAAC;IAEM,WAAW,CAAC,UAAkB,EAAE,QAAiB;QACtD,IAAI,CAAC,QAAQ,EAAE;YACb,IAAI,CAAC,eAAe,CAAC,KAAK,GAAG,UAAU,GAAG,CAAC,CAAC;YAC5C,IAAI,CAAC,eAAe,CAAC,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC;YAC/C,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;YAC/B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC/B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;SAC/C;IACH,CAAC;IAEM,SAAS;QACd,QAAQ,IAAI,CAAC,WAAW,EAAE;YACxB,KAAK,IAAI;gBACP,OAAO,IAAI,CAAC,QAAQ,CAAC;YAEvB;gBACE,OAAO,IAAI,CAAC,QAAQ,CAAC;SACxB;IACH,CAAC;IAEM,WAAW,CAAC,YAAoB;QACrC,IAAI,gBAAgB,GAAY,KAAK,CAAC;QACtC,IAAI,IAAI,CAAC,WAAW,EAAE,YAAY,EAAE;YAClC,IAAI,IAAI,CAAC,eAAe,EAAE;gBACxB,gBAAgB,GAAG,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,IAAI,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;aACpM;iBAAM;gBACL,gBAAgB,GAAG,IAAI,CAAC,QAAQ,GAAG,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC;aACtF;SACF;QAED,IAAI,gBAAgB,GAAY,KAAK,CAAC;QACtC,IAAI,IAAI,CAAC,WAAW,EAAE,YAAY,EAAE;YAClC,IAAI,IAAI,CAAC,eAAe,EAAE;gBACxB,gBAAgB,GAAG,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,IAAI,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;aACpM;iBAAM;gBACL,gBAAgB,GAAG,IAAI,CAAC,QAAQ,GAAG,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC;aACtF;SACF;QAED,OAAO,gBAAgB,IAAI,gBAAgB,CAAC;IAC9C,CAAC;IAEM,gBAAgB,CAAC,KAAuB;QAC7C,IAAI,KAAK,IAAI,MAAM,IAAI,IAAI,CAAC,WAAW,EAAE,YAAY,EAAE;YACrD,IAAI,IAAI,CAAC,eAAe,EAAE;gBACxB,OAAO,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC;aACjE;iBAAM;gBACL,OAAO,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC;aAC3D;SACF;QAED,IAAI,KAAK,IAAI,OAAO,IAAI,IAAI,CAAC,WAAW,EAAE,YAAY,EAAE;YACtD,IAAI,IAAI,CAAC,eAAe,EAAE;gBACxB,OAAO,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC;aACjE;iBAAM;gBACL,OAAO,IAAI,CAAC,QAAQ,GAAG,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC;aAChE;SACF;IACH,CAAC;IAGD,eAAe;QACb,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;YAC/B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAChC;IACH,CAAC;+GAzIU,2BAA2B;mGAA3B,2BAA2B,mRCPxC,6hDA+BA;;4FDxBa,2BAA2B;kBALvC,SAAS;+BACE,sBAAsB;0EAKA,aAAa;sBAA5C,MAAM;uBAAC,eAAe;gBACS,aAAa;sBAA5C,MAAM;uBAAC,eAAe;gBAEP,WAAW;sBAA1B,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBA+HN,eAAe;sBADd,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {Component, EventEmitter, HostListener, Input, OnInit, Output} from '@angular/core';\n\n@Component({\n  selector: 'gravity-month-picker',\n  templateUrl: './gravity-month-picker.component.html',\n  styleUrls: ['./gravity-month-picker.component.scss']\n})\nexport class GravityMonthPickerComponent implements OnInit {\n  @Output('closeCalendar') public closeCalendar: EventEmitter<boolean> = new EventEmitter();\n  @Output('monthSelected') public monthSelected: EventEmitter<GravityMonthPickerDate> = new EventEmitter();\n\n  @Input() public currentLang: string = 'en';\n  @Input() public monthConfig: {\n    customMonthDate?: GravityMonthPickerDate;\n    maxMonthDate?: GravityMonthPickerDate;\n    minMonthDate?: GravityMonthPickerDate;\n  };\n\n  public readonly monthsEn: string[] = [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"June\", \"July\", \"Aug\", \"Sept\", \"Oct\", \"Nov\", \"Dec\"];\n  public readonly monthsEs: string[] = [\"En\", \"Feb\", \"Mar\", \"Abr\", \"May\", \"Jun\", \"Jul\", \"Ag\", \"Set\", \"Oct\", \"Nov\", \"Dic\"];\n\n  public isShowingCalendar: boolean = false;\n  public isShowingMonths: boolean = true;\n  public monthPickerData: GravityMonthPickerDate = {} as GravityMonthPickerDate;\n  public monthIndex: number;\n  public yearBase: number;\n  public yearDisplayed: number;\n\n  constructor() {\n    this.monthIndex = new Date().getUTCMonth();\n    this.yearDisplayed = new Date().getUTCFullYear();\n    this.yearBase = GravityMonthPickerComponent.getYearsRangeBase(this.yearDisplayed);\n  }\n\n  ngOnInit() {\n    if (this.monthConfig?.customMonthDate) {\n      this.monthPickerData.month = this.monthConfig.customMonthDate.month;\n      this.monthPickerData.year = this.monthConfig.customMonthDate.year;\n    }\n  }\n\n  public showCalendar(): void {\n    this.isShowingCalendar = true;\n  }\n\n  public hideCalendar(): void {\n    this.isShowingCalendar = false;\n  }\n\n  private updateYear(changeRange?: number, newYear?: number): void {\n    if (changeRange) {\n      this.yearDisplayed += changeRange;\n    } else if (newYear) {\n      this.yearDisplayed = newYear;\n    }\n\n    this.yearBase = GravityMonthPickerComponent.getYearsRangeBase(this.yearDisplayed);\n  }\n\n  public addYear(): void {\n    this.updateYear(this.isShowingMonths ? 1 : 10);\n  }\n\n  public subtractYear(): void {\n    this.updateYear(this.isShowingMonths ? -1 : -10);\n  }\n\n  public changeYear(newYear: number, disabled: boolean) {\n    if (!disabled) {\n      this.updateYear(null, newYear);\n      this.isShowingMonths = true;\n    }\n  }\n\n  private static getYearsRangeBase(year: number): number {\n    return (year - year % 10) - 1;\n  }\n\n  public changeMonth(monthIndex: number, disabled: boolean) {\n    if (!disabled) {\n      this.monthPickerData.month = monthIndex + 1;\n      this.monthPickerData.year = this.yearDisplayed;\n      this.isShowingCalendar = false;\n      this.closeCalendar.emit(false);\n      this.monthSelected.emit(this.monthPickerData);\n    }\n  }\n\n  public getMonths(): string[] {\n    switch (this.currentLang) {\n      case 'es':\n        return this.monthsEs;\n\n      default:\n        return this.monthsEn;\n    }\n  }\n\n  public getDisabled(currentIndex: number): boolean {\n    let minMonthDisabled: boolean = false;\n    if (this.monthConfig?.minMonthDate) {\n      if (this.isShowingMonths) {\n        minMonthDisabled = this.yearDisplayed < this.monthConfig.minMonthDate.year || (this.yearDisplayed == this.monthConfig.minMonthDate.year && currentIndex + 1 < this.monthConfig.minMonthDate.month);\n      } else {\n        minMonthDisabled = this.yearBase + currentIndex < this.monthConfig.minMonthDate.year;\n      }\n    }\n\n    let maxMonthDisabled: boolean = false;\n    if (this.monthConfig?.maxMonthDate) {\n      if (this.isShowingMonths) {\n        maxMonthDisabled = this.yearDisplayed > this.monthConfig.maxMonthDate.year || (this.yearDisplayed == this.monthConfig.maxMonthDate.year && currentIndex + 1 > this.monthConfig.maxMonthDate.month);\n      } else {\n        maxMonthDisabled = this.yearBase + currentIndex > this.monthConfig.maxMonthDate.year;\n      }\n    }\n\n    return minMonthDisabled || maxMonthDisabled;\n  }\n\n  public getArrowDisabled(arrow: 'left' | 'right'): boolean {\n    if (arrow == 'left' && this.monthConfig?.minMonthDate) {\n      if (this.isShowingMonths) {\n        return this.yearDisplayed <= this.monthConfig.minMonthDate.year;\n      } else {\n        return this.yearBase < this.monthConfig.minMonthDate.year;\n      }\n    }\n\n    if (arrow == 'right' && this.monthConfig?.maxMonthDate) {\n      if (this.isShowingMonths) {\n        return this.yearDisplayed >= this.monthConfig.maxMonthDate.year;\n      } else {\n        return this.yearBase + 12 > this.monthConfig.maxMonthDate.year;\n      }\n    }\n  }\n\n  @HostListener('document:click', ['$event'])\n  onDocumentClick(): void {\n    if (this.isShowingCalendar) {\n      this.isShowingCalendar = false;\n      this.closeCalendar.emit(false);\n    }\n  }\n}\n\nexport interface GravityMonthPickerDate {\n  month: number;\n  year: number;\n}\n","<ng-container *ngIf=\"isShowingCalendar\">\n  <div class=\"calendar-header\">\n    <div class=\"month-picker-arrow month-picker-arrow-previous\">\n      <button class=\"hr-label sm-regular\" [disabled]=\"getArrowDisabled('left')\" (click)=\"subtractYear()\">\n        <span></span>\n      </button>\n    </div>\n    <div class=\"hr-label md-regular month-picker-year\">\n      <span (click)=\"$event.stopPropagation(); isShowingMonths = false\" *ngIf=\"isShowingMonths\">\n        {{yearDisplayed}}\n      </span>\n      <span (click)=\"$event.stopPropagation(); isShowingMonths = true\" *ngIf=\"!isShowingMonths\">\n        {{yearBase + 1}} - {{yearBase + 10}}\n      </span>\n    </div>\n    <div class=\"month-picker-arrow month-picker-arrow-next\">\n      <button class=\"hr-label sm-regular\" [disabled]=\"getArrowDisabled('right')\" (click)=\"addYear()\">\n        <span></span>\n      </button>\n    </div>\n  </div>\n  <div class=\"calendar-body hr-label sm-regular\">\n    <article [class.active]=\"(isShowingMonths && monthPickerData.month == i + 1 && monthPickerData.year == yearDisplayed) || (!isShowingMonths && monthPickerData.year == i + yearBase)\"\n             [class.disabled]=\"getDisabled(i)\"\n             (click)=\"isShowingMonths ? changeMonth(i, getDisabled(i)) : changeYear(i + yearBase, getDisabled(i))\"\n             *ngFor=\"let month of getMonths(); let i = index\">\n      <span *ngIf=\"isShowingMonths\">{{month}}</span>\n      <span *ngIf=\"!isShowingMonths\">{{i + yearBase}}</span>\n    </article>\n  </div>\n</ng-container>\n"]}
@@ -1,40 +0,0 @@
1
- import { EventEmitter, OnInit } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export declare class GravityMonthPickerComponent implements OnInit {
4
- closeCalendar: EventEmitter<boolean>;
5
- monthSelected: EventEmitter<GravityMonthPickerDate>;
6
- currentLang: string;
7
- monthConfig: {
8
- customMonthDate?: GravityMonthPickerDate;
9
- maxMonthDate?: GravityMonthPickerDate;
10
- minMonthDate?: GravityMonthPickerDate;
11
- };
12
- readonly monthsEn: string[];
13
- readonly monthsEs: string[];
14
- isShowingCalendar: boolean;
15
- isShowingMonths: boolean;
16
- monthPickerData: GravityMonthPickerDate;
17
- monthIndex: number;
18
- yearBase: number;
19
- yearDisplayed: number;
20
- constructor();
21
- ngOnInit(): void;
22
- showCalendar(): void;
23
- hideCalendar(): void;
24
- private updateYear;
25
- addYear(): void;
26
- subtractYear(): void;
27
- changeYear(newYear: number, disabled: boolean): void;
28
- private static getYearsRangeBase;
29
- changeMonth(monthIndex: number, disabled: boolean): void;
30
- getMonths(): string[];
31
- getDisabled(currentIndex: number): boolean;
32
- getArrowDisabled(arrow: 'left' | 'right'): boolean;
33
- onDocumentClick(): void;
34
- static ɵfac: i0.ɵɵFactoryDeclaration<GravityMonthPickerComponent, never>;
35
- static ɵcmp: i0.ɵɵComponentDeclaration<GravityMonthPickerComponent, "gravity-month-picker", never, { "currentLang": { "alias": "currentLang"; "required": false; }; "monthConfig": { "alias": "monthConfig"; "required": false; }; }, { "closeCalendar": "closeCalendar"; "monthSelected": "monthSelected"; }, never, never, false, never>;
36
- }
37
- export interface GravityMonthPickerDate {
38
- month: number;
39
- year: number;
40
- }