@progressio_resources/gravity-design-system 2.3.3 → 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.
@@ -1,10 +1,8 @@
1
- import { AfterViewInit, EventEmitter, OnChanges, SimpleChanges } from '@angular/core';
2
- import { NgbDate, NgbDateStruct } from "@ng-bootstrap/ng-bootstrap";
3
- import { GravityMonthPickerDate } from "./gravity-month-picker/gravity-month-picker.component";
1
+ import { EventEmitter, OnChanges, SimpleChanges } from '@angular/core';
4
2
  import * as i0 from "@angular/core";
5
- export declare class GravityCalendarComponent implements OnChanges, AfterViewInit {
3
+ export declare class GravityCalendarComponent implements OnChanges {
6
4
  calendarResponse: EventEmitter<Date>;
7
- calendarType: 'date' | 'month';
5
+ calendarType: 'day' | 'month' | 'year';
8
6
  currentLang: string;
9
7
  cypressTag: string;
10
8
  datesConfig: {
@@ -14,38 +12,26 @@ export declare class GravityCalendarComponent implements OnChanges, AfterViewIni
14
12
  minDate?: Date;
15
13
  };
16
14
  label: string;
17
- monthConfig: {
18
- customMonthDate?: GravityMonthPickerDate;
19
- maxMonthDate?: GravityMonthPickerDate;
20
- minMonthDate?: GravityMonthPickerDate;
21
- };
22
15
  required: boolean;
23
16
  state: 'readonly' | 'disabled' | 'enabled';
24
17
  supportTextContent: string;
25
18
  supportTextType: 'neutro' | 'negative' | 'positive';
26
- private datePicker;
27
- private datepickerInput;
28
- private monthPickerInput;
29
- calendarOpened: boolean;
19
+ bsDatepickerConfig: {
20
+ containerClass: string;
21
+ isAnimated: boolean;
22
+ selectFromOtherMonth: boolean;
23
+ showWeekNumbers: boolean;
24
+ };
25
+ readonly elementId: string;
30
26
  focusInput: boolean;
31
- maxDate: NgbDateStruct;
32
- minDate: NgbDateStruct;
27
+ maxDate: Date;
28
+ minDate: Date;
33
29
  selectedDate: Date;
34
- selectedDateInput: string;
35
- private customDateFlag;
30
+ constructor();
36
31
  ngOnChanges(changes: SimpleChanges): void;
37
- ngAfterViewInit(): void;
38
- updateSelectedDate($event: NgbDate): void;
39
- focusCustomDate(customDate: Date): void;
32
+ updateSelectedDate($event: Date): void;
40
33
  resetCalendar(newDate: Date): void;
41
- private changeDateManually;
42
- private static formatNgbDate;
43
- private static formatMonthDate;
44
- private static formatTSDate;
45
- private static formatDateToNgbDateStruct;
46
- private static convertNgbDateToDate;
47
- private static convertMonthDateToDate;
48
- handleMonthPickerResponse(response: GravityMonthPickerDate): void;
34
+ getBsDatepickerContainer(): string;
49
35
  static ɵfac: i0.ɵɵFactoryDeclaration<GravityCalendarComponent, never>;
50
- static ɵcmp: i0.ɵɵComponentDeclaration<GravityCalendarComponent, "gravity-calendar", never, { "calendarType": { "alias": "calendarType"; "required": false; }; "currentLang": { "alias": "currentLang"; "required": false; }; "cypressTag": { "alias": "cypressTag"; "required": false; }; "datesConfig": { "alias": "datesConfig"; "required": false; }; "label": { "alias": "label"; "required": false; }; "monthConfig": { "alias": "monthConfig"; "required": false; }; "required": { "alias": "required"; "required": false; }; "state": { "alias": "state"; "required": false; }; "supportTextContent": { "alias": "supportTextContent"; "required": false; }; "supportTextType": { "alias": "supportTextType"; "required": false; }; }, { "calendarResponse": "response"; }, never, never, false, never>;
36
+ static ɵcmp: i0.ɵɵComponentDeclaration<GravityCalendarComponent, "gravity-calendar", never, { "calendarType": { "alias": "calendarType"; "required": false; }; "currentLang": { "alias": "currentLang"; "required": false; }; "cypressTag": { "alias": "cypressTag"; "required": false; }; "datesConfig": { "alias": "datesConfig"; "required": false; }; "label": { "alias": "label"; "required": false; }; "required": { "alias": "required"; "required": false; }; "state": { "alias": "state"; "required": false; }; "supportTextContent": { "alias": "supportTextContent"; "required": false; }; "supportTextType": { "alias": "supportTextType"; "required": false; }; }, { "calendarResponse": "response"; }, never, never, false, never>;
51
37
  }
@@ -1,12 +1,17 @@
1
- import { EventEmitter } from '@angular/core';
2
- import { PrettyRadioChange } from "ngx-pretty-checkbox";
1
+ import { AfterViewInit, EventEmitter } from '@angular/core';
3
2
  import * as i0 from "@angular/core";
4
- export declare class GravityCheckboxComponent {
5
- value: any;
6
- disabled: boolean;
3
+ export declare class GravityCheckboxComponent implements AfterViewInit {
7
4
  checked: boolean;
8
- change: EventEmitter<PrettyRadioChange>;
9
- onChange(event: PrettyRadioChange): void;
5
+ disabled: boolean;
6
+ name: string;
7
+ value: string;
8
+ change: EventEmitter<{
9
+ value: string;
10
+ checked: boolean;
11
+ }>;
12
+ isCheckboxActive: boolean;
13
+ ngAfterViewInit(): void;
14
+ toggleCheckbox(): void;
10
15
  static ɵfac: i0.ɵɵFactoryDeclaration<GravityCheckboxComponent, never>;
11
- static ɵcmp: i0.ɵɵComponentDeclaration<GravityCheckboxComponent, "gravity-checkbox", never, { "value": { "alias": "value"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "checked": { "alias": "checked"; "required": false; }; }, { "change": "change"; }, never, ["*"], false, never>;
16
+ static ɵcmp: i0.ɵɵComponentDeclaration<GravityCheckboxComponent, "gravity-checkbox", never, { "checked": { "alias": "checked"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "name": { "alias": "name"; "required": false; }; "value": { "alias": "value"; "required": false; }; }, { "change": "change"; }, never, ["*"], false, never>;
12
17
  }
@@ -1,7 +1,6 @@
1
- import { EventEmitter } from '@angular/core';
2
- import { PrettyCheckBoxChange } from "ngx-pretty-checkbox/lib/model";
1
+ import { AfterViewInit, EventEmitter } from '@angular/core';
3
2
  import * as i0 from "@angular/core";
4
- export declare class GravitySwitchComponent {
3
+ export declare class GravitySwitchComponent implements AfterViewInit {
5
4
  currentLang: string;
6
5
  customCheck: boolean;
7
6
  cypressTag: string;
@@ -10,7 +9,9 @@ export declare class GravitySwitchComponent {
10
9
  state: 'readonly' | 'disabled' | 'enabled';
11
10
  toggleOptions: string[];
12
11
  switchResponse: EventEmitter<boolean>;
13
- toggleSwitchHandler($event: PrettyCheckBoxChange): void;
12
+ isSwitchActive: boolean;
13
+ ngAfterViewInit(): void;
14
+ toggleSwitch(): void;
14
15
  static ɵfac: i0.ɵɵFactoryDeclaration<GravitySwitchComponent, never>;
15
16
  static ɵcmp: i0.ɵɵComponentDeclaration<GravitySwitchComponent, "gravity-switch", never, { "currentLang": { "alias": "currentLang"; "required": false; }; "customCheck": { "alias": "customCheck"; "required": false; }; "cypressTag": { "alias": "cypressTag"; "required": false; }; "label": { "alias": "label"; "required": false; }; "required": { "alias": "required"; "required": false; }; "state": { "alias": "state"; "required": false; }; "toggleOptions": { "alias": "toggleOptions"; "required": false; }; }, { "switchResponse": "response"; }, never, never, false, never>;
16
17
  }
@@ -6,21 +6,21 @@ import * as i4 from "./components/gravity-checkbox/gravity-checkbox.component";
6
6
  import * as i5 from "./components/gravity-dialog/gravity-dialog.component";
7
7
  import * as i6 from "./components/gravity-dropdown-list/gravity-dropdown-list.component";
8
8
  import * as i7 from "./components/gravity-icon/gravity-icon.component";
9
- import * as i8 from "./components/gravity-calendar/gravity-month-picker/gravity-month-picker.component";
10
- import * as i9 from "./components/gravity-notification/gravity-notification.component";
11
- import * as i10 from "./components/gravity-notification-instant/gravity-notification-instant-container.component";
12
- import * as i11 from "./components/gravity-radio-button/gravity-radio-button.component";
13
- import * as i12 from "./components/gravity-stepper/gravity-stepper.component";
14
- import * as i13 from "./components/gravity-switch/gravity-switch.component";
15
- import * as i14 from "./components/gravity-table/gravity-table.component";
16
- import * as i15 from "./components/gravity-text-field/gravity-text-field.component";
17
- import * as i16 from "./components/gravity-tree-view/gravity-tree-view.component";
18
- import * as i17 from "./components/gravity-tree-view/node/node.component";
19
- import * as i18 from "./components/gravity-tree-view/node/node-toggle/node-toggle.component";
20
- import * as i19 from "./components/gravity-tree-view/node/node-checkbox/node-checkbox.component";
21
- import * as i20 from "./components/gravity-tree-view/node/node-name/node-name.component";
22
- import * as i21 from "angular-svg-icon";
23
- import * as i22 from "angular-svg-icon-preloader";
9
+ import * as i8 from "./components/gravity-notification/gravity-notification.component";
10
+ import * as i9 from "./components/gravity-notification-instant/gravity-notification-instant-container.component";
11
+ import * as i10 from "./components/gravity-radio-button/gravity-radio-button.component";
12
+ import * as i11 from "./components/gravity-stepper/gravity-stepper.component";
13
+ import * as i12 from "./components/gravity-switch/gravity-switch.component";
14
+ import * as i13 from "./components/gravity-table/gravity-table.component";
15
+ import * as i14 from "./components/gravity-text-field/gravity-text-field.component";
16
+ import * as i15 from "./components/gravity-tree-view/gravity-tree-view.component";
17
+ import * as i16 from "./components/gravity-tree-view/node/node.component";
18
+ import * as i17 from "./components/gravity-tree-view/node/node-toggle/node-toggle.component";
19
+ import * as i18 from "./components/gravity-tree-view/node/node-checkbox/node-checkbox.component";
20
+ import * as i19 from "./components/gravity-tree-view/node/node-name/node-name.component";
21
+ import * as i20 from "angular-svg-icon";
22
+ import * as i21 from "angular-svg-icon-preloader";
23
+ import * as i22 from "ngx-bootstrap/datepicker";
24
24
  import * as i23 from "@angular/common";
25
25
  import * as i24 from "@angular/forms";
26
26
  import * as i25 from "./vendor/gravity-tooltip/gravity-tooltip.module";
@@ -29,6 +29,6 @@ import * as i27 from "@ng-select/ng-select";
29
29
  import * as i28 from "ngx-pretty-checkbox";
30
30
  export declare class GravityDesignSystemModule {
31
31
  static ɵfac: i0.ɵɵFactoryDeclaration<GravityDesignSystemModule, never>;
32
- static ɵmod: i0.ɵɵNgModuleDeclaration<GravityDesignSystemModule, [typeof i1.GravityAttachFileComponent, typeof i2.GravityButtonComponent, typeof i3.GravityCalendarComponent, typeof i4.GravityCheckboxComponent, typeof i5.GravityDialogComponent, typeof i6.GravityDropdownListComponent, typeof i7.GravityIconComponent, typeof i8.GravityMonthPickerComponent, typeof i9.GravityNotificationComponent, typeof i10.GravityNotificationInstantContainerComponent, typeof i11.GravityRadioButtonComponent, typeof i12.GravityStepperComponent, typeof i13.GravitySwitchComponent, typeof i14.GravityTableComponent, typeof i15.GravityTextFieldComponent, typeof i16.GravityTreeViewComponent, typeof i17.NodeComponent, typeof i18.NodeToggleComponent, typeof i19.NodeCheckboxComponent, typeof i20.NodeNameComponent], [typeof i21.AngularSvgIconModule, typeof i22.AngularSvgIconPreloaderModule, typeof i23.CommonModule, typeof i24.FormsModule, typeof i25.GravityTooltipModule, typeof i26.NgbDatepickerModule, typeof i26.NgbProgressbarModule, typeof i26.NgbToastModule, typeof i27.NgSelectModule, typeof i28.NgxPrettyCheckboxModule, typeof i24.ReactiveFormsModule], [typeof i1.GravityAttachFileComponent, typeof i2.GravityButtonComponent, typeof i3.GravityCalendarComponent, typeof i4.GravityCheckboxComponent, typeof i5.GravityDialogComponent, typeof i6.GravityDropdownListComponent, typeof i7.GravityIconComponent, typeof i10.GravityNotificationInstantContainerComponent, typeof i11.GravityRadioButtonComponent, typeof i12.GravityStepperComponent, typeof i13.GravitySwitchComponent, typeof i14.GravityTableComponent, typeof i15.GravityTextFieldComponent, typeof i25.GravityTooltipModule, typeof i16.GravityTreeViewComponent]>;
32
+ static ɵmod: i0.ɵɵNgModuleDeclaration<GravityDesignSystemModule, [typeof i1.GravityAttachFileComponent, typeof i2.GravityButtonComponent, typeof i3.GravityCalendarComponent, typeof i4.GravityCheckboxComponent, typeof i5.GravityDialogComponent, typeof i6.GravityDropdownListComponent, typeof i7.GravityIconComponent, typeof i8.GravityNotificationComponent, typeof i9.GravityNotificationInstantContainerComponent, typeof i10.GravityRadioButtonComponent, typeof i11.GravityStepperComponent, typeof i12.GravitySwitchComponent, typeof i13.GravityTableComponent, typeof i14.GravityTextFieldComponent, typeof i15.GravityTreeViewComponent, typeof i16.NodeComponent, typeof i17.NodeToggleComponent, typeof i18.NodeCheckboxComponent, typeof i19.NodeNameComponent], [typeof i20.AngularSvgIconModule, typeof i21.AngularSvgIconPreloaderModule, typeof i22.BsDatepickerModule, typeof i23.CommonModule, typeof i24.FormsModule, typeof i25.GravityTooltipModule, typeof i26.NgbDatepickerModule, typeof i26.NgbProgressbarModule, typeof i26.NgbToastModule, typeof i27.NgSelectModule, typeof i28.NgxPrettyCheckboxModule, typeof i24.ReactiveFormsModule], [typeof i1.GravityAttachFileComponent, typeof i2.GravityButtonComponent, typeof i3.GravityCalendarComponent, typeof i4.GravityCheckboxComponent, typeof i5.GravityDialogComponent, typeof i6.GravityDropdownListComponent, typeof i7.GravityIconComponent, typeof i9.GravityNotificationInstantContainerComponent, typeof i10.GravityRadioButtonComponent, typeof i11.GravityStepperComponent, typeof i12.GravitySwitchComponent, typeof i13.GravityTableComponent, typeof i14.GravityTextFieldComponent, typeof i25.GravityTooltipModule, typeof i15.GravityTreeViewComponent]>;
33
33
  static ɵinj: i0.ɵɵInjectorDeclaration<GravityDesignSystemModule>;
34
34
  }
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@progressio_resources/gravity-design-system",
3
3
  "description": "Gravity Design System",
4
- "version": "2.3.3",
4
+ "version": "2.4.0",
5
5
  "license": "SEE LICENSE IN LIBRARY-LICENSE",
6
6
  "peerDependencies": {
7
7
  "@angular/common": "^16.2.12",
@@ -12,6 +12,7 @@
12
12
  "@popperjs/core": "^2.11.8",
13
13
  "angular-svg-icon": "^16.1.0",
14
14
  "angular-svg-icon-preloader": "^6.0.0",
15
+ "ngx-bootstrap": "^12.0.0",
15
16
  "ngx-pretty-checkbox": "^16.0.0",
16
17
  "pretty-checkbox": "^3.0.3"
17
18
  },
@@ -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":"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","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"]}