lib-portal-angular 0.0.84 → 0.0.85

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,41 +1,42 @@
1
- import { CommonModule } from "@angular/common";
2
- import { NgModule } from "@angular/core";
3
- import { FormsModule, ReactiveFormsModule } from "@angular/forms";
4
- import { NgSelectModule } from "@ng-select/ng-select";
5
- import { AutofocusDirective } from "../directive/autofocus-directive/autofocus.directive";
6
- import { CepMaskDirective } from "../directive/cep-mask.directive";
7
- import { CnpjMaskDirective } from "../directive/cnpj-mask.directive";
8
- import { CpfMaskDirective } from "../directive/cpf-mask.directive";
9
- import { LucideIconsModule } from "../icons/lucide-icons.module";
10
- import { AccordionArgentaComponent } from "./accordion/accordion.component";
11
- import { AlertComponent } from "./alert/alert.component";
12
- import { AppBackgroundComponent } from "./app-background/app-background.component";
13
- import { BadgeComponent } from "./badge/badge.component";
14
- import { BasicRegistrationComponent } from "./basic-registration/basic-registration.component";
15
- import { ButtonComponent } from "./button/button.component";
16
- import { CalendarArgentaComponent } from "./calendar-argenta/calendar-argenta.component";
17
- import { CardComponent } from "./card/card.component";
18
- import { CheckboxComponent } from "./checkbox/checkbox.component";
19
- import { CodeHighlightComponent } from "./code-highlight/code-highlight.component";
20
- import { ConfirmationComponent } from "./confirmation/confirmation.component";
21
- import { CustomPaginationComponent } from "./custom-pagination/custom-pagination.component";
22
- import { CustomSwitchComponent } from "./custom-switch/custom-switch.component";
23
- import { FileUploadComponent } from "./file-upload/file-upload.component";
24
- import { InputComponent } from "./imput/input.component";
25
- import { JsonViewerComponent } from "./json-viewer/json-viewer.component";
26
- import { ModalComponent } from "./modal/modal.component";
27
- import { MultiSelectCategoryComponent } from "./multi-select-category/multi-select-category.component";
28
- import { MultiSelectComponent } from "./multi-select/multi-select.component";
29
- import { RadioComponent } from "./radio/radio.component";
30
- import { SearchCustomerComponent } from "./search-customer/search-customer.component";
31
- import { SearchInputComponent } from "./search-input/search-input.component";
32
- import { SelectComponent } from "./select/select.component";
33
- import { TabComponent } from "./tab/tab.component";
34
- import { DataTableComponent } from "./tables/data-table.component";
35
- import { TextareaComponent } from "./textarea/textarea.component";
36
- import { TreeNodeComponent } from "./tree-node/tree-node.component";
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
4
+ import { NgSelectModule } from '@ng-select/ng-select';
5
+ import { AutofocusDirective } from '../directive/autofocus-directive/autofocus.directive';
6
+ import { CepMaskDirective } from '../directive/cep-mask.directive';
7
+ import { CnpjMaskDirective } from '../directive/cnpj-mask.directive';
8
+ import { CpfMaskDirective } from '../directive/cpf-mask.directive';
9
+ import { LucideIconsModule } from '../icons/lucide-icons.module';
10
+ import { AccordionArgentaComponent } from './accordion/accordion.component';
11
+ import { AlertComponent } from './alert/alert.component';
12
+ import { AppBackgroundComponent } from './app-background/app-background.component';
13
+ import { BadgeComponent } from './badge/badge.component';
14
+ import { BasicRegistrationComponent } from './basic-registration/basic-registration.component';
15
+ import { ButtonComponent } from './button/button.component';
16
+ import { CalendarArgentaComponent } from './calendar-argenta/calendar-argenta.component';
17
+ import { CardComponent } from './card/card.component';
18
+ import { CheckboxComponent } from './checkbox/checkbox.component';
19
+ import { CodeHighlightComponent } from './code-highlight/code-highlight.component';
20
+ import { ConfirmationComponent } from './confirmation/confirmation.component';
21
+ import { CustomPaginationComponent } from './custom-pagination/custom-pagination.component';
22
+ import { CustomSwitchComponent } from './custom-switch/custom-switch.component';
23
+ import { DragDropListComponent } from './drag-drop-list/drag-drop-list.component';
37
24
  import { DynamicModalComponent } from "./dynamic-modal/dynamic-modal.component";
38
25
  import { DynamicTableComponent } from "./dynamic-table/dynamic-table.component";
26
+ import { FileUploadComponent } from './file-upload/file-upload.component';
27
+ import { InputComponent } from './imput/input.component';
28
+ import { JsonViewerComponent } from './json-viewer/json-viewer.component';
29
+ import { ModalComponent } from './modal/modal.component';
30
+ import { MultiSelectCategoryComponent } from './multi-select-category/multi-select-category.component';
31
+ import { MultiSelectComponent } from './multi-select/multi-select.component';
32
+ import { RadioComponent } from './radio/radio.component';
33
+ import { SearchCustomerComponent } from './search-customer/search-customer.component';
34
+ import { SearchInputComponent } from './search-input/search-input.component';
35
+ import { SelectComponent } from './select/select.component';
36
+ import { TabComponent } from './tab/tab.component';
37
+ import { DataTableComponent } from './tables/data-table.component';
38
+ import { TextareaComponent } from './textarea/textarea.component';
39
+ import { TreeNodeComponent } from './tree-node/tree-node.component';
39
40
  import * as i0 from "@angular/core";
40
41
  export class ComponentsModule {
41
42
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
@@ -70,6 +71,7 @@ export class ComponentsModule {
70
71
  AccordionArgentaComponent,
71
72
  JsonViewerComponent,
72
73
  ModalComponent,
74
+ DragDropListComponent,
73
75
  DynamicModalComponent,
74
76
  DynamicTableComponent], imports: [CommonModule,
75
77
  FormsModule,
@@ -110,6 +112,7 @@ export class ComponentsModule {
110
112
  AccordionArgentaComponent,
111
113
  JsonViewerComponent,
112
114
  ModalComponent,
115
+ DragDropListComponent,
113
116
  DynamicModalComponent,
114
117
  DynamicTableComponent] }); }
115
118
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, imports: [CommonModule,
@@ -156,6 +159,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
156
159
  AccordionArgentaComponent,
157
160
  JsonViewerComponent,
158
161
  ModalComponent,
162
+ DragDropListComponent,
159
163
  DynamicModalComponent,
160
164
  DynamicTableComponent,
161
165
  ],
@@ -202,9 +206,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
202
206
  AccordionArgentaComponent,
203
207
  JsonViewerComponent,
204
208
  ModalComponent,
209
+ DragDropListComponent,
205
210
  DynamicModalComponent,
206
211
  DynamicTableComponent,
207
212
  ],
208
213
  }]
209
214
  }] });
