Skip to content

olksndrdevhub/django-easy-pdf3

 
 

Repository files navigation

Django PDF rendering

Django PDF rendering, the easy way.

Build Status

Latest Version

Wheel

License

Developed at en.ig.ma software shop.

Development Version

Info: Add support for Django 4 in 0.1.4 version

Note: This fork support Django>=2.0 with "xhtml2pdf" as rendering backend! Support with WeasyPrint is not tested! Note: A new PDF rendering backend using WeasyPrint for more accurate rendering is in development under the develop branch. See nigma#34 for changes, testing and discussion.

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. Install django-easy-pdf3 package:

    $ pip install django-easy-pdf3

    or add django-easy-pdf3 to your requirements.txt

  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'

Documentation

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

A live demo is at easy-pdf.herokuapp.com. You can run it locally after installing dependencies by running python demo.py script from the cloned repository or through Docker with make demo.

Dependencies

django-easy-pdf3 depends on:

  • django>=2.0
  • xhtml2pdf>=0.2b1
  • reportlab

License

django-easy-pdf3 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 en@ig.ma.

About

PDF views, the easy way

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 62.3%
  • HTML 25.7%
  • Makefile 9.0%
  • Dockerfile 3.0%