lib-portal-angular 0.0.73 → 0.0.75

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 (28) hide show
  1. package/esm2022/lib/components/accordion/accordion.component.mjs +2 -2
  2. package/esm2022/lib/components/badge/badge.component.mjs +43 -66
  3. package/esm2022/lib/components/button/button.component.mjs +82 -105
  4. package/esm2022/lib/components/calendar-argenta/calendar-argenta.component.mjs +2 -2
  5. package/esm2022/lib/components/confirmation/confirmation.component.mjs +2 -2
  6. package/esm2022/lib/components/custom-pagination/custom-pagination.component.mjs +2 -2
  7. package/esm2022/lib/components/custom-switch/custom-switch.component.mjs +2 -2
  8. package/esm2022/lib/components/file-upload/file-upload.component.mjs +2 -2
  9. package/esm2022/lib/components/imput/input.component.mjs +2 -2
  10. package/esm2022/lib/components/modal/modal.component.mjs +2 -2
  11. package/esm2022/lib/components/multi-select/multi-select.component.mjs +2 -2
  12. package/esm2022/lib/components/radio/radio.component.mjs +14 -48
  13. package/esm2022/lib/components/search-customer/search-customer.component.mjs +5 -4
  14. package/esm2022/lib/components/search-input/search-input.component.mjs +2 -2
  15. package/esm2022/lib/components/select/select.component.mjs +2 -2
  16. package/esm2022/lib/components/tab/tab.component.mjs +2 -2
  17. package/esm2022/lib/components/tables/data-table.component.mjs +2 -2
  18. package/esm2022/lib/components/tree-node/tree-node.component.mjs +3 -3
  19. package/esm2022/lib/function/SetThemeColors.mjs +39 -0
  20. package/esm2022/public-api.mjs +66 -64
  21. package/fesm2022/lib-portal-angular.mjs +209 -250
  22. package/fesm2022/lib-portal-angular.mjs.map +1 -1
  23. package/lib/components/badge/badge.component.d.ts +7 -7
  24. package/lib/components/button/button.component.d.ts +8 -6
  25. package/lib/components/radio/radio.component.d.ts +2 -2
  26. package/lib/function/SetThemeColors.d.ts +14 -0
  27. package/package.json +1 -1
  28. package/public-api.d.ts +64 -63
@@ -45,11 +45,11 @@ export class AccordionArgentaComponent {
45
45
  }
46
46
  }
