@sachin9822/reports-lib 0.0.81 → 0.0.83

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.
@@ -7,13 +7,11 @@ export class ReportService {
7
7
  this.http = http;
8
8
  this.errorHandler = errorHandler;
9
9
  this.injector = injector;
10
- this.systemReportUrl = '/api/v1/CompanyConfiguration/SystemReports';
11
10
  this.serviceUrl = "https://4xplus-local.xpressmoney.tech:8752";
12
- this.AccGlDetailsEnquiryReportUrl = "/api/v1/Report/AccGlDetailsEnquiryReport";
13
11
  }
14
12
  getAccGLDetailsReport(formattedDate, dateType, sysCompanyCode, sysUserId, companyName) {
15
13
  if (formattedDate) {
16
- const apiPath = `${this.serviceUrl}${this.AccGlDetailsEnquiryReportUrl}/GetAccGLFDetailsEnquiryReport/${formattedDate}/${dateType}/${sysCompanyCode}/${sysUserId}/${companyName}`;
14
+ const apiPath = `${this.serviceUrl}/api/v1/Report/AccGlDetailsEnquiryReport/GetAccGLFDetailsEnquiryReport/${formattedDate}/${dateType}/${sysCompanyCode}/${sysUserId}/${companyName}`;
17
15
  return this.http.get(apiPath);
18
16
  }
19
17
  else {
@@ -41,4 +39,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
41
39
  providedIn: 'root'
42
40
  }]
43
41
  }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i0.ErrorHandler }, { type: i0.Injector }]; } });
