Skip to content

Latest commit

 

History

History
122 lines (80 loc) · 3.22 KB

README.rst

File metadata and controls

122 lines (80 loc) · 3.22 KB

Django PDF rendering

Django PDF rendering, easily convert html responses to pdf responses

Latest Version Wheel License

Developed by William Otieno.

Overview

This app makes rendering PDF files in Django really easy. It can be used to create invoices, bills and other documents from simple HTML markup and CSS styles. You can even embed images and use custom fonts.

The library provides both Class-Based View that is almost a drop-in replacement for Django's TemplateView as well as helper functions to render PDFs in the backend outside the request scope (i.e. using Celery workers).

Quickstart

  1. Include dj-easy-pdf, xhtml2pdf in your requirements.txt file. If you are on Python 3 you need to install the latest version of Reportlab and the beta version of xhtml2pdf:

    $ pip install dj-easy-pdf
    
  2. Add easy_pdf to INSTALLED_APPS.

  3. Create HTML template for PDF document and add a view that will render it:

    {% extends "easy_pdf/base.html" %}
    
    {% block content %}
        <div id="content">
            <h1>Hi there!</h1>
        </div>
    {% endblock %}
    
    from easy_pdf.views import PDFTemplateView
    
    class HelloPDFView(PDFTemplateView):
        template_name = 'hello.html'
  4. You can also use a mixin to output PDF from Django generic views:

    class PDFUserDetailView(PDFTemplateResponseMixin, DetailView):
        model = get_user_model()
        template_name = 'user_detail.html'
  5. If you're using Function Based views then:

    from easy_pdf.rendering import render_to_pdf_response
    
    def pdf_output(request):
        context = {}
        return render_to_pdf_response(request, "output.html", context)

Documentation

The full documentation is at dj-easy-pdf.readthedocs.io.

Dependencies

dj-easy-pdf depends on:

  • django>=3.2
  • xhtml2pdf
  • reportlab

License

dj-easy-pdf is released under the MIT license.

Other Resources

Commercial Support

This app and many other help us build better software and focus on delivering quality projects faster. We would love to help you with your next project so get in touch by dropping an email at jimmywilliamotieno@gmail.com

Inspired By What we Do?

Donate