lib-portal-angular 0.0.83 → 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.
- package/esm2022/lib/components/components.module.mjs +49 -39
- package/esm2022/lib/components/drag-drop-list/drag-drop-list.component.mjs +91 -0
- package/esm2022/lib/components/dynamic-table/dynamic-table-config.mjs +2 -0
- package/esm2022/lib/components/dynamic-table/dynamic-table.component.mjs +58 -0
- package/esm2022/lib/components/tables/data-table.component.mjs +13 -7
- package/esm2022/lib/lib-portal-angular.module.mjs +4 -1
- package/esm2022/lib/service/excel-service.service.mjs +81 -0
- package/esm2022/public-api.mjs +9 -26
- package/fesm2022/lib-portal-angular.mjs +382 -149
- package/fesm2022/lib-portal-angular.mjs.map +1 -1
- package/lib/components/components.module.d.ts +8 -6
- package/lib/components/drag-drop-list/drag-drop-list.component.d.ts +35 -0
- package/lib/components/dynamic-table/dynamic-table-config.d.ts +17 -0
- package/lib/components/dynamic-table/dynamic-table.component.d.ts +19 -0
- package/lib/components/tables/data-table.component.d.ts +9 -7
- package/lib/service/excel-service.service.d.ts +40 -0
- package/package.json +4 -2
- package/public-api.d.ts +6 -25
@@ -1,40 +1,42 @@
|
|
1
|
-
import { CommonModule } from
|
2
|
-
import { NgModule } from
|
3
|
-
import { FormsModule, ReactiveFormsModule } from
|
4
|
-
import { NgSelectModule } from
|
5
|
-
import { AutofocusDirective } from
|
6
|
-
import { CepMaskDirective } from
|
7
|
-
import { CnpjMaskDirective } from
|
8
|
-
import { CpfMaskDirective } from
|
9
|
-
import { LucideIconsModule } from
|
10
|
-
import { AccordionArgentaComponent } from
|
11
|
-
import { AlertComponent } from
|
12
|
-
import { AppBackgroundComponent } from
|
13
|
-
import { BadgeComponent } from
|
14
|
-
import { BasicRegistrationComponent } from
|
15
|
-
import { ButtonComponent } from
|
16
|
-
import { CalendarArgentaComponent } from
|
17
|
-
import { CardComponent } from
|
18
|
-
import { CheckboxComponent } from
|
19
|
-
import { CodeHighlightComponent } from
|
20
|
-
import { ConfirmationComponent } from
|
21
|
-
import { CustomPaginationComponent } from
|
22
|
-
import { CustomSwitchComponent } from
|
23
|
-
import {
|
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";
|
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';
|
38
40
|
import * as i0 from "@angular/core";
|
39
41
|
export class ComponentsModule {
|
40
42
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
@@ -69,7 +71,9 @@ export class ComponentsModule {
|
|
69
71
|
AccordionArgentaComponent,
|
70
72
|
JsonViewerComponent,
|
71
73
|
ModalComponent,
|
72
|
-
|
74
|
+
DragDropListComponent,
|
75
|
+
DynamicModalComponent,
|
76
|
+
DynamicTableComponent], imports: [CommonModule,
|
73
77
|
FormsModule,
|
74
78
|
ReactiveFormsModule,
|
75
79
|
NgSelectModule,
|
@@ -108,7 +112,9 @@ export class ComponentsModule {
|
|
108
112
|
AccordionArgentaComponent,
|
109
113
|
JsonViewerComponent,
|
110
114
|
ModalComponent,
|
111
|
-
|
115
|
+
DragDropListComponent,
|
116
|
+
DynamicModalComponent,
|
117
|
+
DynamicTableComponent] }); }
|
112
118
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, imports: [CommonModule,
|
113
119
|
FormsModule,
|
114
120
|
ReactiveFormsModule,
|
@@ -153,7 +159,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
153
159
|
AccordionArgentaComponent,
|
154
160
|
JsonViewerComponent,
|
155
161
|
ModalComponent,
|
162
|
+
DragDropListComponent,
|
156
163
|
DynamicModalComponent,
|
164
|
+
DynamicTableComponent,
|
157
165
|
],
|
158
166
|
imports: [
|
159
167
|
CommonModule,
|
@@ -198,8 +206,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
198
206
|
AccordionArgentaComponent,
|
199
207
|
JsonViewerComponent,
|
200
208
|
ModalComponent,
|
209
|
+
DragDropListComponent,
|
201
210
|
DynamicModalComponent,
|
211
|
+
DynamicTableComponent,
|
202
212
|
],
|
203
213
|
}]
|
204
214
|
}] });
|
205
|
-
//# 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\";\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  ],\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  ],\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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAA;AACtE,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAA;AAC9B,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAA;;;;AAY5D,MAAM,OAAO,qBAAqB;IAoBhC;QAlBS,oBAAe,GAAe,EAAE,CAAC;QAEhC,2BAAsB,GAAuB,IAAI,YAAY,EAAQ,CAAC;QACtE,4BAAuB,GAAG,IAAI,YAAY,EAAU,CAAC;QAGtD,iBAAY,GAAe,EAAE,CAAC;QAE7B,wBAAmB,GAAuB,IAAI,YAAY,EAAQ,CAAC;QACnE,yBAAoB,GAAG,IAAI,YAAY,EAAU,CAAC;QAEpD,gCAA2B,GAAG,IAAI,OAAO,EAAU,CAAC;QACpD,6BAAwB,GAAG,IAAI,OAAO,EAAU,CAAC;QAGzD,kBAAa,GAAG,aAAa,CAAC,CAAC,sCAAsC;QACrE,gBAAW,GAAoB,IAAI,CAAA;QAGjC,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YAC5E,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACzE,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW,CAAC,IAAc;QACxB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC1B,CAAC;IAED,UAAU,CAAC,KAAgB;QACzB,KAAK,CAAC,cAAc,EAAE,CAAC;IACzB,CAAC;IAED,MAAM,CAAC,IAAgB,EAAE,KAAgB;QACvC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAC7C,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;gBAChB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBAClC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aAC7B;YACD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;SACzB;IACH,CAAC;IAEO,UAAU,CAAC,IAAS;QAC1B,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACzD,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACjC,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;gBAChB,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;aACvB;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,0BAA0B,CAAC,KAAU;QACnC,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC5D,CAAC;IAED,uBAAuB,CAAC,KAAU;QAChC,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACzD,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,mBAAoB,CAAC,IAAI,EAAE,CAAA;IAClC,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,sBAAuB,CAAC,IAAI,EAAE,CAAA;IACrC,CAAC;+GAzEU,qBAAqB;mGAArB,qBAAqB,6fCflC,qjEAsEA;;4FDvDa,qBAAqB;kBALjC,SAAS;+BACE,wBAAwB;0EAKzB,gBAAgB;sBAAxB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,sBAAsB;sBAA9B,KAAK;gBACI,sBAAsB;sBAA/B,MAAM;gBACG,uBAAuB;sBAAhC,MAAM;gBAEE,aAAa;sBAArB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACI,mBAAmB;sBAA5B,MAAM;gBACG,oBAAoB;sBAA7B,MAAM","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"]}
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export {};
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy10YWJsZS1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saWItcG9ydGFsLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2R5bmFtaWMtdGFibGUvZHluYW1pYy10YWJsZS1jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlbXBsYXRlUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuZXhwb3J0IGludGVyZmFjZSBEeW5hbWljVGFibGVDb2x1bW4ge1xuICBrZXk6IHN0cmluZzsgLy8gSWRlbnRpZmljYWRvciBkYSBjb2x1bmFcbiAgaGVhZGVyOiBzdHJpbmc7IC8vIE5vbWUgZG8gY2FiZcOnYWxob1xuICB0eXBlOiBcInRleHRcIiB8IFwidGVtcGxhdGVcIjsgLy8gVGlwbyBkZSBjb250ZcO6ZG9cbiAgd2lkdGg/OiBzdHJpbmc7IC8vIExhcmd1cmEgZGEgY29sdW5hXG4gIHRlbXBsYXRlPzogVGVtcGxhdGVSZWY8YW55PjsgLy8gVGVtcGxhdGUgQW5ndWxhciBwYXJhIGNvbnRlw7pkbyBkaW7Dom1pY29cbn1cblxuZXhwb3J0IGludGVyZmFjZSBEeW5hbWljVGFibGVDb25maWcge1xuICBjb2x1bW5zOiBEeW5hbWljVGFibGVDb2x1bW5bXTsgLy8gQ29uZmlndXJhw6fDo28gZGUgY29sdW5hc1xuICBkYXRhOiBhbnlbXTsgLy8gRGFkb3MgZGEgdGFiZWxhXG4gIHNob3dIZWFkZXI/OiBib29sZWFuOyAvLyBFeGliaXIgb3UgbsOjbyBvIGNhYmXDp2FsaG9cbiAgcGFnaW5hdGlvbj86IGJvb2xlYW47IC8vIE1vc3RyYXIgb3Ugb2N1bHRhciBwYWdpbmHDp8Ojb1xuICBpdGVtc1BlclBhZ2U/OiBudW1iZXI7IC8vIE7Dum1lcm8gZGUgaXRlbnMgcG9yIHDDoWdpbmFcbiAgaXNOZXN0ZWQ/OiBib29sZWFuOyAvLyBJbmRpY2Egc2UgYSB0YWJlbGEgw6kgYW5pbmhhZGFcbiAgdG90YWxJdGVtcz86IG51bWJlcjsgLy8gVG90YWwgZGUgaXRlbnMgZG8gYmFjay1lbmQgKG9wY2lvbmFsKVxufVxuIl19
|
@@ -0,0 +1,58 @@
|
|
1
|
+
import { Component, Input } from "@angular/core";
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
import * as i1 from "@angular/common";
|
4
|
+
import * as i2 from "../custom-pagination/custom-pagination.component";
|
5
|
+
export class DynamicTableComponent {
|
6
|
+
constructor() {
|
7
|
+
this.itemsPerPageOptions = [10, 20, 50];
|
8
|
+
this.showPageInfo = true;
|
9
|
+
this.currentPage = 1;
|
10
|
+
this.itemsPerPage = 10;
|
11
|
+
}
|
12
|
+
get totalItems() {
|
13
|
+
return this.config.totalItems ?? this.config.data.length;
|
14
|
+
}
|
15
|
+
get paginatedData() {
|
16
|
+
if (!this.config.pagination) {
|
17
|
+
// Retorna todos os dados se a paginação estiver desativada
|
18
|
+
return this.config.data;
|
19
|
+
}
|
20
|
+
const itemsPerPage = this.config.itemsPerPage || this.itemsPerPage;
|
21
|
+
const startIndex = (this.currentPage - 1) * itemsPerPage;
|
22
|
+
return this.config.data.slice(startIndex, startIndex + itemsPerPage);
|
23
|
+
}
|
24
|
+
ngOnInit() {
|
25
|
+
if (!this.config || !this.config.columns || !this.config.data) {
|
26
|
+
throw new Error("DynamicTableComponent: Configuração inválida.");
|
27
|
+
}
|
28
|
+
// Define valores padrão se não especificados
|
29
|
+
this.config.showHeader = this.config.showHeader ?? true; // Exibe o cabeçalho por padrão
|
30
|
+
this.config.pagination = this.config.pagination ?? true; // Ativa paginação por padrão
|
31
|
+
this.itemsPerPage = this.config.itemsPerPage || 10;
|
32
|
+
}
|
33
|
+
onPageChange(newPage) {
|
34
|
+
this.currentPage = newPage;
|
35
|
+
}
|
36
|
+
onItemsPerPageChange(event) {
|
37
|
+
const target = event.target;
|
38
|
+
this.itemsPerPage = +target.value;
|
39
|
+
this.currentPage = 1; // Reinicia a paginação ao alterar os itens por página
|
40
|
+
}
|
41
|
+
// Getter para garantir que totalItems nunca seja undefined
|
42
|
+
get safeTotalItems() {
|
43
|
+
return this.totalItems || 0;
|
44
|
+
}
|
45
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
46
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DynamicTableComponent, selector: "argenta-dynamic-table", inputs: { config: "config", itemsPerPageOptions: "itemsPerPageOptions", showPageInfo: "showPageInfo" }, ngImport: i0, template: "<table class=\"table\" [ngClass]=\"{ nested: config.isNested }\">\n <thead *ngIf=\"config.showHeader\">\n <tr>\n <th *ngFor=\"let column of config.columns\">{{ column.header }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let row of paginatedData\">\n <td *ngFor=\"let column of config.columns\">\n <ng-container [ngSwitch]=\"column.type\">\n <span *ngSwitchCase=\"'text'\">{{ row[column.key] }}</span>\n <ng-container *ngSwitchCase=\"'template'\">\n <ng-container\n *ngTemplateOutlet=\"\n column.template || null;\n context: { $implicit: row }\n \"\n ></ng-container>\n </ng-container>\n </ng-container>\n </td>\n </tr>\n </tbody>\n</table>\n\n<div\n class=\"text-center pagination-controls\"\n [ngClass]=\"{ nested: config.isNested }\"\n *ngIf=\"config.pagination\"\n>\n <custom-pagination\n [totalItems]=\"safeTotalItems\"\n [itemsPerPage]=\"itemsPerPage\"\n [currentPage]=\"currentPage\"\n [showPageInfo]=\"showPageInfo\"\n (pageChange)=\"onPageChange($event)\"\n >\n </custom-pagination>\n</div>\n", styles: ["@charset \"UTF-8\";.table{width:100%;border-collapse:collapse;border-spacing:0}.table{width:100%;border-collapse:separate;border-spacing:0;overflow:hidden}.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{border-top-left-radius:10px}.table thead th:last-child{border-top-right-radius:10px}.table.nested thead th{font-size:.7rem;padding:7px;line-height:.8}.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.nested tbody td:first-child{padding-left:1rem}.table tbody tr:hover{background-color:#f5f5f5!important;transition:background-color .3s ease}.table.nested tbody tr:hover{background-color:#f0f0f0!important}.pagination-controls{display:flex;justify-content:center;align-items:center;margin-top:1rem}.pagination-controls.nested{font-size:.7rem;transform:scale(.7);margin-top:.5rem}.data-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.left-section{display:flex;align-items:center}.items-per-page-label{font-family:var(--font-family);font-size:14px;color:#666;margin-right:.5rem}.custom-select{font-family:var(--font-family);font-size:14px;padding:.375rem 1.75rem .375rem .75rem;border:1px solid #ccc;border-radius:.25rem;appearance:none;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}.custom-select:focus{border-color:#80bdff;outline:none;box-shadow:0 0 0 .2rem #007bff40}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i2.CustomPaginationComponent, selector: "custom-pagination", inputs: ["totalItems", "itemsPerPage", "currentPage", "showPageInfo"], outputs: ["pageChange"] }] }); }
|
47
|
+
}
|
48
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DynamicTableComponent, decorators: [{
|
49
|
+
type: Component,
|
50
|
+
args: [{ selector: "argenta-dynamic-table", template: "<table class=\"table\" [ngClass]=\"{ nested: config.isNested }\">\n <thead *ngIf=\"config.showHeader\">\n <tr>\n <th *ngFor=\"let column of config.columns\">{{ column.header }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let row of paginatedData\">\n <td *ngFor=\"let column of config.columns\">\n <ng-container [ngSwitch]=\"column.type\">\n <span *ngSwitchCase=\"'text'\">{{ row[column.key] }}</span>\n <ng-container *ngSwitchCase=\"'template'\">\n <ng-container\n *ngTemplateOutlet=\"\n column.template || null;\n context: { $implicit: row }\n \"\n ></ng-container>\n </ng-container>\n </ng-container>\n </td>\n </tr>\n </tbody>\n</table>\n\n<div\n class=\"text-center pagination-controls\"\n [ngClass]=\"{ nested: config.isNested }\"\n *ngIf=\"config.pagination\"\n>\n <custom-pagination\n [totalItems]=\"safeTotalItems\"\n [itemsPerPage]=\"itemsPerPage\"\n [currentPage]=\"currentPage\"\n [showPageInfo]=\"showPageInfo\"\n (pageChange)=\"onPageChange($event)\"\n >\n </custom-pagination>\n</div>\n", styles: ["@charset \"UTF-8\";.table{width:100%;border-collapse:collapse;border-spacing:0}.table{width:100%;border-collapse:separate;border-spacing:0;overflow:hidden}.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{border-top-left-radius:10px}.table thead th:last-child{border-top-right-radius:10px}.table.nested thead th{font-size:.7rem;padding:7px;line-height:.8}.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.nested tbody td:first-child{padding-left:1rem}.table tbody tr:hover{background-color:#f5f5f5!important;transition:background-color .3s ease}.table.nested tbody tr:hover{background-color:#f0f0f0!important}.pagination-controls{display:flex;justify-content:center;align-items:center;margin-top:1rem}.pagination-controls.nested{font-size:.7rem;transform:scale(.7);margin-top:.5rem}.data-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.left-section{display:flex;align-items:center}.items-per-page-label{font-family:var(--font-family);font-size:14px;color:#666;margin-right:.5rem}.custom-select{font-family:var(--font-family);font-size:14px;padding:.375rem 1.75rem .375rem .75rem;border:1px solid #ccc;border-radius:.25rem;appearance:none;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}.custom-select:focus{border-color:#80bdff;outline:none;box-shadow:0 0 0 .2rem #007bff40}\n"] }]
|
51
|
+
}], ctorParameters: function () { return []; }, propDecorators: { config: [{
|
52
|
+
type: Input
|
53
|
+
}], itemsPerPageOptions: [{
|
54
|
+
type: Input
|
55
|
+
}], showPageInfo: [{
|
56
|
+
type: Input
|
57
|
+
}] } });
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy10YWJsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saWItcG9ydGFsLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2R5bmFtaWMtdGFibGUvZHluYW1pYy10YWJsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saWItcG9ydGFsLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2R5bmFtaWMtdGFibGUvZHluYW1pYy10YWJsZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBdUIsTUFBTSxlQUFlLENBQUM7Ozs7QUFRdEUsTUFBTSxPQUFPLHFCQUFxQjtJQVFoQztRQU5TLHdCQUFtQixHQUFHLENBQUMsRUFBRSxFQUFFLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNuQyxpQkFBWSxHQUFHLElBQUksQ0FBQztRQUU3QixnQkFBVyxHQUFHLENBQUMsQ0FBQztRQUNoQixpQkFBWSxHQUFHLEVBQUUsQ0FBQztJQUVILENBQUM7SUFFaEIsSUFBSSxVQUFVO1FBQ1osT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDM0QsQ0FBQztJQUVELElBQUksYUFBYTtRQUNmLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsRUFBRTtZQUMzQiwyREFBMkQ7WUFDM0QsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQztTQUN6QjtRQUVELE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsWUFBWSxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUM7UUFDbkUsTUFBTSxVQUFVLEdBQUcsQ0FBQyxJQUFJLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQyxHQUFHLFlBQVksQ0FBQztRQUN6RCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxVQUFVLEVBQUUsVUFBVSxHQUFHLFlBQVksQ0FBQyxDQUFDO0lBQ3ZFLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFO1lBQzdELE1BQU0sSUFBSSxLQUFLLENBQUMsK0NBQStDLENBQUMsQ0FBQztTQUNsRTtRQUVELDZDQUE2QztRQUM3QyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsQ0FBQywrQkFBK0I7UUFDeEYsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLElBQUksSUFBSSxDQUFDLENBQUMsNkJBQTZCO1FBQ3RGLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxZQUFZLElBQUksRUFBRSxDQUFDO0lBQ3JELENBQUM7SUFFRCxZQUFZLENBQUMsT0FBZTtRQUMxQixJQUFJLENBQUMsV0FBVyxHQUFHLE9BQU8sQ0FBQztJQUM3QixDQUFDO0lBRUQsb0JBQW9CLENBQUMsS0FBWTtRQUMvQixNQUFNLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBMkIsQ0FBQztRQUNqRCxJQUFJLENBQUMsWUFBWSxHQUFHLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQztRQUNsQyxJQUFJLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQyxDQUFDLHNEQUFzRDtJQUM5RSxDQUFDO0lBRUQsMkRBQTJEO0lBQzNELElBQUksY0FBYztRQUNoQixPQUFPLElBQUksQ0FBQyxVQUFVLElBQUksQ0FBQyxDQUFDO0lBQzlCLENBQUM7K0dBakRVLHFCQUFxQjttR0FBckIscUJBQXFCLHFLQ1JsQywycENBdUNBOzs0RkQvQmEscUJBQXFCO2tCQUxqQyxTQUFTOytCQUNFLHVCQUF1QjswRUFLeEIsTUFBTTtzQkFBZCxLQUFLO2dCQUNHLG1CQUFtQjtzQkFBM0IsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgVGVtcGxhdGVSZWYsIE9uSW5pdCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBEeW5hbWljVGFibGVDb25maWcgfSBmcm9tIFwiLi9keW5hbWljLXRhYmxlLWNvbmZpZ1wiO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6IFwiYXJnZW50YS1keW5hbWljLXRhYmxlXCIsXG4gIHRlbXBsYXRlVXJsOiBcIi4vZHluYW1pYy10YWJsZS5jb21wb25lbnQuaHRtbFwiLFxuICBzdHlsZVVybHM6IFtcIi4vZHluYW1pYy10YWJsZS5jb21wb25lbnQuc2Nzc1wiXSxcbn0pXG5leHBvcnQgY2xhc3MgRHluYW1pY1RhYmxlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgY29uZmlnITogRHluYW1pY1RhYmxlQ29uZmlnO1xuICBASW5wdXQoKSBpdGVtc1BlclBhZ2VPcHRpb25zID0gWzEwLCAyMCwgNTBdO1xuICBASW5wdXQoKSBzaG93UGFnZUluZm8gPSB0cnVlO1xuXG4gIGN1cnJlbnRQYWdlID0gMTtcbiAgaXRlbXNQZXJQYWdlID0gMTA7XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIGdldCB0b3RhbEl0ZW1zKCkge1xuICAgIHJldHVybiB0aGlzLmNvbmZpZy50b3RhbEl0ZW1zID8/IHRoaXMuY29uZmlnLmRhdGEubGVuZ3RoO1xuICB9XG5cbiAgZ2V0IHBhZ2luYXRlZERhdGEoKSB7XG4gICAgaWYgKCF0aGlzLmNvbmZpZy5wYWdpbmF0aW9uKSB7XG4gICAgICAvLyBSZXRvcm5hIHRvZG9zIG9zIGRhZG9zIHNlIGEgcGFnaW5hw6fDo28gZXN0aXZlciBkZXNhdGl2YWRhXG4gICAgICByZXR1cm4gdGhpcy5jb25maWcuZGF0YTtcbiAgICB9XG5cbiAgICBjb25zdCBpdGVtc1BlclBhZ2UgPSB0aGlzLmNvbmZpZy5pdGVtc1BlclBhZ2UgfHwgdGhpcy5pdGVtc1BlclBhZ2U7XG4gICAgY29uc3Qgc3RhcnRJbmRleCA9ICh0aGlzLmN1cnJlbnRQYWdlIC0gMSkgKiBpdGVtc1BlclBhZ2U7XG4gICAgcmV0dXJuIHRoaXMuY29uZmlnLmRhdGEuc2xpY2Uoc3RhcnRJbmRleCwgc3RhcnRJbmRleCArIGl0ZW1zUGVyUGFnZSk7XG4gIH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMuY29uZmlnIHx8ICF0aGlzLmNvbmZpZy5jb2x1bW5zIHx8ICF0aGlzLmNvbmZpZy5kYXRhKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXCJEeW5hbWljVGFibGVDb21wb25lbnQ6IENvbmZpZ3VyYcOnw6NvIGludsOhbGlkYS5cIik7XG4gICAgfVxuXG4gICAgLy8gRGVmaW5lIHZhbG9yZXMgcGFkcsOjbyBzZSBuw6NvIGVzcGVjaWZpY2Fkb3NcbiAgICB0aGlzLmNvbmZpZy5zaG93SGVhZGVyID0gdGhpcy5jb25maWcuc2hvd0hlYWRlciA/PyB0cnVlOyAvLyBFeGliZSBvIGNhYmXDp2FsaG8gcG9yIHBhZHLDo29cbiAgICB0aGlzLmNvbmZpZy5wYWdpbmF0aW9uID0gdGhpcy5jb25maWcucGFnaW5hdGlvbiA/PyB0cnVlOyAvLyBBdGl2YSBwYWdpbmHDp8OjbyBwb3IgcGFkcsOjb1xuICAgIHRoaXMuaXRlbXNQZXJQYWdlID0gdGhpcy5jb25maWcuaXRlbXNQZXJQYWdlIHx8IDEwO1xuICB9XG5cbiAgb25QYWdlQ2hhbmdlKG5ld1BhZ2U6IG51bWJlcikge1xuICAgIHRoaXMuY3VycmVudFBhZ2UgPSBuZXdQYWdlO1xuICB9XG5cbiAgb25JdGVtc1BlclBhZ2VDaGFuZ2UoZXZlbnQ6IEV2ZW50KSB7XG4gICAgY29uc3QgdGFyZ2V0ID0gZXZlbnQudGFyZ2V0IGFzIEhUTUxTZWxlY3RFbGVtZW50O1xuICAgIHRoaXMuaXRlbXNQZXJQYWdlID0gK3RhcmdldC52YWx1ZTtcbiAgICB0aGlzLmN1cnJlbnRQYWdlID0gMTsgLy8gUmVpbmljaWEgYSBwYWdpbmHDp8OjbyBhbyBhbHRlcmFyIG9zIGl0ZW5zIHBvciBww6FnaW5hXG4gIH1cblxuICAvLyBHZXR0ZXIgcGFyYSBnYXJhbnRpciBxdWUgdG90YWxJdGVtcyBudW5jYSBzZWphIHVuZGVmaW5lZFxuICBnZXQgc2FmZVRvdGFsSXRlbXMoKTogbnVtYmVyIHtcbiAgICByZXR1cm4gdGhpcy50b3RhbEl0ZW1zIHx8IDA7XG4gIH1cbn1cbiIsIjx0YWJsZSBjbGFzcz1cInRhYmxlXCIgW25nQ2xhc3NdPVwieyBuZXN0ZWQ6IGNvbmZpZy5pc05lc3RlZCB9XCI+XG4gIDx0aGVhZCAqbmdJZj1cImNvbmZpZy5zaG93SGVhZGVyXCI+XG4gICAgPHRyPlxuICAgICAgPHRoICpuZ0Zvcj1cImxldCBjb2x1bW4gb2YgY29uZmlnLmNvbHVtbnNcIj57eyBjb2x1bW4uaGVhZGVyIH19PC90aD5cbiAgICA8L3RyPlxuICA8L3RoZWFkPlxuICA8dGJvZHk+XG4gICAgPHRyICpuZ0Zvcj1cImxldCByb3cgb2YgcGFnaW5hdGVkRGF0YVwiPlxuICAgICAgPHRkICpuZ0Zvcj1cImxldCBjb2x1bW4gb2YgY29uZmlnLmNvbHVtbnNcIj5cbiAgICAgICAgPG5nLWNvbnRhaW5lciBbbmdTd2l0Y2hdPVwiY29sdW1uLnR5cGVcIj5cbiAgICAgICAgICA8c3BhbiAqbmdTd2l0Y2hDYXNlPVwiJ3RleHQnXCI+e3sgcm93W2NvbHVtbi5rZXldIH19PC9zcGFuPlxuICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nU3dpdGNoQ2FzZT1cIid0ZW1wbGF0ZSdcIj5cbiAgICAgICAgICAgIDxuZy1jb250YWluZXJcbiAgICAgICAgICAgICAgKm5nVGVtcGxhdGVPdXRsZXQ9XCJcbiAgICAgICAgICAgICAgICBjb2x1bW4udGVtcGxhdGUgfHwgbnVsbDtcbiAgICAgICAgICAgICAgICBjb250ZXh0OiB7ICRpbXBsaWNpdDogcm93IH1cbiAgICAgICAgICAgICAgXCJcbiAgICAgICAgICAgID48L25nLWNvbnRhaW5lcj5cbiAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgICA8L3RkPlxuICAgIDwvdHI+XG4gIDwvdGJvZHk+XG48L3RhYmxlPlxuXG48ZGl2XG4gIGNsYXNzPVwidGV4dC1jZW50ZXIgcGFnaW5hdGlvbi1jb250cm9sc1wiXG4gIFtuZ0NsYXNzXT1cInsgbmVzdGVkOiBjb25maWcuaXNOZXN0ZWQgfVwiXG4gICpuZ0lmPVwiY29uZmlnLnBhZ2luYXRpb25cIlxuPlxuICA8Y3VzdG9tLXBhZ2luYXRpb25cbiAgICBbdG90YWxJdGVtc109XCJzYWZlVG90YWxJdGVtc1wiXG4gICAgW2l0ZW1zUGVyUGFnZV09XCJpdGVtc1BlclBhZ2VcIlxuICAgIFtjdXJyZW50UGFnZV09XCJjdXJyZW50UGFnZVwiXG4gICAgW3Nob3dQYWdlSW5mb109XCJzaG93UGFnZUluZm9cIlxuICAgIChwYWdlQ2hhbmdlKT1cIm9uUGFnZUNoYW5nZSgkZXZlbnQpXCJcbiAgPlxuICA8L2N1c3RvbS1wYWdpbmF0aW9uPlxuPC9kaXY+XG4iXX0=
|