44
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwb3J0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yZXBvcnRzLWxpYi9zcmMvbGliL3NlcnZpY2VzL3JlcG9ydC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBZ0IsVUFBVSxFQUFZLE1BQU0sZUFBZSxDQUFDO0FBRW5FLE9BQU8sRUFBYyxVQUFVLEVBQUUsTUFBTSxNQUFNLENBQUM7OztBQU05QyxNQUFNLE9BQU8sYUFBYTtJQVV4QixZQUFvQixJQUFnQixFQUFVLFlBQTBCLEVBQVUsUUFBa0I7UUFBaEYsU0FBSSxHQUFKLElBQUksQ0FBWTtRQUFVLGlCQUFZLEdBQVosWUFBWSxDQUFjO1FBQVUsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQUo1RixvQkFBZSxHQUFHLDRDQUE0QyxDQUFDO1FBS3JFLElBQUksQ0FBQyxVQUFVLEdBQUcsNENBQTRDLENBQUM7UUFDOUQsSUFBSSxDQUFDLDRCQUE0QixHQUFHLDBDQUEwQyxDQUFDO0lBRWxGLENBQUM7SUFNTSxxQkFBcUIsQ0FBQyxhQUFpQyxFQUFFLFFBQWdCLEVBQUUsY0FBc0IsRUFBRSxTQUFpQixFQUFFLFdBQW1CO1FBRzlJLElBQUksYUFBYSxFQUFFO1lBQ2pCLE1BQU0sT0FBTyxHQUFHLEdBQUcsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsNEJBQTRCLGtDQUFrQyxhQUFhLElBQUksUUFBUSxJQUFJLGNBQWMsSUFBSSxTQUFTLElBQUksV0FBVyxFQUFFLENBQUM7WUFDbEwsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBaUMsT0FBTyxDQUFDLENBQUM7U0FDL0Q7YUFBTTtZQUVMLE1BQU0sV0FBVyxHQUFHLElBQUksSUFBSSxFQUFFLENBQUMsa0JBQWtCLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDM0QsTUFBTSxPQUFPLEdBQUcsNEVBQTRFLFdBQVcscUJBQXFCLENBQUMsQ0FBQywyQ0FBMkM7WUFHekssT0FBTyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztTQUM3QztJQUNILENBQUM7SUFLTSw2QkFBNkI7UUFDbEMsSUFBSSxjQUFjLEdBQUcsY0FBYyxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQzlELElBQUksZUFBZSxHQUFHLGNBQWMsQ0FBQyxPQUFPLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUVoRSxJQUFJLGNBQWMsRUFBRTtZQUNsQixPQUFPLGNBQWMsQ0FBQyxPQUFPLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxDQUFDO1NBQ2pEO2FBQU07WUFDTCxPQUFPLGVBQWUsQ0FBQyxPQUFPLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxDQUFDO1NBQ2xEO0lBR0gsQ0FBQzs7MEdBbERVLGFBQWE7OEdBQWIsYUFBYSxjQUZaLE1BQU07MkZBRVAsYUFBYTtrQkFIekIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgRXJyb3JIYW5kbGVyLCBJbmplY3RhYmxlLCBJbmplY3RvciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWNjR2xEZXRhaWxzRW5xdWlyeVJlcG9ydE1vZGVsIH0gZnJvbSAnLi4vbW9kZWxzL2FjYy1nbC1kZXRhaWxzLWVucXVpcnktcmVwb3J0L2FjY2dsLWRldGFpbHMtZW5xdWlyeS1yZXBvcnRtb2RlbCc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlLCB0aHJvd0Vycm9yIH0gZnJvbSAncnhqcyc7XG5cblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgUmVwb3J0U2VydmljZSB7XG5cblxuXG4gIHByaXZhdGUgc2VydmljZVVybDogc3RyaW5nO1xuICBwcml2YXRlIEFjY0dsRGV0YWlsc0VucXVpcnlSZXBvcnRVcmw6IHN0cmluZztcbiAgcHJpdmF0ZSBzeXN0ZW1SZXBvcnRVcmwgPSAnL2FwaS92MS9Db21wYW55Q29uZmlndXJhdGlvbi9TeXN0ZW1SZXBvcnRzJztcblxuXG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBodHRwOiBIdHRwQ2xpZW50LCBwcml2YXRlIGVycm9ySGFuZGxlcjogRXJyb3JIYW5kbGVyLCBwcml2YXRlIGluamVjdG9yOiBJbmplY3Rvcikge1xuICAgIHRoaXMuc2VydmljZVVybCA9IFwiaHR0cHM6Ly80eHBsdXMtbG9jYWwueHByZXNzbW9uZXkudGVjaDo4NzUyXCI7XG4gICAgIHRoaXMuQWNjR2xEZXRhaWxzRW5xdWlyeVJlcG9ydFVybCA9IFwiL2FwaS92MS9SZXBvcnQvQWNjR2xEZXRhaWxzRW5xdWlyeVJlcG9ydFwiO1xuXG4gIH1cblxuXG5cblxuXG4gIHB1YmxpYyBnZXRBY2NHTERldGFpbHNSZXBvcnQoZm9ybWF0dGVkRGF0ZTogc3RyaW5nIHwgdW5kZWZpbmVkLCBkYXRlVHlwZTogc3RyaW5nLCBzeXNDb21wYW55Q29kZTogc3RyaW5nLCBzeXNVc2VySWQ6IHN0cmluZywgY29tcGFueU5hbWU6IHN0cmluZyk6IE9ic2VydmFibGU8QWNjR2xEZXRhaWxzRW5xdWlyeVJlcG9ydE1vZGVsPiB7XG5cblxuICAgIGlmIChmb3JtYXR0ZWREYXRlKSB7XG4gICAgICBjb25zdCBhcGlQYXRoID0gYCR7dGhpcy5zZXJ2aWNlVXJsfSR7dGhpcy5BY2NHbERldGFpbHNFbnF1aXJ5UmVwb3J0VXJsfS9HZXRBY2NHTEZEZXRhaWxzRW5xdWlyeVJlcG9ydC8ke2Zvcm1hdHRlZERhdGV9LyR7ZGF0ZVR5cGV9LyR7c3lzQ29tcGFueUNvZGV9LyR7c3lzVXNlcklkfS8ke2NvbXBhbnlOYW1lfWA7XG4gICAgICByZXR1cm4gdGhpcy5odHRwLmdldDxBY2NHbERldGFpbHNFbnF1aXJ5UmVwb3J0TW9kZWw+KGFwaVBhdGgpO1xuICAgIH0gZWxzZSB7XG5cbiAgICAgIGNvbnN0IGV4YW1wbGVEYXRlID0gbmV3IERhdGUoKS50b0xvY2FsZURhdGVTdHJpbmcoJ2VuLUdCJyk7XG4gICAgICBjb25zdCBtZXNzYWdlID0gYEludmFsaWQgRGF0ZSBGb3JtYXQhXFxuRGF0ZSBzaG91bGQgYmUgaW4gZGQvTU0veXl5eSBmb3JtYXQuXFxuRm9yIGV4YW1wbGU6ICR7ZXhhbXBsZURhdGV9IGFzIGRheS9tb250aC95ZWFyLmA7IC8vXFxuTm90ZSA6IFllYXIgY2Fubm90IGJlIGdyZWF0ZXIgdGhhbiA5OTk5XG5cblxuICAgICAgcmV0dXJuIHRocm93RXJyb3IoKCkgPT4gbmV3IEVycm9yKG1lc3NhZ2UpKTtcbiAgICB9XG4gIH1cblxuXG5cblxuICBwdWJsaWMgZ2V0VXNlck5hbWVGcm9tU2Vzc2lvblN0b3JhZ2UoKTogc3RyaW5nIHtcbiAgICBsZXQgZm9zc2lsVXNlck5hbWUgPSBzZXNzaW9uU3RvcmFnZS5nZXRJdGVtKCdmb3NzaWx1c2VybmFtZScpO1xuICAgIGxldCBlenJlbWl0dXNlcm5hbWUgPSBzZXNzaW9uU3RvcmFnZS5nZXRJdGVtKCdlenJlbWl0dXNlcm5hbWUnKTtcblxuICAgIGlmIChmb3NzaWxVc2VyTmFtZSkge1xuICAgICAgcmV0dXJuIGZvc3NpbFVzZXJOYW1lLnJlcGxhY2UoL15cIiguKilcIiQvLCAnJDEnKTtcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIGV6cmVtaXR1c2VybmFtZS5yZXBsYWNlKC9eXCIoLiopXCIkLywgJyQxJyk7XG4gICAgfVxuXG5cbiAgfVxuXG5cbn1cbiJdfQ==
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwb3J0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yZXBvcnRzLWxpYi9zcmMvbGliL3NlcnZpY2VzL3JlcG9ydC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBZ0IsVUFBVSxFQUFZLE1BQU0sZUFBZSxDQUFDO0FBRW5FLE9BQU8sRUFBYyxVQUFVLEVBQUUsTUFBTSxNQUFNLENBQUM7OztBQU05QyxNQUFNLE9BQU8sYUFBYTtJQUl4QixZQUFvQixJQUFnQixFQUFVLFlBQTBCLEVBQVUsUUFBa0I7UUFBaEYsU0FBSSxHQUFKLElBQUksQ0FBWTtRQUFVLGlCQUFZLEdBQVosWUFBWSxDQUFjO1FBQVUsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQUNsRyxJQUFJLENBQUMsVUFBVSxHQUFHLDRDQUE0QyxDQUFDO0lBQ2pFLENBQUM7SUFFTSxxQkFBcUIsQ0FBQyxhQUFpQyxFQUFFLFFBQWdCLEVBQUUsY0FBc0IsRUFBRSxTQUFpQixFQUFFLFdBQW1CO1FBQzlJLElBQUksYUFBYSxFQUFFO1lBQ2pCLE1BQU0sT0FBTyxHQUFHLEdBQUcsSUFBSSxDQUFDLFVBQVUsMEVBQTBFLGFBQWEsSUFBSSxRQUFRLElBQUksY0FBYyxJQUFJLFNBQVMsSUFBSSxXQUFXLEVBQUUsQ0FBQztZQUN0TCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFpQyxPQUFPLENBQUMsQ0FBQztTQUMvRDthQUFNO1lBRUwsTUFBTSxXQUFXLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUMzRCxNQUFNLE9BQU8sR0FBRyw0RUFBNEUsV0FBVyxxQkFBcUIsQ0FBQyxDQUFDLDJDQUEyQztZQUN6SyxPQUFPLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1NBQzdDO0lBQ0gsQ0FBQztJQUVNLDZCQUE2QjtRQUNsQyxJQUFJLGNBQWMsR0FBRyxjQUFjLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDOUQsSUFBSSxlQUFlLEdBQUcsY0FBYyxDQUFDLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1FBRWhFLElBQUksY0FBYyxFQUFFO1lBQ2xCLE9BQU8sY0FBYyxDQUFDLE9BQU8sQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUM7U0FDakQ7YUFBTTtZQUNMLE9BQU8sZUFBZSxDQUFDLE9BQU8sQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUM7U0FDbEQ7SUFDSCxDQUFDOzswR0E3QlUsYUFBYTs4R0FBYixhQUFhLGNBRlosTUFBTTsyRkFFUCxhQUFhO2tCQUh6QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBFcnJvckhhbmRsZXIsIEluamVjdGFibGUsIEluamVjdG9yIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBY2NHbERldGFpbHNFbnF1aXJ5UmVwb3J0TW9kZWwgfSBmcm9tICcuLi9tb2RlbHMvYWNjLWdsLWRldGFpbHMtZW5xdWlyeS1yZXBvcnQvYWNjZ2wtZGV0YWlscy1lbnF1aXJ5LXJlcG9ydG1vZGVsJztcbmltcG9ydCB7IE9ic2VydmFibGUsIHRocm93RXJyb3IgfSBmcm9tICdyeGpzJztcblxuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBSZXBvcnRTZXJ2aWNlIHtcblxuICBwcml2YXRlIHNlcnZpY2VVcmw6IHN0cmluZztcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGh0dHA6IEh0dHBDbGllbnQsIHByaXZhdGUgZXJyb3JIYW5kbGVyOiBFcnJvckhhbmRsZXIsIHByaXZhdGUgaW5qZWN0b3I6IEluamVjdG9yKSB7XG4gICAgdGhpcy5zZXJ2aWNlVXJsID0gXCJodHRwczovLzR4cGx1cy1sb2NhbC54cHJlc3Ntb25leS50ZWNoOjg3NTJcIjtcbiAgfVxuXG4gIHB1YmxpYyBnZXRBY2NHTERldGFpbHNSZXBvcnQoZm9ybWF0dGVkRGF0ZTogc3RyaW5nIHwgdW5kZWZpbmVkLCBkYXRlVHlwZTogc3RyaW5nLCBzeXNDb21wYW55Q29kZTogc3RyaW5nLCBzeXNVc2VySWQ6IHN0cmluZywgY29tcGFueU5hbWU6IHN0cmluZyk6IE9ic2VydmFibGU8QWNjR2xEZXRhaWxzRW5xdWlyeVJlcG9ydE1vZGVsPiB7XG4gICAgaWYgKGZvcm1hdHRlZERhdGUpIHtcbiAgICAgIGNvbnN0IGFwaVBhdGggPSBgJHt0aGlzLnNlcnZpY2VVcmx9L2FwaS92MS9SZXBvcnQvQWNjR2xEZXRhaWxzRW5xdWlyeVJlcG9ydC9HZXRBY2NHTEZEZXRhaWxzRW5xdWlyeVJlcG9ydC8ke2Zvcm1hdHRlZERhdGV9LyR7ZGF0ZVR5cGV9LyR7c3lzQ29tcGFueUNvZGV9LyR7c3lzVXNlcklkfS8ke2NvbXBhbnlOYW1lfWA7XG4gICAgICByZXR1cm4gdGhpcy5odHRwLmdldDxBY2NHbERldGFpbHNFbnF1aXJ5UmVwb3J0TW9kZWw+KGFwaVBhdGgpO1xuICAgIH0gZWxzZSB7XG5cbiAgICAgIGNvbnN0IGV4YW1wbGVEYXRlID0gbmV3IERhdGUoKS50b0xvY2FsZURhdGVTdHJpbmcoJ2VuLUdCJyk7XG4gICAgICBjb25zdCBtZXNzYWdlID0gYEludmFsaWQgRGF0ZSBGb3JtYXQhXFxuRGF0ZSBzaG91bGQgYmUgaW4gZGQvTU0veXl5eSBmb3JtYXQuXFxuRm9yIGV4YW1wbGU6ICR7ZXhhbXBsZURhdGV9IGFzIGRheS9tb250aC95ZWFyLmA7IC8vXFxuTm90ZSA6IFllYXIgY2Fubm90IGJlIGdyZWF0ZXIgdGhhbiA5OTk5XG4gICAgICByZXR1cm4gdGhyb3dFcnJvcigoKSA9PiBuZXcgRXJyb3IobWVzc2FnZSkpO1xuICAgIH1cbiAgfVxuXG4gIHB1YmxpYyBnZXRVc2VyTmFtZUZyb21TZXNzaW9uU3RvcmFnZSgpIDogc3RyaW5nIHtcbiAgICBsZXQgZm9zc2lsVXNlck5hbWUgPSBzZXNzaW9uU3RvcmFnZS5nZXRJdGVtKCdmb3NzaWx1c2VybmFtZScpO1xuICAgIGxldCBlenJlbWl0dXNlcm5hbWUgPSBzZXNzaW9uU3RvcmFnZS5nZXRJdGVtKCdlenJlbWl0dXNlcm5hbWUnKTtcblxuICAgIGlmIChmb3NzaWxVc2VyTmFtZSkge1xuICAgICAgcmV0dXJuIGZvc3NpbFVzZXJOYW1lLnJlcGxhY2UoL15cIiguKilcIiQvLCAnJDEnKTtcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIGV6cmVtaXR1c2VybmFtZS5yZXBsYWNlKC9eXCIoLiopXCIkLywgJyQxJyk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -1,77 +1,203 @@
1
1
  import { Injectable } from '@angular/core';
