@sachin9822/reports-lib 0.0.72 → 0.0.74
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/esm2020/lib/components/acc-gl-details-enquiry-report/acc-gl-details-enquiry-report.component.mjs +122 -216
- package/esm2020/lib/shared/export.service.mjs +107 -0
- package/fesm2015/sachin9822-reports-lib.mjs +222 -210
- package/fesm2015/sachin9822-reports-lib.mjs.map +1 -1
- package/fesm2020/sachin9822-reports-lib.mjs +222 -213
- package/fesm2020/sachin9822-reports-lib.mjs.map +1 -1
- package/lib/components/acc-gl-details-enquiry-report/acc-gl-details-enquiry-report.component.d.ts +6 -5
- package/lib/shared/export.service.d.ts +18 -0
- package/package.json +1 -1
@@ -0,0 +1,107 @@
|
|
1
|
+
import { Injectable } from '@angular/core';
|
2
|
+
import 'jspdf-autotable';
|
3
|
+
import * as FileSaver from 'file-saver';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
export class ExportService {
|
6
|
+
constructor() { }
|
7
|
+
exportToPdf(headers, rows, doc, startY, fileName) {
|
8
|
+
const columnStyles = {};
|
9
|
+
headers.forEach((_, i) => {
|
10
|
+
columnStyles[i] = { cellWidth: 'auto' };
|
11
|
+
});
|
12
|
+
doc.autoTable({
|
13
|
+
head: [headers],
|
14
|
+
body: rows,
|
15
|
+
startY: startY,
|
16
|
+
theme: 'grid',
|
17
|
+
headStyles: {
|
18
|
+
fillColor: [220, 220, 220],
|
19
|
+
textColor: 0,
|
20
|
+
fontStyle: 'bold',
|
21
|
+
fontSize: 9,
|
22
|
+
halign: 'center',
|
23
|
+
},
|
24
|
+
bodyStyles: {
|
25
|
+
fontSize: 8,
|
26
|
+
fillColor: [255, 255, 255],
|
27
|
+
textColor: [0, 0, 0],
|
28
|
+
},
|
29
|
+
styles: {
|
30
|
+
cellPadding: 2,
|
31
|
+
overflow: 'linebreak',
|
32
|
+
minCellHeight: 6,
|
33
|
+
},
|
34
|
+
columnStyles: columnStyles,
|
35
|
+
});
|
36
|
+
doc.save(fileName);
|
37
|
+
}
|
38
|
+
exportToExcel(headers, rows, worksheet, workbook, fileName) {
|
39
|
+
// Add header row
|
40
|
+
const headerRow = worksheet.addRow(headers);
|
41
|
+
headerRow.font = { bold: true };
|
42
|
+
headerRow.fill = {
|
43
|
+
type: 'pattern',
|
44
|
+
pattern: 'solid',
|
45
|
+
fgColor: { argb: 'D9D9D9' }
|
46
|
+
};
|
47
|
+
headerRow.alignment = { vertical: 'middle', horizontal: 'center' };
|
48
|
+
headerRow.border = {
|
49
|
+
top: { style: 'thin' }, bottom: { style: 'thin' },
|
50
|
+
left: { style: 'thin' }, right: { style: 'thin' }
|
51
|
+
};
|
52
|
+
const dataStartRow = worksheet.lastRow.number + 1;
|
53
|
+
// Add data rows
|
54
|
+
rows.forEach(rowData => {
|
55
|
+
const dataRow = worksheet.addRow(rowData);
|
56
|
+
dataRow.border = {
|
57
|
+
top: { style: 'thin' }, bottom: { style: 'thin' },
|
58
|
+
left: { style: 'thin' }, right: { style: 'thin' }
|
59
|
+
};
|
60
|
+
});
|
61
|
+
const totalColumns = headers.length;
|
62
|
+
// Auto-width for each column
|
63
|
+
for (let i = 1; i <= totalColumns; i++) {
|
64
|
+
let maxLength = 5;
|
65
|
+
const headerVal = headerRow.getCell(i).value?.toString() ?? '';
|
66
|
+
maxLength = Math.max(maxLength, headerVal.length);
|
67
|
+
for (let rowNum = dataStartRow; rowNum <= worksheet.lastRow.number; rowNum++) {
|
68
|
+
const cell = worksheet.getRow(rowNum).getCell(i);
|
69
|
+
const val = cell.value ? cell.value.toString() : '';
|
70
|
+
maxLength = Math.max(maxLength, val.length);
|
71
|
+
}
|
72
|
+
worksheet.getColumn(i).width = maxLength + 2;
|
73
|
+
}
|
74
|
+
// Export as Excel file
|
75
|
+
workbook.xlsx.writeBuffer().then(buffer => {
|
76
|
+
const blob = new Blob([buffer], {
|
77
|
+
type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
|
78
|
+
});
|
79
|
+
FileSaver.saveAs(blob, fileName);
|
80
|
+
});
|
81
|
+
}
|
82
|
+
exportToCsv(headers, rows, metadata = [], fileName) {
|
83
|
+
// Combine metadata + blank line + headers + data
|
84
|
+
const csvContent = [...metadata, [], headers, ...rows]
|
85
|
+
.map(e => e.join(','))
|
86
|
+
.join('\n');
|
87
|
+
this.downloadFile(csvContent, fileName, 'text/csv');
|
88
|
+
}
|
89
|
+
downloadFile(data, filename, type) {
|
90
|
+
const blob = new Blob([data], { type });
|
91
|
+
const link = document.createElement('a');
|
92
|
+
link.href = URL.createObjectURL(blob);
|
93
|
+
link.setAttribute('download', filename);
|
94
|
+
document.body.appendChild(link);
|
95
|
+
link.click();
|
96
|
+
document.body.removeChild(link);
|
97
|
+
}
|
98
|
+
}
|
99
|
+
ExportService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ExportService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
100
|
+
ExportService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ExportService, providedIn: 'root' });
|
101
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ExportService, decorators: [{
|
102
|
+
type: Injectable,
|
103
|
+
args: [{
|
104
|
+
providedIn: 'root'
|
105
|
+
}]
|
106
|
+
}], ctorParameters: function () { return []; } });
|
107
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"export.service.js","sourceRoot":"","sources":["../../../../../projects/reports-lib/src/lib/shared/export.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport jsPDF from 'jspdf';\nimport 'jspdf-autotable';\nimport * as ExcelJS from 'exceljs';\nimport * as FileSaver from 'file-saver';\n\n\ndeclare module 'jspdf' {\n  interface jsPDF {\n    autoTable: (options: any) => jsPDF;\n  }\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ExportService {\n\n  constructor() { }\n\n\n  \n\n  exportToPdf(headers: string[], rows: any[][], doc: jsPDF, startY: number, fileName: string): void {\n    const columnStyles: { [key: number]: any } = {};\n    headers.forEach((_, i) => {\n      columnStyles[i] = { cellWidth: 'auto' };\n    });\n\n    doc.autoTable({\n      head: [headers],\n      body: rows,\n      startY: startY,\n      theme: 'grid',\n      headStyles: {\n        fillColor: [220, 220, 220],\n        textColor: 0,\n        fontStyle: 'bold',\n        fontSize: 9,\n        halign: 'center',\n      },\n      bodyStyles: {\n        fontSize: 8,\n        fillColor: [255, 255, 255],\n        textColor: [0, 0, 0],\n      },\n      styles: {\n        cellPadding: 2,\n        overflow: 'linebreak',\n        minCellHeight: 6,\n      },\n      columnStyles: columnStyles,\n    });\n\n    doc.save(fileName);\n  }\n\n\n\n\n\n  exportToExcel(\n    headers: string[],\n    rows: any[][],\n    worksheet: ExcelJS.Worksheet,\n    workbook: ExcelJS.Workbook,\n    fileName: string\n  ): void {\n    // Add header row\n    const headerRow = worksheet.addRow(headers);\n    headerRow.font = { bold: true };\n    headerRow.fill = {\n      type: 'pattern',\n      pattern: 'solid',\n      fgColor: { argb: 'D9D9D9' }\n    };\n    headerRow.alignment = { vertical: 'middle', horizontal: 'center' };\n    headerRow.border = {\n      top: { style: 'thin' }, bottom: { style: 'thin' },\n      left: { style: 'thin' }, right: { style: 'thin' }\n    };\n\n    const dataStartRow = worksheet.lastRow!.number + 1;\n\n    // Add data rows\n    rows.forEach(rowData => {\n      const dataRow = worksheet.addRow(rowData);\n      dataRow.border = {\n        top: { style: 'thin' }, bottom: { style: 'thin' },\n        left: { style: 'thin' }, right: { style: 'thin' }\n      };\n    });\n\n    const totalColumns = headers.length;\n\n    // Auto-width for each column\n    for (let i = 1; i <= totalColumns; i++) {\n      let maxLength = 5;\n      const headerVal = headerRow.getCell(i).value?.toString() ?? '';\n      maxLength = Math.max(maxLength, headerVal.length);\n\n      for (let rowNum = dataStartRow; rowNum <= worksheet.lastRow!.number; rowNum++) {\n        const cell = worksheet.getRow(rowNum).getCell(i);\n        const val = cell.value ? cell.value.toString() : '';\n        maxLength = Math.max(maxLength, val.length);\n      }\n\n      worksheet.getColumn(i).width = maxLength + 2;\n    }\n\n    // Export as Excel file\n    workbook.xlsx.writeBuffer().then(buffer => {\n      const blob = new Blob([buffer], {\n        type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'\n      });\n      FileSaver.saveAs(blob, fileName);\n    });\n  }\n\n\n\n\n\n\n  exportToCsv(\n    headers: string[],\n    rows: string[][],\n    metadata: string[][] = [],\n    fileName: string\n  ): void {\n    // Combine metadata + blank line + headers + data\n    const csvContent = [...metadata, [], headers, ...rows]\n      .map(e => e.join(','))\n      .join('\\n');\n\n    this.downloadFile(csvContent, fileName, 'text/csv');\n  }\n\n  private downloadFile(data: string, filename: string, type: string): void {\n    const blob = new Blob([data], { type });\n    const link = document.createElement('a');\n    link.href = URL.createObjectURL(blob);\n    link.setAttribute('download', filename);\n    document.body.appendChild(link);\n    link.click();\n    document.body.removeChild(link);\n  }\n\n\n\n\n}\n"]}
|