lib-portal-angular 0.0.75 → 0.0.77

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,12 +1,13 @@
1
- import { Component, EventEmitter, Input, Output, ChangeDetectionStrategy, } from "@angular/core";
1
+ import { Component, EventEmitter, Input, Output, ChangeDetectionStrategy, ViewChild, } from "@angular/core";
2
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, cdr) {
7
+ constructor(authService, cdr, renderer) {
8
8
  this.authService = authService;
9
9
  this.cdr = cdr;
10
+ this.renderer = renderer;
10
11
  this.type = "button";
11
12
  this.label = "Submit";
12
13
  this.btnClass = ButtonClasses.Primary;
@@ -30,6 +31,9 @@ export class ButtonComponent {
30
31
  ngOnInit() {
31
32
  this.validateInputs();
32
33
  }
34
+ ngAfterViewInit() {
35
+ this.addHoverEffect(); // Chama o método para aplicar o efeito de hover
36
+ }
33
37
  ngOnChanges(changes) {
34
38
  if (changes) {
35
39
  this.validateInputs();
@@ -125,6 +129,110 @@ export class ButtonComponent {
125
129
  filter: activeFilter,
126
130
  };
127
131
  }
132
+ addHoverEffect() {
133
+ const buttonElement = this.buttonElement.nativeElement;
134
+ if (buttonElement) {
135
+ // Evento de mouseover para adicionar box-shadow
136
+ this.renderer.listen(buttonElement, "mouseover", () => {
137
+ const hoverColor = this.calculateHoverColor(); // Calcula a cor de hover
138
+ this.renderer.setStyle(buttonElement, "box-shadow", `0 0 0 0.15rem ${hoverColor}`);
139
+ });
140
+ // Evento de mouseout para remover o box-shadow
141
+ this.renderer.listen(buttonElement, "mouseout", () => {
142
+ this.renderer.setStyle(buttonElement, "box-shadow", "none");
143
+ });
144
+ }
145
+ }
146
+ // Calcula a cor de hover com base na classe de botão
147
+ calculateHoverColor() {
148
+ switch (this.btnClass) {
149
+ case ButtonClasses.Primary:
150
+ return getComputedStyle(document.documentElement)
151
+ .getPropertyValue("--primary-color")
152
+ .trim();
153
+ case ButtonClasses.Secondary:
154
+ return getComputedStyle(document.documentElement)
155
+ .getPropertyValue("--secondary-color")
156
+ .trim();
157
+ case ButtonClasses.Success:
158
+ return getComputedStyle(document.documentElement)
159
+ .getPropertyValue("--success-color")
160
+ .trim();
161
+ case ButtonClasses.Danger:
162
+ return getComputedStyle(document.documentElement)
163
+ .getPropertyValue("--danger-color")
164
+ .trim();
165
+ case ButtonClasses.Warning:
166
+ return getComputedStyle(document.documentElement)
167
+ .getPropertyValue("--warning-color")
168
+ .trim();
169
+ case ButtonClasses.Info:
170
+ return getComputedStyle(document.documentElement)
171
+ .getPropertyValue("--info-color")
172
+ .trim();
173
+ case ButtonClasses.Link:
174
+ return getComputedStyle(document.documentElement)
175
+ .getPropertyValue("light-color")
176
+ .trim();
177
+ case ButtonClasses.Light:
178
+ return getComputedStyle(document.documentElement)
179
+ .getPropertyValue("--light-color")
180
+ .trim();
181
+ case ButtonClasses.Dark:
182
+ return getComputedStyle(document.documentElement)
183
+ .getPropertyValue("--dark-color")
184
+ .trim();
185
+ default:
186
+ return getComputedStyle(document.documentElement)
187
+ .getPropertyValue("--primary-color")
188
+ .trim();
189
+ }
190
+ }
191
+ // Calcula a cor de fundo original
192
+ calculateOriginalColor() {
193
+ switch (this.btnClass) {
194
+ case ButtonClasses.Primary:
195
+ return getComputedStyle(document.documentElement)
196
+ .getPropertyValue("--primary-color")
197
+ .trim();
198
+ case ButtonClasses.Secondary:
199
+ return getComputedStyle(document.documentElement)
200
+ .getPropertyValue("--secondary-color")
201
+ .trim();
202
+ case ButtonClasses.Success:
203
+ return getComputedStyle(document.documentElement)
204
+ .getPropertyValue("--success-color")
205
+ .trim();
206
+ case ButtonClasses.Danger:
207
+ return getComputedStyle(document.documentElement)
208
+ .getPropertyValue("--danger-color")
209
+ .trim();
210
+ case ButtonClasses.Warning:
211
+ return getComputedStyle(document.documentElement)
212
+ .getPropertyValue("--warning-color")
213
+ .trim();
214
+ case ButtonClasses.Info:
215
+ return getComputedStyle(document.documentElement)
216
+ .getPropertyValue("--info-color")
217
+ .trim();
218
+ case ButtonClasses.Link:
219
+ return getComputedStyle(document.documentElement)
220
+ .getPropertyValue("transparent")
221
+ .trim();
222
+ case ButtonClasses.Light:
223
+ return getComputedStyle(document.documentElement)
224
+ .getPropertyValue("--light-color")
225
+ .trim();
226
+ case ButtonClasses.Dark:
227
+ return getComputedStyle(document.documentElement)
228
+ .getPropertyValue("--dark-color")
229
+ .trim();
230
+ default:
231
+ return getComputedStyle(document.documentElement)
232
+ .getPropertyValue("--primary-color")
233
+ .trim();
234
+ }
235
+ }
128
236
  hasPermission() {
129
237
  if (!this.permissions || this.permissions.length === 0) {
130
238
  return true;
@@ -150,13 +258,13 @@ export class ButtonComponent {
150
258
  console.log("Save button clicked", event);
151
259
  // Lógica para salvar alterações
152
260
  }
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 }); }
261
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ButtonComponent, deps: [{ token: i1.AuthService }, { token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
262
+ 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" }, viewQueries: [{ propertyName: "buttonElement", first: true, predicate: ["buttonElement"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"hasPermission()\">\n <button\n #buttonElement\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 [attr.type]=\"type\"\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}\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 }); }
155
263
  }
156
264
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ButtonComponent, decorators: [{
157
265
  type: Component,
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: [{
266
+ args: [{ selector: "argenta-custom-button", changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"hasPermission()\">\n <button\n #buttonElement\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 [attr.type]=\"type\"\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}\n"] }]
267
+ }], ctorParameters: function () { return [{ type: i1.AuthService }, { type: i0.ChangeDetectorRef }, { type: i0.Renderer2 }]; }, propDecorators: { type: [{
160
268
  type: Input
161
269
  }], label: [{
162
270
  type: Input
@@ -188,5 +296,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
188
296
  type: Input
189
297
  }], onButtonClick: [{
190
298
  type: Output
299
+ }], buttonElement: [{
300
+ type: ViewChild,
301
+ args: ["buttonElement"]
191
302
  }] } });
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"]}
303
+ //# 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  ElementRef,\n  ViewChild,\n  AfterViewInit,\n  Renderer2,\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, AfterViewInit {\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  @ViewChild(\"buttonElement\") buttonElement!: ElementRef<HTMLButtonElement>;\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    private renderer: Renderer2\n  ) {}\n\n  ngOnInit(): void {\n    this.validateInputs();\n  }\n\n  ngAfterViewInit(): void {\n    this.addHoverEffect(); // Chama o método para aplicar o efeito de hover\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  private addHoverEffect(): void {\n    const buttonElement = this.buttonElement.nativeElement;\n\n    if (buttonElement) {\n      // Evento de mouseover para adicionar box-shadow\n      this.renderer.listen(buttonElement, \"mouseover\", () => {\n        const hoverColor = this.calculateHoverColor(); // Calcula a cor de hover\n        this.renderer.setStyle(\n          buttonElement,\n          \"box-shadow\",\n          `0 0 0 0.15rem ${hoverColor}`\n        );\n      });\n\n      // Evento de mouseout para remover o box-shadow\n      this.renderer.listen(buttonElement, \"mouseout\", () => {\n        this.renderer.setStyle(buttonElement, \"box-shadow\", \"none\");\n      });\n    }\n  }\n\n  // Calcula a cor de hover com base na classe de botão\n  private calculateHoverColor(): string {\n    switch (this.btnClass) {\n      case ButtonClasses.Primary:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--primary-color\")\n          .trim();\n      case ButtonClasses.Secondary:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--secondary-color\")\n          .trim();\n      case ButtonClasses.Success:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--success-color\")\n          .trim();\n      case ButtonClasses.Danger:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--danger-color\")\n          .trim();\n      case ButtonClasses.Warning:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--warning-color\")\n          .trim();\n      case ButtonClasses.Info:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--info-color\")\n          .trim();\n      case ButtonClasses.Link:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"light-color\")\n          .trim();\n      case ButtonClasses.Light:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--light-color\")\n          .trim();\n      case ButtonClasses.Dark:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--dark-color\")\n          .trim();\n      default:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--primary-color\")\n          .trim();\n    }\n  }\n\n  // Calcula a cor de fundo original\n  private calculateOriginalColor(): string {\n    switch (this.btnClass) {\n      case ButtonClasses.Primary:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--primary-color\")\n          .trim();\n      case ButtonClasses.Secondary:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--secondary-color\")\n          .trim();\n      case ButtonClasses.Success:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--success-color\")\n          .trim();\n      case ButtonClasses.Danger:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--danger-color\")\n          .trim();\n      case ButtonClasses.Warning:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--warning-color\")\n          .trim();\n      case ButtonClasses.Info:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--info-color\")\n          .trim();\n      case ButtonClasses.Link:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"transparent\")\n          .trim();\n      case ButtonClasses.Light:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--light-color\")\n          .trim();\n      case ButtonClasses.Dark:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--dark-color\")\n          .trim();\n      default:\n        return getComputedStyle(document.documentElement)\n          .getPropertyValue(\"--primary-color\")\n          .trim();\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    #buttonElement\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    [attr.type]=\"type\"\n  >\n    {{ label }}\n  </button>\n</ng-container>\n"]}
@@ -48,11 +48,11 @@ export class TabComponent {
48
48
  }
49
49
  }
50
50
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TabComponent, deps: [{ token: i1.AuthService }], target: i0.ɵɵFactoryTarget.Component }); }
51
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TabComponent, selector: "argenta-tab", inputs: { tabs: "tabs", activeTabIndex: "activeTabIndex", componentPermissions: "componentPermissions" }, outputs: { tabChanged: "tabChanged" }, ngImport: i0, template: "<ng-container *ngIf=\"hasComponentPermission()\">\n <ul class=\"nav nav-tabs\">\n <ng-container *ngFor=\"let tab of tabs; let i = index\">\n <li class=\"nav-item\" *ngIf=\"hasPermission(tab.permissions)\">\n <a\n class=\"nav-link\"\n [class.active]=\"i === activeTabIndex\"\n (click)=\"selectTab(i, $event)\"\n href=\"#\"\n >{{ tab.label }}</a\n >\n </li>\n </ng-container>\n </ul>\n <div class=\"tab-content\">\n <div\n *ngFor=\"let tab of tabs; let i = index\"\n class=\"tab-pane fade\"\n [ngClass]=\"{ 'show active': i === activeTabIndex }\"\n >\n <ng-container *ngTemplateOutlet=\"tab.content\"></ng-container>\n </div>\n </div>\n</ng-container>\n", styles: [".nav-tabs .nav-item .nav-link{cursor:pointer;font-family:var(--font-family);border-top-left-radius:.3rem;border-top-right-radius:.3rem;font-size:14px;color:#00444c;border:1px solid #ddd;transition:background-color .3s ease,color .3s ease}.nav-tabs .nav-item .nav-link.active{background-color:#00444c;color:#fff;border-color:transparent}.nav-tabs .nav-item .nav-link:hover{background-color:#2ca58d;color:#fff}.tab-content .tab-pane{padding:1rem;border:1px solid #ddd;border-top:none}.nav-tabs .nav-item .nav-link{color:var(--primary-color)}.nav-tabs .nav-item .nav-link.active{background-color:var(--primary-color);color:var(--text-color)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
51
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TabComponent, selector: "argenta-tab", inputs: { tabs: "tabs", activeTabIndex: "activeTabIndex", componentPermissions: "componentPermissions" }, outputs: { tabChanged: "tabChanged" }, ngImport: i0, template: "<ng-container *ngIf=\"hasComponentPermission()\">\n <ul class=\"nav nav-tabs\">\n <ng-container *ngFor=\"let tab of tabs; let i = index\">\n <li class=\"nav-item\" *ngIf=\"hasPermission(tab.permissions)\">\n <a\n class=\"nav-link\"\n [class.active]=\"i === activeTabIndex\"\n (click)=\"selectTab(i, $event)\"\n href=\"#\"\n >{{ tab.label }}</a\n >\n </li>\n </ng-container>\n </ul>\n <div class=\"tab-content\">\n <div\n *ngFor=\"let tab of tabs; let i = index\"\n class=\"tab-pane fade\"\n [ngClass]=\"{ 'show active': i === activeTabIndex }\"\n >\n <ng-container *ngTemplateOutlet=\"tab.content\"></ng-container>\n </div>\n </div>\n</ng-container>\n", styles: [".nav-tabs .nav-item .nav-link{cursor:pointer;font-family:var(--font-family);border-top-left-radius:.3rem;border-top-right-radius:.3rem;font-size:14px;color:var(--primary-color);border:1px solid #ddd;transition:background-color .3s ease,color .3s ease}.nav-tabs .nav-item .nav-link.active{background-color:var(--primary-color);color:var(--background-color);border-color:transparent}.nav-tabs .nav-item .nav-link:hover{background-color:var(--secondary-color);color:var(--background-color)}.tab-content .tab-pane{padding:1rem;border:1px solid #ddd;border-top:none}.nav-tabs .nav-item .nav-link{color:var(--primary-color)}.nav-tabs .nav-item .nav-link.active{background-color:var(--primary-color);color:var(--text-color)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
52
52
  }
53
53
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TabComponent, decorators: [{
54
54
  type: Component,
55
- args: [{ selector: 'argenta-tab', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"hasComponentPermission()\">\n <ul class=\"nav nav-tabs\">\n <ng-container *ngFor=\"let tab of tabs; let i = index\">\n <li class=\"nav-item\" *ngIf=\"hasPermission(tab.permissions)\">\n <a\n class=\"nav-link\"\n [class.active]=\"i === activeTabIndex\"\n (click)=\"selectTab(i, $event)\"\n href=\"#\"\n >{{ tab.label }}</a\n >\n </li>\n </ng-container>\n </ul>\n <div class=\"tab-content\">\n <div\n *ngFor=\"let tab of tabs; let i = index\"\n class=\"tab-pane fade\"\n [ngClass]=\"{ 'show active': i === activeTabIndex }\"\n >\n <ng-container *ngTemplateOutlet=\"tab.content\"></ng-container>\n </div>\n </div>\n</ng-container>\n", styles: [".nav-tabs .nav-item .nav-link{cursor:pointer;font-family:var(--font-family);border-top-left-radius:.3rem;border-top-right-radius:.3rem;font-size:14px;color:#00444c;border:1px solid #ddd;transition:background-color .3s ease,color .3s ease}.nav-tabs .nav-item .nav-link.active{background-color:#00444c;color:#fff;border-color:transparent}.nav-tabs .nav-item .nav-link:hover{background-color:#2ca58d;color:#fff}.tab-content .tab-pane{padding:1rem;border:1px solid #ddd;border-top:none}.nav-tabs .nav-item .nav-link{color:var(--primary-color)}.nav-tabs .nav-item .nav-link.active{background-color:var(--primary-color);color:var(--text-color)}\n"] }]
55
+ args: [{ selector: 'argenta-tab', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"hasComponentPermission()\">\n <ul class=\"nav nav-tabs\">\n <ng-container *ngFor=\"let tab of tabs; let i = index\">\n <li class=\"nav-item\" *ngIf=\"hasPermission(tab.permissions)\">\n <a\n class=\"nav-link\"\n [class.active]=\"i === activeTabIndex\"\n (click)=\"selectTab(i, $event)\"\n href=\"#\"\n >{{ tab.label }}</a\n >\n </li>\n </ng-container>\n </ul>\n <div class=\"tab-content\">\n <div\n *ngFor=\"let tab of tabs; let i = index\"\n class=\"tab-pane fade\"\n [ngClass]=\"{ 'show active': i === activeTabIndex }\"\n >\n <ng-container *ngTemplateOutlet=\"tab.content\"></ng-container>\n </div>\n </div>\n</ng-container>\n", styles: [".nav-tabs .nav-item .nav-link{cursor:pointer;font-family:var(--font-family);border-top-left-radius:.3rem;border-top-right-radius:.3rem;font-size:14px;color:var(--primary-color);border:1px solid #ddd;transition:background-color .3s ease,color .3s ease}.nav-tabs .nav-item .nav-link.active{background-color:var(--primary-color);color:var(--background-color);border-color:transparent}.nav-tabs .nav-item .nav-link:hover{background-color:var(--secondary-color);color:var(--background-color)}.tab-content .tab-pane{padding:1rem;border:1px solid #ddd;border-top:none}.nav-tabs .nav-item .nav-link{color:var(--primary-color)}.nav-tabs .nav-item .nav-link.active{background-color:var(--primary-color);color:var(--text-color)}\n"] }]
56
56
  }], ctorParameters: function () { return [{ type: i1.AuthService }]; }, propDecorators: { tabs: [{
57
57
  type: Input
58
58
  }], activeTabIndex: [{
@@ -169,11 +169,11 @@ export class DataTableComponent {
169
169
  this.onButtonClick.emit(); // Emitindo o evento
170
170
  }
171
171
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataTableComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.AuthService }, { token: i2.RefreshService }], target: i0.ɵɵFactoryTarget.Component }); }
172
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DataTableComponent, selector: "argenta-list-data-table", inputs: { columns: "columns", hiddenColumns: "hiddenColumns", defaultItemsPerPage: "defaultItemsPerPage", itemsPerPageLabel: "itemsPerPageLabel", showActionColumn: "showActionColumn", actionColumnLabel: "actionColumnLabel", totalItems: "totalItems", fetchDataFunction: "fetchDataFunction", editPermissions: "editPermissions", deletePermissions: "deletePermissions", viewPermissions: "viewPermissions", showPageInfo: "showPageInfo", pageText: "pageText", ofText: "ofText", filterDescription: "filterDescription", buttonLabel: "buttonLabel" }, outputs: { sortChange: "sortChange", pageChange: "pageChange", itemsPerPageChange: "itemsPerPageChange", onEditTable: "onEditTable", onDeleteTable: "onDeleteTable", onViewTable: "onViewTable", onButtonClick: "onButtonClick" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"data-table-header\" style=\"margin-top: 2.5rem;\">\n <div class=\"left-section\">\n <div class=\"form-group\">\n <label for=\"itemsPerPageSelect\" class=\"items-per-page-label\">{{ itemsPerPageLabel }}</label>\n <select\n id=\"itemsPerPageSelect\"\n class=\"form-control form-control-sm d-inline-block w-auto custom-select\"\n [(ngModel)]=\"defaultItemsPerPage\"\n (ngModelChange)=\"onItemsPerPageChange()\">\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">{{ option }}</option>\n </select>\n </div>\n </div>\n <div *ngIf=\"buttonLabel && buttonLabel.length > 0\" class=\"right-section\">\n <button class=\"custom-button\" (click)=\"onNewButtonClick()\">\n <lucide-icon name=\"plus\" [size]=\"28\" [strokeWidth]=\"1.75\"></lucide-icon>\n {{ buttonLabel }}\n </button>\n </div>\n</div>\n\n<div class=\"search-input-container\">\n <argenta-search-input id=\"search\" label=\"\" placeholder=\"Buscar\" [(ngModel)]=\"filterDescription\" (search)=\"onSearch($event)\"></argenta-search-input>\n</div>\n\n<div class=\"table-responsive\" style=\"margin-top: 1rem;\">\n <table class=\"table table-hover\">\n <thead>\n <tr>\n <ng-container *ngFor=\"let column of columns\">\n <th *ngIf=\"!isColumnHidden(column.prop)\" (click)=\"onSort(column.prop)\">\n {{ column.label }}\n </th>\n </ng-container>\n <th *ngIf=\"showActionColumn\" class=\"text-end\" style=\"padding-right: 6.3rem;\">{{ actionColumnLabel }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let item of pagedData; let i = index\">\n <ng-container *ngFor=\"let column of columns\">\n <td *ngIf=\"!isColumnHidden(column.prop)\">\n {{ getNestedProperty(item, column.prop) }}\n </td>\n </ng-container>\n <td *ngIf=\"showActionColumn\" class=\"text-end\">\n <div class=\"d-flex justify-content-end\">\n <div *ngIf=\"hasPermission(editPermissions) && onEditTable.observers.length > 0\" (click)=\"handleAction('edit', item, i)\" class=\"clickable-icon\" style=\"margin-right: 1.5rem;\">\n <lucide-icon name=\"square-pen\" [size]=\"20\" color=\"#2CA58D\" [strokeWidth]=\"1.75\"></lucide-icon>\n </div>\n <div *ngIf=\"hasPermission(viewPermissions) && onViewTable.observers.length > 0\" (click)=\"handleAction('view', item, i)\" class=\"clickable-icon\" style=\"margin-right: 1.5rem;\">\n <lucide-icon name=\"user-round\" [size]=\"20\" color=\"#2CA58D\" [strokeWidth]=\"1.75\"></lucide-icon>\n </div>\n <div *ngIf=\"hasPermission(deletePermissions) && onDeleteTable.observers.length > 0\" (click)=\"handleAction('delete', item, i)\" class=\"clickable-icon\" style=\"margin-right: 1.5rem;\">\n <i-lucide name=\"trash-2\" [size]=\"20\" color=\"#F26E6E\" [strokeWidth]=\"1.75\"></i-lucide>\n </div>\n </div>\n </td>\n </tr>\n </tbody>\n </table>\n</div>\n\n<div class=\"text-center pagination-controls\">\n <custom-pagination\n [totalItems]=\"totalItems\"\n [itemsPerPage]=\"defaultItemsPerPage\"\n [currentPage]=\"currentPage\"\n [showPageInfo]=\"showPageInfo\"\n (pageChange)=\"onPageChange($event)\">\n </custom-pagination>\n</div>\n", styles: ["@charset \"UTF-8\";.clickable-icon{cursor:pointer}:host{font-family:var(--font-family)}.data-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:-.2rem}.left-section,.right-section{display:flex;align-items:center}.search-input-container{display:flex;justify-content:flex-start}.left-section .form-group{display:flex;align-items:center}.items-per-page-label{font-family:var(--font-family);font-size:14px;color:#666;margin-right:.2rem}.custom-select{font-family:var(--font-family);font-size:14px;color:#666;background:#fff url('data:image/svg+xml;charset=US-ASCII,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 4 5\"><path fill=\"#666\" d=\"M2 0L0 2h4L2 0zM2 5l2-2H0l2 2z\"/></svg>') no-repeat right .75rem center/8px 10px;border:1px solid #ccc;border-radius:.25rem;padding:.375rem 1.75rem .375rem .75rem;appearance:none;-webkit-appearance:none;-moz-appearance:none}.custom-select:focus{border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem #007bff40}.table{font-family:var(--font-family);font-size:var(--table-font-size, 14px);color:var(--table-font-color, #737b7b);border-collapse:separate;border-spacing:0;border-radius:8px;overflow:hidden}.table thead tr{height:60px}.table thead th{background-color:var(--primary-color);color:var(--text-color);font-family:var(--font-family);font-size:14px;font-weight:600;padding:10px;border-bottom:.1rem solid #dcdcdc;text-align:center;line-height:2.5}.table thead th:first-child{text-align:left;padding-left:1.4rem}.table tbody td{font-family:var(--font-family);font-size:14px;color:#737b7b;padding:10px;border-bottom:.1rem solid #dcdcdc;text-align:center}.table tbody td:first-child{text-align:left;padding-left:1.4rem}.table tbody tr:last-child td{border-bottom:.1rem solid #dcdcdc}.table tbody td{border-right:none;border-left:none}.table thead th:first-child{border-top-left-radius:0}.table thead th:last-child{border-top-right-radius:0}.table tbody tr:last-child td:first-child{border-bottom-left-radius:0}.table tbody tr:last-child td:last-child{border-bottom-right-radius:0}.btn-icon{width:24px;height:24px;background-size:cover;display:inline-block;cursor:pointer;margin-right:16px}.pagination-controls{display:flex;justify-content:center;align-items:center;margin-top:1rem}.custom-button{display:flex;align-items:center;padding:.5rem 1rem .5rem .5rem;border-radius:.25rem;transition:background-color .3s,border-color .3s,filter .3s;font-family:var(--font-family);font-size:16px;font-weight:600;height:40px;letter-spacing:.005em;text-align:left;color:#fff;background-color:var(--secondary-color);border:none;cursor:pointer}.custom-button lucide-icon{margin-right:.5rem}.custom-button:hover{box-shadow:0 0 0 .2rem #7e7e7e40}.custom-button:active{background-color:#7e7e7e40}.custom-button:focus{outline:none;box-shadow:0 0 0 .2rem #7e7e7e40}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.LucideAngularComponent, selector: "lucide-angular, lucide-icon, i-lucide, span-lucide", inputs: ["class", "name", "img", "color", "absoluteStrokeWidth", "size", "strokeWidth"] }, { kind: "component", type: i6.CustomPaginationComponent, selector: "custom-pagination", inputs: ["totalItems", "itemsPerPage", "currentPage", "showPageInfo"], outputs: ["pageChange"] }, { kind: "component", type: i7.SearchInputComponent, selector: "argenta-search-input", inputs: ["id", "label", "type", "placeholder", "value", "disabled", "readonly", "autofocus", "maxlength", "minlength", "required", "pattern", "debounceTime"], outputs: ["search", "inputChange", "change", "focus", "blur", "keyup", "keydown", "keypress"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
172
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DataTableComponent, selector: "argenta-list-data-table", inputs: { columns: "columns", hiddenColumns: "hiddenColumns", defaultItemsPerPage: "defaultItemsPerPage", itemsPerPageLabel: "itemsPerPageLabel", showActionColumn: "showActionColumn", actionColumnLabel: "actionColumnLabel", totalItems: "totalItems", fetchDataFunction: "fetchDataFunction", editPermissions: "editPermissions", deletePermissions: "deletePermissions", viewPermissions: "viewPermissions", showPageInfo: "showPageInfo", pageText: "pageText", ofText: "ofText", filterDescription: "filterDescription", buttonLabel: "buttonLabel" }, outputs: { sortChange: "sortChange", pageChange: "pageChange", itemsPerPageChange: "itemsPerPageChange", onEditTable: "onEditTable", onDeleteTable: "onDeleteTable", onViewTable: "onViewTable", onButtonClick: "onButtonClick" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"data-table-header\" style=\"margin-top: 2.5rem;\">\n <div class=\"left-section\">\n <div class=\"form-group\">\n <label for=\"itemsPerPageSelect\" class=\"items-per-page-label\">{{ itemsPerPageLabel }}</label>\n <select\n id=\"itemsPerPageSelect\"\n class=\"form-control form-control-sm d-inline-block w-auto custom-select\"\n [(ngModel)]=\"defaultItemsPerPage\"\n (ngModelChange)=\"onItemsPerPageChange()\">\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">{{ option }}</option>\n </select>\n </div>\n </div>\n <div *ngIf=\"buttonLabel && buttonLabel.length > 0\" class=\"right-section\">\n <button class=\"custom-button\" (click)=\"onNewButtonClick()\">\n <lucide-icon name=\"plus\" [size]=\"28\" [strokeWidth]=\"1.75\"></lucide-icon>\n {{ buttonLabel }}\n </button>\n </div>\n</div>\n\n<div class=\"search-input-container\">\n <argenta-search-input id=\"search\" label=\"\" placeholder=\"Buscar\" [(ngModel)]=\"filterDescription\" (search)=\"onSearch($event)\"></argenta-search-input>\n</div>\n\n<div class=\"table-responsive\" style=\"margin-top: 1rem;\">\n <table class=\"table table-hover\">\n <thead>\n <tr>\n <ng-container *ngFor=\"let column of columns\">\n <th *ngIf=\"!isColumnHidden(column.prop)\" (click)=\"onSort(column.prop)\">\n {{ column.label }}\n </th>\n </ng-container>\n <th *ngIf=\"showActionColumn\" class=\"text-end\" style=\"padding-right: 6.3rem;\">{{ actionColumnLabel }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let item of pagedData; let i = index\">\n <ng-container *ngFor=\"let column of columns\">\n <td *ngIf=\"!isColumnHidden(column.prop)\">\n {{ getNestedProperty(item, column.prop) }}\n </td>\n </ng-container>\n <td *ngIf=\"showActionColumn\" class=\"text-end\">\n <div class=\"d-flex justify-content-end\">\n <div *ngIf=\"hasPermission(editPermissions) && onEditTable.observers.length > 0\" (click)=\"handleAction('edit', item, i)\" class=\"clickable-icon\" style=\"margin-right: 1.5rem;\">\n <lucide-icon name=\"square-pen\" [size]=\"20\" color=\"#2CA58D\" [strokeWidth]=\"1.75\"></lucide-icon>\n </div>\n <div *ngIf=\"hasPermission(viewPermissions) && onViewTable.observers.length > 0\" (click)=\"handleAction('view', item, i)\" class=\"clickable-icon\" style=\"margin-right: 1.5rem;\">\n <lucide-icon name=\"user-round\" [size]=\"20\" color=\"#2CA58D\" [strokeWidth]=\"1.75\"></lucide-icon>\n </div>\n <div *ngIf=\"hasPermission(deletePermissions) && onDeleteTable.observers.length > 0\" (click)=\"handleAction('delete', item, i)\" class=\"clickable-icon\" style=\"margin-right: 1.5rem;\">\n <i-lucide name=\"trash-2\" [size]=\"20\" color=\"#F26E6E\" [strokeWidth]=\"1.75\"></i-lucide>\n </div>\n </div>\n </td>\n </tr>\n </tbody>\n </table>\n</div>\n\n<div class=\"text-center pagination-controls\">\n <custom-pagination\n [totalItems]=\"totalItems\"\n [itemsPerPage]=\"defaultItemsPerPage\"\n [currentPage]=\"currentPage\"\n [showPageInfo]=\"showPageInfo\"\n (pageChange)=\"onPageChange($event)\">\n </custom-pagination>\n</div>\n", styles: ["@charset \"UTF-8\";.clickable-icon{cursor:pointer}:host{font-family:var(--font-family)}.data-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:-.2rem}.left-section,.right-section{display:flex;align-items:center}.search-input-container{display:flex;justify-content:flex-start}.left-section .form-group{display:flex;align-items:center}.items-per-page-label{font-family:var(--font-family);font-size:14px;color:#666;margin-right:.2rem}.custom-select{font-family:var(--font-family);font-size:14px;color:#666;background:#fff url('data:image/svg+xml;charset=US-ASCII,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 4 5\"><path fill=\"#666\" d=\"M2 0L0 2h4L2 0zM2 5l2-2H0l2 2z\"/></svg>') no-repeat right .75rem center/8px 10px;border:1px solid #ccc;border-radius:.25rem;padding:.375rem 1.75rem .375rem .75rem;appearance:none;-webkit-appearance:none;-moz-appearance:none}.custom-select:focus{border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem #007bff40}.table{font-family:var(--font-family);font-size:var(--table-font-size, 14px);color:var(--table-font-color, #737b7b);border-collapse:separate;border-spacing:0;border-radius:8px;overflow:hidden}.table thead tr{height:60px}.table thead th{background-color:var(--primary-color);color:var(--text-color);font-family:var(--font-family);font-size:14px;font-weight:600;padding:10px;border-bottom:.1rem solid #dcdcdc;text-align:center;line-height:2.5}.table thead th:first-child{text-align:left;padding-left:1.4rem}.table tbody td{font-family:var(--font-family);font-size:14px;color:#737b7b;padding:10px;border-bottom:.1rem solid #dcdcdc;text-align:center}.table tbody td:first-child{text-align:left;padding-left:1.4rem}.table tbody tr:last-child td{border-bottom:.1rem solid #dcdcdc}.table tbody td{border-right:none;border-left:none}.table thead th:first-child{border-top-left-radius:0}.table thead th:last-child{border-top-right-radius:0}.table tbody tr:last-child td:first-child{border-bottom-left-radius:0}.table tbody tr:last-child td:last-child{border-bottom-right-radius:0}.btn-icon{width:24px;height:24px;background-size:cover;display:inline-block;cursor:pointer;margin-right:16px}.pagination-controls{display:flex;justify-content:center;align-items:center;margin-top:1rem}.custom-button{display:flex;align-items:center;padding:.5rem 1rem .5rem .5rem;border-radius:.25rem;transition:background-color .3s,border-color .3s,filter .3s;font-family:var(--font-family);font-size:16px;font-weight:600;height:40px;letter-spacing:.005em;text-align:left;color:#fff;background-color:var(--secondary-color);border:none;cursor:pointer}.custom-button lucide-icon{margin-right:.5rem}.custom-button:hover{box-shadow:0 0 0 .15rem var(--secondary-color)}.custom-button:active{background-color:var(--secondary-color)}.custom-button:focus{outline:none;box-shadow:0 0 0 .15rem var(--secondary-color)}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.LucideAngularComponent, selector: "lucide-angular, lucide-icon, i-lucide, span-lucide", inputs: ["class", "name", "img", "color", "absoluteStrokeWidth", "size", "strokeWidth"] }, { kind: "component", type: i6.CustomPaginationComponent, selector: "custom-pagination", inputs: ["totalItems", "itemsPerPage", "currentPage", "showPageInfo"], outputs: ["pageChange"] }, { kind: "component", type: i7.SearchInputComponent, selector: "argenta-search-input", inputs: ["id", "label", "type", "placeholder", "value", "disabled", "readonly", "autofocus", "maxlength", "minlength", "required", "pattern", "debounceTime"], outputs: ["search", "inputChange", "change", "focus", "blur", "keyup", "keydown", "keypress"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
173
173
  }
174
174
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataTableComponent, decorators: [{
175
175
  type: Component,
176
- args: [{ selector: 'argenta-list-data-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"data-table-header\" style=\"margin-top: 2.5rem;\">\n <div class=\"left-section\">\n <div class=\"form-group\">\n <label for=\"itemsPerPageSelect\" class=\"items-per-page-label\">{{ itemsPerPageLabel }}</label>\n <select\n id=\"itemsPerPageSelect\"\n class=\"form-control form-control-sm d-inline-block w-auto custom-select\"\n [(ngModel)]=\"defaultItemsPerPage\"\n (ngModelChange)=\"onItemsPerPageChange()\">\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">{{ option }}</option>\n </select>\n </div>\n </div>\n <div *ngIf=\"buttonLabel && buttonLabel.length > 0\" class=\"right-section\">\n <button class=\"custom-button\" (click)=\"onNewButtonClick()\">\n <lucide-icon name=\"plus\" [size]=\"28\" [strokeWidth]=\"1.75\"></lucide-icon>\n {{ buttonLabel }}\n </button>\n </div>\n</div>\n\n<div class=\"search-input-container\">\n <argenta-search-input id=\"search\" label=\"\" placeholder=\"Buscar\" [(ngModel)]=\"filterDescription\" (search)=\"onSearch($event)\"></argenta-search-input>\n</div>\n\n<div class=\"table-responsive\" style=\"margin-top: 1rem;\">\n <table class=\"table table-hover\">\n <thead>\n <tr>\n <ng-container *ngFor=\"let column of columns\">\n <th *ngIf=\"!isColumnHidden(column.prop)\" (click)=\"onSort(column.prop)\">\n {{ column.label }}\n </th>\n </ng-container>\n <th *ngIf=\"showActionColumn\" class=\"text-end\" style=\"padding-right: 6.3rem;\">{{ actionColumnLabel }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let item of pagedData; let i = index\">\n <ng-container *ngFor=\"let column of columns\">\n <td *ngIf=\"!isColumnHidden(column.prop)\">\n {{ getNestedProperty(item, column.prop) }}\n </td>\n </ng-container>\n <td *ngIf=\"showActionColumn\" class=\"text-end\">\n <div class=\"d-flex justify-content-end\">\n <div *ngIf=\"hasPermission(editPermissions) && onEditTable.observers.length > 0\" (click)=\"handleAction('edit', item, i)\" class=\"clickable-icon\" style=\"margin-right: 1.5rem;\">\n <lucide-icon name=\"square-pen\" [size]=\"20\" color=\"#2CA58D\" [strokeWidth]=\"1.75\"></lucide-icon>\n </div>\n <div *ngIf=\"hasPermission(viewPermissions) && onViewTable.observers.length > 0\" (click)=\"handleAction('view', item, i)\" class=\"clickable-icon\" style=\"margin-right: 1.5rem;\">\n <lucide-icon name=\"user-round\" [size]=\"20\" color=\"#2CA58D\" [strokeWidth]=\"1.75\"></lucide-icon>\n </div>\n <div *ngIf=\"hasPermission(deletePermissions) && onDeleteTable.observers.length > 0\" (click)=\"handleAction('delete', item, i)\" class=\"clickable-icon\" style=\"margin-right: 1.5rem;\">\n <i-lucide name=\"trash-2\" [size]=\"20\" color=\"#F26E6E\" [strokeWidth]=\"1.75\"></i-lucide>\n </div>\n </div>\n </td>\n </tr>\n </tbody>\n </table>\n</div>\n\n<div class=\"text-center pagination-controls\">\n <custom-pagination\n [totalItems]=\"totalItems\"\n [itemsPerPage]=\"defaultItemsPerPage\"\n [currentPage]=\"currentPage\"\n [showPageInfo]=\"showPageInfo\"\n (pageChange)=\"onPageChange($event)\">\n </custom-pagination>\n</div>\n", styles: ["@charset \"UTF-8\";.clickable-icon{cursor:pointer}:host{font-family:var(--font-family)}.data-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:-.2rem}.left-section,.right-section{display:flex;align-items:center}.search-input-container{display:flex;justify-content:flex-start}.left-section .form-group{display:flex;align-items:center}.items-per-page-label{font-family:var(--font-family);font-size:14px;color:#666;margin-right:.2rem}.custom-select{font-family:var(--font-family);font-size:14px;color:#666;background:#fff url('data:image/svg+xml;charset=US-ASCII,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 4 5\"><path fill=\"#666\" d=\"M2 0L0 2h4L2 0zM2 5l2-2H0l2 2z\"/></svg>') no-repeat right .75rem center/8px 10px;border:1px solid #ccc;border-radius:.25rem;padding:.375rem 1.75rem .375rem .75rem;appearance:none;-webkit-appearance:none;-moz-appearance:none}.custom-select:focus{border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem #007bff40}.table{font-family:var(--font-family);font-size:var(--table-font-size, 14px);color:var(--table-font-color, #737b7b);border-collapse:separate;border-spacing:0;border-radius:8px;overflow:hidden}.table thead tr{height:60px}.table thead th{background-color:var(--primary-color);color:var(--text-color);font-family:var(--font-family);font-size:14px;font-weight:600;padding:10px;border-bottom:.1rem solid #dcdcdc;text-align:center;line-height:2.5}.table thead th:first-child{text-align:left;padding-left:1.4rem}.table tbody td{font-family:var(--font-family);font-size:14px;color:#737b7b;padding:10px;border-bottom:.1rem solid #dcdcdc;text-align:center}.table tbody td:first-child{text-align:left;padding-left:1.4rem}.table tbody tr:last-child td{border-bottom:.1rem solid #dcdcdc}.table tbody td{border-right:none;border-left:none}.table thead th:first-child{border-top-left-radius:0}.table thead th:last-child{border-top-right-radius:0}.table tbody tr:last-child td:first-child{border-bottom-left-radius:0}.table tbody tr:last-child td:last-child{border-bottom-right-radius:0}.btn-icon{width:24px;height:24px;background-size:cover;display:inline-block;cursor:pointer;margin-right:16px}.pagination-controls{display:flex;justify-content:center;align-items:center;margin-top:1rem}.custom-button{display:flex;align-items:center;padding:.5rem 1rem .5rem .5rem;border-radius:.25rem;transition:background-color .3s,border-color .3s,filter .3s;font-family:var(--font-family);font-size:16px;font-weight:600;height:40px;letter-spacing:.005em;text-align:left;color:#fff;background-color:var(--secondary-color);border:none;cursor:pointer}.custom-button lucide-icon{margin-right:.5rem}.custom-button:hover{box-shadow:0 0 0 .2rem #7e7e7e40}.custom-button:active{background-color:#7e7e7e40}.custom-button:focus{outline:none;box-shadow:0 0 0 .2rem #7e7e7e40}\n"] }]
176
+ args: [{ selector: 'argenta-list-data-table', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"data-table-header\" style=\"margin-top: 2.5rem;\">\n <div class=\"left-section\">\n <div class=\"form-group\">\n <label for=\"itemsPerPageSelect\" class=\"items-per-page-label\">{{ itemsPerPageLabel }}</label>\n <select\n id=\"itemsPerPageSelect\"\n class=\"form-control form-control-sm d-inline-block w-auto custom-select\"\n [(ngModel)]=\"defaultItemsPerPage\"\n (ngModelChange)=\"onItemsPerPageChange()\">\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">{{ option }}</option>\n </select>\n </div>\n </div>\n <div *ngIf=\"buttonLabel && buttonLabel.length > 0\" class=\"right-section\">\n <button class=\"custom-button\" (click)=\"onNewButtonClick()\">\n <lucide-icon name=\"plus\" [size]=\"28\" [strokeWidth]=\"1.75\"></lucide-icon>\n {{ buttonLabel }}\n </button>\n </div>\n</div>\n\n<div class=\"search-input-container\">\n <argenta-search-input id=\"search\" label=\"\" placeholder=\"Buscar\" [(ngModel)]=\"filterDescription\" (search)=\"onSearch($event)\"></argenta-search-input>\n</div>\n\n<div class=\"table-responsive\" style=\"margin-top: 1rem;\">\n <table class=\"table table-hover\">\n <thead>\n <tr>\n <ng-container *ngFor=\"let column of columns\">\n <th *ngIf=\"!isColumnHidden(column.prop)\" (click)=\"onSort(column.prop)\">\n {{ column.label }}\n </th>\n </ng-container>\n <th *ngIf=\"showActionColumn\" class=\"text-end\" style=\"padding-right: 6.3rem;\">{{ actionColumnLabel }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let item of pagedData; let i = index\">\n <ng-container *ngFor=\"let column of columns\">\n <td *ngIf=\"!isColumnHidden(column.prop)\">\n {{ getNestedProperty(item, column.prop) }}\n </td>\n </ng-container>\n <td *ngIf=\"showActionColumn\" class=\"text-end\">\n <div class=\"d-flex justify-content-end\">\n <div *ngIf=\"hasPermission(editPermissions) && onEditTable.observers.length > 0\" (click)=\"handleAction('edit', item, i)\" class=\"clickable-icon\" style=\"margin-right: 1.5rem;\">\n <lucide-icon name=\"square-pen\" [size]=\"20\" color=\"#2CA58D\" [strokeWidth]=\"1.75\"></lucide-icon>\n </div>\n <div *ngIf=\"hasPermission(viewPermissions) && onViewTable.observers.length > 0\" (click)=\"handleAction('view', item, i)\" class=\"clickable-icon\" style=\"margin-right: 1.5rem;\">\n <lucide-icon name=\"user-round\" [size]=\"20\" color=\"#2CA58D\" [strokeWidth]=\"1.75\"></lucide-icon>\n </div>\n <div *ngIf=\"hasPermission(deletePermissions) && onDeleteTable.observers.length > 0\" (click)=\"handleAction('delete', item, i)\" class=\"clickable-icon\" style=\"margin-right: 1.5rem;\">\n <i-lucide name=\"trash-2\" [size]=\"20\" color=\"#F26E6E\" [strokeWidth]=\"1.75\"></i-lucide>\n </div>\n </div>\n </td>\n </tr>\n </tbody>\n </table>\n</div>\n\n<div class=\"text-center pagination-controls\">\n <custom-pagination\n [totalItems]=\"totalItems\"\n [itemsPerPage]=\"defaultItemsPerPage\"\n [currentPage]=\"currentPage\"\n [showPageInfo]=\"showPageInfo\"\n (pageChange)=\"onPageChange($event)\">\n </custom-pagination>\n</div>\n", styles: ["@charset \"UTF-8\";.clickable-icon{cursor:pointer}:host{font-family:var(--font-family)}.data-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:-.2rem}.left-section,.right-section{display:flex;align-items:center}.search-input-container{display:flex;justify-content:flex-start}.left-section .form-group{display:flex;align-items:center}.items-per-page-label{font-family:var(--font-family);font-size:14px;color:#666;margin-right:.2rem}.custom-select{font-family:var(--font-family);font-size:14px;color:#666;background:#fff url('data:image/svg+xml;charset=US-ASCII,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 4 5\"><path fill=\"#666\" d=\"M2 0L0 2h4L2 0zM2 5l2-2H0l2 2z\"/></svg>') no-repeat right .75rem center/8px 10px;border:1px solid #ccc;border-radius:.25rem;padding:.375rem 1.75rem .375rem .75rem;appearance:none;-webkit-appearance:none;-moz-appearance:none}.custom-select:focus{border-color:#80bdff;outline:0;box-shadow:0 0 0 .2rem #007bff40}.table{font-family:var(--font-family);font-size:var(--table-font-size, 14px);color:var(--table-font-color, #737b7b);border-collapse:separate;border-spacing:0;border-radius:8px;overflow:hidden}.table thead tr{height:60px}.table thead th{background-color:var(--primary-color);color:var(--text-color);font-family:var(--font-family);font-size:14px;font-weight:600;padding:10px;border-bottom:.1rem solid #dcdcdc;text-align:center;line-height:2.5}.table thead th:first-child{text-align:left;padding-left:1.4rem}.table tbody td{font-family:var(--font-family);font-size:14px;color:#737b7b;padding:10px;border-bottom:.1rem solid #dcdcdc;text-align:center}.table tbody td:first-child{text-align:left;padding-left:1.4rem}.table tbody tr:last-child td{border-bottom:.1rem solid #dcdcdc}.table tbody td{border-right:none;border-left:none}.table thead th:first-child{border-top-left-radius:0}.table thead th:last-child{border-top-right-radius:0}.table tbody tr:last-child td:first-child{border-bottom-left-radius:0}.table tbody tr:last-child td:last-child{border-bottom-right-radius:0}.btn-icon{width:24px;height:24px;background-size:cover;display:inline-block;cursor:pointer;margin-right:16px}.pagination-controls{display:flex;justify-content:center;align-items:center;margin-top:1rem}.custom-button{display:flex;align-items:center;padding:.5rem 1rem .5rem .5rem;border-radius:.25rem;transition:background-color .3s,border-color .3s,filter .3s;font-family:var(--font-family);font-size:16px;font-weight:600;height:40px;letter-spacing:.005em;text-align:left;color:#fff;background-color:var(--secondary-color);border:none;cursor:pointer}.custom-button lucide-icon{margin-right:.5rem}.custom-button:hover{box-shadow:0 0 0 .15rem var(--secondary-color)}.custom-button:active{background-color:var(--secondary-color)}.custom-button:focus{outline:none;box-shadow:0 0 0 .15rem var(--secondary-color)}\n"] }]
177
177
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.AuthService }, { type: i2.RefreshService }]; }, propDecorators: { columns: [{
178
178
  type: Input
179
179
  }], hiddenColumns: [{