jsPDF Vuetify Tutorial to Generate a TAX Salary PDF Invoice in Vue.js and Javascript Full Project For Beginners

jsPDF Vuetify Tutorial to Generate a TAX Salary PDF Invoice in Vue.js and Javascript Full Project For Beginners

 

Welcome folks today in this blog post we will be generating tax salary invoice in pdf document using jspdf and vuetify framework in vue.js and javascript. All the source code of the application will be given below.

 

 

 

 

 

Get Started

 

 

 

 

In order to get started we need to make a index.html file and copy paste the following code

 

 

 

index.html

 

 

 

<!DOCTYPE html>
<html>
  <head>
    <title>jsPDF Vuetify PDF Tax Salary Invoice in Javascript</title>
  </head>
  <body>
    
</body>
  <script src="https://cdn.jsdelivr.net/npm/vue@2.x/dist/vue.js"></script>
  <script src="https://cdn.jsdelivr.net/npm/vuetify@2.x/dist/vuetify.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.5.3/jspdf.min.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf-autotable/3.2.4/jspdf.plugin.autotable.min.js"></script>
</html>

 

 

Here we have used the cdn for all the libraries which are used inside the project which are namely are as follows

 

 

jspdf cdn

 

jspdf-autotable cdn

 

vue cdn

 

vuetify cdn

 

All these libraries are used inside this project. And after this we will make the tax salary invoice template inside html and css which are as follows

 

 

<div id="app">
  <v-app>
    <div class="v-container">
   
      <div class="col-xs-12 col-sm-4 col-md-6" id="logo" align="center"> <img src="https://www.smartpractice.co.za/gerhard/ExportUI/images/logo.png" width="150px" ></div>
      <div class="col-xs-8 col-md-6" align="right" id="invInfo">
        <h1>TAX INVOICE</h1>
        <div class="col-xs-12 col-sm-8" align="right">NUMBER:<br>
          REFERENCE:<br>
          DATE:<br>
          DUE DATE:<br>
          SALES REP:<br>
          OVERALL DISCOUNT %:<br>
          PAGES:
        </div>
        <div class="col-xs-12 col-sm-4" align="right">123456789<br>
          ___<br>
          ___<br>
          ___<br>
          ___<br>
          ___<br>
          ___
        </div>
      </div>
      
  </div>
  
  <div class="container">
  <div class="col-sm-6 col-md-3">
      <tr>            <h4>FROM:</h4>           </tr>
        <address>
          <p class="h2" style="line-height:0.3; font-weight:750">COMPANY, Inc.</p><br>
          VAT NO.: <br>    
          1355 Market Street, Suite 900<br>
          San Francisco, CA 94103<br>
          <abbr title="Phone"> P:</abbr> (123) 456-7890
        </address>
    </div>
        
       <div class="col-sm-6 col-md-3">
      <tr>            <h4>TO:</h4>           </tr>
        <address>
          <p class="h2" style="line-height:0.3; font-weight:750">COMPANY, Inc.</p><br>
          CUSTOMER VAT NO.: <br>
          1355 Market Street, Suite 900<br>
          San Francisco, CA 94103<br>
          <abbr title="Phone"> P:</abbr> (123) 456-7890
        </address>
    </div>
      </div>
  
   
     <div class="container">
       <table class="table">
         <thead>
           <tr>
           <th class="col-sm-3 ">Description</th>       
           <th class="col-sm-1">Quantity</th>
           <th class="col-sm-1">Price/Unit</th>         
           <th class="col-sm-1">Disc%</th>      
           <th class="col-sm-1">VAT%</th>                  
           <th class="col-sm-2" style="text-align: right">Excl. Total</th>         
            <th class="col-sm-2" style="text-align: right">Incl. Total</th>
           </tr>
         </thead>
         <tbody>
           <tr>
           <td class="col-sm-3 ">Item Description</td>       
           <td class="col-sm-1">10</td>
           <td class="col-sm-1">4500.00</td>         
           <td class="col-sm-1">0.00</td>      
           <td class="col-sm-1">675.00</td>                  
           <td class="col-sm-2" style="text-align: right">4500.00</td>         
            <td class="col-sm-2" style="text-align: right">5175.00</td>
           </tr>
         </tbody>
            </table>
    
       
       <br /><br />
       <v-btn type="button" class="btn btn-success" @click='generatePDF'>Generate PDF</v-btn>



  </v-app>
</div>

 

See also  Build a Browser or Device Information Finder Using HTML5 CSS3 and Javascript Full Project For Beginners

 

Now we also need to add some css code to style the template as well which are as follows

 

 

body {
  margin: 0.2em;
}

#logo {
  margin-top: 10px;
  
}

.container {
  margin-left: auto; 
  margin-right: auto;
}

h4 {
  font-color: #707070;
  font-weight: 450;
}

th {
  background-color: #EFEFEF;
  table-border: black;
  font-size: 14px;
  font-weight: 600;
  align-text: left;
}

 

 

