Skip to main content

PDF rendering views for the Wagtail CMS

Project description

wagtail-pdf-view

Create PDF response views for Wagtail pages.

The goal of this extension is to provide a flexible but easy to use way to render Wagtail pages as PDF. With this extension you can utilize all the benefits from the wagtail page system (previews, drafts, history) as well as the power of StreamField and RichText for your generated PDF document.

Currently weasyprint (for HTML to PDF conversion) and latex is supported. If you are undecided which one to use, weasyprint is recommended.

Installing

Install the latest version from pypi:

pip install -U wagtail-pdf-view
# and either this for HTML -> PDF
pip install -U django-weasyprint
# and/or this for Latex -> PDF
pip install -U django-tex

and add the following to your installed apps:

INSTALLED_APPS = [
    ...
    'wagtail_pdf_view',
    'wagtail.contrib.routable_page',
    ...
]

While weasyprint is installed as dependency of django-weasyprint and works out of the box, a working latex interpreter (lualatex) must be installed on your system if you want to use django-tex.

If django-weasyprint and django-tex is installed, weasyprint is selected by default. For django-tex you should set DEFAULT_PDF_VIEW_PROVIDER = WagtailTexView in your settings.

Usage

All you need to do to render your Wagtail page as PDF, is to inherit from PdfModelMixin.

If you want to use latex, read the latex section below.

Further configuration options include:

  • ROUTE_CONFIG to enable rendering of the default HTML view and the PDF view at the same time
  • stylesheets resp. get_stylesheets to include CSS stylesheets for weasyprint
  • attachment to control the file attachment (i.e. whether to download the PDF or open it in the browser)

Examples

A very simple example page using Wagtails StreamField. Like for a regular Wagtail page, the template should be located under: <app_dir>/templates/<app>/simple_pdf_page.html If you're using django-tex the template extention .tex is expected.

from wagtail.core.models import Page
from wagtail.core.fields import RichTextField, StreamField
from wagtail.core import blocks
from wagtail.admin.edit_handlers import FieldPanel, StreamFieldPanel

from wagtail_pdf_view.mixins import PdfViewPageMixin

# Inherit from PdfViewPageMixin
class SimplePdfPage(PdfViewPageMixin, Page):

    # you can create fields as you're used to, e.g. StreamField
    content = StreamField([
        ("heading", blocks.CharBlock(form_classname="full title")),
        ("text", blocks.RichTextBlock()),
    ], blank=True)

    # content panel for the CMS (same as always)
    content_panels = Page.content_panels + [
        StreamFieldPanel("content"),
    ]

    # OPTIONAL: If you want to include a stylesheet
    #stylesheets = ["css/your_stylesheet.css"]

Usage of ROUTE_CONFIG:

Default configuration:

class PdfOnlyPage(PdfViewPageMixin, Page):

    # PDF only
    ROUTE_CONFIG = [
        ("pdf", r'^$'),
        ("html", None),
    ]

By default only the pdf-view is available, i.e. you may only view this page as pdf. This is useful when you just want to display a generated pdf document easily.

A HTML first page: You can access the wagtail page as you're used e.g. 127.0.0.1/mypage. The PDF version will be available under pdf/ e.g. 127.0.0.1/mypage/pdf

class HtmlAndPdfPage(PdfViewPageMixin, Page):

    # HTML first
    ROUTE_CONFIG = [
        ("html", r'^$'),
        ("pdf", r'^pdf/$'),
    ]

Note that the order of html and pdf is not arbitrary: The entry you set first, will be displayed by default when using wagtails preview function. Depending on your case, you may want to put pdf in the first place, so your editors get the pdf-view by default, while html-page url stays the same for the users. In both cases your editors may access both views through the drop-down menu integrated in the preview button.

A PDF first page: The PDF version is displayed with the regular url and you can access the wagtail page under /html, e.g. 127.0.0.1/mypage/html

class HtmlAndPdfPage(PdfViewPageMixin, Page):

    # PDF first
    ROUTE_CONFIG = [
        ("pdf", r'^$'),
        ("html", r'^html/$'),
    ]

ROUTE_CONFIG is build on wagtails routable_page, you can specify routes as you want (e.g. ("html", r'^web/$'))

Using latex

When you want to use latex instead of HTML, you should be aware of the following:

You need to add django_tex to INSTALLED_APPS:

INSTALLED_APPS = [
    ...
    'django_tex',
    ...
]

You need to add the jinja tex engine to TEMPLATES in your settings.py:

TEMPLATES += [
    {
        'NAME': 'tex',
        'BACKEND': 'django_tex.engine.TeXEngine', 
        'APP_DIRS': True,
        'OPTIONS': {
            'environment': 'wagtail_pdf_view.environment.latex_environment',
        },
    },
]

Set DEFAULT_PDF_VIEW_PROVIDER in your settings:

from wagtail_pdf_view.views import WagtailTexView
DEFAULT_PDF_VIEW_PROVIDER = WagtailTexView

In case you just want to use latex for a specific model settings you can overrite PDF_VIEW_PROVIDER:

from wagtail_pdf_view.views import WagtailTexView

class SimplePdfPage(PdfViewPageMixin, Page):

    # render with LaTeX instead
    PDF_VIEW_PROVIDER = WagtailTexView

In general you should include wagtail_preamble.tex, which provides required packages and commands for proper richtext handling.

{% include 'wagtail_preamble.tex' %}

You can set custom width for the richtext image insertion

{% raw %}
\renewcommand{\fullwidth} {0.8\textwidth}
\renewcommand{\partialwidth} {0.5\textwidth}
{% endraw  %} 

A very useful block is raw, this prevents the jinja rendering engine from interpreting everything inside. This is nice if you want to create a latex command

{% raw  %}
{% endraw  %}

For further information read the django-tex github page

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

wagtail-pdf-view-0.1.2.tar.gz (13.2 kB view details)

Uploaded Source

Built Distribution

wagtail_pdf_view-0.1.2-py3-none-any.whl (16.2 kB view details)

Uploaded Python 3

File details

Details for the file wagtail-pdf-view-0.1.2.tar.gz.

File metadata

  • Download URL: wagtail-pdf-view-0.1.2.tar.gz
  • Upload date:
  • Size: 13.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.7.3 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.2

File hashes

Hashes for wagtail-pdf-view-0.1.2.tar.gz
Algorithm Hash digest
SHA256 4a40cdcd6a402db648b485c166af8613075d8479e5cd757a3f5270d57bfd75a7
MD5 375cd41355e39a9f216b259296f8afd4
BLAKE2b-256 bd33abc6cfe53c31a8888aa364eadc7ab6536d1276a144a0cef7c388789090ff

See more details on using hashes here.

File details

Details for the file wagtail_pdf_view-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: wagtail_pdf_view-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 16.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.7.3 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.2

File hashes

Hashes for wagtail_pdf_view-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 fa1c800f08205040d2ddd5c003cc3ecdb7ae866614ece2f2a24f234d857f4ee7
MD5 70f48406dfc5e711ba604d91d424e791
BLAKE2b-256 5ba38b3198155fbf33351911b0f0ea8646167f6f53cc3a4400cefbcb5003ba04

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page