210
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"components.module.js","sourceRoot":"","sources":["../../../../../projects/lib-portal-angular/src/lib/components/components.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from \"@angular/common\";\nimport { NgModule } from \"@angular/core\";\nimport { FormsModule, ReactiveFormsModule } from \"@angular/forms\";\nimport { NgSelectModule } from \"@ng-select/ng-select\";\nimport { AutofocusDirective } from \"../directive/autofocus-directive/autofocus.directive\";\nimport { CepMaskDirective } from \"../directive/cep-mask.directive\";\nimport { CnpjMaskDirective } from \"../directive/cnpj-mask.directive\";\nimport { CpfMaskDirective } from \"../directive/cpf-mask.directive\";\nimport { LucideIconsModule } from \"../icons/lucide-icons.module\";\nimport { AccordionArgentaComponent } from \"./accordion/accordion.component\";\nimport { AlertComponent } from \"./alert/alert.component\";\nimport { AppBackgroundComponent } from \"./app-background/app-background.component\";\nimport { BadgeComponent } from \"./badge/badge.component\";\nimport { BasicRegistrationComponent } from \"./basic-registration/basic-registration.component\";\nimport { ButtonComponent } from \"./button/button.component\";\nimport { CalendarArgentaComponent } from \"./calendar-argenta/calendar-argenta.component\";\nimport { CardComponent } from \"./card/card.component\";\nimport { CheckboxComponent } from \"./checkbox/checkbox.component\";\nimport { CodeHighlightComponent } from \"./code-highlight/code-highlight.component\";\nimport { ConfirmationComponent } from \"./confirmation/confirmation.component\";\nimport { CustomPaginationComponent } from \"./custom-pagination/custom-pagination.component\";\nimport { CustomSwitchComponent } from \"./custom-switch/custom-switch.component\";\nimport { FileUploadComponent } from \"./file-upload/file-upload.component\";\nimport { InputComponent } from \"./imput/input.component\";\nimport { JsonViewerComponent } from \"./json-viewer/json-viewer.component\";\nimport { ModalComponent } from \"./modal/modal.component\";\nimport { MultiSelectCategoryComponent } from \"./multi-select-category/multi-select-category.component\";\nimport { MultiSelectComponent } from \"./multi-select/multi-select.component\";\nimport { RadioComponent } from \"./radio/radio.component\";\nimport { SearchCustomerComponent } from \"./search-customer/search-customer.component\";\nimport { SearchInputComponent } from \"./search-input/search-input.component\";\nimport { SelectComponent } from \"./select/select.component\";\nimport { TabComponent } from \"./tab/tab.component\";\nimport { DataTableComponent } from \"./tables/data-table.component\";\nimport { TextareaComponent } from \"./textarea/textarea.component\";\nimport { TreeNodeComponent } from \"./tree-node/tree-node.component\";\nimport { DynamicModalComponent } from \"./dynamic-modal/dynamic-modal.component\";\nimport { DynamicTableComponent } from \"./dynamic-table/dynamic-table.component\";\n@NgModule({\n  declarations: [\n    ButtonComponent,\n    CardComponent,\n    InputComponent,\n    CheckboxComponent,\n    TextareaComponent,\n    SelectComponent,\n    RadioComponent,\n    MultiSelectComponent,\n    DataTableComponent,\n    CodeHighlightComponent,\n    BadgeComponent,\n    AlertComponent,\n    ConfirmationComponent,\n    AutofocusDirective,\n    CepMaskDirective,\n    CnpjMaskDirective,\n    CpfMaskDirective,\n    CustomPaginationComponent,\n    TreeNodeComponent,\n    SearchInputComponent,\n    AppBackgroundComponent,\n    BasicRegistrationComponent,\n    CustomSwitchComponent,\n    SearchCustomerComponent,\n    TabComponent,\n    FileUploadComponent,\n    MultiSelectCategoryComponent,\n    CalendarArgentaComponent,\n    AccordionArgentaComponent,\n    JsonViewerComponent,\n    ModalComponent,\n    DynamicModalComponent,\n    DynamicTableComponent,\n  ],\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    NgSelectModule,\n    LucideIconsModule,\n  ],\n  exports: [\n    ButtonComponent,\n    CardComponent,\n    InputComponent,\n    CheckboxComponent,\n    TextareaComponent,\n    SelectComponent,\n    RadioComponent,\n    MultiSelectComponent,\n    FormsModule,\n    ReactiveFormsModule,\n    NgSelectModule,\n    DataTableComponent,\n    CodeHighlightComponent,\n    BadgeComponent,\n    AlertComponent,\n    ConfirmationComponent,\n    AutofocusDirective,\n    CepMaskDirective,\n    CnpjMaskDirective,\n    CpfMaskDirective,\n    CustomPaginationComponent,\n    TreeNodeComponent,\n    SearchInputComponent,\n    LucideIconsModule,\n    AppBackgroundComponent,\n    BasicRegistrationComponent,\n    CustomSwitchComponent,\n    SearchCustomerComponent,\n    TabComponent,\n    FileUploadComponent,\n    MultiSelectCategoryComponent,\n    CalendarArgentaComponent,\n    AccordionArgentaComponent,\n    JsonViewerComponent,\n    ModalComponent,\n    DynamicModalComponent,\n    DynamicTableComponent,\n  ],\n})\nexport class ComponentsModule {}\n"]}
215
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"components.module.js","sourceRoot":"","sources":["../../../../../projects/lib-portal-angular/src/lib/components/components.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport { NgModule } from '@angular/core'\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms'\nimport { NgSelectModule } from '@ng-select/ng-select'\nimport { AutofocusDirective } from '../directive/autofocus-directive/autofocus.directive'\nimport { CepMaskDirective } from '../directive/cep-mask.directive'\nimport { CnpjMaskDirective } from '../directive/cnpj-mask.directive'\nimport { CpfMaskDirective } from '../directive/cpf-mask.directive'\nimport { LucideIconsModule } from '../icons/lucide-icons.module'\nimport { AccordionArgentaComponent } from './accordion/accordion.component'\nimport { AlertComponent } from './alert/alert.component'\nimport { AppBackgroundComponent } from './app-background/app-background.component'\nimport { BadgeComponent } from './badge/badge.component'\nimport { BasicRegistrationComponent } from './basic-registration/basic-registration.component'\nimport { ButtonComponent } from './button/button.component'\nimport { CalendarArgentaComponent } from './calendar-argenta/calendar-argenta.component'\nimport { CardComponent } from './card/card.component'\nimport { CheckboxComponent } from './checkbox/checkbox.component'\nimport { CodeHighlightComponent } from './code-highlight/code-highlight.component'\nimport { ConfirmationComponent } from './confirmation/confirmation.component'\nimport { CustomPaginationComponent } from './custom-pagination/custom-pagination.component'\nimport { CustomSwitchComponent } from './custom-switch/custom-switch.component'\nimport { DragDropListComponent } from './drag-drop-list/drag-drop-list.component'\nimport { DynamicModalComponent } from \"./dynamic-modal/dynamic-modal.component\"\nimport { DynamicTableComponent } from \"./dynamic-table/dynamic-table.component\"\nimport { FileUploadComponent } from './file-upload/file-upload.component'\nimport { InputComponent } from './imput/input.component'\nimport { JsonViewerComponent } from './json-viewer/json-viewer.component'\nimport { ModalComponent } from './modal/modal.component'\nimport { MultiSelectCategoryComponent } from './multi-select-category/multi-select-category.component'\nimport { MultiSelectComponent } from './multi-select/multi-select.component'\nimport { RadioComponent } from './radio/radio.component'\nimport { SearchCustomerComponent } from './search-customer/search-customer.component'\nimport { SearchInputComponent } from './search-input/search-input.component'\nimport { SelectComponent } from './select/select.component'\nimport { TabComponent } from './tab/tab.component'\nimport { DataTableComponent } from './tables/data-table.component'\nimport { TextareaComponent } from './textarea/textarea.component'\nimport { TreeNodeComponent } from './tree-node/tree-node.component'\n@NgModule({\n  declarations: [\n    ButtonComponent,\n    CardComponent,\n    InputComponent,\n    CheckboxComponent,\n    TextareaComponent,\n    SelectComponent,\n    RadioComponent,\n    MultiSelectComponent,\n    DataTableComponent,\n    CodeHighlightComponent,\n    BadgeComponent,\n    AlertComponent,\n    ConfirmationComponent,\n    AutofocusDirective,\n    CepMaskDirective,\n    CnpjMaskDirective,\n    CpfMaskDirective,\n    CustomPaginationComponent,\n    TreeNodeComponent,\n    SearchInputComponent,\n    AppBackgroundComponent,\n    BasicRegistrationComponent,\n    CustomSwitchComponent,\n    SearchCustomerComponent,\n    TabComponent,\n    FileUploadComponent,\n    MultiSelectCategoryComponent,\n    CalendarArgentaComponent,\n    AccordionArgentaComponent,\n    JsonViewerComponent,\n    ModalComponent,\n    DragDropListComponent,\n    DynamicModalComponent,\n    DynamicTableComponent,\n  ],\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    NgSelectModule,\n    LucideIconsModule,\n  ],\n  exports: [\n    ButtonComponent,\n    CardComponent,\n    InputComponent,\n    CheckboxComponent,\n    TextareaComponent,\n    SelectComponent,\n    RadioComponent,\n    MultiSelectComponent,\n    FormsModule,\n    ReactiveFormsModule,\n    NgSelectModule,\n    DataTableComponent,\n    CodeHighlightComponent,\n    BadgeComponent,\n    AlertComponent,\n    ConfirmationComponent,\n    AutofocusDirective,\n    CepMaskDirective,\n    CnpjMaskDirective,\n    CpfMaskDirective,\n    CustomPaginationComponent,\n    TreeNodeComponent,\n    SearchInputComponent,\n    LucideIconsModule,\n    AppBackgroundComponent,\n    BasicRegistrationComponent,\n    CustomSwitchComponent,\n    SearchCustomerComponent,\n    TabComponent,\n    FileUploadComponent,\n    MultiSelectCategoryComponent,\n    CalendarArgentaComponent,\n    AccordionArgentaComponent,\n    JsonViewerComponent,\n    ModalComponent,\n    DragDropListComponent,\n    DynamicModalComponent,\n    DynamicTableComponent,\n  ],\n})\nexport class ComponentsModule {}\n"]}
@@ -0,0 +1,91 @@
1
+ import { Component, EventEmitter, Input, Output } from "@angular/core";
2
+ import { Subject } from "rxjs";
3
+ import { debounceTime } from "rxjs/operators";
4
+ import { ButtonClasses } from "../../enum/ButtonClassesEnum";
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common";
7
+ import * as i2 from "../button/button.component";
8
+ export class DragDropListComponent {
9
+ constructor() {
10
+ this.nonSelectedList = [];
11
+ this.nonSelectedButtonClick = new EventEmitter();
12
+ this.nonSelectedInputChanged = new EventEmitter();
13
+ this.selectedList = [];
14
+ this.selectedButtonClick = new EventEmitter();
15
+ this.selectedInputChanged = new EventEmitter();
16
+ this.nonSelectedListInputSubject = new Subject();
17
+ this.selectedListInputSubject = new Subject();
18
+ this.ButtonClasses = ButtonClasses; // Adicione a enumeração ao componente
19
+ this.draggedItem = null;
20
+ this.nonSelectedListInputSubject.pipe(debounceTime(2000)).subscribe((value) => {
21
+ this.nonSelectedInputChanged.emit(value);
22
+ });
23
+ this.selectedListInputSubject.pipe(debounceTime(2000)).subscribe((value) => {
24
+ this.selectedInputChanged.emit(value);
25
+ });
26
+ }
27
+ onDragStart(item) {
28
+ this.draggedItem = item;
29
+ }
30
+ onDragOver(event) {
31
+ event.preventDefault();
32
+ }
33
+ onDrop(list, event) {
34
+ event.preventDefault();
35
+ if (this.draggedItem) {
36
+ const index = list.indexOf(this.draggedItem);
37
+ if (index === -1) {
38
+ this.removeItem(this.draggedItem);
39
+ list.push(this.draggedItem);
40
+ }
41
+ this.draggedItem = null;
42
+ }
43
+ }
44
+ removeItem(item) {
45
+ [this.nonSelectedList, this.selectedList].forEach((list) => {
46
+ const index = list.indexOf(item);
47
+ if (index !== -1) {
48
+ list.splice(index, 1);
49
+ }
50
+ });
51
+ }
52
+ nonSelectedListInputChange(event) {
53
+ this.nonSelectedListInputSubject.next(event.target.value);
54
+ }
55
+ selectedListInputChange(event) {
56
+ this.selectedListInputSubject.next(event.target.value);
57
+ }
58
+ selButtonClick() {
59
+ this.selectedButtonClick.emit();
60
+ }
61
+ nonSelButtonClick() {
62
+ this.nonSelectedButtonClick.emit();
63
+ }
64
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DragDropListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
65
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DragDropListComponent, selector: "argenta-drag-drop-list", inputs: { nonSelectedTitle: "nonSelectedTitle", nonSelectedList: "nonSelectedList", nonSelectedButtonLabel: "nonSelectedButtonLabel", selectedTitle: "selectedTitle", selectedList: "selectedList", selectedButtonLabel: "selectedButtonLabel" }, outputs: { nonSelectedButtonClick: "nonSelectedButtonClick", nonSelectedInputChanged: "nonSelectedInputChanged", selectedButtonClick: "selectedButtonClick", selectedInputChanged: "selectedInputChanged" }, ngImport: i0, template: "<!-- Cont\u00EAiner externo para dar a apar\u00EAncia de grupo -->\n<div class=\"group-container\">\n <div class=\"container\">\n <!-- Lista 1 com input -->\n <div\n class=\"list\"\n (dragover)=\"onDragOver($event)\"\n (drop)=\"onDrop(nonSelectedList, $event)\"\n >\n <div class=\"row\">\n <h6 class=\"col-md-8\">{{ nonSelectedTitle }}</h6>\n <div *ngIf=\"nonSelectedButtonLabel\" class=\"col-md-4 align-end\">\n <argenta-custom-button\n label=\"{{ nonSelectedButtonLabel }}\"\n (onButtonClick)=\"nonSelButtonClick()\"\n class=\"align-end\"\n [btnClass]=\"ButtonClasses.Primary\"\n >\n </argenta-custom-button>\n </div>\n </div>\n <input\n type=\"text\"\n class=\"list-input\"\n (input)=\"nonSelectedListInputChange($event)\"\n />\n <div\n *ngFor=\"let item of nonSelectedList\"\n class=\"item-card\"\n draggable=\"true\"\n (dragstart)=\"onDragStart(item)\"\n >\n {{ item.descricao }}\n </div>\n </div>\n\n <!-- Lista 2 com input -->\n <div\n class=\"list\"\n (dragover)=\"onDragOver($event)\"\n (drop)=\"onDrop(selectedList, $event)\"\n >\n <div class=\"row\">\n <h6 class=\"col-md-8\">{{ selectedTitle }}</h6>\n <div *ngIf=\"selectedButtonLabel\" class=\"col-md-4 align-end\">\n <argenta-custom-button\n label=\"{{ selectedButtonLabel }}\"\n (onButtonClick)=\"selButtonClick()\"\n class=\"align-end\"\n [btnClass]=\"ButtonClasses.Primary\"\n >\n </argenta-custom-button>\n </div>\n </div>\n <input\n type=\"text\"\n class=\"list-input\"\n (input)=\"selectedListInputChange($event)\"\n />\n <div\n *ngFor=\"let item of selectedList\"\n class=\"item-card\"\n draggable=\"true\"\n (dragstart)=\"onDragStart(item)\"\n >\n {{ item.descricao }}\n </div>\n </div>\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";.group-container{display:flex;justify-content:center;padding:20px;background-color:#fff;border-radius:12px;box-shadow:0 4px 8px #0000001a;width:80%;margin:auto}.container{display:flex;gap:20px;width:100%}.list{flex:1;padding:10px;background-color:#f0f0f0;border-radius:8px;display:flex;flex-direction:column;align-items:flex-start;gap:10px}.list-input{width:100%;height:40px;margin-bottom:15px;border-radius:4px;border:1px solid #ccc;outline:none;font-size:1rem;resize:none}.item-card{width:100%;padding:15px;background-color:#fff;border-radius:8px;box-shadow:0 2px 5px #0003;cursor:move;display:flex;align-items:center;justify-content:center;text-align:center;font-family:var(--font-family);font-weight:500;font-size:1.1rem;color:#333}.row{display:flex;justify-content:space-between;align-items:center;width:100%;max-height:50px;height:50px}.align-end{display:flex;justify-content:flex-end}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ButtonComponent, selector: "argenta-custom-button", inputs: ["type", "label", "btnClass", "fontSize", "disabled", "autofocus", "form", "formaction", "formenctype", "formmethod", "formnovalidate", "formtarget", "name", "value", "permissions"], outputs: ["onButtonClick"] }] }); }
66
+ }
67
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DragDropListComponent, decorators: [{
68
+ type: Component,
69
+ args: [{ selector: "argenta-drag-drop-list", template: "<!-- Cont\u00EAiner externo para dar a apar\u00EAncia de grupo -->\n<div class=\"group-container\">\n <div class=\"container\">\n <!-- Lista 1 com input -->\n <div\n class=\"list\"\n (dragover)=\"onDragOver($event)\"\n (drop)=\"onDrop(nonSelectedList, $event)\"\n >\n <div class=\"row\">\n <h6 class=\"col-md-8\">{{ nonSelectedTitle }}</h6>\n <div *ngIf=\"nonSelectedButtonLabel\" class=\"col-md-4 align-end\">\n <argenta-custom-button\n label=\"{{ nonSelectedButtonLabel }}\"\n (onButtonClick)=\"nonSelButtonClick()\"\n class=\"align-end\"\n [btnClass]=\"ButtonClasses.Primary\"\n >\n </argenta-custom-button>\n </div>\n </div>\n <input\n type=\"text\"\n class=\"list-input\"\n (input)=\"nonSelectedListInputChange($event)\"\n />\n <div\n *ngFor=\"let item of nonSelectedList\"\n class=\"item-card\"\n draggable=\"true\"\n (dragstart)=\"onDragStart(item)\"\n >\n {{ item.descricao }}\n </div>\n </div>\n\n <!-- Lista 2 com input -->\n <div\n class=\"list\"\n (dragover)=\"onDragOver($event)\"\n (drop)=\"onDrop(selectedList, $event)\"\n >\n <div class=\"row\">\n <h6 class=\"col-md-8\">{{ selectedTitle }}</h6>\n <div *ngIf=\"selectedButtonLabel\" class=\"col-md-4 align-end\">\n <argenta-custom-button\n label=\"{{ selectedButtonLabel }}\"\n (onButtonClick)=\"selButtonClick()\"\n class=\"align-end\"\n [btnClass]=\"ButtonClasses.Primary\"\n >\n </argenta-custom-button>\n </div>\n </div>\n <input\n type=\"text\"\n class=\"list-input\"\n (input)=\"selectedListInputChange($event)\"\n />\n <div\n *ngFor=\"let item of selectedList\"\n class=\"item-card\"\n draggable=\"true\"\n (dragstart)=\"onDragStart(item)\"\n >\n {{ item.descricao }}\n </div>\n </div>\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";.group-container{display:flex;justify-content:center;padding:20px;background-color:#fff;border-radius:12px;box-shadow:0 4px 8px #0000001a;width:80%;margin:auto}.container{display:flex;gap:20px;width:100%}.list{flex:1;padding:10px;background-color:#f0f0f0;border-radius:8px;display:flex;flex-direction:column;align-items:flex-start;gap:10px}.list-input{width:100%;height:40px;margin-bottom:15px;border-radius:4px;border:1px solid #ccc;outline:none;font-size:1rem;resize:none}.item-card{width:100%;padding:15px;background-color:#fff;border-radius:8px;box-shadow:0 2px 5px #0003;cursor:move;display:flex;align-items:center;justify-content:center;text-align:center;font-family:var(--font-family);font-weight:500;font-size:1.1rem;color:#333}.row{display:flex;justify-content:space-between;align-items:center;width:100%;max-height:50px;height:50px}.align-end{display:flex;justify-content:flex-end}\n"] }]
70
+ }], ctorParameters: function () { return []; }, propDecorators: { nonSelectedTitle: [{
71
+ type: Input
72
+ }], nonSelectedList: [{
73
+ type: Input
74
+ }], nonSelectedButtonLabel: [{
75
+ type: Input
76
+ }], nonSelectedButtonClick: [{
77
+ type: Output
78
+ }], nonSelectedInputChanged: [{
79
+ type: Output
80
+ }], selectedTitle: [{
81
+ type: Input
82
+ }], selectedList: [{
83
+ type: Input
84
+ }], selectedButtonLabel: [{
85
+ type: Input
86
+ }], selectedButtonClick: [{
87
+ type: Output
88
+ }], selectedInputChanged: [{
89
+ type: Output
90
+ }] } });
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drag-drop-list.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/drag-drop-list/drag-drop-list.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/drag-drop-list/drag-drop-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from \"@angular/core\"\nimport { Subject } from \"rxjs\"\nimport { debounceTime } from \"rxjs/operators\"\nimport { ButtonClasses } from \"../../enum/ButtonClassesEnum\"\n\ninterface ListItem {\n  id: string;\n  descricao: string;\n}\n\n@Component({\n  selector: \"argenta-drag-drop-list\",\n  templateUrl: \"./drag-drop-list.component.html\",\n  styleUrls: [\"./drag-drop-list.component.scss\"],\n})\nexport class DragDropListComponent {\n  @Input() nonSelectedTitle!: string\n  @Input() nonSelectedList: ListItem[] = [];\n  @Input() nonSelectedButtonLabel?: string\n  @Output() nonSelectedButtonClick: EventEmitter<void> = new EventEmitter<void>();\n  @Output() nonSelectedInputChanged = new EventEmitter<string>();\n\n  @Input() selectedTitle!: string\n  @Input() selectedList: ListItem[] = [];\n  @Input() selectedButtonLabel?: string\n  @Output() selectedButtonClick: EventEmitter<void> = new EventEmitter<void>();\n  @Output() selectedInputChanged = new EventEmitter<string>();\n\n  private nonSelectedListInputSubject = new Subject<string>();\n  private selectedListInputSubject = new Subject<string>();\n\n\n  ButtonClasses = ButtonClasses; // Adicione a enumeração ao componente\n  draggedItem: ListItem | null = null\n\n  constructor() {\n    this.nonSelectedListInputSubject.pipe(debounceTime(2000)).subscribe((value) => {\n      this.nonSelectedInputChanged.emit(value);\n    });\n\n    this.selectedListInputSubject.pipe(debounceTime(2000)).subscribe((value) => {\n      this.selectedInputChanged.emit(value);\n    });\n  }\n\n  onDragStart(item: ListItem) {\n    this.draggedItem = item;\n  }\n\n  onDragOver(event: DragEvent) {\n    event.preventDefault();\n  }\n\n  onDrop(list: ListItem[], event: DragEvent) {\n    event.preventDefault();\n    if (this.draggedItem) {\n      const index = list.indexOf(this.draggedItem);\n      if (index === -1) {\n        this.removeItem(this.draggedItem);\n        list.push(this.draggedItem);\n      }\n      this.draggedItem = null;\n    }\n  }\n\n  private removeItem(item: any) {\n    [this.nonSelectedList, this.selectedList].forEach((list) => {\n      const index = list.indexOf(item);\n      if (index !== -1) {\n        list.splice(index, 1);\n      }\n    });\n  }\n\n  nonSelectedListInputChange(event: any) {\n    this.nonSelectedListInputSubject.next(event.target.value);\n  }\n\n  selectedListInputChange(event: any) {\n    this.selectedListInputSubject.next(event.target.value);\n  }\n\n  selButtonClick() {\n    this.selectedButtonClick!.emit()\n  }\n\n  nonSelButtonClick() {\n    this.nonSelectedButtonClick!.emit()\n  }\n}\n","<!-- Contêiner externo para dar a aparência de grupo -->\n<div class=\"group-container\">\n  <div class=\"container\">\n    <!-- Lista 1 com input -->\n    <div\n      class=\"list\"\n      (dragover)=\"onDragOver($event)\"\n      (drop)=\"onDrop(nonSelectedList, $event)\"\n    >\n      <div class=\"row\">\n        <h6 class=\"col-md-8\">{{ nonSelectedTitle }}</h6>\n        <div *ngIf=\"nonSelectedButtonLabel\" class=\"col-md-4 align-end\">\n          <argenta-custom-button\n            label=\"{{ nonSelectedButtonLabel }}\"\n            (onButtonClick)=\"nonSelButtonClick()\"\n            class=\"align-end\"\n            [btnClass]=\"ButtonClasses.Primary\"\n          >\n          </argenta-custom-button>\n        </div>\n      </div>\n      <input\n        type=\"text\"\n        class=\"list-input\"\n        (input)=\"nonSelectedListInputChange($event)\"\n      />\n      <div\n        *ngFor=\"let item of nonSelectedList\"\n        class=\"item-card\"\n        draggable=\"true\"\n        (dragstart)=\"onDragStart(item)\"\n      >\n        {{ item.descricao }}\n      </div>\n    </div>\n\n    <!-- Lista 2 com input -->\n    <div\n      class=\"list\"\n      (dragover)=\"onDragOver($event)\"\n      (drop)=\"onDrop(selectedList, $event)\"\n    >\n      <div class=\"row\">\n        <h6 class=\"col-md-8\">{{ selectedTitle }}</h6>\n        <div *ngIf=\"selectedButtonLabel\" class=\"col-md-4 align-end\">\n          <argenta-custom-button\n            label=\"{{ selectedButtonLabel }}\"\n            (onButtonClick)=\"selButtonClick()\"\n            class=\"align-end\"\n            [btnClass]=\"ButtonClasses.Primary\"\n          >\n          </argenta-custom-button>\n        </div>\n      </div>\n      <input\n        type=\"text\"\n        class=\"list-input\"\n        (input)=\"selectedListInputChange($event)\"\n      />\n      <div\n        *ngFor=\"let item of selectedList\"\n        class=\"item-card\"\n        draggable=\"true\"\n        (dragstart)=\"onDragStart(item)\"\n      >\n        {{ item.descricao }}\n      </div>\n    </div>\n  </div>\n</div>\n"]}
@@ -1,7 +1,7 @@
1
- import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from "@angular/core";
2
- import { Observable, Subject } from "rxjs";
3
- import { takeUntil } from "rxjs/operators";
4
- import { ButtonClasses } from "../../enum/ButtonClassesEnum"; // Importando o enum
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { Observable, Subject } from 'rxjs';
3
+ import { takeUntil } from 'rxjs/operators';
4
+ import { ButtonClasses } from '../../enum/ButtonClassesEnum'; // Importando o enum
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "../../service/auth-service.service";
7
7
  import * as i2 from "../../service/refresh-service.service";