Now if you open the html file you will see the following screenshot as follows

 

 

 

 

Now we need to add some vue.js and javascript code to convert this template to pdf document. For this purpose we need to use jspdf library.

 

 

// jsPDF docs are found here:
// http://raw.githack.com/MrRio/jsPDF/master/docs/
new Vue({
  el: "#app",
  vuetify: new Vuetify(),
  data() {
    return {
      
      heading: "TAX INVOICE",
    
      items: [
        { description: "Item Description", quantity: "1", unitprice: "450.00", disc: "0.00", vat:  "67.50", excltotal: "450.00", incltotal: "517.50" },
        { description: "Item 2", quantity: "10", unitprice: "4500.00", disc: "0.00", vat:  "675.00", excltotal: "4500.00", incltotal: "5175.00" },
        
      ]
    };
  },
  methods: {
    generatePDF() {
      const vm = this;
       const imgData = '';
      const columns = [
        { title: "Discription", dataKey: "discription" },
        { title: "Quantity", dataKey: "quantity" },
        { title: "UnitPrice", dataKey: "unitprice" },
        { title: "Disc%", dataKey: "disk" },
        { title: "Vat%", dataKey: "vat" },
        { title: "ExclTotal", dataKey: "excltotal" },
        { title: "InclTotal", dataKey: "incltotal" }
      ];
      const doc = new jsPDF("p", "pt");
     
      // text is placed using x, y coordinates
      doc.addImage(imgData, 'JPEG', 45, 30, 90, 118);
      doc
        .setFont("times")
        .setFontSize(22)
        .text(420, 40, "TAX INVOICE");
      doc
        .setFont("times")
        .setFontSize(10)
        .text(400, 70, "NUMBER:");
      doc
        .setFont("times")
        .setFontSize(10)
        .text(490, 70, "123456789");
        doc
        .setFont("times")
        .setFontSize(10)
        .text(385, 85, "REFERENCE:");
      doc
        .setFont("times")
        .setFontSize(10)
        .text(490, 85, "123456789");
        doc
        .setFont("times")
        .setFontSize(10)
        .text(416, 100, "DATE:");
      doc
        .setFont("times")
        .setFontSize(10)
        .text(490, 100, "123456789");
        doc
        .setFont("times")
        .setFontSize(10)
        .text(392, 115, "DUE DATE:");
      doc
        .setFont("times")
        .setFontSize(10)
        .text(490, 115, "123456789");
        doc
        .setFont("times")
        .setFontSize(10)
        .text(390, 130, "SALES REP:");
      doc
        .setFont("times")
        .setFontSize(10)
        .text(490, 130, "123456789");
        doc
        .setFont("times")
        .setFontSize(10)
        .text(330, 145, "OVERALL DISCOUNT %:");
      doc
        .setFont("times")
        .setFontSize(10)
        .text(490, 145, "123456789");
        doc
        .setFont("times")
        .setFontSize(10)
        .text(412, 160, "PAGES:");
      doc
        .setFont("times")
        .setFontSize(10)
        .text(490, 160, "123456789");      
        doc
        .setFont("times")
        .setFontSize(11)
        .text(50, 230, "FROM:");
      doc
        .setFont("times")
        .setFontSize(11)
        .text(300, 230, "TO:");
        doc
        .setFont("times")
        .setFontSize(18)
        .text(50, 250, "COMPANY Inc.");
      doc
        .setFont("times")
        .setFontSize(18)
        .text(300, 250, "COMPANY Inc.");
       doc
        .setFont("times")
        .setFontSize(11)
        .text(50, 280, "VAT NO:");
      doc
        .setFont("times")
        .setFontSize(11)
        .text(300, 280, "CUSTOMER VAT NO:");
       doc
        .setFont("times")
        .setFontSize(10)
        .text(50, 290, "1355 Market Street, Suite 900");
      doc
        .setFont("times")
        .setFontSize(10)
        .text(300, 290, "1355 Market Street, Suite 900");
      doc
        .setFont("times")
        .setFontSize(10)
        .text(50, 300, "San Francisco, CA 94103");
      doc
        .setFont("times")
        .setFontSize(10)
        .text(300, 300, "San Francisco, CA 94103");
      doc
        .setFont("times")
        .setFontSize(10)
        .text(50, 310, "P: (123) 456-7890");
      doc
        .setFont("times")
        .setFontSize(10)
        .text(300, 310, "P: (123) 456-7890");
     
      doc.autoTable(columns, vm.items, {margin: {top: 350}});
      
      doc.setLineWidth(2)
      doc.line(560, 725, 40, 725)
    
      
        doc.save(`${this.heading}.pdf`);
      
      
    }
  }
});

 

See also  Build a Employee Salary Calculator in Browser Using HTML5 CSS3 and Javascript Full Project For Beginners

 

Now if you open the index.html file and you will see a pdf file will be generated automatically. And the screenshot will be as follows.

 

 

 

Leave a Reply