Я получаю следующую ошибку: что я делаю не так?
ng:///AppModule/PDFComponent.ngfactory.js:7 ERROR TypeError: Cannot read property 'forEach' of undefined
at jspdf.plugin.autotable.min.js:12
at Object.e.parseInput (jspdf.plugin.autotable.min.js:12)
at Object.s.API.autoTable (jspdf.plugin.autotable.min.js:12)
at PDFComponent.push../src/app/Shared/Directives/Download/pdf-generator.component.ts.PDFComponent.downloadPDF (main.js:339)
at Object.eval [as handleEvent] (ng:///AppModule/PDFComponent.ngfactory.js:13)
at handleEvent (vendor.js:74287)
at callWithDebugContext (vendor.js:75796)
at Object.debugHandleEvent [as handleEvent] (vendor.js:75383)
at dispatchEvent (vendor.js:70702)
at vendor.js:71327
Ниже приводится мой pdf-компонент
import { Component, Input, EventEmitter, Output,Inject } from '@angular/core';
import {BrowserModule} from '@angular/platform-browser';
import {AuthService} from '../../Services/auth.service';
import * as jsPDF from 'jspdf';
import 'jspdf-autotable';
declare var jsPDF: any; // Important
@Component({
selector: 'pdf-download',
templateUrl: './pdf-generator.component.html',
})
export class PDFComponent {
@Input() downloadData: any;
@Input() columns: any;
@Input() reportName: string;
constructor(private authService: AuthService) { }
// public columns=[];
downloadPDF(){
debugger;
var data = this.downloadData;
var doc = new jsPDF('landscape');
//..................................................Row1 start
var imgData = '';
doc.addImage(imgData, 'PNG', 0, 5);
doc.setFontSize(16);
//doc.setFontType("bold");
doc.text(100, 15, "Report Name: "+this.reportName);
doc.setFontSize(10);
// jaison doc.text(230, 15, "User: "+this.authService.getLoginUserData().FullName);
//..................................................Row1 END
//..................................................Row2 start
doc.setFontSize(10);
// doc.setFontType("normal")
doc.text(10, 25, "Date: " + new Date().toDateString() + " Time: " + new Date().toLocaleTimeString());
//doc.text(5, 25, "1st");
//doc.setFontSize(10);
//doc.text(120, 25, "2nd");
//doc.setFontSize(10);
// doc.text(230, 25, "3rd");
//..................................................Row2 END
var rows = [];
if(data.length>0)
{
for (var key in data) {
debugger;
rows.push(data[key]);
}
}
else
{
doc.setFontSize(10);
doc.text(230, 35, "No Data Found");
}
doc.autoTable(this.columns, rows, {
styles: {
//cellPadding: 1,
fontSize: 10,
rowHeight: 8,
overflow: 'linebreak'
},
headerStyles: { fillColor: [65, 85, 99], valign: 'middle' },
createdCell: function (cell, data) {
if (cell.raw?cell.raw.toLowerCase() == "false" || cell.raw.toLowerCase() == "error":"") {
cell.styles.textColor = "#FF0718";
}
else if (cell.raw?cell.raw.toLowerCase() == "success" || cell.raw.toLowerCase() == "true":"") {
cell.styles.textColor = "#2ACE1E";
}
else if (cell.raw ? cell.raw.toLowerCase() == "fail" || cell.raw.toLowerCase() == "failed":"") {
cell.styles.textColor = "#FF0718";
}
},
//tableWidth: 'wrap',
theme: 'grid',
//pageBreak: 'auto',
margin: { left: 15, right: 5 ,top:40}
});
doc.save(this.reportName+".pdf");
}
testdownload(){
debugger;
// for(var key in this.downloadData[0])
// {
// this.columns.push({title:key,dataKey:key})
// }
var columns = [
{title: "ID", dataKey: "id"},
{title: "Name", dataKey: "name"},
{title: "Country", dataKey: "country"},
];
var rows = [
{"id": 1, "name": "Shaw", "country": "Tanzania"},
{"id": 2, "name": "Nelson", "country": "Kazakhstan"},
{"id": 3, "name": "Garcia", "country": "Madagascar"},
];
var doc = new jsPDF('p', 'pt');
doc.autoTable(columns, rows);
doc.save("table.pdf");
}
}