47
47
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AccordionArgentaComponent, deps: [{ token: i1.AuthService }], target: i0.ɵɵFactoryTarget.Component }); }
48
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AccordionArgentaComponent, selector: "argenta-accordion", inputs: { title: "title", isOpen: "isOpen", permissions: "permissions" }, outputs: { toggleEvent: "toggleEvent" }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"hasPermission()\">\n <div class=\"accordion\">\n <div class=\"accordion-header\" (click)=\"toggle()\" [class.open]=\"isOpen\">\n <h3>{{ title }}</h3>\n <!-- \u00CDcone da seta -->\n <span class=\"accordion-icon\">\u25BC</span>\n </div>\n <div class=\"accordion-content\" [class.open]=\"isOpen\">\n <ng-content></ng-content> <!-- Conte\u00FAdo do accordion -->\n </div>\n </div>\n</ng-container>\n", styles: ["@charset \"UTF-8\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@400;700&display=swap\";body{font-family:Inter,sans-serif}.accordion{border:1px solid #ccc;border-radius:8px;margin-bottom:15px;font-family:Inter,Arial,sans-serif;transition:max-height .4s ease;overflow:hidden}.accordion .accordion-header{background-color:#00444c;color:#fff;cursor:pointer;padding:10px;display:flex;justify-content:space-between;align-items:center;font-size:1.2rem}.accordion .accordion-header h3{margin:0;font-size:1rem;font-weight:700}.accordion .accordion-header .accordion-icon{font-size:1.2rem;transition:transform .4s ease;transform:rotate(0)}.accordion .accordion-header.open .accordion-icon{transform:rotate(180deg)}.accordion .accordion-content{max-height:0;overflow:hidden;padding:0 10px;background-color:#fff;font-size:.9rem;transition:max-height .4s ease,padding .4s ease}.accordion .accordion-content.open{max-height:500px;padding:10px;border-bottom-left-radius:8px;border-bottom-right-radius:8px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
48
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AccordionArgentaComponent, selector: "argenta-accordion", inputs: { title: "title", isOpen: "isOpen", permissions: "permissions" }, outputs: { toggleEvent: "toggleEvent" }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"hasPermission()\">\n <div class=\"accordion\">\n <div class=\"accordion-header\" (click)=\"toggle()\" [class.open]=\"isOpen\">\n <h3>{{ title }}</h3>\n <!-- \u00CDcone da seta -->\n <span class=\"accordion-icon\">\u25BC</span>\n </div>\n <div class=\"accordion-content\" [class.open]=\"isOpen\">\n <ng-content></ng-content> <!-- Conte\u00FAdo do accordion -->\n </div>\n </div>\n</ng-container>\n", styles: ["@charset \"UTF-8\";.accordion{border:1px solid #ccc;border-radius:8px;margin-bottom:15px;font-family:var(--font-family);transition:max-height .4s ease;overflow:hidden}.accordion .accordion-header{background-color:var(--primary-color);color:var(--text-color);cursor:pointer;padding:10px;display:flex;justify-content:space-between;align-items:center;font-size:1.2rem}.accordion .accordion-header h3{margin:0;font-size:1rem;font-weight:700}.accordion .accordion-header .accordion-icon{font-size:1.2rem;transition:transform .4s ease;transform:rotate(0)}.accordion .accordion-header.open .accordion-icon{transform:rotate(180deg)}.accordion .accordion-content{max-height:0;overflow:hidden;padding:0 10px;background-color:#fff;font-size:.9rem;transition:max-height .4s ease,padding .4s ease}.accordion .accordion-content.open{max-height:500px;padding:10px;border-bottom-left-radius:8px;border-bottom-right-radius:8px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
49
49
  }
50
50
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AccordionArgentaComponent, decorators: [{
51
51
  type: Component,
52
- args: [{ selector: 'argenta-accordion', template: "<ng-container *ngIf=\"hasPermission()\">\n <div class=\"accordion\">\n <div class=\"accordion-header\" (click)=\"toggle()\" [class.open]=\"isOpen\">\n <h3>{{ title }}</h3>\n <!-- \u00CDcone da seta -->\n <span class=\"accordion-icon\">\u25BC</span>\n </div>\n <div class=\"accordion-content\" [class.open]=\"isOpen\">\n <ng-content></ng-content> <!-- Conte\u00FAdo do accordion -->\n </div>\n </div>\n</ng-container>\n", styles: ["@charset \"UTF-8\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@400;700&display=swap\";body{font-family:Inter,sans-serif}.accordion{border:1px solid #ccc;border-radius:8px;margin-bottom:15px;font-family:Inter,Arial,sans-serif;transition:max-height .4s ease;overflow:hidden}.accordion .accordion-header{background-color:#00444c;color:#fff;cursor:pointer;padding:10px;display:flex;justify-content:space-between;align-items:center;font-size:1.2rem}.accordion .accordion-header h3{margin:0;font-size:1rem;font-weight:700}.accordion .accordion-header .accordion-icon{font-size:1.2rem;transition:transform .4s ease;transform:rotate(0)}.accordion .accordion-header.open .accordion-icon{transform:rotate(180deg)}.accordion .accordion-content{max-height:0;overflow:hidden;padding:0 10px;background-color:#fff;font-size:.9rem;transition:max-height .4s ease,padding .4s ease}.accordion .accordion-content.open{max-height:500px;padding:10px;border-bottom-left-radius:8px;border-bottom-right-radius:8px}\n"] }]
52
+ args: [{ selector: 'argenta-accordion', template: "<ng-container *ngIf=\"hasPermission()\">\n <div class=\"accordion\">\n <div class=\"accordion-header\" (click)=\"toggle()\" [class.open]=\"isOpen\">\n <h3>{{ title }}</h3>\n <!-- \u00CDcone da seta -->\n <span class=\"accordion-icon\">\u25BC</span>\n </div>\n <div class=\"accordion-content\" [class.open]=\"isOpen\">\n <ng-content></ng-content> <!-- Conte\u00FAdo do accordion -->\n </div>\n </div>\n</ng-container>\n", styles: ["@charset \"UTF-8\";.accordion{border:1px solid #ccc;border-radius:8px;margin-bottom:15px;font-family:var(--font-family);transition:max-height .4s ease;overflow:hidden}.accordion .accordion-header{background-color:var(--primary-color);color:var(--text-color);cursor:pointer;padding:10px;display:flex;justify-content:space-between;align-items:center;font-size:1.2rem}.accordion .accordion-header h3{margin:0;font-size:1rem;font-weight:700}.accordion .accordion-header .accordion-icon{font-size:1.2rem;transition:transform .4s ease;transform:rotate(0)}.accordion .accordion-header.open .accordion-icon{transform:rotate(180deg)}.accordion .accordion-content{max-height:0;overflow:hidden;padding:0 10px;background-color:#fff;font-size:.9rem;transition:max-height .4s ease,padding .4s ease}.accordion .accordion-content.open{max-height:500px;padding:10px;border-bottom-left-radius:8px;border-bottom-right-radius:8px}\n"] }]
53
53
  }], ctorParameters: function () { return [{ type: i1.AuthService }]; }, propDecorators: { title: [{
54
54
  type: Input
55
55
  }], isOpen: [{
@@ -1,11 +1,11 @@
1
- import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, Output } from '@angular/core';
2
- import { ButtonClasses } from '../../enum/ButtonClassesEnum';
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, Output, } from "@angular/core";
2
+ import { ButtonClasses } from "../../enum/ButtonClassesEnum";
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/common";
5
5
  export class BadgeComponent {
6
6
  constructor() {
7
- this.label = 'Mensagem';
8
- this.badgeContent = '+45';
7
+ this.label = "Mensagem";
8
+ this.badgeContent = "+45";
9
9
  this.marginTop = 0;
10
10
  this.marginBottom = 0;
11
11
  this.marginLeft = 0;
@@ -17,56 +17,61 @@ export class BadgeComponent {
17
17
  this.isActive = false;
18
18
  }
19
19
  getDynamicStyles() {
20
- let backgroundColor = '';
21
- let textColor = '#fff'; // Default text color
22
- let borderColor = '';
20
+ let backgroundColor = "";
21
+ let textColor = getComputedStyle(document.documentElement)
22
+ .getPropertyValue("--text-color")
23
+ .trim();
24
+ let borderColor = "";
25
+ const getCSSVariable = (variable) => getComputedStyle(document.documentElement)
26
+ .getPropertyValue(variable)
27
+ .trim();
23
28
  switch (this.btnClass) {
24
29
  case ButtonClasses.Primary:
25
- backgroundColor = '#00444C';
30
+ backgroundColor = getCSSVariable("--primary-color");
26
31
  break;
27
32
  case ButtonClasses.Secondary:
28
- backgroundColor = '#2CA58D';
33
+ backgroundColor = getCSSVariable("--secondary-color");
29
34
  break;
30
35
  case ButtonClasses.Success:
31
- backgroundColor = '#00C853';
36
+ backgroundColor = getCSSVariable("--success-color");
32
37
  break;
33
38
  case ButtonClasses.Danger:
34
- backgroundColor = '#D32F2F';
39
+ backgroundColor = getCSSVariable("--danger-color");
35
40
  break;
36
41
  case ButtonClasses.Warning:
37
- backgroundColor = '#FFC107';
42
+ backgroundColor = getCSSVariable("--warning-color");
38
43
  break;
39
44
  case ButtonClasses.Info:
40
- backgroundColor = '#3EC9D6';
45
+ backgroundColor = getCSSVariable("--info-color");
41
46
  break;
42
47
  case ButtonClasses.Light:
43
- backgroundColor = '#EEF2F6';
44
- textColor = '#00444C'; // Custom text color for Light
48
+ backgroundColor = getCSSVariable("--light-color");
49
+ textColor = getCSSVariable("--primary-color");
45
50
  break;
46
51
  case ButtonClasses.Dark:
47
- backgroundColor = '#111936';
52
+ backgroundColor = getCSSVariable("--dark-color");
48
53
  break;
49
54
  case ButtonClasses.Link:
50
- backgroundColor = 'transparent';
51
- borderColor = '#DDE5E9';
52
- textColor = '#00444C'; // Custom text color for Link
55
+ backgroundColor = "transparent";
56
+ borderColor = getCSSVariable("--link-border-color");
57
+ textColor = getCSSVariable("--primary-color");
53
58
  break;
54
59
  default:
55
- backgroundColor = '#00444C';
60
+ backgroundColor = getCSSVariable("--primary-color");
56
61
  break;
57
62
  }
58
- const hoverFilter = this.isHovered ? 'brightness(80%)' : 'none'; // Adjusted hover brightness
59
- const activeFilter = this.isClicked ? 'brightness(60%)' : hoverFilter; // Adjusted active brightness
63
+ const hoverFilter = this.isHovered ? "brightness(80%)" : "none";
64
+ const activeFilter = this.isClicked ? "brightness(60%)" : hoverFilter;
60
65
  return {
61
- 'margin-top': `${this.marginTop}rem`,
62
- 'margin-bottom': `${this.marginBottom}rem`,
63
- 'margin-left': `${this.marginLeft}rem`,
64
- 'margin-right': `${this.marginRight}rem`,
65
- 'background-color': backgroundColor,
66
- 'color': textColor,
67
- 'border': borderColor ? `1px solid ${borderColor}` : 'none',
68
- 'transition': 'background-color 0.3s, border-color 0.3s, filter 0.3s',
69
- 'filter': activeFilter
66
+ "margin-top": `${this.marginTop}rem`,
67
+ "margin-bottom": `${this.marginBottom}rem`,
68
+ "margin-left": `${this.marginLeft}rem`,
69
+ "margin-right": `${this.marginRight}rem`,
70
+ "background-color": backgroundColor,
71
+ color: textColor,
72
+ border: borderColor ? `1px solid ${borderColor}` : "none",
73
+ transition: "background-color 0.3s, border-color 0.3s, filter 0.3s",
74
+ filter: activeFilter,
70
75
  };
71
76
  }
72
77
  onClick() {
@@ -86,39 +91,11 @@ export class BadgeComponent {
86
91
  this.isClicked = false;
87
92
  }
88
93
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BadgeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
89
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: BadgeComponent, selector: "sim-app-badge", inputs: { label: "label", badgeContent: "badgeContent", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight", btnClass: "btnClass" }, outputs: { buttonClick: "buttonClick" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "mousedown": "onMouseDown()", "mouseup": "onMouseUp()" } }, ngImport: i0, template: `
90
- <button
91
- class="notification-button"
92
- [ngStyle]="getDynamicStyles()"
93
- (click)="onClick()"
94
- [class.hovered]="isHovered"
95
- [class.clicked]="isClicked"
96
- (mousedown)="onMouseDown()"
97
- (mouseup)="onMouseUp()"
98
- (mouseleave)="onMouseLeave()"
99
- (mouseenter)="onMouseEnter()">
100
- {{ label }}
101
- <span class="badge">{{ badgeContent }}</span>
102
- </button>
103
- `, isInline: true, styles: [".notification-button{position:relative;display:inline-block;width:155px;height:58px;padding:14px 29px 14px 36px;border-radius:6px;border:none;font-size:16px;font-weight:700;text-align:center;transition:opacity .3s}.badge{position:absolute;width:52px;height:32px;top:-15px;right:-20px;background-color:#dc3545;color:#fff;border-radius:16px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;font-family:Inter,sans-serif}.notification-button.hovered{opacity:.8}.notification-button.clicked{opacity:.6}\n"], dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
94
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: BadgeComponent, selector: "sim-app-badge", inputs: { label: "label", badgeContent: "badgeContent", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight", btnClass: "btnClass" }, outputs: { buttonClick: "buttonClick" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "mousedown": "onMouseDown()", "mouseup": "onMouseUp()" } }, ngImport: i0, template: "<button\n class=\"notification-button\"\n [ngStyle]=\"getDynamicStyles()\"\n (click)=\"onClick()\"\n [class.hovered]=\"isHovered\"\n [class.clicked]=\"isClicked\"\n (mousedown)=\"onMouseDown()\"\n (mouseup)=\"onMouseUp()\"\n (mouseleave)=\"onMouseLeave()\"\n (mouseenter)=\"onMouseEnter()\"\n>\n {{ label }}\n <span class=\"badge\">{{ badgeContent }}</span>\n</button>\n", styles: [".notification-button{position:relative;display:inline-block;width:155px;height:58px;padding:14px 29px 14px 36px;border-radius:6px;border:none;font-size:16px;font-weight:700;text-align:center;transition:opacity .3s}.badge{position:absolute;width:52px;height:32px;top:-15px;right:-20px;background-color:var(--danger-color);color:var(--text-color);border-radius:16px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;font-family:var(--font-family)}.notification-button.hovered{opacity:.8}.notification-button.clicked{opacity:.6}\n"], dependencies: [{ kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
104
95
  }
105
96
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BadgeComponent, decorators: [{
106
97
  type: Component,
107
- args: [{ selector: 'sim-app-badge', template: `
108
- <button
109
- class="notification-button"
110
- [ngStyle]="getDynamicStyles()"
111
- (click)="onClick()"
112
- [class.hovered]="isHovered"
113
- [class.clicked]="isClicked"
114
- (mousedown)="onMouseDown()"
115
- (mouseup)="onMouseUp()"
116
- (mouseleave)="onMouseLeave()"
117
- (mouseenter)="onMouseEnter()">
118
- {{ label }}
119
- <span class="badge">{{ badgeContent }}</span>
120
- </button>
121
- `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".notification-button{position:relative;display:inline-block;width:155px;height:58px;padding:14px 29px 14px 36px;border-radius:6px;border:none;font-size:16px;font-weight:700;text-align:center;transition:opacity .3s}.badge{position:absolute;width:52px;height:32px;top:-15px;right:-20px;background-color:#dc3545;color:#fff;border-radius:16px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;font-family:Inter,sans-serif}.notification-button.hovered{opacity:.8}.notification-button.clicked{opacity:.6}\n"] }]
98
+ args: [{ selector: "sim-app-badge", changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\n class=\"notification-button\"\n [ngStyle]=\"getDynamicStyles()\"\n (click)=\"onClick()\"\n [class.hovered]=\"isHovered\"\n [class.clicked]=\"isClicked\"\n (mousedown)=\"onMouseDown()\"\n (mouseup)=\"onMouseUp()\"\n (mouseleave)=\"onMouseLeave()\"\n (mouseenter)=\"onMouseEnter()\"\n>\n {{ label }}\n <span class=\"badge\">{{ badgeContent }}</span>\n</button>\n", styles: [".notification-button{position:relative;display:inline-block;width:155px;height:58px;padding:14px 29px 14px 36px;border-radius:6px;border:none;font-size:16px;font-weight:700;text-align:center;transition:opacity .3s}.badge{position:absolute;width:52px;height:32px;top:-15px;right:-20px;background-color:var(--danger-color);color:var(--text-color);border-radius:16px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;font-family:var(--font-family)}.notification-button.hovered{opacity:.8}.notification-button.clicked{opacity:.6}\n"] }]
122
99
  }], propDecorators: { label: [{
123
100
  type: Input
124
101
  }], badgeContent: [{
@@ -137,15 +114,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
137
114
  type: Output
138
115
  }], onMouseEnter: [{
139
116
  type: HostListener,
140
- args: ['mouseenter']
117
+ args: ["mouseenter"]
141
118
  }], onMouseLeave: [{
142
119
  type: HostListener,
143
- args: ['mouseleave']
120
+ args: ["mouseleave"]
144
121
  }], onMouseDown: [{
145
122
  type: HostListener,
146
- args: ['mousedown']
123
+ args: ["mousedown"]
147
124
  }], onMouseUp: [{
148
125
  type: HostListener,
149
- args: ['mouseup']
126
+ args: ["mouseup"]
150
127
  }] } });
151
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badge.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/badge/badge.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, Output } from '@angular/core';\nimport { ButtonClasses } from '../../enum/ButtonClassesEnum';\n\n@Component({\n  selector: 'sim-app-badge',\n  template: `\n    <button\n      class=\"notification-button\"\n      [ngStyle]=\"getDynamicStyles()\"\n      (click)=\"onClick()\"\n      [class.hovered]=\"isHovered\"\n      [class.clicked]=\"isClicked\"\n      (mousedown)=\"onMouseDown()\"\n      (mouseup)=\"onMouseUp()\"\n      (mouseleave)=\"onMouseLeave()\"\n      (mouseenter)=\"onMouseEnter()\">\n      {{ label }}\n      <span class=\"badge\">{{ badgeContent }}</span>\n    </button>\n  `,\n  styles: [`\n    .notification-button {\n      position: relative;\n      display: inline-block;\n      width: 155px;\n      height: 58px;\n      padding: 14px 29px 14px 36px;\n      border-radius: 6px;\n      border: none;\n      font-size: 16px;\n      font-weight: bold;\n      text-align: center;\n      transition: opacity 0.3s;\n    }\n    .badge {\n      position: absolute;\n      width: 52px; /* Largura fixa */\n      height: 32px; /* Altura fixa */\n      top: -15px;\n      right: -20px;\n      background-color: #dc3545;\n      color: #FFFFFF;\n      border-radius: 16px; /* Arredondamento das bordas */\n      display: flex;\n      align-items: center;\n      justify-content: center;\n      font-weight: bold;\n      font-size: 14px;\n      font-family: 'Inter', sans-serif;\n    }\n    .notification-button.hovered {\n      opacity: 0.8;\n    }\n    .notification-button.clicked {\n      opacity: 0.6;\n    }\n  `],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BadgeComponent {\n  @Input() label: string = 'Mensagem';\n  @Input() badgeContent: string = '+45';\n  @Input() marginTop: number = 0;\n  @Input() marginBottom: number = 0;\n  @Input() marginLeft: number = 0;\n  @Input() marginRight: number = 0;\n  @Input() btnClass: ButtonClasses = ButtonClasses.Primary;\n  @Output() buttonClick: EventEmitter<void> = new EventEmitter<void>();\n\n  isHovered: boolean = false;\n  isClicked: boolean = false;\n  isActive: boolean = false;\n\n  getDynamicStyles() {\n    let backgroundColor = '';\n    let textColor = '#fff'; // Default text color\n    let borderColor = '';\n\n    switch (this.btnClass) {\n      case ButtonClasses.Primary:\n        backgroundColor = '#00444C';\n        break;\n      case ButtonClasses.Secondary:\n        backgroundColor = '#2CA58D';\n        break;\n      case ButtonClasses.Success:\n        backgroundColor = '#00C853';\n        break;\n      case ButtonClasses.Danger:\n        backgroundColor = '#D32F2F';\n        break;\n      case ButtonClasses.Warning:\n        backgroundColor = '#FFC107';\n        break;\n      case ButtonClasses.Info:\n        backgroundColor = '#3EC9D6';\n        break;\n      case ButtonClasses.Light:\n        backgroundColor = '#EEF2F6';\n        textColor = '#00444C'; // Custom text color for Light\n        break;\n      case ButtonClasses.Dark:\n        backgroundColor = '#111936';\n        break;\n      case ButtonClasses.Link:\n        backgroundColor = 'transparent';\n        borderColor = '#DDE5E9';\n        textColor = '#00444C'; // Custom text color for Link\n        break;\n      default:\n        backgroundColor = '#00444C';\n        break;\n    }\n\n    const hoverFilter = this.isHovered ? 'brightness(80%)' : 'none'; // Adjusted hover brightness\n    const activeFilter = this.isClicked ? 'brightness(60%)' : hoverFilter; // Adjusted active brightness\n\n    return {\n      'margin-top': `${this.marginTop}rem`,\n      'margin-bottom': `${this.marginBottom}rem`,\n      'margin-left': `${this.marginLeft}rem`,\n      'margin-right': `${this.marginRight}rem`,\n      'background-color': backgroundColor,\n      'color': textColor,\n      'border': borderColor ? `1px solid ${borderColor}` : 'none',\n      'transition': 'background-color 0.3s, border-color 0.3s, filter 0.3s',\n      'filter': activeFilter\n    };\n  }\n\n  onClick() {\n    this.buttonClick.emit();\n  }\n\n  @HostListener('mouseenter')\n  onMouseEnter() {\n    this.isHovered = true;\n  }\n\n  @HostListener('mouseleave')\n  onMouseLeave() {\n    this.isHovered = false;\n    this.isClicked = false;\n  }\n\n  @HostListener('mousedown')\n  onMouseDown() {\n    this.isClicked = true;\n  }\n\n  @HostListener('mouseup')\n  onMouseUp() {\n    this.isClicked = false;\n  }\n}\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badge.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/badge/badge.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/badge/badge.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  HostListener,\n  Input,\n  Output,\n} from \"@angular/core\";\nimport { ButtonClasses } from \"../../enum/ButtonClassesEnum\";\n\n@Component({\n  selector: \"sim-app-badge\",\n  templateUrl: \"./badge.component.html\",\n  styleUrls: [\"./badge.component.scss\"],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BadgeComponent {\n  @Input() label: string = \"Mensagem\";\n  @Input() badgeContent: string = \"+45\";\n  @Input() marginTop: number = 0;\n  @Input() marginBottom: number = 0;\n  @Input() marginLeft: number = 0;\n  @Input() marginRight: number = 0;\n  @Input() btnClass: ButtonClasses = ButtonClasses.Primary;\n  @Output() buttonClick: EventEmitter<void> = new EventEmitter<void>();\n\n  isHovered: boolean = false;\n  isClicked: boolean = false;\n  isActive: boolean = false;\n\n  getDynamicStyles() {\n    let backgroundColor = \"\";\n    let textColor = getComputedStyle(document.documentElement)\n      .getPropertyValue(\"--text-color\")\n      .trim();\n    let borderColor = \"\";\n\n    const getCSSVariable = (variable: string) =>\n      getComputedStyle(document.documentElement)\n        .getPropertyValue(variable)\n        .trim();\n\n    switch (this.btnClass) {\n      case ButtonClasses.Primary:\n        backgroundColor = getCSSVariable(\"--primary-color\");\n        break;\n      case ButtonClasses.Secondary:\n        backgroundColor = getCSSVariable(\"--secondary-color\");\n        break;\n      case ButtonClasses.Success:\n        backgroundColor = getCSSVariable(\"--success-color\");\n        break;\n      case ButtonClasses.Danger:\n        backgroundColor = getCSSVariable(\"--danger-color\");\n        break;\n      case ButtonClasses.Warning:\n        backgroundColor = getCSSVariable(\"--warning-color\");\n        break;\n      case ButtonClasses.Info:\n        backgroundColor = getCSSVariable(\"--info-color\");\n        break;\n      case ButtonClasses.Light:\n        backgroundColor = getCSSVariable(\"--light-color\");\n        textColor = getCSSVariable(\"--primary-color\");\n        break;\n      case ButtonClasses.Dark:\n        backgroundColor = getCSSVariable(\"--dark-color\");\n        break;\n      case ButtonClasses.Link:\n        backgroundColor = \"transparent\";\n        borderColor = getCSSVariable(\"--link-border-color\");\n        textColor = getCSSVariable(\"--primary-color\");\n        break;\n      default:\n        backgroundColor = getCSSVariable(\"--primary-color\");\n        break;\n    }\n\n    const hoverFilter = this.isHovered ? \"brightness(80%)\" : \"none\";\n    const activeFilter = this.isClicked ? \"brightness(60%)\" : hoverFilter;\n\n    return {\n      \"margin-top\": `${this.marginTop}rem`,\n      \"margin-bottom\": `${this.marginBottom}rem`,\n      \"margin-left\": `${this.marginLeft}rem`,\n      \"margin-right\": `${this.marginRight}rem`,\n      \"background-color\": backgroundColor,\n      color: textColor,\n      border: borderColor ? `1px solid ${borderColor}` : \"none\",\n      transition: \"background-color 0.3s, border-color 0.3s, filter 0.3s\",\n      filter: activeFilter,\n    };\n  }\n\n  onClick() {\n    this.buttonClick.emit();\n  }\n\n  @HostListener(\"mouseenter\")\n  onMouseEnter() {\n    this.isHovered = true;\n  }\n\n  @HostListener(\"mouseleave\")\n  onMouseLeave() {\n    this.isHovered = false;\n    this.isClicked = false;\n  }\n\n  @HostListener(\"mousedown\")\n  onMouseDown() {\n    this.isClicked = true;\n  }\n\n  @HostListener(\"mouseup\")\n  onMouseUp() {\n    this.isClicked = false;\n  }\n}\n","<button\n  class=\"notification-button\"\n  [ngStyle]=\"getDynamicStyles()\"\n  (click)=\"onClick()\"\n  [class.hovered]=\"isHovered\"\n  [class.clicked]=\"isClicked\"\n  (mousedown)=\"onMouseDown()\"\n  (mouseup)=\"onMouseUp()\"\n  (mouseleave)=\"onMouseLeave()\"\n  (mouseenter)=\"onMouseEnter()\"\n>\n  {{ label }}\n  <span class=\"badge\">{{ badgeContent }}</span>\n</button>\n"]}
@@ -1,15 +1,16 @@
1
- import { Component, EventEmitter, Input, Output, ChangeDetectionStrategy } from '@angular/core';
2
- import { ButtonClasses } from '../../enum/ButtonClassesEnum';
1
+ import { Component, EventEmitter, Input, Output, ChangeDetectionStrategy, } from "@angular/core";
2
+ import { ButtonClasses } from "../../enum/ButtonClassesEnum";
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "../../service/auth-service.service";
5
5
  import * as i2 from "@angular/common";
6
6
  export class ButtonComponent {
7
- constructor(authService) {
7
+ constructor(authService, cdr) {
8
8
  this.authService = authService;
9
- this.type = 'button';
10
- this.label = 'Submit';
9
+ this.cdr = cdr;
10
+ this.type = "button";
11
+ this.label = "Submit";
11
12
  this.btnClass = ButtonClasses.Primary;
12
- this.fontSize = '1rem';
13
+ this.fontSize = "1rem";
13
14
  this.disabled = false;
14
15
  this.autofocus = false;
15
16
  this.form = null;
@@ -24,6 +25,7 @@ export class ButtonComponent {
24
25
  this.onButtonClick = new EventEmitter();
25
26
  this.isHovered = false;
26
27
  this.isActive = false;
28
+ this.clicked = false;
27
29
  }
28
30
  ngOnInit() {
29
31
  this.validateInputs();
@@ -34,18 +36,18 @@ export class ButtonComponent {
34
36
  }
35
37
  }
36
38
  validateInputs() {
37
- const validTypes = ['button', 'submit', 'reset'];
39
+ const validTypes = ["button", "submit", "reset"];
38
40
  const validClasses = Object.values(ButtonClasses);
39
41
  if (!validTypes.includes(this.type)) {
40
- throw new Error(`Invalid type: ${this.type}. Allowed values are: ${validTypes.join(', ')}`);
42
+ throw new Error(`Invalid type: ${this.type}. Allowed values are: ${validTypes.join(", ")}`);
41
43
  }
42
44
  if (!validClasses.includes(this.btnClass)) {
43
- throw new Error(`Invalid btnClass: ${this.btnClass}. Allowed values are: ${validClasses.join(', ')}`);
45
+ throw new Error(`Invalid btnClass: ${this.btnClass}. Allowed values are: ${validClasses.join(", ")}`);
44
46
  }
45
- if (typeof this.disabled !== 'boolean') {
47
+ if (typeof this.disabled !== "boolean") {
46
48
  throw new Error(`Invalid disabled value: ${this.disabled}. It should be a boolean.`);
47
49
  }
48
- if (typeof this.autofocus !== 'boolean') {
50
+ if (typeof this.autofocus !== "boolean") {
49
51
  throw new Error(`Invalid autofocus value: ${this.autofocus}. It should be a boolean.`);
50
52
  }
51
53
  if (this.permissions && !Array.isArray(this.permissions)) {
@@ -53,59 +55,74 @@ export class ButtonComponent {
53
55
  }
54
56
  }
55
57
  onClick(event) {
58
+ this.clicked = true;
56
59
  this.onButtonClick.emit(event);
60
+ setTimeout(() => {
61
+ this.clicked = false;
62
+ this.cdr.detectChanges();
63
+ }, 80);
57
64
  }
58
65
  get dynamicStyles() {
59
66
  return this.calculateDynamicStyles();
60
67
  }
61
68
  calculateDynamicStyles() {
62
- let backgroundColor = '';
63
- let textColor = '#fff'; // Default text color
64
- let borderColor = '';
65
- switch (this.btnClass) {
66
- case ButtonClasses.Primary:
67
- backgroundColor = '#00444C';
68
- break;
69
- case ButtonClasses.Secondary:
70
- backgroundColor = '#2CA58D';
71
- break;
72
- case ButtonClasses.Success:
73
- backgroundColor = '#00C853';
74
- break;
75
- case ButtonClasses.Danger:
76
- backgroundColor = '#D32F2F';
77
- break;
78
- case ButtonClasses.Warning:
79
- backgroundColor = '#FFC107';
80
- break;
81
- case ButtonClasses.Info:
82
- backgroundColor = '#3EC9D6';
83
- break;
84
- case ButtonClasses.Light:
85
- backgroundColor = '#EEF2F6';
86
- textColor = '#00444C'; // Custom text color for Light
87
- break;
88
- case ButtonClasses.Dark:
89
- backgroundColor = '#111936';
90
- break;
91
- case ButtonClasses.Link:
92
- backgroundColor = 'transparent';
93
- borderColor = '#DDE5E9';
94
- textColor = '#00444C'; // Custom text color for Link
95
- break;
96
- default:
97
- backgroundColor = '#00444C';
98
- break;
69
+ let backgroundColor = "";
70
+ let textColor = getComputedStyle(document.documentElement)
71
+ .getPropertyValue("--text-color")
72
+ .trim(); // Cor de texto padrão
73
+ let borderColor = "";
74
+ const getCSSVariable = (variable) => getComputedStyle(document.documentElement)
75
+ .getPropertyValue(variable)
76
+ .trim();
77
+ if (this.clicked) {
78
+ backgroundColor = "rgba(126, 126, 126, 0.25)"; // Cor temporária ao clicar
99
79
  }
100
- const hoverFilter = this.isHovered ? 'brightness(80%)' : 'none'; // Adjusted hover brightness
101
- const activeFilter = this.isActive ? 'brightness(60%)' : hoverFilter; // Adjusted active brightness
80
+ else {
81
+ switch (this.btnClass) {
82
+ case ButtonClasses.Primary:
83
+ backgroundColor = getCSSVariable("--primary-color");
84
+ break;
85
+ case ButtonClasses.Secondary:
86
+ backgroundColor = getCSSVariable("--secondary-color");
87
+ break;
88
+ case ButtonClasses.Success:
89
+ backgroundColor = getCSSVariable("--success-color");
90
+ break;
91
+ case ButtonClasses.Danger:
92
+ backgroundColor = getCSSVariable("--danger-color");
93
+ break;
94
+ case ButtonClasses.Warning:
95
+ backgroundColor = getCSSVariable("--warning-color");
96
+ break;
97
+ case ButtonClasses.Info:
98
+ backgroundColor = getCSSVariable("--info-color");
99
+ break;
100
+ case ButtonClasses.Light:
101
+ backgroundColor = getCSSVariable("--light-color");
102
+ textColor = getCSSVariable("--primary-color");
103
+ break;
104
+ case ButtonClasses.Dark:
105
+ backgroundColor = getCSSVariable("--dark-color");
106
+ break;
107
+ case ButtonClasses.Link:
108
+ backgroundColor = "transparent";
109
+ borderColor = getCSSVariable("--link-border-color");
110
+ textColor = getCSSVariable("--primary-color");
111
+ break;
112
+ default:
113
+ backgroundColor = getCSSVariable("--primary-color");
114
+ break;
115
+ }
116
+ }
117
+ const hoverFilter = this.isHovered ? "brightness(80%)" : "none";
118
+ const activeFilter = this.isActive ? "brightness(60%)" : hoverFilter;
102
119
  return {
103
- 'font-size': this.fontSize,
104
- 'background-color': backgroundColor,
105
- 'color': textColor,
106
- 'border': borderColor ? `1px solid ${borderColor}` : 'none',
107
- 'transition': 'background-color 0.3s, border-color 0.3s, filter 0.3s',
108
- 'filter': activeFilter
120
+ "font-size": this.fontSize,
121
+ "background-color": backgroundColor,
122
+ color: textColor,
123
+ border: borderColor ? `1px solid ${borderColor}` : "none",
124
+ transition: "background-color 0.3s, border-color 0.3s, filter 0.3s",
125
+ filter: activeFilter,
109
126
  };
110
127
  }
111
128
  hasPermission() {
@@ -117,69 +134,29 @@ export class ButtonComponent {
117
134
  }
118
135
  catch (error) {
119
136
  if (error instanceof Error) {
120
- console.error('Permission error:', error.message);
137
+ console.error("Permission error:", error.message);
121
138
  }
122
139
  else {
123
- console.error('Unknown error occurred during permission check');
140
+ console.error("Unknown error occurred during permission check");
124
141
  }
125
142
  return true;
126
143
  }
127
144
  }
128
145
  onCancel(event) {
129
- console.log('Cancel button clicked', event);
146
+ console.log("Cancel button clicked", event);
130
147
  // Lógica para o cancelamento
131
148
  }
132
149
  onSave(event) {
133
- console.log('Save button clicked', event);
150
+ console.log("Save button clicked", event);
134
151
  // Lógica para salvar alterações
135
152
  }
136
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ButtonComponent, deps: [{ token: i1.AuthService }], target: i0.ɵɵFactoryTarget.Component }); }
137
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ButtonComponent, selector: "argenta-custom-button", inputs: { type: "type", label: "label", btnClass: "btnClass", fontSize: "fontSize", disabled: "disabled", autofocus: "autofocus", form: "form", formaction: "formaction", formenctype: "formenctype", formmethod: "formmethod", formnovalidate: "formnovalidate", formtarget: "formtarget", name: "name", value: "value", permissions: "permissions" }, outputs: { onButtonClick: "onButtonClick" }, usesOnChanges: true, ngImport: i0, template: `
138
- <ng-container *ngIf="hasPermission()">
139
- <button [type]="type"
140
- class="btn"
141
- [ngClass]="btnClass"
142
- [ngStyle]="dynamicStyles"
143
- (click)="onClick($event)"
144
- [disabled]="disabled"
145
- [attr.autofocus]="autofocus ? true : null"
146
- [attr.form]="form"
147
- [attr.formaction]="formaction"
148
- [attr.formenctype]="formenctype"
149
- [attr.formmethod]="formmethod"
150
- [attr.formnovalidate]="formnovalidate"
151
- [attr.formtarget]="formtarget"
152
- [attr.name]="name"
153
- [attr.value]="value">
154
- {{ label }}
155
- </button>
156
- </ng-container>
157
- `, isInline: true, styles: [".btn{padding:.5rem 1rem;border-radius:.25rem;transition:background-color .3s,border-color .3s,filter .3s;font-family:Inter,sans-serif;font-size:16px;font-weight:600;line-height:24px;letter-spacing:.005em;text-align:left}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
153
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ButtonComponent, deps: [{ token: i1.AuthService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
154
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ButtonComponent, selector: "argenta-custom-button", inputs: { type: "type", label: "label", btnClass: "btnClass", fontSize: "fontSize", disabled: "disabled", autofocus: "autofocus", form: "form", formaction: "formaction", formenctype: "formenctype", formmethod: "formmethod", formnovalidate: "formnovalidate", formtarget: "formtarget", name: "name", value: "value", permissions: "permissions" }, outputs: { onButtonClick: "onButtonClick" }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"hasPermission()\">\n <button\n [type]=\"type\"\n class=\"btn\"\n [ngClass]=\"btnClass\"\n [ngStyle]=\"dynamicStyles\"\n (click)=\"onClick($event)\"\n [disabled]=\"disabled\"\n [attr.autofocus]=\"autofocus ? true : null\"\n [attr.form]=\"form\"\n [attr.formaction]=\"formaction\"\n [attr.formenctype]=\"formenctype\"\n [attr.formmethod]=\"formmethod\"\n [attr.formnovalidate]=\"formnovalidate\"\n [attr.formtarget]=\"formtarget\"\n [attr.name]=\"name\"\n [attr.value]=\"value\"\n >\n {{ label }}\n </button>\n</ng-container>\n", styles: [".btn{padding:.5rem 1rem;border-radius:.25rem;transition:background-color .3s,border-color .3s,filter .3s;font-family:var(--font-family);font-size:16px;font-weight:600;line-height:24px;letter-spacing:.005em;text-align:left;box-shadow:none}.btn:hover{box-shadow:0 0 0 .2rem #7e7e7e40}.btn:active{background-color:#7e7e7e40}.btn:focus{outline:none;box-shadow:0 0 0 .2rem #7e7e7e40}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
158
155
  }
159
156
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ButtonComponent, decorators: [{
160
157
  type: Component,
161
- args: [{ selector: 'argenta-custom-button', template: `
162
- <ng-container *ngIf="hasPermission()">
163
- <button [type]="type"
164
- class="btn"
165
- [ngClass]="btnClass"
166
- [ngStyle]="dynamicStyles"
167
- (click)="onClick($event)"
168
- [disabled]="disabled"
169
- [attr.autofocus]="autofocus ? true : null"
170
- [attr.form]="form"
171
- [attr.formaction]="formaction"
172
- [attr.formenctype]="formenctype"
173
- [attr.formmethod]="formmethod"
174
- [attr.formnovalidate]="formnovalidate"
175
- [attr.formtarget]="formtarget"
176
- [attr.name]="name"
177
- [attr.value]="value">
178
- {{ label }}
179
- </button>
180
- </ng-container>
181
- `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [".btn{padding:.5rem 1rem;border-radius:.25rem;transition:background-color .3s,border-color .3s,filter .3s;font-family:Inter,sans-serif;font-size:16px;font-weight:600;line-height:24px;letter-spacing:.005em;text-align:left}\n"] }]
182
- }], ctorParameters: function () { return [{ type: i1.AuthService }]; }, propDecorators: { type: [{
158
+ args: [{ selector: "argenta-custom-button", changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"hasPermission()\">\n <button\n [type]=\"type\"\n class=\"btn\"\n [ngClass]=\"btnClass\"\n [ngStyle]=\"dynamicStyles\"\n (click)=\"onClick($event)\"\n [disabled]=\"disabled\"\n [attr.autofocus]=\"autofocus ? true : null\"\n [attr.form]=\"form\"\n [attr.formaction]=\"formaction\"\n [attr.formenctype]=\"formenctype\"\n [attr.formmethod]=\"formmethod\"\n [attr.formnovalidate]=\"formnovalidate\"\n [attr.formtarget]=\"formtarget\"\n [attr.name]=\"name\"\n [attr.value]=\"value\"\n >\n {{ label }}\n </button>\n</ng-container>\n", styles: [".btn{padding:.5rem 1rem;border-radius:.25rem;transition:background-color .3s,border-color .3s,filter .3s;font-family:var(--font-family);font-size:16px;font-weight:600;line-height:24px;letter-spacing:.005em;text-align:left;box-shadow:none}.btn:hover{box-shadow:0 0 0 .2rem #7e7e7e40}.btn:active{background-color:#7e7e7e40}.btn:focus{outline:none;box-shadow:0 0 0 .2rem #7e7e7e40}\n"] }]
159
+ }], ctorParameters: function () { return [{ type: i1.AuthService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { type: [{
183
160
  type: Input
184
161
  }], label: [{
185
162
  type: Input
@@ -212,4 +189,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
212
189
  }], onButtonClick: [{
213
190
  type: Output
214
191
  }] } });
215
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/button/button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, OnInit, OnChanges, SimpleChanges, ChangeDetectionStrategy } from '@angular/core';\nimport { ButtonClasses } from '../../enum/ButtonClassesEnum';\nimport { AuthService } from '../../service/auth-service.service';\n\n@Component({\n  selector: 'argenta-custom-button',\n  template: `\n    <ng-container *ngIf=\"hasPermission()\">\n      <button [type]=\"type\"\n              class=\"btn\"\n              [ngClass]=\"btnClass\"\n              [ngStyle]=\"dynamicStyles\"\n              (click)=\"onClick($event)\"\n              [disabled]=\"disabled\"\n              [attr.autofocus]=\"autofocus ? true : null\"\n              [attr.form]=\"form\"\n              [attr.formaction]=\"formaction\"\n              [attr.formenctype]=\"formenctype\"\n              [attr.formmethod]=\"formmethod\"\n              [attr.formnovalidate]=\"formnovalidate\"\n              [attr.formtarget]=\"formtarget\"\n              [attr.name]=\"name\"\n              [attr.value]=\"value\">\n        {{ label }}\n      </button>\n    </ng-container>\n  `,\n  styles: [`\n    .btn {\n      padding: 0.5rem 1rem;\n      border-radius: 0.25rem;\n      transition: background-color 0.3s, border-color 0.3s, filter 0.3s;\n      font-family: 'Inter', sans-serif;\n      font-size: 16px;\n      font-weight: 600;\n      line-height: 24px;\n      letter-spacing: 0.005em;\n      text-align: left;\n    }\n  `],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ButtonComponent implements OnInit, OnChanges {\n  @Input() type: string = 'button';\n  @Input() label: string = 'Submit';\n  @Input() btnClass: ButtonClasses = ButtonClasses.Primary;\n  @Input() fontSize: string = '1rem';\n  @Input() disabled: boolean = false;\n  @Input() autofocus: boolean = false;\n  @Input() form: string | null = null;\n  @Input() formaction: string | null = null;\n  @Input() formenctype: string | null = null;\n  @Input() formmethod: string | null = null;\n  @Input() formnovalidate: boolean = false;\n  @Input() formtarget: string | null = null;\n  @Input() name: string | null = null;\n  @Input() value: string | null = null;\n  @Input() permissions: string[] = [];\n\n  @Output() onButtonClick: EventEmitter<Event> = new EventEmitter<Event>();\n\n  private isHovered: boolean = false;\n  private isActive: boolean = false;\n\n  constructor(private authService: AuthService) { }\n\n  ngOnInit(): void {\n    this.validateInputs();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes) {\n      this.validateInputs();\n    }\n  }\n\n  private validateInputs(): void {\n    const validTypes = ['button', 'submit', 'reset'];\n    const validClasses = Object.values(ButtonClasses);\n\n    if (!validTypes.includes(this.type)) {\n      throw new Error(`Invalid type: ${this.type}. Allowed values are: ${validTypes.join(', ')}`);\n    }\n\n    if (!validClasses.includes(this.btnClass)) {\n      throw new Error(`Invalid btnClass: ${this.btnClass}. Allowed values are: ${validClasses.join(', ')}`);\n    }\n\n    if (typeof this.disabled !== 'boolean') {\n      throw new Error(`Invalid disabled value: ${this.disabled}. It should be a boolean.`);\n    }\n\n    if (typeof this.autofocus !== 'boolean') {\n      throw new Error(`Invalid autofocus value: ${this.autofocus}. It should be a boolean.`);\n    }\n\n    if (this.permissions && !Array.isArray(this.permissions)) {\n      throw new Error(`Invalid permissions value: ${this.permissions}. It should be an array of strings.`);\n    }\n  }\n\n  onClick(event: Event) {\n    this.onButtonClick.emit(event);\n  }\n\n  get dynamicStyles() {\n    return this.calculateDynamicStyles();\n  }\n\n  private calculateDynamicStyles() {\n    let backgroundColor = '';\n    let textColor = '#fff'; // Default text color\n    let borderColor = '';\n\n    switch (this.btnClass) {\n      case ButtonClasses.Primary:\n        backgroundColor = '#00444C';\n        break;\n      case ButtonClasses.Secondary:\n        backgroundColor = '#2CA58D';\n        break;\n      case ButtonClasses.Success:\n        backgroundColor = '#00C853';\n        break;\n      case ButtonClasses.Danger:\n        backgroundColor = '#D32F2F';\n        break;\n      case ButtonClasses.Warning:\n        backgroundColor = '#FFC107';\n        break;\n      case ButtonClasses.Info:\n        backgroundColor = '#3EC9D6';\n        break;\n      case ButtonClasses.Light:\n        backgroundColor = '#EEF2F6';\n        textColor = '#00444C'; // Custom text color for Light\n        break;\n      case ButtonClasses.Dark:\n        backgroundColor = '#111936';\n        break;\n      case ButtonClasses.Link:\n        backgroundColor = 'transparent';\n        borderColor = '#DDE5E9';\n        textColor = '#00444C'; // Custom text color for Link\n        break;\n      default:\n        backgroundColor = '#00444C';\n        break;\n    }\n\n    const hoverFilter = this.isHovered ? 'brightness(80%)' : 'none'; // Adjusted hover brightness\n    const activeFilter = this.isActive ? 'brightness(60%)' : hoverFilter; // Adjusted active brightness\n\n    return {\n      'font-size': this.fontSize,\n      'background-color': backgroundColor,\n      'color': textColor,\n      'border': borderColor ? `1px solid ${borderColor}` : 'none',\n      'transition': 'background-color 0.3s, border-color 0.3s, filter 0.3s',\n      'filter': activeFilter\n    };\n  }\n\n  hasPermission(): boolean {\n    if (!this.permissions || this.permissions.length === 0) {\n      return true;\n    }\n\n    try {\n      return this.authService.hasPermission(this.permissions);\n    } catch (error: unknown) {\n      if (error instanceof Error) {\n        console.error('Permission error:', error.message);\n      } else {\n        console.error('Unknown error occurred during permission check');\n      }\n      return true;\n    }\n  }\n\n  onCancel(event: Event) {\n    console.log('Cancel button clicked', event);\n    // Lógica para o cancelamento\n  }\n\n  onSave(event: Event) {\n    console.log('Save button clicked', event);\n    // Lógica para salvar alterações\n  }\n}\n"]}
192
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/button/button.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  OnInit,\n  OnChanges,\n  SimpleChanges,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n} from \"@angular/core\";\nimport { ButtonClasses } from \"../../enum/ButtonClassesEnum\";\nimport { AuthService } from \"../../service/auth-service.service\";\n\n@Component({\n  selector: \"argenta-custom-button\",\n  templateUrl: \"./button.component.html\",\n  styleUrls: [\"./button.component.scss\"],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ButtonComponent implements OnInit, OnChanges {\n  @Input() type: string = \"button\";\n  @Input() label: string = \"Submit\";\n  @Input() btnClass: ButtonClasses = ButtonClasses.Primary;\n  @Input() fontSize: string = \"1rem\";\n  @Input() disabled: boolean = false;\n  @Input() autofocus: boolean = false;\n  @Input() form: string | null = null;\n  @Input() formaction: string | null = null;\n  @Input() formenctype: string | null = null;\n  @Input() formmethod: string | null = null;\n  @Input() formnovalidate: boolean = false;\n  @Input() formtarget: string | null = null;\n  @Input() name: string | null = null;\n  @Input() value: string | null = null;\n  @Input() permissions: string[] = [];\n\n  @Output() onButtonClick: EventEmitter<Event> = new EventEmitter<Event>();\n\n  private isHovered: boolean = false;\n  private isActive: boolean = false;\n\n  clicked: boolean = false;\n\n  constructor(\n    private authService: AuthService,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngOnInit(): void {\n    this.validateInputs();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes) {\n      this.validateInputs();\n    }\n  }\n\n  private validateInputs(): void {\n    const validTypes = [\"button\", \"submit\", \"reset\"];\n    const validClasses = Object.values(ButtonClasses);\n\n    if (!validTypes.includes(this.type)) {\n      throw new Error(\n        `Invalid type: ${this.type}. Allowed values are: ${validTypes.join(\n          \", \"\n        )}`\n      );\n    }\n\n    if (!validClasses.includes(this.btnClass)) {\n      throw new Error(\n        `Invalid btnClass: ${\n          this.btnClass\n        }. Allowed values are: ${validClasses.join(\", \")}`\n      );\n    }\n\n    if (typeof this.disabled !== \"boolean\") {\n      throw new Error(\n        `Invalid disabled value: ${this.disabled}. It should be a boolean.`\n      );\n    }\n\n    if (typeof this.autofocus !== \"boolean\") {\n      throw new Error(\n        `Invalid autofocus value: ${this.autofocus}. It should be a boolean.`\n      );\n    }\n\n    if (this.permissions && !Array.isArray(this.permissions)) {\n      throw new Error(\n        `Invalid permissions value: ${this.permissions}. It should be an array of strings.`\n      );\n    }\n  }\n\n  onClick(event: Event) {\n    this.clicked = true;\n    this.onButtonClick.emit(event);\n    setTimeout(() => {\n      this.clicked = false;\n      this.cdr.detectChanges();\n    }, 80);\n  }\n\n  get dynamicStyles() {\n    return this.calculateDynamicStyles();\n  }\n\n  private calculateDynamicStyles() {\n    let backgroundColor = \"\";\n    let textColor = getComputedStyle(document.documentElement)\n      .getPropertyValue(\"--text-color\")\n      .trim(); // Cor de texto padrão\n    let borderColor = \"\";\n\n    const getCSSVariable = (variable: string) =>\n      getComputedStyle(document.documentElement)\n        .getPropertyValue(variable)\n        .trim();\n\n    if (this.clicked) {\n      backgroundColor = \"rgba(126, 126, 126, 0.25)\"; // Cor temporária ao clicar\n    } else {\n      switch (this.btnClass) {\n        case ButtonClasses.Primary:\n          backgroundColor = getCSSVariable(\"--primary-color\");\n          break;\n        case ButtonClasses.Secondary:\n          backgroundColor = getCSSVariable(\"--secondary-color\");\n          break;\n        case ButtonClasses.Success:\n          backgroundColor = getCSSVariable(\"--success-color\");\n          break;\n        case ButtonClasses.Danger:\n          backgroundColor = getCSSVariable(\"--danger-color\");\n          break;\n        case ButtonClasses.Warning:\n          backgroundColor = getCSSVariable(\"--warning-color\");\n          break;\n        case ButtonClasses.Info:\n          backgroundColor = getCSSVariable(\"--info-color\");\n          break;\n        case ButtonClasses.Light:\n          backgroundColor = getCSSVariable(\"--light-color\");\n          textColor = getCSSVariable(\"--primary-color\");\n          break;\n        case ButtonClasses.Dark:\n          backgroundColor = getCSSVariable(\"--dark-color\");\n          break;\n        case ButtonClasses.Link:\n          backgroundColor = \"transparent\";\n          borderColor = getCSSVariable(\"--link-border-color\");\n          textColor = getCSSVariable(\"--primary-color\");\n          break;\n        default:\n          backgroundColor = getCSSVariable(\"--primary-color\");\n          break;\n      }\n    }\n\n    const hoverFilter = this.isHovered ? \"brightness(80%)\" : \"none\";\n    const activeFilter = this.isActive ? \"brightness(60%)\" : hoverFilter;\n\n    return {\n      \"font-size\": this.fontSize,\n      \"background-color\": backgroundColor,\n      color: textColor,\n      border: borderColor ? `1px solid ${borderColor}` : \"none\",\n      transition: \"background-color 0.3s, border-color 0.3s, filter 0.3s\",\n      filter: activeFilter,\n    };\n  }\n\n  hasPermission(): boolean {\n    if (!this.permissions || this.permissions.length === 0) {\n      return true;\n    }\n\n    try {\n      return this.authService.hasPermission(this.permissions);\n    } catch (error: unknown) {\n      if (error instanceof Error) {\n        console.error(\"Permission error:\", error.message);\n      } else {\n        console.error(\"Unknown error occurred during permission check\");\n      }\n      return true;\n    }\n  }\n\n  onCancel(event: Event) {\n    console.log(\"Cancel button clicked\", event);\n    // Lógica para o cancelamento\n  }\n\n  onSave(event: Event) {\n    console.log(\"Save button clicked\", event);\n    // Lógica para salvar alterações\n  }\n}\n","<ng-container *ngIf=\"hasPermission()\">\n  <button\n    [type]=\"type\"\n    class=\"btn\"\n    [ngClass]=\"btnClass\"\n    [ngStyle]=\"dynamicStyles\"\n    (click)=\"onClick($event)\"\n    [disabled]=\"disabled\"\n    [attr.autofocus]=\"autofocus ? true : null\"\n    [attr.form]=\"form\"\n    [attr.formaction]=\"formaction\"\n    [attr.formenctype]=\"formenctype\"\n    [attr.formmethod]=\"formmethod\"\n    [attr.formnovalidate]=\"formnovalidate\"\n    [attr.formtarget]=\"formtarget\"\n    [attr.name]=\"name\"\n    [attr.value]=\"value\"\n  >\n    {{ label }}\n  </button>\n</ng-container>\n"]}