Skip to main content

A Django template engine powered by Typst

Project description

Django Typst

A Django template engine that uses Typst to render Portable Document Format (PDF) files.

Configuration

To make the typst engine available, you need to add it to the TEMPLATES configuration in your settings.py. e.g.:

TEMPLATES = [
    ...
    {
        "BACKEND": "django_typst.TypstEngine",
        "NAME": "typst",
        "DIRS": [BASE_DIR / "templates"],
        "APP_DIRS": False,
        "OPTIONS": {
            "ROOT": None,
            "FONT_PATHS": [],
            "IGNORE_SYSTEM_FONTS": False,
            "PDF_STANDARD": "1.7",
            "PPI": None,
        }
    },
]

Note that this should be in addition to the standard Django template engine that was already there.

All the OPTIONS are... optional and the values above represent their defaults should no alternative be provided.

Option Description Default
ROOT The root path to use for relative paths None*
FONT_PATHS Paths to look in for fonts []
IGNORE_SYSTEM_FONTS Only consider fonts in the defined font paths False
PDF_STANDARD PDF revision to target (1.7, a2-b, a3-b) "1.7"
PPI Pixel Per Inch for included PNG None

* The engine with use the folder the template is in as the root if one is not specified.

Usage

To use this engine with one of the standard Django class based views you only need to set the template_engine class property to the value "typst". You should also set the content_type property to the value "application/pdf" to ensure the PDF is returned with the correct content type. For example, in a simple TemplateView it would look like this:

from django.views import generic

class MyTemplateView(generic.TemplateView):
  template_engine = "typst"
  content_type = "application/pdf"

  ...

Handling Context

Context data passed into the template it is first encoded in TOML format. Note this means that only data types that can be serialized as TOML can be passed as context variables. We use tomlkit to serialize the context. In practice this means the following types can be included in the context:

  • str
  • int
  • float
  • bool
  • datetime.datetime, .time, and .date
  • list
  • dict

In addition to these types, you can also include decimal.Decimal, uuid.UUID objects, which are rendered to strings before serializing.

There is also special handling for the Django HTTPRequest object, which is converted to a dict before serializing. The contents of that dict are:

{
    "path": request.path,
    "path_info": request.path_info,
    "method": request.method,
    "content_type": request.content_type,
    "content_params": request.content_params,
    "headers": {},  # header-name: header-value
}

To then make use of context within a Typst template you must parse the incoming toml data by adding the following to the top of the typst file:

#let ctx = toml(bytes(sys.inputs.context))

This will deserialize the context and assign it to the typst variable ctx which can then be used in the template like any other variable. For example if you context was something like:

{
  "name": "J Moss",
  "flight": "QF1",
}

Then in your template you will be able to reference it with:

#ctx.name your flight number is #ctx.flight

Or even better is to parse the context as follows:

// Parse context or use defaults
#let ctx = if ("context" in sys.inputs) {
  toml(bytes(sys.inputs.context))
} else {
  (
    "name": "A Citizen",
    "flight": "DL31"
  )
}

This version sets a default if context is not passed in. This allows you to test the template in isolation - say with the Tinymist Extension to VSCode or even just running typst directly on it.

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

django_typst-0.1.0.tar.gz (5.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_typst-0.1.0-py3-none-any.whl (7.5 kB view details)

Uploaded Python 3

File details

Details for the file django_typst-0.1.0.tar.gz.

File metadata

  • Download URL: django_typst-0.1.0.tar.gz
  • Upload date:
  • Size: 5.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for django_typst-0.1.0.tar.gz
Algorithm Hash digest
SHA256 f79eb5f4e4244a4e9f957e90a046529847f8f5b9528232cefb3e93f52b39f92d
MD5 3cfbcbcaae4f236bed9980e933c47218
BLAKE2b-256 4c53faaa9e25afa06d59572079fdbe668ff87e1da64cf83f647f3d0ffae977bb

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_typst-0.1.0.tar.gz:

Publisher: publish.yml on a-musing-moose/django-typst-engine

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file django_typst-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: django_typst-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 7.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for django_typst-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a107eab01ff1efda0663845b93691bcbf6b5553d9e48d031e6039bc19d9278b5
MD5 f41bcaa58206e059c2830cbdde066977
BLAKE2b-256 4136c315fc2974ce2ceefb6afacf2731e5c499231e948e7d8ed83a89a8e0badb

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_typst-0.1.0-py3-none-any.whl:

Publisher: publish.yml on a-musing-moose/django-typst-engine

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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