Skip to main content

Orchestrate end-to-end reproduction of fillable PDF forms as self-contained Typst packages.

Project description

formalizer

Convert a fillable PDF into a self-contained Typst package that anyone can edit and compile to a near-perfect replica.

Maintained by TtQ.

How it works

  1. Extract — PyMuPDF reads the PDF and outputs FIELDS.json (field schema) and pageN.png background images.
  2. Codegen — The orchestrator writes a Typst package with a typed form() function and a pre-filled example.typ.
  3. Fill — Edit example.typ, replace the dummy values with real ones, compile with typst compile.
<out>/
  typst.toml      # package manifest
  lib.typ         # rendering engine
  FIELDS.json     # extracted field schema
  page1.png       # rasterized page backgrounds
  form.typ        # generated API wrapper (do not edit)
  example.typ     # your starting point — edit this

Requirements

  • Python ≥ 3.10
  • typst CLI (for compiling the output package)

Installation

pip install formalizer
# or
uv add formalizer

Usage

CLI

# Generate a package (name defaults to --out basename)
formalizer --pdf form.pdf --out ./my-form

# Override the package name
formalizer --pdf form.pdf --out ./my-form --name custom-name

# Overwrite an existing output directory
formalizer --pdf form.pdf --out ./my-form -f

After generation the CLI auto-compiles example.typexample.pdf so you can immediately preview the result.

Python API

from formalizer import generate

# Minimal — name defaults to the out directory basename
generate(pdf="form.pdf", out="./my-form")

# With options
generate(pdf="form.pdf", out="./my-form", name="custom-name", force=True)

Filling the form

Edit the generated example.typ and pass real values to form():

#import "form.typ": form

#form(
  first_name:  "Jane Smith",
  agree_terms: true,
  gender:      "F",
)

Then compile:

typst compile example.typ filled-form.pdf

Development

# Install in editable mode
pip install -e .

# Run tests
pip install pytest
pytest tests/ -v

Tests that invoke the typst CLI (test_cli, test_codegen_compiles) are skipped automatically if typst is not on PATH.

License

Apache 2.0

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

formalizer-0.2.1.tar.gz (294.4 kB view details)

Uploaded Source

Built Distribution

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

formalizer-0.2.1-py3-none-any.whl (11.6 kB view details)

Uploaded Python 3

File details

Details for the file formalizer-0.2.1.tar.gz.

File metadata

  • Download URL: formalizer-0.2.1.tar.gz
  • Upload date:
  • Size: 294.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for formalizer-0.2.1.tar.gz
Algorithm Hash digest
SHA256 57637b16f54ca56668e0e068ed5e672cfd739da1fd6d6ef2e00329b648a48f7e
MD5 4d76d25a8eafb9885a723ce7b1df0f3c
BLAKE2b-256 aafeb6c2cff7a11f15172bd7264ac792a23232af65bcf09e3e6701d53811e68c

See more details on using hashes here.

Provenance

The following attestation bundles were made for formalizer-0.2.1.tar.gz:

Publisher: publish.yml on nibsbin/formalizer

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

File details

Details for the file formalizer-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: formalizer-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 11.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for formalizer-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 6de08d8191566eabcc1dfcfa35c256df679a68c37cb9f493c2d33704d21ef409
MD5 7ef4f630521ffdbd7d50007fcd227890
BLAKE2b-256 97b1bc732566cf145e0c068b3ef9c8fc5f61dfb7539ef0b4342fa349252e11d4

See more details on using hashes here.

Provenance

The following attestation bundles were made for formalizer-0.2.1-py3-none-any.whl:

Publisher: publish.yml on nibsbin/formalizer

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