1

I'm trying to generate a pdf with css, and I'm not having much success. I have a string that contains html with inline css, but when I use jsPDF, the generated PDF doesn't include styling. I read that in order to include styling, I should also use html2canvas and then add an image with jsPDF. However, none of it works for me.

Here's my code:

@Component({
  selector: 'app-pdf-generator',
  templateUrl: './pdf-generator.component.html',
  styleUrls: ['./pdf-generator.component.css'],      
  host: { '[@routeAnimation]': 'true', 'style' : 'display:block;' }

  onSubmit()
  {
     let servers = this.serversService.getServers();
     var rows = this.buildServerListByOptions(servers)
     var htmlText = this.buildPdfText(rows); //the final html string I want to render on a PDF file.


     //Here I need to genereate a DOM element, create an image of it using html2canvas, and then save as PDF. I **don't** want the element to appear on the page though, only in the PDF file.

     // doc.addImage(canvas, 0,0,100,100);
     // doc.save('report.pdf')

Despite reading all I could find on the web, I still am not able to use the html2canvas library. I would appreciate a code sample that is relevant to my example (creating DOM element dynamically, creating an image of it, adding to PDF) or maybe another way to generate PDF with CSS support using angular.

Thanks!

1 Answer 1

3

Here is an example to generate pdf for your reference.. But here I haven´t used html2canvas for styling. Hope it will help you:

In HTML:

<a class="page-link" style="  (click)="convert()">Generate PDF</a>

In TS file:

import * as jsPDF from 'jspdf';
import 'jspdf-autotable';

And use the below function :

convert() {

    var doc = new jsPDF();
    var col = ["Id", "TypeID","Accnt","Amnt","Start","End","Contrapartida"];
    var rows = [];

    var imgData = ''




var rowCountModNew = [
["1721079361", "0001", "2100074911", "200", "22112017", "23112017", "51696"],
["1721079362", "0002", "2100074912", "300", "22112017", "23112017", "51691"],
["1721079363", "0003", "2100074913", "400", "22112017", "23112017", "51692"],
["1721079364", "0004", "2100074914", "500", "22112017", "23112017", "51693"]
]


rowCountModNew.forEach(element => {
      rows.push(element);

    });



    doc.addImage(imgData, 'JPEG', 90, 60, 20, 20);


    doc.autoTable(col, rows);
    doc.save('Test.pdf');
  }

To add text before and after table:

convert() {       
    var doc = new jsPDF();
    var col = ["Id", "TypeID","Accnt","Amnt","Start","End","Contrapartida"];
    var rows = [];    
    var imgData = ''   


var rowCountModNew = [
["1721079361", "0001", "2100074911", "200", "22112017", "23112017", "51696"],
["1721079362", "0002", "2100074912", "300", "22112017", "23112017", "51691"],
["1721079363", "0003", "2100074913", "400", "22112017", "23112017", "51692"],
["1721079364", "0004", "2100074914", "500", "22112017", "23112017", "51693"]
]

rowCountModNew.forEach(element => {
      rows.push(element);          
    });

    doc.text(80, 20, 'Report Final');
    doc.addImage(imgData, 'JPEG', 90, 40, 20, 20);    
    doc.autoTable(col, rows,{startY: 60});
    doc.text(80, 130, 'Thank you');
    doc.save('Test.pdf');        
  }

And it will look like:enter image description here

Sign up to request clarification or add additional context in comments.

8 Comments

Thanks, but wasn't able to get autotable to work, got that weird error message.
ok..Can you put the error message? And one question..Did you run this command: npm install jspdf-autotable --save
Well, I am able to install it, but when I try to run it I get: doc.autotable is not a function at Pdf-generator.component.ts
I looked up this error and I saw some people fixed it by using require instead of import, but that didn't solve it for me. Still getting the same error.
Finally got it to work after variations on the improts. I have another question though. After using autoTable, is it possible to add more text to the pdf before saving? I tried doc.fromHTML but it ignores the table and as a result the two collide. I want text to appear above the table and below it. Is that possible?
|

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.