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.
- package/esm2022/lib/components/button/button.component.mjs +118 -7
- package/esm2022/lib/components/tab/tab.component.mjs +2 -2
- package/esm2022/lib/components/tables/data-table.component.mjs +2 -2
- package/fesm2022/lib-portal-angular.mjs +121 -10
- package/fesm2022/lib-portal-angular.mjs.map +1 -1
- package/lib/components/button/button.component.d.ts +9 -3
- package/package.json +1 -1
@@ -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}
|
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}
|
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
|
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
|
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 .
|
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 .
|
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: [{
|