lib-portal-angular 0.0.87 → 0.0.89

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (35) hide show
  1. package/esm2022/lib/components/components.module.mjs +65 -40
  2. package/esm2022/lib/components/csv-importer/csv-importer.component.mjs +92 -0
  3. package/esm2022/lib/components/data-excel-exporter/IExcelExportConfig.mjs +2 -0
  4. package/esm2022/lib/components/data-excel-exporter/data-excel-exporter.component.mjs +126 -0
  5. package/esm2022/lib/components/data-excel-import/data-excel-importer.component.mjs +198 -0
  6. package/esm2022/lib/components/multi-select/multi-select.component.mjs +165 -115
  7. package/esm2022/lib/components/pdf-data-handler/argenta-pdf-data-handler.component.mjs +147 -0
  8. package/esm2022/lib/components/pdf-data-handler/function/formatToBrazilianNumber.mjs +7 -0
  9. package/esm2022/lib/components/pdf-data-handler/function/parseBrazilianNumber.mjs +9 -0
  10. package/esm2022/lib/components/pdf-data-handler/interface/DataRow.mjs +2 -0
  11. package/esm2022/lib/components/pdf-data-handler/interface/PdfExportConfig.mjs +2 -0
  12. package/esm2022/lib/components/pdf-data-handler/interface/PdfTableStyles.mjs +2 -0
  13. package/esm2022/lib/components/pdf-data-handler/interface/RowCalculation.mjs +2 -0
  14. package/esm2022/lib/components/pdf-data-handler/interface/TotalizerConfig.mjs +2 -0
  15. package/esm2022/lib/components/pdf-download/argenta-pdf-download.component.mjs +51 -0
  16. package/esm2022/public-api.mjs +36 -5
  17. package/fesm2022/lib-portal-angular.mjs +1095 -422
  18. package/fesm2022/lib-portal-angular.mjs.map +1 -1
  19. package/lib/components/components.module.d.ts +10 -5
  20. package/lib/components/csv-importer/csv-importer.component.d.ts +19 -0
  21. package/lib/components/data-excel-exporter/IExcelExportConfig.d.ts +21 -0
  22. package/lib/components/data-excel-exporter/data-excel-exporter.component.d.ts +9 -0
  23. package/lib/components/data-excel-import/data-excel-importer.component.d.ts +44 -0
  24. package/lib/components/multi-select/multi-select.component.d.ts +20 -9
  25. package/lib/components/pdf-data-handler/argenta-pdf-data-handler.component.d.ts +15 -0
  26. package/lib/components/pdf-data-handler/function/formatToBrazilianNumber.d.ts +1 -0
  27. package/lib/components/pdf-data-handler/function/parseBrazilianNumber.d.ts +1 -0
  28. package/lib/components/pdf-data-handler/interface/DataRow.d.ts +3 -0
  29. package/lib/components/pdf-data-handler/interface/PdfExportConfig.d.ts +12 -0
  30. package/lib/components/pdf-data-handler/interface/PdfTableStyles.d.ts +28 -0
  31. package/lib/components/pdf-data-handler/interface/RowCalculation.d.ts +4 -0
  32. package/lib/components/pdf-data-handler/interface/TotalizerConfig.d.ts +8 -0
  33. package/lib/components/pdf-download/argenta-pdf-download.component.d.ts +13 -0
  34. package/package.json +1 -1
  35. package/public-api.d.ts +34 -3
@@ -1,42 +1,47 @@
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';
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";
24
37
  import { DynamicModalComponent } from "./dynamic-modal/dynamic-modal.component";
25
38
  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
+ import { ArgentaPdfDataHandlerComponent } from "./pdf-data-handler/argenta-pdf-data-handler.component";
40
+ import { ArgentaPdfDownloadComponent } from "./pdf-download/argenta-pdf-download.component";
41
+ import { DragDropListComponent } from "./drag-drop-list/drag-drop-list.component";
42
+ import { DataExcelExporterComponent } from "./data-excel-exporter/data-excel-exporter.component";
43
+ import { DataExcelImporterComponent } from "./data-excel-import/data-excel-importer.component";
44
+ import { CsvImporterComponent } from "./csv-importer/csv-importer.component";
40
45
  import * as i0 from "@angular/core";
