lib-portal-angular 0.0.92 → 0.0.93
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/data-excel-exporter/IExcelExportConfig.mjs +1 -1
- package/esm2022/lib/components/data-excel-exporter/data-excel-exporter.component.mjs +29 -20
- package/fesm2022/lib-portal-angular.mjs +28 -19
- package/fesm2022/lib-portal-angular.mjs.map +1 -1
- package/lib/components/data-excel-exporter/IExcelExportConfig.d.ts +0 -1
- package/lib/components/data-excel-exporter/data-excel-exporter.component.d.ts +4 -3
- package/package.json +1 -1
@@ -1,2 +1,2 @@
|
|
1
1
|
export {};
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSUV4Y2VsRXhwb3J0Q29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGliLXBvcnRhbC1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy9kYXRhLWV4Y2VsLWV4cG9ydGVyL0lFeGNlbEV4cG9ydENvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJRXhjZWxFeHBvcnRDb25maWcge1xuICBmaWxlTmFtZTogc3RyaW5nOyAvLyBOb21lIGRvIGFycXVpdm8gRXhjZWxcbiAgc2hlZXROYW1lPzogc3RyaW5nOyAvLyBOb21lIGRhIHBsYW5pbGhhXG4gIHRpdGxlPzogc3RyaW5nOyAvLyBUw610dWxvIG5vIHRvcG8gZGEgcGxhbmlsaGFcbiAgdGl0bGVXaWR0aHM/OiBudW1iZXJbXTsgLy8gTGFyZ3VyYSBwZXJzb25hbGl6YWRhIGRhcyBjb2x1bmFzIGRvIHTDrXR1bG9cbiAgdGFibGVIZWFkZXJzPzogc3RyaW5nW107IC8vIENhYmXDp2FsaG9zIGRhIHRhYmVsYVxuICB0YWJsZUtleXM/OiBzdHJpbmdbXTsgLy8gQ2hhdmVzIGRvcyBkYWRvc1xuICBudW1lcmljQ29sdW1ucz86IHN0cmluZ1tdOyAvLyBDb2x1bmFzIG51bcOpcmljYXNcbiAgY29sdW1uV2lkdGhzPzogbnVtYmVyW107IC8vIExhcmd1cmEgZGFzIGNvbHVuYXMgZW0gY2FyYWN0ZXJlc1xuICBtdWx0aXBsZVNoZWV0cz86IHtcbiAgICBzaGVldE5hbWU6IHN0cmluZzsgLy8gTm9tZSBkYSBwbGFuaWxoYVxuICAgIHRpdGxlPzogc3RyaW5nOyAvLyBUw610dWxvIG5vIHRvcG8gZGEgcGxhbmlsaGFcbiAgICB0aXRsZVdpZHRocz86IG51bWJlcltdOyAvLyBMYXJndXJhIHBlcnNvbmFsaXphZGEgZG8gdMOtdHVsb1xuICAgIHRhYmxlSGVhZGVyczogc3RyaW5nW107IC8vIENhYmXDp2FsaG9zIGRhIHRhYmVsYVxuICAgIHRhYmxlS2V5czogc3RyaW5nW107IC8vIENoYXZlcyBkb3MgZGFkb3NcbiAgICBudW1lcmljQ29sdW1ucz86IHN0cmluZ1tdOyAvLyBDb2x1bmFzIG51bcOpcmljYXNcbiAgICBjb2x1bW5XaWR0aHM/OiBudW1iZXJbXTsgLy8gTGFyZ3VyYSBkYXMgY29sdW5hcyBlbSBjYXJhY3RlcmVzXG4gICAgZGF0YTogYW55W107IC8vIERhZG9zIGRhIHBsYW5pbGhhXG4gIH1bXTtcbn1cbiJdfQ==
|
@@ -5,15 +5,22 @@ export class DataExcelExporterComponent {
|
|
5
5
|
constructor() {
|
6
6
|
this.data = [];
|
7
7
|
}
|
8
|
-
exportToExcel() {
|
9
|
-
|
8
|
+
async exportToExcel() {
|
9
|
+
let sheetConfig;
|
10
|
+
if (this.config instanceof Promise) {
|
11
|
+
sheetConfig = await this.config;
|
12
|
+
}
|
13
|
+
else {
|
14
|
+
sheetConfig = this.config;
|
15
|
+
}
|
16
|
+
if (!this.config || (!this.data.length && !sheetConfig.multipleSheets)) {
|
10
17
|
console.warn("Nenhuma configuração ou dados fornecidos.");
|
11
18
|
return;
|
12
19
|
}
|
13
20
|
const workbook = XLSX.utils.book_new();
|
14
21
|
// Verifica se múltiplas planilhas estão configuradas
|
15
|
-
if (
|
16
|
-
|
22
|
+
if (sheetConfig.multipleSheets) {
|
23
|
+
sheetConfig.multipleSheets.forEach((sheetConfig) => {
|
17
24
|
const worksheet = XLSX.utils.aoa_to_sheet([]);
|
18
25
|
// Adiciona o título, se houver
|
19
26
|
let startRow = 0;
|
@@ -65,29 +72,29 @@ export class DataExcelExporterComponent {
|
|
65
72
|
const worksheet = XLSX.utils.aoa_to_sheet([]);
|
66
73
|
// Adiciona título, se houver
|
67
74
|
let startRow = 0;
|
68
|
-
if (
|
69
|
-
XLSX.utils.sheet_add_aoa(worksheet, [[
|
75
|
+
if (sheetConfig.title) {
|
76
|
+
XLSX.utils.sheet_add_aoa(worksheet, [[sheetConfig.title]], {
|
70
77
|
origin: "A1",
|
71
78
|
});
|
72
79
|
// Define larguras do título
|
73
|
-
if (
|
74
|
-
worksheet["!cols"] =
|
80
|
+
if (sheetConfig.titleWidths) {
|
81
|
+
worksheet["!cols"] = sheetConfig.titleWidths.map((width) => ({
|
75
82
|
wch: width,
|
76
83
|
}));
|
77
84
|
}
|
78
85
|
// Mescla o título
|
79
|
-
if (
|
86
|
+
if (sheetConfig.tableHeaders) {
|
80
87
|
worksheet["!merges"] = worksheet["!merges"] || [];
|
81
88
|
worksheet["!merges"].push({
|
82
89
|
s: { r: 0, c: 0 },
|
83
|
-
e: { r: 0, c:
|
90
|
+
e: { r: 0, c: sheetConfig.tableHeaders.length - 1 },
|
84
91
|
});
|
85
92
|
}
|
86
93
|
startRow = 1;
|
87
94
|
}
|
88
95
|
// Adiciona cabeçalhos
|
89
|
-
if (
|
90
|
-
XLSX.utils.sheet_add_aoa(worksheet, [
|
96
|
+
if (sheetConfig.tableHeaders) {
|
97
|
+
XLSX.utils.sheet_add_aoa(worksheet, [sheetConfig.tableHeaders], {
|
91
98
|
origin: `A${startRow + 1}`,
|
92
99
|
});
|
93
100
|
}
|
@@ -97,30 +104,32 @@ export class DataExcelExporterComponent {
|
|
97
104
|
skipHeader: true,
|
98
105
|
});
|
99
106
|
// Define larguras das colunas
|
100
|
-
if (
|
101
|
-
worksheet["!cols"] =
|
107
|
+
if (sheetConfig.columnWidths) {
|
108
|
+
worksheet["!cols"] = sheetConfig.columnWidths.map((width) => ({
|
102
109
|
wch: width,
|
103
110
|
}));
|
104
111
|
}
|
105
112
|
// Adiciona a planilha ao workbook
|
106
|
-
XLSX.utils.book_append_sheet(workbook, worksheet,
|
113
|
+
XLSX.utils.book_append_sheet(workbook, worksheet, sheetConfig.sheetName);
|
107
114
|
}
|
108
115
|
// Salva o arquivo Excel
|
109
|
-
XLSX.writeFile(workbook,
|
116
|
+
XLSX.writeFile(workbook, sheetConfig.fileName);
|
110
117
|
}
|
111
118
|
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()">{{
|
119
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DataExcelExporterComponent, selector: "argenta-excel-exporter", inputs: { config: "config", buttonLabel: "buttonLabel", data: "data" }, ngImport: i0, template: `
|
120
|
+
<button (click)="exportToExcel()">{{ buttonLabel }}</button>
|
114
121
|
`, 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
122
|
}
|
116
123
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataExcelExporterComponent, decorators: [{
|
117
124
|
type: Component,
|
118
125
|
args: [{ selector: "argenta-excel-exporter", template: `
|
119
|
-
<button (click)="exportToExcel()">{{
|
126
|
+
<button (click)="exportToExcel()">{{ buttonLabel }}</button>
|
120
127
|
`, 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
128
|
}], propDecorators: { config: [{
|
122
129
|
type: Input
|
130
|
+
}], buttonLabel: [{
|
131
|
+
type: Input
|
123
132
|
}], data: [{
|
124
133
|
type: Input
|
125
134
|
}] } });
|
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"]}
|
135
|
+
//# 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()\">{{ buttonLabel }}</button>\n  `,\n  styleUrls: [\"./data-excel-exporter.component.scss\"],\n})\nexport class DataExcelExporterComponent {\n  @Input() config!: IExcelExportConfig | Promise<IExcelExportConfig>;\n  @Input() buttonLabel!: string\n  @Input() data: any[] = [];\n\n  async exportToExcel(): Promise<void> {\n    let sheetConfig: IExcelExportConfig\n    if (this.config instanceof Promise) {\n      sheetConfig = await this.config;\n    } else {\n      sheetConfig = this.config;\n    }\n\n    if (!this.config || (!this.data.length && !sheetConfig.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 (sheetConfig.multipleSheets) {\n      sheetConfig.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 (sheetConfig.title) {\n        XLSX.utils.sheet_add_aoa(worksheet, [[sheetConfig.title]], {\n          origin: \"A1\",\n        });\n\n        // Define larguras do título\n        if (sheetConfig.titleWidths) {\n          worksheet[\"!cols\"] = sheetConfig.titleWidths.map((width) => ({\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      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 (sheetConfig.columnWidths) {\n        worksheet[\"!cols\"] = sheetConfig.columnWidths.map((width) => ({\n          wch: width,\n        }));\n      }\n\n      // Adiciona a planilha ao workbook\n      XLSX.utils.book_append_sheet(workbook, worksheet, sheetConfig.sheetName!);\n    }\n\n    // Salva o arquivo Excel\n    XLSX.writeFile(workbook, sheetConfig.fileName);\n  }\n}\n"]}
|
@@ -3937,15 +3937,22 @@ class DataExcelExporterComponent {
|
|
3937
3937
|
constructor() {
|
3938
3938
|
this.data = [];
|
3939
3939
|
}
|
3940
|
-
exportToExcel() {
|
3941
|
-
|
3940
|
+
async exportToExcel() {
|
3941
|
+
let sheetConfig;
|
3942
|
+
if (this.config instanceof Promise) {
|
3943
|
+
sheetConfig = await this.config;
|
3944
|
+
}
|
3945
|
+
else {
|
3946
|
+
sheetConfig = this.config;
|
3947
|
+
}
|
3948
|
+
if (!this.config || (!this.data.length && !sheetConfig.multipleSheets)) {
|
3942
3949
|
console.warn("Nenhuma configuração ou dados fornecidos.");
|
3943
3950
|
return;
|
3944
3951
|
}
|
3945
3952
|
const workbook = XLSX.utils.book_new();
|
3946
3953
|
// Verifica se múltiplas planilhas estão configuradas
|
3947
|
-
if (
|
3948
|
-
|
3954
|
+
if (sheetConfig.multipleSheets) {
|
3955
|
+
sheetConfig.multipleSheets.forEach((sheetConfig) => {
|
3949
3956
|
const worksheet = XLSX.utils.aoa_to_sheet([]);
|
3950
3957
|
// Adiciona o título, se houver
|
3951
3958
|
let startRow = 0;
|
@@ -3997,29 +4004,29 @@ class DataExcelExporterComponent {
|
|
3997
4004
|
const worksheet = XLSX.utils.aoa_to_sheet([]);
|
3998
4005
|
// Adiciona título, se houver
|
3999
4006
|
let startRow = 0;
|
4000
|
-
if (
|
4001
|
-
XLSX.utils.sheet_add_aoa(worksheet, [[
|
4007
|
+
if (sheetConfig.title) {
|
4008
|
+
XLSX.utils.sheet_add_aoa(worksheet, [[sheetConfig.title]], {
|
4002
4009
|
origin: "A1",
|
4003
4010
|
});
|
4004
4011
|
// Define larguras do título
|
4005
|
-
if (
|
4006
|
-
worksheet["!cols"] =
|
4012
|
+
if (sheetConfig.titleWidths) {
|
4013
|
+
worksheet["!cols"] = sheetConfig.titleWidths.map((width) => ({
|
4007
4014
|
wch: width,
|
4008
4015
|
}));
|
4009
4016
|
}
|
4010
4017
|
// Mescla o título
|
4011
|
-
if (
|
4018
|
+
if (sheetConfig.tableHeaders) {
|
4012
4019
|
worksheet["!merges"] = worksheet["!merges"] || [];
|
4013
4020
|
worksheet["!merges"].push({
|
4014
4021
|
s: { r: 0, c: 0 },
|
4015
|
-
e: { r: 0, c:
|
4022
|
+
e: { r: 0, c: sheetConfig.tableHeaders.length - 1 },
|
4016
4023
|
});
|
4017
4024
|
}
|
4018
4025
|
startRow = 1;
|
4019
4026
|
}
|
4020
4027
|
// Adiciona cabeçalhos
|
4021
|
-
if (
|
4022
|
-
XLSX.utils.sheet_add_aoa(worksheet, [
|
4028
|
+
if (sheetConfig.tableHeaders) {
|
4029
|
+
XLSX.utils.sheet_add_aoa(worksheet, [sheetConfig.tableHeaders], {
|
4023
4030
|
origin: `A${startRow + 1}`,
|
4024
4031
|
});
|
4025
4032
|
}
|
@@ -4029,29 +4036,31 @@ class DataExcelExporterComponent {
|
|
4029
4036
|
skipHeader: true,
|
4030
4037
|
});
|
4031
4038
|
// Define larguras das colunas
|
4032
|
-
if (
|
4033
|
-
worksheet["!cols"] =
|
4039
|
+
if (sheetConfig.columnWidths) {
|
4040
|
+
worksheet["!cols"] = sheetConfig.columnWidths.map((width) => ({
|
4034
4041
|
wch: width,
|
4035
4042
|
}));
|
4036
4043
|
}
|
4037
4044
|
// Adiciona a planilha ao workbook
|
4038
|
-
XLSX.utils.book_append_sheet(workbook, worksheet,
|
4045
|
+
XLSX.utils.book_append_sheet(workbook, worksheet, sheetConfig.sheetName);
|
4039
4046
|
}
|
4040
4047
|
// Salva o arquivo Excel
|
4041
|
-
XLSX.writeFile(workbook,
|
4048
|
+
XLSX.writeFile(workbook, sheetConfig.fileName);
|
4042
4049
|
}
|
4043
4050
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataExcelExporterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
4044
|
-
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: `
|
4045
|
-
<button (click)="exportToExcel()">{{
|
4051
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DataExcelExporterComponent, selector: "argenta-excel-exporter", inputs: { config: "config", buttonLabel: "buttonLabel", data: "data" }, ngImport: i0, template: `
|
4052
|
+
<button (click)="exportToExcel()">{{ buttonLabel }}</button>
|
4046
4053
|
`, 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"] }); }
|
4047
4054
|
}
|
4048
4055
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataExcelExporterComponent, decorators: [{
|
4049
4056
|
type: Component,
|
4050
4057
|
args: [{ selector: "argenta-excel-exporter", template: `
|
4051
|
-
<button (click)="exportToExcel()">{{
|
4058
|
+
<button (click)="exportToExcel()">{{ buttonLabel }}</button>
|
4052
4059
|
`, 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"] }]
|
4053
4060
|
}], propDecorators: { config: [{
|
4054
4061
|
type: Input
|
4062
|
+
}], buttonLabel: [{
|
4063
|
+
type: Input
|
4055
4064
|
}], data: [{
|
4056
4065
|
type: Input
|
4057
4066
|
}] } });
|