@@ -35,6 +35,8 @@ export class DataTableComponent {
35
35
  this.buttonLabel = "";
36
36
  this.pagedData = [];
37
37
  this.initialFilterField = null;
38
+ this.buttonList = [];
39
+ this.sortChange = new EventEmitter();
38
40
  this.pageChange = new EventEmitter();
39
41
  this.itemsPerPageChange = new EventEmitter();
40
42
  this.onEditTable = new EventEmitter();
@@ -228,11 +230,11 @@ export class DataTableComponent {
228
230
  this.onButtonClick.emit(); // Emitindo o evento
229
231
  }
230
232
  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 }); }
231
- 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", pagedData: "pagedData", initialFilterField: "initialFilterField" }, outputs: { pageChange: "pageChange", itemsPerPageChange: "itemsPerPageChange", onEditTable: "onEditTable", onDeleteTable: "onDeleteTable", onViewTable: "onViewTable", onButtonClick: "onButtonClick", filterFieldChange: "filterFieldChange" }, 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\">{{\n itemsPerPageLabel\n }}</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 >\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">\n {{ option }}\n </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\n id=\"search\"\n label=\"\"\n placeholder=\"Buscar\"\n [(ngModel)]=\"filterDescription\"\n (search)=\"onSearch($event)\"\n ></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\n *ngIf=\"!isColumnHidden(column.prop)\"\n (click)=\"onSelectSearchField(column.prop)\"\n >\n {{ column.label }}\n <span>\n <i-lucide\n name=\"arrow-up\"\n [size]=\"14\"\n [class.selected]=\"\n column.isSearchSelected && sortDirection === 'asc'\n \"\n ></i-lucide>\n <i-lucide\n name=\"arrow-down\"\n [size]=\"14\"\n [class.selected]=\"\n column.isSearchSelected && sortDirection === 'desc'\n \"\n ></i-lucide>\n </span>\n </th>\n </ng-container>\n <th\n *ngIf=\"showActionColumn\"\n class=\"text-end\"\n style=\"padding-right: 6.3rem\"\n >\n {{ actionColumnLabel }}\n </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\n *ngIf=\"\n hasPermission(editPermissions) &&\n onEditTable.observers.length > 0\n \"\n (click)=\"handleAction('edit', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <lucide-icon\n name=\"square-pen\"\n [size]=\"20\"\n color=\"#2CA58D\"\n [strokeWidth]=\"1.75\"\n ></lucide-icon>\n </div>\n <div\n *ngIf=\"\n hasPermission(viewPermissions) &&\n onViewTable.observers.length > 0\n \"\n (click)=\"handleAction('view', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <lucide-icon\n name=\"user-round\"\n [size]=\"20\"\n color=\"#2CA58D\"\n [strokeWidth]=\"1.75\"\n ></lucide-icon>\n </div>\n <div\n *ngIf=\"\n hasPermission(deletePermissions) &&\n onDeleteTable.observers.length > 0\n \"\n (click)=\"handleAction('delete', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <i-lucide\n name=\"trash-2\"\n [size]=\"20\"\n color=\"#F26E6E\"\n [strokeWidth]=\"1.75\"\n ></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 >\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)}.selected{color:var(--secondary-color);stroke-width:8}\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 }); }
233
+ 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", pagedData: "pagedData", initialFilterField: "initialFilterField", buttonList: "buttonList" }, outputs: { sortChange: "sortChange", pageChange: "pageChange", itemsPerPageChange: "itemsPerPageChange", onEditTable: "onEditTable", onDeleteTable: "onDeleteTable", onViewTable: "onViewTable", onButtonClick: "onButtonClick", filterFieldChange: "filterFieldChange" }, 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\">{{\n itemsPerPageLabel\n }}</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 >\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">\n {{ option }}\n </option>\n </select>\n </div>\n </div>\n <div class=\"right-section\">\n <div *ngIf=\"buttonList && buttonList.length > 0\" class=\"ng-button-row\">\n <ng-container *ngFor=\"let buttonTemplate of buttonList\">\n <ng-container\n *ngTemplateOutlet=\"buttonTemplate\"\n class=\"ng-button\"\n ></ng-container>\n </ng-container>\n </div>\n <button\n *ngIf=\"buttonLabel && buttonLabel.length > 0\"\n class=\"custom-button\"\n (click)=\"onNewButtonClick()\"\n >\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\n id=\"search\"\n label=\"\"\n placeholder=\"Buscar\"\n [(ngModel)]=\"filterDescription\"\n (search)=\"onSearch($event)\"\n ></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\n *ngIf=\"!isColumnHidden(column.prop)\"\n (click)=\"onSelectSearchField(column.prop)\"\n >\n {{ column.label }}\n <span>\n <i-lucide\n name=\"arrow-up\"\n [size]=\"14\"\n [class.selected]=\"\n column.isSearchSelected && sortDirection === 'asc'\n \"\n ></i-lucide>\n <i-lucide\n name=\"arrow-down\"\n [size]=\"14\"\n [class.selected]=\"\n column.isSearchSelected && sortDirection === 'desc'\n \"\n ></i-lucide>\n </span>\n </th>\n </ng-container>\n <th\n *ngIf=\"showActionColumn\"\n class=\"text-end\"\n style=\"padding-right: 6.3rem\"\n >\n {{ actionColumnLabel }}\n </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\n *ngIf=\"\n hasPermission(editPermissions) &&\n onEditTable.observers.length > 0\n \"\n (click)=\"handleAction('edit', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <lucide-icon\n name=\"square-pen\"\n [size]=\"20\"\n color=\"#2CA58D\"\n [strokeWidth]=\"1.75\"\n ></lucide-icon>\n </div>\n <div\n *ngIf=\"\n hasPermission(viewPermissions) &&\n onViewTable.observers.length > 0\n \"\n (click)=\"handleAction('view', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <lucide-icon\n name=\"user-round\"\n [size]=\"20\"\n color=\"#2CA58D\"\n [strokeWidth]=\"1.75\"\n ></lucide-icon>\n </div>\n <div\n *ngIf=\"\n hasPermission(deletePermissions) &&\n onDeleteTable.observers.length > 0\n \"\n (click)=\"handleAction('delete', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <i-lucide\n name=\"trash-2\"\n [size]=\"20\"\n color=\"#F26E6E\"\n [strokeWidth]=\"1.75\"\n ></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 >\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)}.selected{color:var(--secondary-color);stroke-width:8}.ng-button-row{display:flex;gap:10px;margin-right:10px;margin-left:10px}\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: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { 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 }); }
232
234
  }
