Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Uncaught ReferenceError: jsPDF is not defined

So this is my HTML code where I'm trying to get whatever is outputted in the div abc to a downloadable pdf file.

<!-- Page Heading -->
<div class="row">
    <div class="col-lg-12">
        <h1 class="page-header">
            Reports
        </h1>
        <ol class="breadcrumb">
            <li>
                <i class="fa fa-dashboard"></i>  <a href="dashboard">Dashboard</a>
            </li>
            <li class="active">
                <i class="fa fa-edit"></i> Reports
            </li>

        </ol>
        <body>
          <div id="abc">
</div>
<div id="editor"></div>
<button id="cmd">Download Survey Report</button>
        <div id="abc">

        </div>
        </body>

        <script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/1.3.3/jspdf.min.js"></script>
        <script>

                var doc = new jsPDF();
                var specialElementHandlers = {
                  '#editor': function (element, renderer) {
                return true;
            }
        };

        $('#cmd').click(function () {
            doc.fromHTML($('#abc').html(), 15, 15, {
                'width': 170,
                    'elementHandlers': specialElementHandlers
            });
            doc.save('SurveyReport.pdf');
        });
        </script>


        <script>
        firebase.auth().onAuthStateChanged(function(user){
          if(user){
            var userID = user.uid;
            RetrieveSurvey(userID,1,PrintSurvey(document.getElementById("abc")));
          }
        })
        </script>

    </div>
</div>

And I'm getting this error on the console:

"Uncaught ReferenceError: jsPDF is not defined"

I am not sure what I'm doing wrong here, I even added jsPDF in the script tag...

like image 534
D. A Avatar asked Apr 10 '17 21:04

D. A


1 Answers

Use this:

window.jsPDF = window.jspdf.jsPDF;
like image 177
Ganj Khani Avatar answered Oct 07 '22 20:10

Ganj Khani