django-easy-pdf

PDF views, the easy way

Latest version: 0.1.1 registry icon
Maintenance score
0
Safety score
0
Popularity score
23
Check your open source dependency risks. Get immediate insight about security, stability and licensing risks.
Security
  Vulnerabilities
Version Suggest Low Medium High Critical
0.1.1 0 0 0 0 0
0.1.0 0 0 0 0 0

Stability
Latest release:

0.1.1 - This version may not be safe as it has not been updated for a long time. Find out if your coding project uses this component and get notified of any reported security vulnerabilities with Meterian-X Open Source Security Platform

Licensing

Maintain your licence declarations and avoid unwanted licences to protect your IP the way you intended.

MIT   -   MIT License

Not a wildcard

Not proprietary

OSI Compliant



Django PDF rendering

Django PDF rendering, the easy way.

.. image:: https://circleci.com/gh/nigma/django-easy-pdf/tree/master.svg?style=svg :target: https://circleci.com/gh/nigma/django-easy-pdf/tree/master :alt: Build Status .. image:: https://img.shields.io/pypi/v/django-easy-pdf.svg :target: https://pypi.python.org/pypi/django-easy-pdf/ :alt: Latest Version .. image:: https://img.shields.io/badge/wheel-yes-green.svg :target: https://pypi.python.org/pypi/django-easy-pdf/ :alt: Wheel .. image:: https://img.shields.io/pypi/l/django-easy-pdf.svg :target: https://pypi.python.org/pypi/django-easy-pdf/ :alt: License

Developed at en.ig.ma software shop <http://en.ig.ma>_.

Development Version

Note: A new PDF rendering backend using WeasyPrint for more accurate rendering is in development under the develop branch. See https://github.com/nigma/django-easy-pdf/pull/34 for changes, testing and discussion.

If you rely on the xhtml2pdf rendering backend and templates pin the package version to django-easy-pdf>=0.1.1<0.2.0.

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 django-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 xhtml2pdf>=0.2b1

  2. Add easy_pdf to INSTALLED_APPS.

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

    .. code-block:: css+django

     {% extends "easy_pdf/base.html" %}
    
     {% block content %}
         <div id="content">
             <h1>Hi there!</h1>
         </div>
     {% endblock %}
    

    .. code-block:: python

     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:

    .. code-block:: python

     class PDFUserDetailView(PDFTemplateResponseMixin, DetailView):
         model = get_user_model()
         template_name = 'user_detail.html'
    

Documentation

The full documentation is at django-easy-pdf.readthedocs.io <https://django-easy-pdf.readthedocs.io/>_.

A live demo is at easy-pdf.herokuapp.com <https://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-pdf depends on:

- ``django>=1.10``
- ``xhtml2pdf>=0.2b1``
- ``reportlab``

License

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