41
46
  export class ComponentsModule {
42
47
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
@@ -73,7 +78,12 @@ export class ComponentsModule {
73
78
  ModalComponent,
74
79
  DragDropListComponent,
75
80
  DynamicModalComponent,
76
- DynamicTableComponent], imports: [CommonModule,
81
+ DynamicTableComponent,
82
+ ArgentaPdfDataHandlerComponent,
83
+ ArgentaPdfDownloadComponent,
84
+ DataExcelExporterComponent,
85
+ DataExcelImporterComponent,
86
+ CsvImporterComponent], imports: [CommonModule,
77
87
  FormsModule,
78
88
  ReactiveFormsModule,
79
89
  NgSelectModule,
@@ -114,7 +124,12 @@ export class ComponentsModule {
114
124
  ModalComponent,
115
125
  DragDropListComponent,
116
126
  DynamicModalComponent,
117
- DynamicTableComponent] }); }
127
+ DynamicTableComponent,
128
+ ArgentaPdfDataHandlerComponent,
129
+ ArgentaPdfDownloadComponent,
130
+ DataExcelExporterComponent,
131
+ DataExcelImporterComponent,
132
+ CsvImporterComponent] }); }
118
133
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, imports: [CommonModule,
119
134
  FormsModule,
120
135
  ReactiveFormsModule,
@@ -162,6 +177,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
162
177
  DragDropListComponent,
163
178
  DynamicModalComponent,
164
179
  DynamicTableComponent,
180
+ ArgentaPdfDataHandlerComponent,
181
+ ArgentaPdfDownloadComponent,
182
+ DataExcelExporterComponent,
183
+ DataExcelImporterComponent,
184
+ CsvImporterComponent,
165
185
  ],
166
186
  imports: [
167
187
  CommonModule,
@@ -209,7 +229,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
209
229
  DragDropListComponent,
210
230
  DynamicModalComponent,
211
231
  DynamicTableComponent,
232
+ ArgentaPdfDataHandlerComponent,
233
+ ArgentaPdfDownloadComponent,
234
+ DataExcelExporterComponent,
235
+ DataExcelImporterComponent,
236
+ CsvImporterComponent,
212
237
  ],
213
238
  }]