233
235
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataTableComponent, decorators: [{
234
236
  type: Component,
235
- 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\">{{\n itemsPerPageLabel\n }}</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 >\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">\n {{ option }}\n </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\n id=\"search\"\n label=\"\"\n placeholder=\"Buscar\"\n [(ngModel)]=\"filterDescription\"\n (search)=\"onSearch($event)\"\n ></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\n *ngIf=\"!isColumnHidden(column.prop)\"\n (click)=\"onSelectSearchField(column.prop)\"\n >\n {{ column.label }}\n <span>\n <i-lucide\n name=\"arrow-up\"\n [size]=\"14\"\n [class.selected]=\"\n column.isSearchSelected && sortDirection === 'asc'\n \"\n ></i-lucide>\n <i-lucide\n name=\"arrow-down\"\n [size]=\"14\"\n [class.selected]=\"\n column.isSearchSelected && sortDirection === 'desc'\n \"\n ></i-lucide>\n </span>\n </th>\n </ng-container>\n <th\n *ngIf=\"showActionColumn\"\n class=\"text-end\"\n style=\"padding-right: 6.3rem\"\n >\n {{ actionColumnLabel }}\n </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\n *ngIf=\"\n hasPermission(editPermissions) &&\n onEditTable.observers.length > 0\n \"\n (click)=\"handleAction('edit', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <lucide-icon\n name=\"square-pen\"\n [size]=\"20\"\n color=\"#2CA58D\"\n [strokeWidth]=\"1.75\"\n ></lucide-icon>\n </div>\n <div\n *ngIf=\"\n hasPermission(viewPermissions) &&\n onViewTable.observers.length > 0\n \"\n (click)=\"handleAction('view', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <lucide-icon\n name=\"user-round\"\n [size]=\"20\"\n color=\"#2CA58D\"\n [strokeWidth]=\"1.75\"\n ></lucide-icon>\n </div>\n <div\n *ngIf=\"\n hasPermission(deletePermissions) &&\n onDeleteTable.observers.length > 0\n \"\n (click)=\"handleAction('delete', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <i-lucide\n name=\"trash-2\"\n [size]=\"20\"\n color=\"#F26E6E\"\n [strokeWidth]=\"1.75\"\n ></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 >\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)}.selected{color:var(--secondary-color);stroke-width:8}\n"] }]
237
+ 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\">{{\n itemsPerPageLabel\n }}</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 >\n <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">\n {{ option }}\n </option>\n </select>\n </div>\n </div>\n <div class=\"right-section\">\n <div *ngIf=\"buttonList && buttonList.length > 0\" class=\"ng-button-row\">\n <ng-container *ngFor=\"let buttonTemplate of buttonList\">\n <ng-container\n *ngTemplateOutlet=\"buttonTemplate\"\n class=\"ng-button\"\n ></ng-container>\n </ng-container>\n </div>\n <button\n *ngIf=\"buttonLabel && buttonLabel.length > 0\"\n class=\"custom-button\"\n (click)=\"onNewButtonClick()\"\n >\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\n id=\"search\"\n label=\"\"\n placeholder=\"Buscar\"\n [(ngModel)]=\"filterDescription\"\n (search)=\"onSearch($event)\"\n ></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\n *ngIf=\"!isColumnHidden(column.prop)\"\n (click)=\"onSelectSearchField(column.prop)\"\n >\n {{ column.label }}\n <span>\n <i-lucide\n name=\"arrow-up\"\n [size]=\"14\"\n [class.selected]=\"\n column.isSearchSelected && sortDirection === 'asc'\n \"\n ></i-lucide>\n <i-lucide\n name=\"arrow-down\"\n [size]=\"14\"\n [class.selected]=\"\n column.isSearchSelected && sortDirection === 'desc'\n \"\n ></i-lucide>\n </span>\n </th>\n </ng-container>\n <th\n *ngIf=\"showActionColumn\"\n class=\"text-end\"\n style=\"padding-right: 6.3rem\"\n >\n {{ actionColumnLabel }}\n </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\n *ngIf=\"\n hasPermission(editPermissions) &&\n onEditTable.observers.length > 0\n \"\n (click)=\"handleAction('edit', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <lucide-icon\n name=\"square-pen\"\n [size]=\"20\"\n color=\"#2CA58D\"\n [strokeWidth]=\"1.75\"\n ></lucide-icon>\n </div>\n <div\n *ngIf=\"\n hasPermission(viewPermissions) &&\n onViewTable.observers.length > 0\n \"\n (click)=\"handleAction('view', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <lucide-icon\n name=\"user-round\"\n [size]=\"20\"\n color=\"#2CA58D\"\n [strokeWidth]=\"1.75\"\n ></lucide-icon>\n </div>\n <div\n *ngIf=\"\n hasPermission(deletePermissions) &&\n onDeleteTable.observers.length > 0\n \"\n (click)=\"handleAction('delete', item, i)\"\n class=\"clickable-icon\"\n style=\"margin-right: 1.5rem\"\n >\n <i-lucide\n name=\"trash-2\"\n [size]=\"20\"\n color=\"#F26E6E\"\n [strokeWidth]=\"1.75\"\n ></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 >\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)}.selected{color:var(--secondary-color);stroke-width:8}.ng-button-row{display:flex;gap:10px;margin-right:10px;margin-left:10px}\n"] }]
236
238
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.AuthService }, { type: i2.RefreshService }]; }, propDecorators: { columns: [{
237
239
  type: Input
238
240
  }], hiddenColumns: [{
@@ -269,6 +271,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
269
271
  type: Input
270
272
  }], initialFilterField: [{
271
273
  type: Input
274
+ }], buttonList: [{
275
+ type: Input
276
+ }], sortChange: [{
277
+ type: Output
272
278
  }], pageChange: [{
273
279
  type: Output
274
280
  }], itemsPerPageChange: [{
@@ -284,4 +290,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
284
290
  }], filterFieldChange: [{
285
291
  type: Output
286
292
  }] } });
