First time poster, have usually been able to work every problem out myself. I'm at a loss on this one.
I have had almost this exact code snippet work on another project but this time it works at times and others it doesn't
If needed I can post the rest of the project. Or I'll make a sandbox and post the link when the wife goes to bed.
import jsPDF from 'jspdf'
const doc = new jsPDF();
const img = '../../assets/AADONOTDELETEused (2).jpg'
var width = doc.internal.pageSize.getWidth()
var height = doc.internal.pageSize.getHeight()
doc.addImage(img, 'JPEG', 0, 0, width, height);
// Set the font size and text alignment for form field values
doc.setFontSize(9);
// Fill in the form field values
doc.text(formData.name, 42, 50); // Name field
doc.text(formData.phone, 136, 50); // Phone field
doc.text(formData.email, 100, 60); // Email field
doc.text(formData.address, 31, 70); // Address field
doc.text(formData.year, 12, 92); // Year field
doc.text(formData.model, 12, 108); // Accessories field
doc.text(formData.stockNum, 42, 139); // StockNum field
doc.text(formData.trade, 22, 180); // Trade field
doc.text(formData.deposit, 31, 163); // Deposit field
doc.text(formData.options, 15, 211); // Accessories field
doc.text(formData.msrp, 118, 98); // Accessories field
doc.text(formData.freight, 188, 85); // Accessories field
doc.text(formData.commodity, 188, 93); // Accessories field
doc.text(formData.pdi, 188, 101); // Accessories field
// Save the filled PDF document
doc.save(("{formData.name}.pdf"));
};
I have tried taking each of the inputs and test them seperatly, maybe it was the data being passed. Even that does't show me what exactly is wrong because I'll take the name field out and it works or if left in, it works. I'm obviously missing something, I've went over the docs, google, other peoples projects hopefully some stackover wizard could help me out on this.
ERROR Invalid arguments passed to jsPDF.text at E.y.private.text.y.text
Was at work with nothing to do and started again to go over other people's projects who implemented this lib, and saw different syntax being used and just gave it a shot. I don't know why this worked, because my original code worked in other projects. If you get stuck at the same place I was I hope this helps. The trigger used; onClick={ModifyPdf}
`
function ModifyPdf() {
const doc = new jsPDF();
const img = ' clipped for obvious reasons'
var width = doc.internal.pageSize.getWidth()
var height = doc.internal.pageSize.getHeight()
doc.addImage(img, 'JPEG', 0, 0, width, height);
// Set the font size and text alignment for form field values
doc.setFontSize(9);
// Fill in the form field values
doc.text(42, 50, `${formData.name}`); // Name field
doc.text( 136, 50, `${formData.phone}`); // Phone field
doc.text( 100, 60, `${formData.email}`); // Email field
doc.text( 31, 70, `${formData.address}`); // Address field
doc.text( 12, 92, `${formData.year}`); // Year field
doc.text( 12, 108, `${formData.model}`); // Accessories field
doc.text( 42, 139, `${formData.stockNum}`); // StockNum field
doc.text( 22, 180, `${formData.trade}`); // Trade field
doc.text( 31, 163, `${formData.deposit}`); // Deposit field
doc.text( 15, 211, `${formData.options}`); // Accessories field
doc.text( 118, 98, `${fetchedData.msrp}`); // Accessories field
doc.text( 188, 85, `${fetchedData.freight}`); // Accessories field
doc.text( 188, 93, `${fetchedData.commodity}`); // Accessories field
doc.text( 188, 101, `${fetchedData.pdi}`); // Accessories field
// Save the filled PDF document
doc.save((`${formData.name}.pdf`));
}; `