214
239
  }] });
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"]}
240
+ //# 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\";\nimport { ArgentaPdfDataHandlerComponent } from \"./pdf-data-handler/argenta-pdf-data-handler.component\";\nimport { ArgentaPdfDownloadComponent } from \"./pdf-download/argenta-pdf-download.component\";\nimport { DragDropListComponent } from \"./drag-drop-list/drag-drop-list.component\";\nimport { DataExcelExporterComponent } from \"./data-excel-exporter/data-excel-exporter.component\";\nimport { DataExcelImporterComponent } from \"./data-excel-import/data-excel-importer.component\";\nimport { CsvImporterComponent } from \"./csv-importer/csv-importer.component\";\n\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    ArgentaPdfDataHandlerComponent,\n    ArgentaPdfDownloadComponent,\n    DataExcelExporterComponent,\n    DataExcelImporterComponent,\n    CsvImporterComponent,\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    ArgentaPdfDataHandlerComponent,\n    ArgentaPdfDownloadComponent,\n    DataExcelExporterComponent,\n    DataExcelImporterComponent,\n    CsvImporterComponent,\n  ],\n})\nexport class ComponentsModule {}\n"]}
@@ -0,0 +1,92 @@
1
+ import { Component, Input } from "@angular/core";
2
+ import * as XLSX from "xlsx";
3
+ import * as i0 from "@angular/core";
4
+ export class CsvImporterComponent {
5
+ constructor() {
6
+ this.config = {
7
+ acceptedFileTypes: [".xlsx", ".xls", ".csv"],
8
+ detectHeaders: true,
9
+ delimiter: ";",
10
+ onImport: () => { },
11
+ };
12
+ }
13
+ handleFileInput(event) {
14
+ const file = event.target.files[0];
15
+ if (file) {
16
+ const reader = new FileReader();
17
+ // Detecta se o arquivo é CSV
18
+ if (file.name.endsWith(".csv")) {
19
+ reader.onload = (e) => {
20
+ const csvData = e.target.result;
21
+ const delimiter = this.config.delimiter ?? ";"; // Usa delimitador configurado ou padrão
22
+ const jsonData = this.parseCSV(csvData, delimiter);
23
+ this.processData(jsonData);
24
+ };
25
+ reader.readAsText(file);
26
+ }
27
+ else {
28
+ // Processa arquivos Excel (XLSX/XLS)
29
+ reader.onload = (e) => {
30
+ const data = new Uint8Array(e.target.result);
31
+ const workbook = XLSX.read(data, { type: "array" });
32
+ const sheetName = workbook.SheetNames[0];
33
+ const worksheet = workbook.Sheets[sheetName];
34
+ const jsonData = XLSX.utils.sheet_to_json(worksheet, {
35
+ header: 1,
36
+ defval: "",
37
+ });
38
+ this.processData(jsonData);
39
+ };
40
+ reader.readAsArrayBuffer(file);
41
+ }
42
+ }
43
+ }
44
+ parseCSV(csvData, delimiter = ";") {
45
+ return csvData
46
+ .split("\n")
47
+ .map((row) => row.split(delimiter).map((cell) => cell.trim()));
48
+ }
49
+ processData(jsonData) {
50
+ const headers = this.getHeaders(jsonData);
51
+ const dataRows = jsonData.slice(headers ? 1 : 0);
52
+ const formattedData = this.formatData(dataRows, headers);
53
+ this.config.onImport(formattedData);
54
+ }
55
+ getHeaders(data) {
56
+ if (this.config.customHeaders) {
57
+ return this.config.customHeaders;
58
+ }
59
+ if (this.config.detectHeaders && data.length > 0) {
60
+ return data[0].map((header, index) => this.normalizeHeader(header || `col_${index}`));
61
+ }
62
+ return null; // Nenhum cabeçalho detectado
63
+ }
64
+ formatData(dataRows, headers) {
65
+ if (!headers) {
66
+ return dataRows; // Retorna dados brutos se não houver cabeçalhos
67
+ }
68
+ return dataRows.map((row) => {
69
+ const record = {};
70
+ headers.forEach((header, index) => {
71
+ record[header] = row[index] ?? "";
72
+ });
73
+ return record;
74
+ });
75
+ }
76
+ normalizeHeader(header) {
77
+ return String(header)
78
+ .normalize("NFD")
79
+ .replace(/[\u0300-\u036f]/g, "")
80
+ .replace(/\s+/g, "_")
81
+ .toLowerCase();
82
+ }
83
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CsvImporterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
84
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CsvImporterComponent, selector: "argenta-csv-importer", inputs: { config: "config" }, ngImport: i0, template: "<div class=\"excel-importer\">\n <input\n type=\"file\"\n (change)=\"handleFileInput($event)\"\n [accept]=\"config.acceptedFileTypes?.join(',')\"\n style=\"display: none\"\n #fileInput\n />\n <button (click)=\"fileInput.click()\">Importar Arquivo</button>\n</div>\n", styles: [".excel-importer button{background-color:var(--primary-color);color:var(--text-color);font-family:var(--font-family);padding:10px 20px;border:none;cursor:pointer}.excel-importer button:hover{background-color:var(--secondary-color)}\n"] }); }
85
+ }
86
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CsvImporterComponent, decorators: [{
87
+ type: Component,
88
+ args: [{ selector: "argenta-csv-importer", template: "<div class=\"excel-importer\">\n <input\n type=\"file\"\n (change)=\"handleFileInput($event)\"\n [accept]=\"config.acceptedFileTypes?.join(',')\"\n style=\"display: none\"\n #fileInput\n />\n <button (click)=\"fileInput.click()\">Importar Arquivo</button>\n</div>\n", styles: [".excel-importer button{background-color:var(--primary-color);color:var(--text-color);font-family:var(--font-family);padding:10px 20px;border:none;cursor:pointer}.excel-importer button:hover{background-color:var(--secondary-color)}\n"] }]
89
+ }], propDecorators: { config: [{
90
+ type: Input
91
+ }] } });
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"csv-importer.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/csv-importer/csv-importer.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/csv-importer/csv-importer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from \"@angular/core\";\nimport * as XLSX from \"xlsx\";\n\nexport interface CsvExcelImporterConfig {\n  acceptedFileTypes?: string[]; // Tipos de arquivos permitidos (padrão: .xlsx, .xls, .csv)\n  detectHeaders?: boolean; // Detectar automaticamente cabeçalhos (padrão: true)\n  customHeaders?: string[]; // Fornecer cabeçalhos personalizados\n  delimiter?: string; // Delimitador para arquivos CSV (padrão: \";\")\n  onImport: (data: any[]) => void; // Callback para manipular os dados\n}\n\n@Component({\n  selector: \"argenta-csv-importer\",\n  templateUrl: \"./csv-importer.component.html\",\n  styleUrls: [\"./csv-importer.component.scss\"],\n})\nexport class CsvImporterComponent {\n  @Input() config: CsvExcelImporterConfig = {\n    acceptedFileTypes: [\".xlsx\", \".xls\", \".csv\"],\n    detectHeaders: true,\n    delimiter: \";\",\n    onImport: () => {},\n  };\n\n  handleFileInput(event: any): void {\n    const file = event.target.files[0];\n    if (file) {\n      const reader = new FileReader();\n\n      // Detecta se o arquivo é CSV\n      if (file.name.endsWith(\".csv\")) {\n        reader.onload = (e: any) => {\n          const csvData = e.target.result;\n          const delimiter = this.config.delimiter ?? \";\"; // Usa delimitador configurado ou padrão\n          const jsonData = this.parseCSV(csvData, delimiter);\n          this.processData(jsonData);\n        };\n        reader.readAsText(file);\n      } else {\n        // Processa arquivos Excel (XLSX/XLS)\n        reader.onload = (e: any) => {\n          const data = new Uint8Array(e.target.result);\n          const workbook = XLSX.read(data, { type: \"array\" });\n          const sheetName = workbook.SheetNames[0];\n          const worksheet = workbook.Sheets[sheetName];\n\n          const jsonData = XLSX.utils.sheet_to_json<any[]>(worksheet, {\n            header: 1,\n            defval: \"\",\n          });\n\n          this.processData(jsonData);\n        };\n        reader.readAsArrayBuffer(file);\n      }\n    }\n  }\n\n  private parseCSV(csvData: string, delimiter: string = \";\"): any[][] {\n    return csvData\n      .split(\"\\n\")\n      .map((row) => row.split(delimiter).map((cell) => cell.trim()));\n  }\n\n  private processData(jsonData: any[][]): void {\n    const headers = this.getHeaders(jsonData);\n    const dataRows = jsonData.slice(headers ? 1 : 0);\n\n    const formattedData = this.formatData(dataRows, headers);\n    this.config.onImport(formattedData);\n  }\n\n  private getHeaders(data: any[][]): string[] | null {\n    if (this.config.customHeaders) {\n      return this.config.customHeaders;\n    }\n    if (this.config.detectHeaders && data.length > 0) {\n      return data[0].map((header: any, index: number) =>\n        this.normalizeHeader(header || `col_${index}`)\n      );\n    }\n    return null; // Nenhum cabeçalho detectado\n  }\n\n  private formatData(dataRows: any[][], headers: string[] | null): any[] {\n    if (!headers) {\n      return dataRows; // Retorna dados brutos se não houver cabeçalhos\n    }\n\n    return dataRows.map((row) => {\n      const record: any = {};\n      headers.forEach((header, index) => {\n        record[header] = row[index] ?? \"\";\n      });\n      return record;\n    });\n  }\n\n  private normalizeHeader(header: any): string {\n    return String(header)\n      .normalize(\"NFD\")\n      .replace(/[\\u0300-\\u036f]/g, \"\")\n      .replace(/\\s+/g, \"_\")\n      .toLowerCase();\n  }\n}\n","<div class=\"excel-importer\">\n  <input\n    type=\"file\"\n    (change)=\"handleFileInput($event)\"\n    [accept]=\"config.acceptedFileTypes?.join(',')\"\n    style=\"display: none\"\n    #fileInput\n  />\n  <button (click)=\"fileInput.click()\">Importar Arquivo</button>\n</div>\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSUV4Y2VsRXhwb3J0Q29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGliLXBvcnRhbC1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy9kYXRhLWV4Y2VsLWV4cG9ydGVyL0lFeGNlbEV4cG9ydENvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJRXhjZWxFeHBvcnRDb25maWcge1xuICBidXR0b25MYWJlbDogc3RyaW5nOyAvLyBUZXh0byBkbyBib3TDo29cbiAgZmlsZU5hbWU6IHN0cmluZzsgLy8gTm9tZSBkbyBhcnF1aXZvIEV4Y2VsXG4gIHNoZWV0TmFtZT86IHN0cmluZzsgLy8gTm9tZSBkYSBwbGFuaWxoYVxuICB0aXRsZT86IHN0cmluZzsgLy8gVMOtdHVsbyBubyB0b3BvIGRhIHBsYW5pbGhhXG4gIHRpdGxlV2lkdGhzPzogbnVtYmVyW107IC8vIExhcmd1cmEgcGVyc29uYWxpemFkYSBkYXMgY29sdW5hcyBkbyB0w610dWxvXG4gIHRhYmxlSGVhZGVycz86IHN0cmluZ1tdOyAvLyBDYWJlw6dhbGhvcyBkYSB0YWJlbGFcbiAgdGFibGVLZXlzPzogc3RyaW5nW107IC8vIENoYXZlcyBkb3MgZGFkb3NcbiAgbnVtZXJpY0NvbHVtbnM/OiBzdHJpbmdbXTsgLy8gQ29sdW5hcyBudW3DqXJpY2FzXG4gIGNvbHVtbldpZHRocz86IG51bWJlcltdOyAvLyBMYXJndXJhIGRhcyBjb2x1bmFzIGVtIGNhcmFjdGVyZXNcbiAgbXVsdGlwbGVTaGVldHM/OiB7XG4gICAgc2hlZXROYW1lOiBzdHJpbmc7IC8vIE5vbWUgZGEgcGxhbmlsaGFcbiAgICB0aXRsZT86IHN0cmluZzsgLy8gVMOtdHVsbyBubyB0b3BvIGRhIHBsYW5pbGhhXG4gICAgdGl0bGVXaWR0aHM/OiBudW1iZXJbXTsgLy8gTGFyZ3VyYSBwZXJzb25hbGl6YWRhIGRvIHTDrXR1bG9cbiAgICB0YWJsZUhlYWRlcnM6IHN0cmluZ1tdOyAvLyBDYWJlw6dhbGhvcyBkYSB0YWJlbGFcbiAgICB0YWJsZUtleXM6IHN0cmluZ1tdOyAvLyBDaGF2ZXMgZG9zIGRhZG9zXG4gICAgbnVtZXJpY0NvbHVtbnM/OiBzdHJpbmdbXTsgLy8gQ29sdW5hcyBudW3DqXJpY2FzXG4gICAgY29sdW1uV2lkdGhzPzogbnVtYmVyW107IC8vIExhcmd1cmEgZGFzIGNvbHVuYXMgZW0gY2FyYWN0ZXJlc1xuICAgIGRhdGE6IGFueVtdOyAvLyBEYWRvcyBkYSBwbGFuaWxoYVxuICB9W107XG59XG4iXX0=
@@ -0,0 +1,126 @@
1
+ import { Component, Input } from "@angular/core";
2
+ import * as XLSX from "xlsx";
3
+ import * as i0 from "@angular/core";
4
+ export class DataExcelExporterComponent {
5
+ constructor() {
6
+ this.data = [];
7
+ }
8
+ exportToExcel() {
9
+ if (!this.config || (!this.data.length && !this.config.multipleSheets)) {
10
+ console.warn("Nenhuma configuração ou dados fornecidos.");
11
+ return;
12
+ }
13
+ const workbook = XLSX.utils.book_new();
14
+ // Verifica se múltiplas planilhas estão configuradas
15
+ if (this.config.multipleSheets) {
16
+ this.config.multipleSheets.forEach((sheetConfig) => {
17
+ const worksheet = XLSX.utils.aoa_to_sheet([]);
18
+ // Adiciona o título, se houver
19
+ let startRow = 0;
20
+ if (sheetConfig.title) {
21
+ XLSX.utils.sheet_add_aoa(worksheet, [[sheetConfig.title]], {
22
+ origin: "A1",
23
+ });
24
+ // Define larguras personalizadas do título
25
+ if (sheetConfig.titleWidths) {
26
+ worksheet["!cols"] = sheetConfig.titleWidths.map((width) => ({
27
+ wch: width,
28
+ }));
29
+ }
30
+ // Mescla o título
31
+ if (sheetConfig.tableHeaders) {
32
+ worksheet["!merges"] = worksheet["!merges"] || [];
33
+ worksheet["!merges"].push({
34
+ s: { r: 0, c: 0 },
35
+ e: { r: 0, c: sheetConfig.tableHeaders.length - 1 },
36
+ });
37
+ }
38
+ startRow = 1;
39
+ }
40
+ // Adiciona cabeçalhos
41
+ if (sheetConfig.tableHeaders) {
42
+ XLSX.utils.sheet_add_aoa(worksheet, [sheetConfig.tableHeaders], {
43
+ origin: `A${startRow + 1}`,
44
+ });
45
+ }
46
+ // Adiciona dados
47
+ if (sheetConfig.data) {
48
+ XLSX.utils.sheet_add_json(worksheet, sheetConfig.data, {
49
+ origin: `A${startRow + 2}`,
50
+ skipHeader: true,
51
+ });
52
+ }
53
+ // Define larguras das colunas
54
+ if (sheetConfig.columnWidths) {
55
+ worksheet["!cols"] = sheetConfig.columnWidths.map((width) => ({
56
+ wch: width,
57
+ }));
58
+ }
59
+ // Adiciona a planilha ao workbook
60
+ XLSX.utils.book_append_sheet(workbook, worksheet, sheetConfig.sheetName);
61
+ });
62
+ }
63
+ else {
64
+ // Caso não haja múltiplas planilhas, processa a planilha única
65
+ const worksheet = XLSX.utils.aoa_to_sheet([]);
66
+ // Adiciona título, se houver
67
+ let startRow = 0;
68
+ if (this.config.title) {
69
+ XLSX.utils.sheet_add_aoa(worksheet, [[this.config.title]], {
70
+ origin: "A1",
71
+ });
72
+ // Define larguras do título
73
+ if (this.config.titleWidths) {
74
+ worksheet["!cols"] = this.config.titleWidths.map((width) => ({
75
+ wch: width,
76
+ }));
77
+ }
78
+ // Mescla o título
79
+ if (this.config.tableHeaders) {
80
+ worksheet["!merges"] = worksheet["!merges"] || [];
81
+ worksheet["!merges"].push({
82
+ s: { r: 0, c: 0 },
83
+ e: { r: 0, c: this.config.tableHeaders.length - 1 },
84
+ });
85
+ }
86
+ startRow = 1;
87
+ }
88
+ // Adiciona cabeçalhos
89
+ if (this.config.tableHeaders) {
90
+ XLSX.utils.sheet_add_aoa(worksheet, [this.config.tableHeaders], {
91
+ origin: `A${startRow + 1}`,
92
+ });
93
+ }
94
+ // Adiciona dados
95
+ XLSX.utils.sheet_add_json(worksheet, this.data, {
96
+ origin: `A${startRow + 2}`,
97
+ skipHeader: true,
98
+ });
99
+ // Define larguras das colunas
100
+ if (this.config.columnWidths) {
101
+ worksheet["!cols"] = this.config.columnWidths.map((width) => ({
102
+ wch: width,
103
+ }));
104
+ }
105
+ // Adiciona a planilha ao workbook
106
+ XLSX.utils.book_append_sheet(workbook, worksheet, this.config.sheetName);
107
+ }
108
+ // Salva o arquivo Excel
109
+ XLSX.writeFile(workbook, this.config.fileName);
110
+ }
111
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataExcelExporterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
112
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DataExcelExporterComponent, selector: "argenta-excel-exporter", inputs: { config: "config", data: "data" }, ngImport: i0, template: `
113
+ <button (click)="exportToExcel()">{{ config?.buttonLabel }}</button>
114
+ `, isInline: true, styles: ["button{background-color:var(--primary-color);color:var(--text-color);font-family:var(--font-family);padding:10px 20px;border:none;cursor:pointer}button:hover{background-color:var(--secondary-color)}\n"] }); }
115
+ }
116
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataExcelExporterComponent, decorators: [{
117
+ type: Component,
118
+ args: [{ selector: "argenta-excel-exporter", template: `
119
+ <button (click)="exportToExcel()">{{ config?.buttonLabel }}</button>
120
+ `, styles: ["button{background-color:var(--primary-color);color:var(--text-color);font-family:var(--font-family);padding:10px 20px;border:none;cursor:pointer}button:hover{background-color:var(--secondary-color)}\n"] }]
121
+ }], propDecorators: { config: [{
122
+ type: Input
123
+ }], data: [{
124
+ type: Input
125
+ }] } });
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-excel-exporter.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/data-excel-exporter/data-excel-exporter.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from \"@angular/core\";\nimport * as XLSX from \"xlsx\";\nimport { IExcelExportConfig } from \"./IExcelExportConfig\";\n\n@Component({\n  selector: \"argenta-excel-exporter\",\n  template: `\n    <button (click)=\"exportToExcel()\">{{ config?.buttonLabel }}</button>\n  `,\n  styleUrls: [\"./data-excel-exporter.component.scss\"],\n})\nexport class DataExcelExporterComponent {\n  @Input() config!: IExcelExportConfig;\n  @Input() data: any[] = [];\n\n  exportToExcel(): void {\n    if (!this.config || (!this.data.length && !this.config.multipleSheets)) {\n      console.warn(\"Nenhuma configuração ou dados fornecidos.\");\n      return;\n    }\n\n    const workbook = XLSX.utils.book_new();\n\n    // Verifica se múltiplas planilhas estão configuradas\n    if (this.config.multipleSheets) {\n      this.config.multipleSheets.forEach((sheetConfig: any) => {\n        const worksheet = XLSX.utils.aoa_to_sheet([]);\n\n        // Adiciona o título, se houver\n        let startRow = 0;\n        if (sheetConfig.title) {\n          XLSX.utils.sheet_add_aoa(worksheet, [[sheetConfig.title]], {\n            origin: \"A1\",\n          });\n\n          // Define larguras personalizadas do título\n          if (sheetConfig.titleWidths) {\n            worksheet[\"!cols\"] = sheetConfig.titleWidths.map((width: any) => ({\n              wch: width,\n            }));\n          }\n\n          // Mescla o título\n          if (sheetConfig.tableHeaders) {\n            worksheet[\"!merges\"] = worksheet[\"!merges\"] || [];\n            worksheet[\"!merges\"].push({\n              s: { r: 0, c: 0 },\n              e: { r: 0, c: sheetConfig.tableHeaders.length - 1 },\n            });\n          }\n\n          startRow = 1;\n        }\n\n        // Adiciona cabeçalhos\n        if (sheetConfig.tableHeaders) {\n          XLSX.utils.sheet_add_aoa(worksheet, [sheetConfig.tableHeaders], {\n            origin: `A${startRow + 1}`,\n          });\n        }\n\n        // Adiciona dados\n        if (sheetConfig.data) {\n          XLSX.utils.sheet_add_json(worksheet, sheetConfig.data, {\n            origin: `A${startRow + 2}`,\n            skipHeader: true,\n          });\n        }\n\n        // Define larguras das colunas\n        if (sheetConfig.columnWidths) {\n          worksheet[\"!cols\"] = sheetConfig.columnWidths.map((width: any) => ({\n            wch: width,\n          }));\n        }\n\n        // Adiciona a planilha ao workbook\n        XLSX.utils.book_append_sheet(\n          workbook,\n          worksheet,\n          sheetConfig.sheetName\n        );\n      });\n    } else {\n      // Caso não haja múltiplas planilhas, processa a planilha única\n      const worksheet = XLSX.utils.aoa_to_sheet([]);\n\n      // Adiciona título, se houver\n      let startRow = 0;\n      if (this.config.title) {\n        XLSX.utils.sheet_add_aoa(worksheet, [[this.config.title]], {\n          origin: \"A1\",\n        });\n\n        // Define larguras do título\n        if (this.config.titleWidths) {\n          worksheet[\"!cols\"] = this.config.titleWidths.map((width) => ({\n            wch: width,\n          }));\n        }\n\n        // Mescla o título\n        if (this.config.tableHeaders) {\n          worksheet[\"!merges\"] = worksheet[\"!merges\"] || [];\n          worksheet[\"!merges\"].push({\n            s: { r: 0, c: 0 },\n            e: { r: 0, c: this.config.tableHeaders.length - 1 },\n          });\n        }\n\n        startRow = 1;\n      }\n\n      // Adiciona cabeçalhos\n      if (this.config.tableHeaders) {\n        XLSX.utils.sheet_add_aoa(worksheet, [this.config.tableHeaders], {\n          origin: `A${startRow + 1}`,\n        });\n      }\n\n      // Adiciona dados\n      XLSX.utils.sheet_add_json(worksheet, this.data, {\n        origin: `A${startRow + 2}`,\n        skipHeader: true,\n      });\n\n      // Define larguras das colunas\n      if (this.config.columnWidths) {\n        worksheet[\"!cols\"] = this.config.columnWidths.map((width) => ({\n          wch: width,\n        }));\n      }\n\n      // Adiciona a planilha ao workbook\n      XLSX.utils.book_append_sheet(workbook, worksheet, this.config.sheetName!);\n    }\n\n    // Salva o arquivo Excel\n    XLSX.writeFile(workbook, this.config.fileName);\n  }\n}\n"]}