287
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/tables/data-table.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/tables/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from \"@angular/core\";\nimport { Observable, Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\nimport { ButtonClasses } from \"../../enum/ButtonClassesEnum\"; // Importando o enum\nimport { AuthService } from \"../../service/auth-service.service\";\nimport { RefreshService } from \"../../service/refresh-service.service\";\nimport { IDataIndexPaginate, IPaginateResult } from \"./data-paginate.service\";\n\n@Component({\n  selector: \"argenta-list-data-table\",\n  templateUrl: \"./data-table.component.html\",\n  styleUrls: [\"./data-table.component.scss\"],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataTableComponent implements OnInit, OnDestroy {\n  @Input() columns: {\n    label: string;\n    prop: string;\n    isSearchSelected?: boolean;\n  }[] = [];\n  @Input() hiddenColumns: string[] = [];\n  @Input() defaultItemsPerPage: number = 10;\n  @Input() itemsPerPageLabel: string = \"Items per page:\";\n  @Input() showActionColumn: boolean = false;\n  @Input() actionColumnLabel: string = \"Actions\";\n  @Input() totalItems: number = 0;\n\n  @Input() fetchDataFunction: (\n    params: IDataIndexPaginate\n  ) => Observable<IPaginateResult<any>> = () => {\n    return new Observable((subscriber) =>\n      subscriber.error(\n        \"Implement the fetchDataFunction to fetch paginated data from the back-end.\"\n      )\n    );\n  };\n\n  @Input() editPermissions: string[] = [];\n  @Input() deletePermissions: string[] = [];\n  @Input() viewPermissions: string[] = [];\n  @Input() showPageInfo: boolean = true;\n  @Input() pageText: string = \"Page\";\n  @Input() ofText: string = \"of\";\n  @Input() filterDescription: string = \"\";\n  @Input() buttonLabel: string = \"\";\n  @Input() pagedData: any[] = [];\n  @Input() initialFilterField: string | null = null;\n\n  @Output() pageChange: EventEmitter<number> = new EventEmitter();\n  @Output() itemsPerPageChange: EventEmitter<number> = new EventEmitter();\n  @Output() onEditTable: EventEmitter<any> = new EventEmitter();\n  @Output() onDeleteTable: EventEmitter<any> = new EventEmitter();\n  @Output() onViewTable: EventEmitter<any> = new EventEmitter();\n  @Output() onButtonClick: EventEmitter<void> = new EventEmitter();\n  @Output() filterFieldChange: EventEmitter<string> = new EventEmitter();\n\n  itemsPerPageOptions: number[] = [5, 10, 15, 25];\n  currentPage: number = 1;\n  sortColumn: string = \"\";\n  sortDirection: \"asc\" | \"desc\" = \"asc\";\n  selectedSearchField: string = \"\";\n  isLoading = false;\n  private destroy$ = new Subject<void>();\n  private isInitialized = false; // Flag para evitar chamadas duplas\n  ButtonClasses = ButtonClasses;\n\n  labelStyle = {\n    \"font-family\": \"Inter, Arial, sans-serif\",\n    \"font-size\": \"14px\",\n    color: \"#000\",\n  };\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private authService: AuthService,\n    private refreshService: RefreshService\n  ) {}\n\n  ngOnInit() {\n    if (this.initialFilterField) {\n      // Se o usuário definir o initialFilterField, ele será usado como o campo inicial\n      this.selectedSearchField = this.initialFilterField;\n      this.sortColumn = this.initialFilterField;\n      this.sortDirection = \"asc\";\n\n      this.columns = this.columns.map((column) => ({\n        ...column,\n        isSearchSelected: column.prop === this.initialFilterField,\n      }));\n    } else if (this.columns.length > 0) {\n      // Caso contrário, usa a primeira coluna como padrão\n      this.selectedSearchField = this.columns[0].prop;\n      this.sortColumn = this.columns[0].prop;\n      this.sortDirection = \"asc\";\n\n      this.columns = this.columns.map((column) => ({\n        ...column,\n        isSearchSelected: column.prop === this.selectedSearchField,\n      }));\n    }\n\n    //this.fetchData();\n    this.refreshService.refresh$\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => {\n        if (this.isInitialized) {\n          this.refreshData();\n        }\n      });\n\n    this.isInitialized = true;\n  }\n\n  // ngOnChanges(changes: SimpleChanges) {\n  //   if (\n  //     changes[\"totalItems\"] ||\n  //     changes[\"defaultItemsPerPage\"] ||\n  //     changes[\"currentPage\"] ||\n  //     changes[\"fetchDataFunction\"] ||\n  //     changes[\"filterDescription\"]\n  //   ) {\n  //     this.fetchData();\n  //   }\n  // }\n\n  ngOnDestroy() {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  protected getNestedProperty(obj: any, path: string): any {\n    return path.split(\".\").reduce((acc, part) => acc && acc[part], obj);\n  }\n\n  fetchData() {\n    if (this.fetchDataFunction) {\n      this.isLoading = true;\n      const params: IDataIndexPaginate = {\n        filterDescription: this.filterDescription,\n        filterField: this.selectedSearchField,\n        pageNumber: this.currentPage ?? 1,\n        pageSize: this.defaultItemsPerPage ?? 10,\n        sortColumn: this.sortColumn,\n        sortDirection: this.sortDirection,\n      };\n\n      this.fetchDataFunction(params)\n        .pipe(takeUntil(this.destroy$))\n        .subscribe({\n          next: (result) => {\n            this.pagedData = result.items;\n            this.totalItems = result.totalItems;\n            this.isLoading = false;\n            this.cdr.markForCheck();\n          },\n          error: (error) => {\n            console.error(\"Error fetching data:\", error);\n            this.isLoading = false;\n          },\n        });\n    }\n  }\n\n  refreshData() {\n    this.fetchData();\n  }\n\n  onPageChange(page: number) {\n    this.currentPage = page;\n    this.pageChange.emit(page);\n    this.fetchData();\n  }\n\n  onItemsPerPageChange() {\n    this.currentPage = 1;\n    this.itemsPerPageChange.emit(this.defaultItemsPerPage);\n    this.fetchData();\n  }\n\n  onSelectSearchField(columnProp: string) {\n    if (this.sortColumn === columnProp) {\n      this.sortDirection = this.sortDirection === \"asc\" ? \"desc\" : \"asc\";\n    } else {\n      this.sortDirection = \"asc\";\n    }\n\n    this.selectedSearchField = columnProp;\n    this.sortColumn = columnProp;\n\n    this.columns = this.columns.map((column) => ({\n      ...column,\n      isSearchSelected: column.prop === columnProp,\n    }));\n\n    this.filterFieldChange.emit(this.selectedSearchField);\n\n    if (this.fetchDataFunction) {\n      this.fetchDataFunction({\n        filterDescription: this.filterDescription,\n        filterField: this.selectedSearchField,\n        pageNumber: this.currentPage,\n        pageSize: this.defaultItemsPerPage,\n        sortColumn: this.sortColumn,\n        sortDirection: this.sortDirection,\n      }).subscribe({\n        next: (result) => {\n          this.pagedData = result.items;\n          this.totalItems = result.totalItems;\n          this.cdr.markForCheck();\n        },\n        error: (error) => {\n          console.error(\"Erro ao buscar dados:\", error);\n        },\n      });\n    }\n  }\n\n  handleAction(action: string, item: any, index: number) {\n    switch (action) {\n      case \"edit\":\n        if (this.hasPermission(this.editPermissions)) {\n          this.onEditTable.emit({ item, index });\n        }\n        break;\n      case \"delete\":\n        if (this.hasPermission(this.deletePermissions)) {\n          this.onDeleteTable.emit({ item, index });\n        }\n        break;\n      case \"view\":\n        if (this.hasPermission(this.viewPermissions)) {\n          this.onViewTable.emit({ item, index });\n        }\n        break;\n    }\n  }\n\n  hasPermission(requiredPermissions: string[]): boolean {\n    if (!requiredPermissions || requiredPermissions.length === 0) {\n      return true;\n    }\n\n    try {\n      return this.authService.hasPermission(requiredPermissions);\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  isColumnHidden(columnProp: string): boolean {\n    return this.hiddenColumns.includes(columnProp);\n  }\n\n  onSearch(searchText: string) {\n    this.filterDescription = searchText;\n    this.currentPage = 1; // Resetar para a primeira página\n    this.fetchData();\n  }\n\n  onNewButtonClick() {\n    this.onButtonClick.emit(); // Emitindo o evento\n  }\n}\n","<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\">{{\n        itemsPerPageLabel\n      }}</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      >\n        <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">\n          {{ option }}\n        </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\n    id=\"search\"\n    label=\"\"\n    placeholder=\"Buscar\"\n    [(ngModel)]=\"filterDescription\"\n    (search)=\"onSearch($event)\"\n  ></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\n            *ngIf=\"!isColumnHidden(column.prop)\"\n            (click)=\"onSelectSearchField(column.prop)\"\n          >\n            {{ column.label }}\n            <span>\n              <i-lucide\n                name=\"arrow-up\"\n                [size]=\"14\"\n                [class.selected]=\"\n                  column.isSearchSelected && sortDirection === 'asc'\n                \"\n              ></i-lucide>\n              <i-lucide\n                name=\"arrow-down\"\n                [size]=\"14\"\n                [class.selected]=\"\n                  column.isSearchSelected && sortDirection === 'desc'\n                \"\n              ></i-lucide>\n            </span>\n          </th>\n        </ng-container>\n        <th\n          *ngIf=\"showActionColumn\"\n          class=\"text-end\"\n          style=\"padding-right: 6.3rem\"\n        >\n          {{ actionColumnLabel }}\n        </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\n              *ngIf=\"\n                hasPermission(editPermissions) &&\n                onEditTable.observers.length > 0\n              \"\n              (click)=\"handleAction('edit', item, i)\"\n              class=\"clickable-icon\"\n              style=\"margin-right: 1.5rem\"\n            >\n              <lucide-icon\n                name=\"square-pen\"\n                [size]=\"20\"\n                color=\"#2CA58D\"\n                [strokeWidth]=\"1.75\"\n              ></lucide-icon>\n            </div>\n            <div\n              *ngIf=\"\n                hasPermission(viewPermissions) &&\n                onViewTable.observers.length > 0\n              \"\n              (click)=\"handleAction('view', item, i)\"\n              class=\"clickable-icon\"\n              style=\"margin-right: 1.5rem\"\n            >\n              <lucide-icon\n                name=\"user-round\"\n                [size]=\"20\"\n                color=\"#2CA58D\"\n                [strokeWidth]=\"1.75\"\n              ></lucide-icon>\n            </div>\n            <div\n              *ngIf=\"\n                hasPermission(deletePermissions) &&\n                onDeleteTable.observers.length > 0\n              \"\n              (click)=\"handleAction('delete', item, i)\"\n              class=\"clickable-icon\"\n              style=\"margin-right: 1.5rem\"\n            >\n              <i-lucide\n                name=\"trash-2\"\n                [size]=\"20\"\n                color=\"#F26E6E\"\n                [strokeWidth]=\"1.75\"\n              ></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  >\n  </custom-pagination>\n</div>\n"]}
293
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/tables/data-table.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/tables/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, OnDestroy, OnInit, Output, TemplateRef } from '@angular/core'\nimport { Observable, Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\nimport { ButtonClasses } from '../../enum/ButtonClassesEnum'; // Importando o enum\nimport { AuthService } from '../../service/auth-service.service'\nimport { RefreshService } from '../../service/refresh-service.service'\nimport { IDataIndexPaginate, IPaginateResult } from './data-paginate.service'\n\n@Component({\n  selector: \"argenta-list-data-table\",\n  templateUrl: \"./data-table.component.html\",\n  styleUrls: [\"./data-table.component.scss\"],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataTableComponent implements OnInit, OnDestroy {\n  @Input() columns: {\n    label: string;\n    prop: string;\n    isSearchSelected?: boolean;\n  }[] = [];\n  @Input() hiddenColumns: string[] = [];\n  @Input() defaultItemsPerPage: number = 10;\n  @Input() itemsPerPageLabel: string = \"Items per page:\";\n  @Input() showActionColumn: boolean = false;\n  @Input() actionColumnLabel: string = \"Actions\";\n  @Input() totalItems: number = 0;\n\n  @Input() fetchDataFunction: (\n    params: IDataIndexPaginate\n  ) => Observable<IPaginateResult<any>> = () => {\n    return new Observable((subscriber) =>\n      subscriber.error(\n        \"Implement the fetchDataFunction to fetch paginated data from the back-end.\"\n      )\n    );\n  };\n\n  @Input() editPermissions: string[] = [];\n  @Input() deletePermissions: string[] = [];\n  @Input() viewPermissions: string[] = [];\n  @Input() showPageInfo: boolean = true;\n  @Input() pageText: string = \"Page\";\n  @Input() ofText: string = \"of\";\n  @Input() filterDescription: string = \"\";\n  @Input() buttonLabel: string = \"\";\n  @Input() pagedData: any[] = [];\n  @Input() initialFilterField: string | null = null;\n  @Input() buttonList?: TemplateRef<any>[] = [];\n\n  @Output() sortChange: EventEmitter<any> = new EventEmitter();\n  @Output() pageChange: EventEmitter<number> = new EventEmitter();\n  @Output() itemsPerPageChange: EventEmitter<number> = new EventEmitter();\n  @Output() onEditTable: EventEmitter<any> = new EventEmitter();\n  @Output() onDeleteTable: EventEmitter<any> = new EventEmitter();\n  @Output() onViewTable: EventEmitter<any> = new EventEmitter();\n  @Output() onButtonClick: EventEmitter<void> = new EventEmitter();\n  @Output() filterFieldChange: EventEmitter<string> = new EventEmitter();\n\n  itemsPerPageOptions: number[] = [5, 10, 15, 25];\n  currentPage: number = 1;\n  sortColumn: string = \"\";\n  sortDirection: \"asc\" | \"desc\" = \"asc\";\n  selectedSearchField: string = \"\";\n  isLoading = false;\n  private destroy$ = new Subject<void>();\n  private isInitialized = false; // Flag para evitar chamadas duplas\n  ButtonClasses = ButtonClasses;\n\n  labelStyle = {\n    \"font-family\": \"Inter, Arial, sans-serif\",\n    \"font-size\": \"14px\",\n    color: \"#000\",\n  };\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private authService: AuthService,\n    private refreshService: RefreshService\n  ) {}\n\n  ngOnInit() {\n    if (this.initialFilterField) {\n      // Se o usuário definir o initialFilterField, ele será usado como o campo inicial\n      this.selectedSearchField = this.initialFilterField;\n      this.sortColumn = this.initialFilterField;\n      this.sortDirection = \"asc\";\n\n      this.columns = this.columns.map((column) => ({\n        ...column,\n        isSearchSelected: column.prop === this.initialFilterField,\n      }));\n    } else if (this.columns.length > 0) {\n      // Caso contrário, usa a primeira coluna como padrão\n      this.selectedSearchField = this.columns[0].prop;\n      this.sortColumn = this.columns[0].prop;\n      this.sortDirection = \"asc\";\n\n      this.columns = this.columns.map((column) => ({\n        ...column,\n        isSearchSelected: column.prop === this.selectedSearchField,\n      }));\n    }\n\n    //this.fetchData();\n    this.refreshService.refresh$\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => {\n        if (this.isInitialized) {\n          this.refreshData();\n        }\n      });\n\n    this.isInitialized = true;\n  }\n\n  // ngOnChanges(changes: SimpleChanges) {\n  //   if (\n  //     changes[\"totalItems\"] ||\n  //     changes[\"defaultItemsPerPage\"] ||\n  //     changes[\"currentPage\"] ||\n  //     changes[\"fetchDataFunction\"] ||\n  //     changes[\"filterDescription\"]\n  //   ) {\n  //     this.fetchData();\n  //   }\n  // }\n\n  ngOnDestroy() {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  protected getNestedProperty(obj: any, path: string): any {\n    return path.split(\".\").reduce((acc, part) => acc && acc[part], obj);\n  }\n\n  fetchData() {\n    if (this.fetchDataFunction) {\n      this.isLoading = true;\n      const params: IDataIndexPaginate = {\n        filterDescription: this.filterDescription,\n        filterField: this.selectedSearchField,\n        pageNumber: this.currentPage ?? 1,\n        pageSize: this.defaultItemsPerPage ?? 10,\n        sortColumn: this.sortColumn,\n        sortDirection: this.sortDirection,\n      };\n\n      this.fetchDataFunction(params)\n        .pipe(takeUntil(this.destroy$))\n        .subscribe({\n          next: (result) => {\n            this.pagedData = result.items;\n            this.totalItems = result.totalItems;\n            this.isLoading = false;\n            this.cdr.markForCheck();\n          },\n          error: (error) => {\n            console.error(\"Error fetching data:\", error);\n            this.isLoading = false;\n          },\n        });\n    }\n  }\n\n  refreshData() {\n    this.fetchData();\n  }\n\n  onPageChange(page: number) {\n    this.currentPage = page;\n    this.pageChange.emit(page);\n    this.fetchData();\n  }\n\n  onItemsPerPageChange() {\n    this.currentPage = 1;\n    this.itemsPerPageChange.emit(this.defaultItemsPerPage);\n    this.fetchData();\n  }\n\n  onSelectSearchField(columnProp: string) {\n    if (this.sortColumn === columnProp) {\n      this.sortDirection = this.sortDirection === \"asc\" ? \"desc\" : \"asc\";\n    } else {\n      this.sortDirection = \"asc\";\n    }\n\n    this.selectedSearchField = columnProp;\n    this.sortColumn = columnProp;\n\n    this.columns = this.columns.map((column) => ({\n      ...column,\n      isSearchSelected: column.prop === columnProp,\n    }));\n\n    this.filterFieldChange.emit(this.selectedSearchField);\n\n    if (this.fetchDataFunction) {\n      this.fetchDataFunction({\n        filterDescription: this.filterDescription,\n        filterField: this.selectedSearchField,\n        pageNumber: this.currentPage,\n        pageSize: this.defaultItemsPerPage,\n        sortColumn: this.sortColumn,\n        sortDirection: this.sortDirection,\n      }).subscribe({\n        next: (result) => {\n          this.pagedData = result.items;\n          this.totalItems = result.totalItems;\n          this.cdr.markForCheck();\n        },\n        error: (error) => {\n          console.error(\"Erro ao buscar dados:\", error);\n        },\n      });\n    }\n  }\n\n  handleAction(action: string, item: any, index: number) {\n    switch (action) {\n      case \"edit\":\n        if (this.hasPermission(this.editPermissions)) {\n          this.onEditTable.emit({ item, index });\n        }\n        break;\n      case \"delete\":\n        if (this.hasPermission(this.deletePermissions)) {\n          this.onDeleteTable.emit({ item, index });\n        }\n        break;\n      case \"view\":\n        if (this.hasPermission(this.viewPermissions)) {\n          this.onViewTable.emit({ item, index });\n        }\n        break;\n    }\n  }\n\n  hasPermission(requiredPermissions: string[]): boolean {\n    if (!requiredPermissions || requiredPermissions.length === 0) {\n      return true;\n    }\n\n    try {\n      return this.authService.hasPermission(requiredPermissions);\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  isColumnHidden(columnProp: string): boolean {\n    return this.hiddenColumns.includes(columnProp);\n  }\n\n  onSearch(searchText: string) {\n    this.filterDescription = searchText;\n    this.currentPage = 1; // Resetar para a primeira página\n    this.fetchData();\n  }\n\n  onNewButtonClick() {\n    this.onButtonClick.emit(); // Emitindo o evento\n  }\n}\n","<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\">{{\n        itemsPerPageLabel\n      }}</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      >\n        <option *ngFor=\"let option of itemsPerPageOptions\" [value]=\"option\">\n          {{ option }}\n        </option>\n      </select>\n    </div>\n  </div>\n  <div class=\"right-section\">\n    <div *ngIf=\"buttonList && buttonList.length > 0\" class=\"ng-button-row\">\n      <ng-container *ngFor=\"let buttonTemplate of buttonList\">\n        <ng-container\n          *ngTemplateOutlet=\"buttonTemplate\"\n          class=\"ng-button\"\n        ></ng-container>\n      </ng-container>\n    </div>\n    <button\n      *ngIf=\"buttonLabel && buttonLabel.length > 0\"\n      class=\"custom-button\"\n      (click)=\"onNewButtonClick()\"\n    >\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\n    id=\"search\"\n    label=\"\"\n    placeholder=\"Buscar\"\n    [(ngModel)]=\"filterDescription\"\n    (search)=\"onSearch($event)\"\n  ></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\n            *ngIf=\"!isColumnHidden(column.prop)\"\n            (click)=\"onSelectSearchField(column.prop)\"\n          >\n            {{ column.label }}\n            <span>\n              <i-lucide\n                name=\"arrow-up\"\n                [size]=\"14\"\n                [class.selected]=\"\n                  column.isSearchSelected && sortDirection === 'asc'\n                \"\n              ></i-lucide>\n              <i-lucide\n                name=\"arrow-down\"\n                [size]=\"14\"\n                [class.selected]=\"\n                  column.isSearchSelected && sortDirection === 'desc'\n                \"\n              ></i-lucide>\n            </span>\n          </th>\n        </ng-container>\n        <th\n          *ngIf=\"showActionColumn\"\n          class=\"text-end\"\n          style=\"padding-right: 6.3rem\"\n        >\n          {{ actionColumnLabel }}\n        </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\n              *ngIf=\"\n                hasPermission(editPermissions) &&\n                onEditTable.observers.length > 0\n              \"\n              (click)=\"handleAction('edit', item, i)\"\n              class=\"clickable-icon\"\n              style=\"margin-right: 1.5rem\"\n            >\n              <lucide-icon\n                name=\"square-pen\"\n                [size]=\"20\"\n                color=\"#2CA58D\"\n                [strokeWidth]=\"1.75\"\n              ></lucide-icon>\n            </div>\n            <div\n              *ngIf=\"\n                hasPermission(viewPermissions) &&\n                onViewTable.observers.length > 0\n              \"\n              (click)=\"handleAction('view', item, i)\"\n              class=\"clickable-icon\"\n              style=\"margin-right: 1.5rem\"\n            >\n              <lucide-icon\n                name=\"user-round\"\n                [size]=\"20\"\n                color=\"#2CA58D\"\n                [strokeWidth]=\"1.75\"\n              ></lucide-icon>\n            </div>\n            <div\n              *ngIf=\"\n                hasPermission(deletePermissions) &&\n                onDeleteTable.observers.length > 0\n              \"\n              (click)=\"handleAction('delete', item, i)\"\n              class=\"clickable-icon\"\n              style=\"margin-right: 1.5rem\"\n            >\n              <i-lucide\n                name=\"trash-2\"\n                [size]=\"20\"\n                color=\"#F26E6E\"\n                [strokeWidth]=\"1.75\"\n              ></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  >\n  </custom-pagination>\n</div>\n"]}