2
+ import jsPDF from 'jspdf';
2
3
  import 'jspdf-autotable';
4
+ import * as ExcelJS from 'exceljs';
3
5
  import * as FileSaver from 'file-saver';
4
6
  import * as i0 from "@angular/core";
5
7
  export class ExportService {
6
- constructor() { }
7
- exportToPdf(headers, rows, doc, startY, fileName) {
8
- const columnStyles = {};
9
- headers.forEach((_, i) => {
10
- columnStyles[i] = { cellWidth: 'auto' };
8
+ constructor() {
9
+ this.pdfFontSize = 10;
10
+ this.pdfLineHeight = 7;
11
+ this.pdfLeftMargin = 15;
12
+ this.loadImageAsBase64('assets/images/XMLogo.png').then(base64 => {
13
+ this.logoBase64 = base64;
14
+ });
15
+ }
16
+ // ------------------------ Utility ------------------------
17
+ loadImageAsBase64(imagePath) {
18
+ return new Promise((resolve, reject) => {
19
+ const img = new Image();
20
+ img.crossOrigin = 'anonymous';
21
+ img.src = imagePath;
22
+ img.onload = () => {
23
+ const scale = 6;
24
+ const canvas = document.createElement('canvas');
25
+ canvas.width = img.width * scale;
26
+ canvas.height = img.height * scale;
27
+ const ctx = canvas.getContext('2d');
28
+ if (ctx) {
29
+ ctx.scale(scale, scale);
30
+ ctx.drawImage(img, 0, 0);
31
+ const base64 = canvas.toDataURL('image/png', 1.0); // 1.0 = highest quality
32
+ resolve(base64);
33
+ }
34
+ else {
35
+ reject('Failed to get canvas context.');
36
+ }
37
+ };
38
+ img.onerror = () => reject('Failed to load image: ' + imagePath);
39
+ });
40
+ }
41
+ formatDate(value) {
42
+ const date = new Date(value);
43
+ return isNaN(date.getTime()) ? '' :
44
+ `${date.getDate().toString().padStart(2, '0')}/${(date.getMonth() + 1).toString().padStart(2, '0')}/${date.getFullYear()}`;
45
+ }
46
+ formatDateTime(date) {
47
+ return `${date.getDate().toString().padStart(2, '0')}/` +
48
+ `${(date.getMonth() + 1).toString().padStart(2, '0')}/` +
49
+ `${date.getFullYear()} ` +
50
+ `${date.getHours().toString().padStart(2, '0')}:` +
51
+ `${date.getMinutes().toString().padStart(2, '0')}`;
52
+ }
53
+ generateReportMetadata(metadata) {
54
+ return metadata.filter(([_, value]) => value !== undefined && value !== null);
55
+ }
56
+ prepareExportTable(data, columnDefs, options = {}) {
57
+ const { excludeFields = ['srno', 'serial', 'action'], currencyFields = [] } = options;
58
+ const filteredColumns = columnDefs.filter(col => col.field &&
59
+ !excludeFields.some(ex => col.field.toLowerCase().includes(ex)) &&
60
+ !excludeFields.some(ex => col.headerName?.toLowerCase().includes(ex)));
61
+ const headers = ['Sr No', ...filteredColumns.map(col => col.headerName || col.field)];
62
+ const rows = data.map((row, index) => {
63
+ const rowData = filteredColumns.map(col => {
64
+ let value = row[col.field];
65
+ const fieldName = col.field?.toLowerCase() || '';
66
+ // Handle various date field names
67
+ if ((fieldName.includes('date') ||
68
+ fieldName.includes('businessdate')) &&
69
+ value) {
70
+ value = this.formatDate(value);
71
+ }
72
+ // Format currency fields
73
+ if (currencyFields.includes(col.field) && value != null) {
74
+ value = parseFloat(value).toFixed(3);
75
+ }
76
+ return value ?? '';
77
+ });
78
+ return [index + 1, ...rowData];
79
+ });
80
+ return { headers, rows };
81
+ }
82
+ // ------------------------ PDF Universal ------------------------
83
+ async exportToPdfUniversal(title, metadata, headers, rows, fileName) {
84
+ const doc = new jsPDF({ orientation: 'landscape', unit: 'mm', format: [400, 210] });
85
+ const logoWidth = 38.4, logoHeight = 17.5, logoX = 15, logoY = 10;
86
+ const pageWidth = doc.internal.pageSize.width;
87
+ const titleY = 18;
88
+ if (this.logoBase64) {
89
+ doc.addImage(this.logoBase64, 'PNG', logoX, logoY, logoWidth, logoHeight);
90
+ }
91
+ doc.setFontSize(15);
92
+ doc.setFont('helvetica', 'bold');
93
+ doc.text(title, pageWidth / 2, titleY, { align: 'center' });
94
+ let currentY = titleY + 14;
95
+ doc.setFontSize(this.pdfFontSize);
96
+ metadata.forEach(([label, value], i) => {
97
+ const y = currentY + i * this.pdfLineHeight;
98
+ doc.setFont('helvetica', 'bold');
99
+ doc.text(label, this.pdfLeftMargin, y);
100
+ const labelWidth = doc.getTextWidth(label + ' ');
101
+ doc.setFont('helvetica', 'normal');
102
+ doc.text(value, this.pdfLeftMargin + labelWidth, y);
11
103
  });
104
+ currentY += metadata.length * this.pdfLineHeight + 5;
105
+ const columnStyles = {};
106
+ headers.forEach((_, i) => columnStyles[i] = { cellWidth: 'auto' });
12
107
  doc.autoTable({
13
108
  head: [headers],
14
109
  body: rows,
15
- startY: startY,
110
+ startY: currentY,
16
111
  theme: 'grid',
17
112
  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,
113
+ fillColor: [220, 220, 220], textColor: 0,
114
+ fontStyle: 'bold', fontSize: 9, halign: 'center',
33
115
  },
34
- columnStyles: columnStyles,
116
+ bodyStyles: { fontSize: 8, fillColor: [255, 255, 255], textColor: [0, 0, 0] },
117
+ styles: { cellPadding: 2, overflow: 'linebreak', minCellHeight: 6 },
118
+ columnStyles
35
119
  });
36
120
  doc.save(fileName);
37
121
  }
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' }
122
+ // ------------------------ Excel Universal ------------------------
123
+ exportToExcelUniversal(title, metadata, headers, rows, fileName) {
124
+ const workbook = new ExcelJS.Workbook();
125
+ const worksheet = workbook.addWorksheet(title);
126
+ let currentRow = 1;
127
+ // Add image if available
128
+ if (this.logoBase64) {
129
+ const base64Data = this.logoBase64.replace(/^data:image\/\w+;base64,/, '');
130
+ const imageId = workbook.addImage({
131
+ base64: base64Data,
132
+ extension: 'png',
133
+ });
134
+ // Place image at top-left (e.g., A1:C4)
135
+ worksheet.addImage(imageId, {
136
+ tl: { col: 0, row: 0 },
137
+ ext: { width: 145, height: 66 },
138
+ editAs: 'oneCell'
139
+ });
140
+ }
141
+ // Add title aligned in middle horizontally (merged across all columns)
142
+ const titleRow = worksheet.getRow(currentRow);
143
+ titleRow.getCell(4).value = title;
144
+ titleRow.getCell(4).font = { bold: true, size: 16 };
145
+ titleRow.getCell(4).alignment = { vertical: 'middle', horizontal: 'left' };
146
+ const titleMergeEnd = String.fromCharCode(64 + headers.length);
147
+ worksheet.mergeCells(`D${currentRow}:${titleMergeEnd}${currentRow}`);
148
+ currentRow += 3; // Move past image space
149
+ // Add metadata
150
+ metadata.forEach(([label, value]) => {
151
+ const row = worksheet.getRow(currentRow++);
152
+ const cell = row.getCell(1);
153
+ cell.value = {
154
+ richText: [
155
+ { text: `${label}: `, font: { bold: true } },
156
+ { text: value ?? '', font: { bold: false } }
157
+ ]
158
+ };
159
+ worksheet.mergeCells(`A${row.number}:${String.fromCharCode(64 + headers.length)}${row.number}`);
160
+ });
161
+ worksheet.addRow([]);
162
+ currentRow++;
163
+ // Add table header row
164
+ const headerRow = worksheet.getRow(currentRow++);
165
+ headers.forEach((header, i) => {
166
+ const cell = headerRow.getCell(i + 1);
167
+ cell.value = header;
168
+ cell.font = { bold: true };
169
+ cell.fill = { type: 'pattern', pattern: 'solid', fgColor: { argb: 'D9D9D9' } };
170
+ cell.alignment = { vertical: 'middle', horizontal: 'center' };
171
+ cell.border = {
172
+ top: { style: 'thin' },
173
+ bottom: { style: 'thin' },
174
+ left: { style: 'thin' },
175
+ right: { style: 'thin' }
59
176
  };
60
177
  });
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);
178
+ const dataStartRow = currentRow;
179
+ rows.forEach(rowData => {
180
+ const row = worksheet.getRow(currentRow++);
181
+ rowData.forEach((value, i) => {
182
+ const cell = row.getCell(i + 1);
183
+ cell.value = value;
184
+ cell.border = {
185
+ top: { style: 'thin' },
186
+ bottom: { style: 'thin' },
187
+ left: { style: 'thin' },
188
+ right: { style: 'thin' }
189
+ };
190
+ });
191
+ });
192
+ // Auto column widths
193
+ for (let i = 1; i <= headers.length; i++) {
194
+ let maxLength = headers[i - 1].length;
67
195
  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() : '';
196
+ const val = worksheet.getRow(rowNum).getCell(i).value?.toString() || '';
70
197
  maxLength = Math.max(maxLength, val.length);
71
198
  }
72
199
  worksheet.getColumn(i).width = maxLength + 2;
73
200
  }
74
- // Export as Excel file
75
201
  workbook.xlsx.writeBuffer().then(buffer => {
76
202
  const blob = new Blob([buffer], {
77
203
  type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
@@ -79,11 +205,16 @@ export class ExportService {
79
205
  FileSaver.saveAs(blob, fileName);
80
206
  });
81
207
  }
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');
208
+ // ------------------------ CSV Universal ------------------------
209
+ exportToCsvUniversal(title, metadata, headers, rows, fileName) {
210
+ const metaRows = metadata.map(([k, v]) => [`${k}: ${v}`]);
211
+ const csvContent = [
212
+ [title],
213
+ ...metaRows,
214
+ [],
215
+ headers,
216
+ ...rows.map(row => row.map(value => `"${value}"`))
217
+ ].map(e => e.join(',')).join('\n');
87
218
  this.downloadFile(csvContent, fileName, 'text/csv');
88
219
  }
89
220
  downloadFile(data, filename, type) {
@@ -104,4 +235,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
104
235
  providedIn: 'root'
105
236
  }]
106
237
  }], 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"]}
238
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"export.service.js","sourceRoot":"","sources":["../../../../../projects/reports-lib/src/lib/shared/export.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,iBAAiB,CAAC;AACzB,OAAO,KAAK,OAAO,MAAM,SAAS,CAAC;AACnC,OAAO,KAAK,SAAS,MAAM,YAAY,CAAC;;AAYxC,MAAM,OAAO,aAAa;IAOxB;QALiB,gBAAW,GAAG,EAAE,CAAC;QACjB,kBAAa,GAAG,CAAC,CAAC;QAClB,kBAAa,GAAG,EAAE,CAAC;QAIlC,IAAI,CAAC,iBAAiB,CAAC,0BAA0B,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;YAC/D,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;QAC3B,CAAC,CAAC,CAAC;IACL,CAAC;IAED,4DAA4D;IACpD,iBAAiB,CAAC,SAAiB;QACzC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,MAAM,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;YACxB,GAAG,CAAC,WAAW,GAAG,WAAW,CAAC;YAC9B,GAAG,CAAC,GAAG,GAAG,SAAS,CAAC;YAEpB,GAAG,CAAC,MAAM,GAAG,GAAG,EAAE;gBAChB,MAAM,KAAK,GAAG,CAAC,CAAC;gBAChB,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;gBAChD,MAAM,CAAC,KAAK,GAAG,GAAG,CAAC,KAAK,GAAG,KAAK,CAAC;gBACjC,MAAM,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,GAAG,KAAK,CAAC;gBAEnC,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;gBACpC,IAAI,GAAG,EAAE;oBACP,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;oBACxB,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;oBACzB,MAAM,MAAM,GAAG,MAAM,CAAC,SAAS,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC,CAAC,wBAAwB;oBAC3E,OAAO,CAAC,MAAM,CAAC,CAAC;iBACjB;qBAAM;oBACL,MAAM,CAAC,+BAA+B,CAAC,CAAC;iBACzC;YACH,CAAC,CAAC;YAEF,GAAG,CAAC,OAAO,GAAG,GAAG,EAAE,CAAC,MAAM,CAAC,wBAAwB,GAAG,SAAS,CAAC,CAAC;QACnE,CAAC,CAAC,CAAC;IACL,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7B,OAAO,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YACjC,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;IAC/H,CAAC;IACD,cAAc,CAAC,IAAU;QACvB,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG;YACrD,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG;YACvD,GAAG,IAAI,CAAC,WAAW,EAAE,GAAG;YACxB,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG;YACjD,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;IACvD,CAAC;IAED,sBAAsB,CAAC,QAA4B;QACjD,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,CAAC,CAAC;IAChF,CAAC;IAED,kBAAkB,CAAC,IAAW,EAAE,UAAiB,EAAE,UAG/C,EAAE;QACJ,MAAM,EAAE,aAAa,GAAG,CAAC,MAAM,EAAE,QAAQ,EAAE,QAAQ,CAAC,EAAE,cAAc,GAAG,EAAE,EAAE,GAAG,OAAO,CAAC;QAEtF,MAAM,eAAe,GAAG,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAC9C,GAAG,CAAC,KAAK;YACT,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YAC/D,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,UAAU,EAAE,WAAW,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CACtE,CAAC;QAEF,MAAM,OAAO,GAAG,CAAC,OAAO,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,UAAU,IAAI,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;QAEtF,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;YACnC,MAAM,OAAO,GAAG,eAAe,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;gBACxC,IAAI,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBAC3B,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;gBAEjD,kCAAkC;gBAClC,IACE,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC;oBACzB,SAAS,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;oBACrC,KAAK,EACL;oBACA,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;iBAChC;gBAED,yBAAyB;gBACzB,IAAI,cAAc,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,KAAK,IAAI,IAAI,EAAE;oBACvD,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;iBACtC;gBACD,OAAO,KAAK,IAAI,EAAE,CAAC;YACrB,CAAC,CAAC,CAAC;YACH,OAAO,CAAC,KAAK,GAAG,CAAC,EAAE,GAAG,OAAO,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;QACH,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IAC3B,CAAC;IAED,kEAAkE;IAClE,KAAK,CAAC,oBAAoB,CAAC,KAAa,EAAE,QAA4B,EAAE,OAAiB,EAAE,IAAa,EAAE,QAAgB;QACxH,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,EAAE,WAAW,EAAE,WAAW,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC;QAEpF,MAAM,SAAS,GAAG,IAAI,EAAE,UAAU,GAAG,IAAI,EAAE,KAAK,GAAG,EAAE,EAAE,KAAK,GAAG,EAAE,CAAC;QAClE,MAAM,SAAS,GAAG,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC;QAC9C,MAAM,MAAM,GAAG,EAAE,CAAC;QAElB,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;SAC3E;QAED,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;QACpB,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;QACjC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,SAAS,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;QAE5D,IAAI,QAAQ,GAAG,MAAM,GAAG,EAAE,CAAC;QAC3B,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAClC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,EAAE,CAAC,EAAE,EAAE;YACrC,MAAM,CAAC,GAAG,QAAQ,GAAG,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC;YAC5C,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;YACjC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;YACvC,MAAM,UAAU,GAAG,GAAG,CAAC,YAAY,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC;YACjD,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YACnC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,aAAa,GAAG,UAAU,EAAE,CAAC,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;QACH,QAAQ,IAAI,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QAErD,MAAM,YAAY,GAA2B,EAAE,CAAC;QAChD,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,GAAG,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAC;QAEnE,GAAG,CAAC,SAAS,CAAC;YACZ,IAAI,EAAE,CAAC,OAAO,CAAC;YACf,IAAI,EAAE,IAAI;YACV,MAAM,EAAE,QAAQ;YAChB,KAAK,EAAE,MAAM;YACb,UAAU,EAAE;gBACV,SAAS,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,SAAS,EAAE,CAAC;gBACxC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,EAAE,MAAM,EAAE,QAAQ;aACjD;YACD,UAAU,EAAE,EAAE,QAAQ,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE;YAC7E,MAAM,EAAE,EAAE,WAAW,EAAE,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,EAAE;YACnE,YAAY;SACb,CAAC,CAAC;QAEH,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACrB,CAAC;IAED,oEAAoE;IACpE,sBAAsB,CAAC,KAAa,EAAE,QAA4B,EAAE,OAAiB,EAAE,IAAa,EAAE,QAAgB;QACpH,MAAM,QAAQ,GAAG,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;QACxC,MAAM,SAAS,GAAG,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAE/C,IAAI,UAAU,GAAG,CAAC,CAAC;QAEnB,yBAAyB;QACzB,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,0BAA0B,EAAE,EAAE,CAAC,CAAC;YAC3E,MAAM,OAAO,GAAG,QAAQ,CAAC,QAAQ,CAAC;gBAChC,MAAM,EAAE,UAAU;gBAClB,SAAS,EAAE,KAAK;aACjB,CAAC,CAAC;YAEH,wCAAwC;YACxC,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE;gBAC1B,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE;gBACtB,GAAG,EAAE,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,EAAE,EAAE;gBAC/B,MAAM,EAAE,SAAS;aAClB,CAAC,CAAC;SACJ;QAED,uEAAuE;QACvE,MAAM,QAAQ,GAAG,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QAC9C,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,KAAK,CAAC;QAClC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC;QACpD,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,EAAE,QAAQ,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC;QAE3E,MAAM,aAAa,GAAG,MAAM,CAAC,YAAY,CAAC,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;QAC/D,SAAS,CAAC,UAAU,CAAC,IAAI,UAAU,IAAI,aAAa,GAAG,UAAU,EAAE,CAAC,CAAC;QACrE,UAAU,IAAI,CAAC,CAAC,CAAC,wBAAwB;QAEzC,eAAe;QACf,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,EAAE,EAAE;YAClC,MAAM,GAAG,GAAG,SAAS,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC,CAAC;YAC3C,MAAM,IAAI,GAAG,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAC5B,IAAI,CAAC,KAAK,GAAG;gBACX,QAAQ,EAAE;oBACR,EAAE,IAAI,EAAE,GAAG,KAAK,IAAI,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE;oBAC5C,EAAE,IAAI,EAAE,KAAK,IAAI,EAAE,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE;iBAC7C;aACF,CAAC;YACF,SAAS,CAAC,UAAU,CAAC,IAAI,GAAG,CAAC,MAAM,IAAI,MAAM,CAAC,YAAY,CAAC,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC;QAClG,CAAC,CAAC,CAAC;QAEH,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACrB,UAAU,EAAE,CAAC;QAEb,uBAAuB;QACvB,MAAM,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC,CAAC;QACjD,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC5B,MAAM,IAAI,GAAG,SAAS,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YACtC,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC;YACpB,IAAI,CAAC,IAAI,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;YAC3B,IAAI,CAAC,IAAI,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,CAAC;YAC/E,IAAI,CAAC,SAAS,GAAG,EAAE,QAAQ,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC;YAC9D,IAAI,CAAC,MAAM,GAAG;gBACZ,GAAG,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;gBACtB,MAAM,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;gBACzB,IAAI,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;gBACvB,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;aACzB,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,MAAM,YAAY,GAAG,UAAU,CAAC;QAChC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;YACrB,MAAM,GAAG,GAAG,SAAS,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC,CAAC;YAC3C,OAAO,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;gBAC3B,MAAM,IAAI,GAAG,GAAG,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;gBAChC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;gBACnB,IAAI,CAAC,MAAM,GAAG;oBACZ,GAAG,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;oBACtB,MAAM,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;oBACzB,IAAI,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;oBACvB,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE;iBACzB,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,qBAAqB;QACrB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACxC,IAAI,SAAS,GAAG,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC;YACtC,KAAK,IAAI,MAAM,GAAG,YAAY,EAAE,MAAM,IAAI,SAAS,CAAC,OAAQ,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE;gBAC7E,MAAM,GAAG,GAAG,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;gBACxE,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;aAC7C;YACD,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,SAAS,GAAG,CAAC,CAAC;SAC9C;QAED,QAAQ,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;YACxC,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,MAAM,CAAC,EAAE;gBAC9B,IAAI,EAAE,mEAAmE;aAC1E,CAAC,CAAC;YACH,SAAS,CAAC,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QACnC,CAAC,CAAC,CAAC;IACL,CAAC;IAGD,kEAAkE;IAClE,oBAAoB,CAAC,KAAa,EAAE,QAA4B,EAAE,OAAiB,EAAE,IAAa,EAAE,QAAgB;QAClH,MAAM,QAAQ,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1D,MAAM,UAAU,GAAG;YACjB,CAAC,KAAK,CAAC;YACP,GAAG,QAAQ;YACX,EAAE;YACF,OAAO;YACP,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,KAAK,GAAG,CAAC,CAAC;SACnD,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEnC,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC;IACtD,CAAC;IAEO,YAAY,CAAC,IAAY,EAAE,QAAgB,EAAE,IAAY;QAC/D,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC;QACxC,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;QACzC,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;QACxC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAChC,IAAI,CAAC,KAAK,EAAE,CAAC;QACb,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;;0GA1QU,aAAa;8GAAb,aAAa,cAFZ,MAAM;2FAEP,aAAa;kBAHzB,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","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  private readonly pdfFontSize = 10;\n  private readonly pdfLineHeight = 7;\n  private readonly pdfLeftMargin = 15;\n  private logoBase64: string | undefined;\n\n  constructor() {\n    this.loadImageAsBase64('assets/images/XMLogo.png').then(base64 => {\n      this.logoBase64 = base64;\n    });\n  }\n\n  // ------------------------ Utility ------------------------\n  private loadImageAsBase64(imagePath: string): Promise<string> {\n    return new Promise((resolve, reject) => {\n      const img = new Image();\n      img.crossOrigin = 'anonymous';\n      img.src = imagePath;\n\n      img.onload = () => {\n        const scale = 6;\n        const canvas = document.createElement('canvas');\n        canvas.width = img.width * scale;\n        canvas.height = img.height * scale;\n\n        const ctx = canvas.getContext('2d');\n        if (ctx) {\n          ctx.scale(scale, scale);\n          ctx.drawImage(img, 0, 0);\n          const base64 = canvas.toDataURL('image/png', 1.0); // 1.0 = highest quality\n          resolve(base64);\n        } else {\n          reject('Failed to get canvas context.');\n        }\n      };\n\n      img.onerror = () => reject('Failed to load image: ' + imagePath);\n    });\n  }\n\n  formatDate(value: any): string {\n    const date = new Date(value);\n    return isNaN(date.getTime()) ? '' :\n      `${date.getDate().toString().padStart(2, '0')}/${(date.getMonth() + 1).toString().padStart(2, '0')}/${date.getFullYear()}`;\n  }\n  formatDateTime(date: Date): string {\n    return `${date.getDate().toString().padStart(2, '0')}/` +\n      `${(date.getMonth() + 1).toString().padStart(2, '0')}/` +\n      `${date.getFullYear()} ` +\n      `${date.getHours().toString().padStart(2, '0')}:` +\n      `${date.getMinutes().toString().padStart(2, '0')}`;\n  }\n\n  generateReportMetadata(metadata: [string, string][]): [string, string][] {\n    return metadata.filter(([_, value]) => value !== undefined && value !== null);\n  }\n\n  prepareExportTable(data: any[], columnDefs: any[], options: {\n    excludeFields?: string[],\n    currencyFields?: string[]\n  } = {}): { headers: string[], rows: any[][] } {\n    const { excludeFields = ['srno', 'serial', 'action'], currencyFields = [] } = options;\n\n    const filteredColumns = columnDefs.filter(col =>\n      col.field &&\n      !excludeFields.some(ex => col.field.toLowerCase().includes(ex)) &&\n      !excludeFields.some(ex => col.headerName?.toLowerCase().includes(ex))\n    );\n\n    const headers = ['Sr No', ...filteredColumns.map(col => col.headerName || col.field)];\n\n    const rows = data.map((row, index) => {\n      const rowData = filteredColumns.map(col => {\n        let value = row[col.field];\n        const fieldName = col.field?.toLowerCase() || '';\n\n        // Handle various date field names\n        if (\n          (fieldName.includes('date') ||\n            fieldName.includes('businessdate')) &&\n          value\n        ) {\n          value = this.formatDate(value);\n        }\n\n        // Format currency fields\n        if (currencyFields.includes(col.field) && value != null) {\n          value = parseFloat(value).toFixed(3);\n        }\n        return value ?? '';\n      });\n      return [index + 1, ...rowData];\n    });\n    return { headers, rows };\n  }\n\n  // ------------------------ PDF Universal ------------------------\n  async exportToPdfUniversal(title: string, metadata: [string, string][], headers: string[], rows: any[][], fileName: string): Promise<void> {\n    const doc = new jsPDF({ orientation: 'landscape', unit: 'mm', format: [400, 210] });\n\n    const logoWidth = 38.4, logoHeight = 17.5, logoX = 15, logoY = 10;\n    const pageWidth = doc.internal.pageSize.width;\n    const titleY = 18;\n\n    if (this.logoBase64) {\n      doc.addImage(this.logoBase64, 'PNG', logoX, logoY, logoWidth, logoHeight);\n    }\n\n    doc.setFontSize(15);\n    doc.setFont('helvetica', 'bold');\n    doc.text(title, pageWidth / 2, titleY, { align: 'center' });\n\n    let currentY = titleY + 14;\n    doc.setFontSize(this.pdfFontSize);\n    metadata.forEach(([label, value], i) => {\n      const y = currentY + i * this.pdfLineHeight;\n      doc.setFont('helvetica', 'bold');\n      doc.text(label, this.pdfLeftMargin, y);\n      const labelWidth = doc.getTextWidth(label + ' ');\n      doc.setFont('helvetica', 'normal');\n      doc.text(value, this.pdfLeftMargin + labelWidth, y);\n    });\n    currentY += metadata.length * this.pdfLineHeight + 5;\n\n    const columnStyles: { [key: number]: any } = {};\n    headers.forEach((_, i) => columnStyles[i] = { cellWidth: 'auto' });\n\n    doc.autoTable({\n      head: [headers],\n      body: rows,\n      startY: currentY,\n      theme: 'grid',\n      headStyles: {\n        fillColor: [220, 220, 220], textColor: 0,\n        fontStyle: 'bold', fontSize: 9, halign: 'center',\n      },\n      bodyStyles: { fontSize: 8, fillColor: [255, 255, 255], textColor: [0, 0, 0] },\n      styles: { cellPadding: 2, overflow: 'linebreak', minCellHeight: 6 },\n      columnStyles\n    });\n\n    doc.save(fileName);\n  }\n\n  // ------------------------ Excel Universal ------------------------\n  exportToExcelUniversal(title: string, metadata: [string, string][], headers: string[], rows: any[][], fileName: string): void {\n    const workbook = new ExcelJS.Workbook();\n    const worksheet = workbook.addWorksheet(title);\n\n    let currentRow = 1;\n\n    // Add image if available\n    if (this.logoBase64) {\n      const base64Data = this.logoBase64.replace(/^data:image\\/\\w+;base64,/, '');\n      const imageId = workbook.addImage({\n        base64: base64Data,\n        extension: 'png',\n      });\n\n      // Place image at top-left (e.g., A1:C4)\n      worksheet.addImage(imageId, {\n        tl: { col: 0, row: 0 },\n        ext: { width: 145, height: 66 },\n        editAs: 'oneCell'\n      });\n    }\n\n    // Add title aligned in middle horizontally (merged across all columns)\n    const titleRow = worksheet.getRow(currentRow);\n    titleRow.getCell(4).value = title;\n    titleRow.getCell(4).font = { bold: true, size: 16 };\n    titleRow.getCell(4).alignment = { vertical: 'middle', horizontal: 'left' };\n\n    const titleMergeEnd = String.fromCharCode(64 + headers.length);\n    worksheet.mergeCells(`D${currentRow}:${titleMergeEnd}${currentRow}`);\n    currentRow += 3; // Move past image space\n\n    // Add metadata\n    metadata.forEach(([label, value]) => {\n      const row = worksheet.getRow(currentRow++);\n      const cell = row.getCell(1);\n      cell.value = {\n        richText: [\n          { text: `${label}: `, font: { bold: true } },\n          { text: value ?? '', font: { bold: false } }\n        ]\n      };\n      worksheet.mergeCells(`A${row.number}:${String.fromCharCode(64 + headers.length)}${row.number}`);\n    });\n\n    worksheet.addRow([]);\n    currentRow++;\n\n    // Add table header row\n    const headerRow = worksheet.getRow(currentRow++);\n    headers.forEach((header, i) => {\n      const cell = headerRow.getCell(i + 1);\n      cell.value = header;\n      cell.font = { bold: true };\n      cell.fill = { type: 'pattern', pattern: 'solid', fgColor: { argb: 'D9D9D9' } };\n      cell.alignment = { vertical: 'middle', horizontal: 'center' };\n      cell.border = {\n        top: { style: 'thin' },\n        bottom: { style: 'thin' },\n        left: { style: 'thin' },\n        right: { style: 'thin' }\n      };\n    });\n\n    const dataStartRow = currentRow;\n    rows.forEach(rowData => {\n      const row = worksheet.getRow(currentRow++);\n      rowData.forEach((value, i) => {\n        const cell = row.getCell(i + 1);\n        cell.value = value;\n        cell.border = {\n          top: { style: 'thin' },\n          bottom: { style: 'thin' },\n          left: { style: 'thin' },\n          right: { style: 'thin' }\n        };\n      });\n    });\n\n    // Auto column widths\n    for (let i = 1; i <= headers.length; i++) {\n      let maxLength = headers[i - 1].length;\n      for (let rowNum = dataStartRow; rowNum <= worksheet.lastRow!.number; rowNum++) {\n        const val = worksheet.getRow(rowNum).getCell(i).value?.toString() || '';\n        maxLength = Math.max(maxLength, val.length);\n      }\n      worksheet.getColumn(i).width = maxLength + 2;\n    }\n\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  // ------------------------ CSV Universal ------------------------\n  exportToCsvUniversal(title: string, metadata: [string, string][], headers: string[], rows: any[][], fileName: string): void {\n    const metaRows = metadata.map(([k, v]) => [`${k}: ${v}`]);\n    const csvContent = [\n      [title],\n      ...metaRows,\n      [],\n      headers,\n      ...rows.map(row => row.map(value => `\"${value}\"`))\n    ].map(e => e.join(',')).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"]}