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.0.tar.gz (294.2 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.0-py3-none-any.whl (11.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: formalizer-0.2.0.tar.gz
  • Upload date:
  • Size: 294.2 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.0.tar.gz
Algorithm Hash digest
SHA256 ff70b5ecf770524e5cdae5acc714cc84a9f35918ba1b5a7c4f8b27c8ac0eed71
MD5 f2adc92aca1edc7145a6ac2f7f664f30
BLAKE2b-256 343ebdf8e3e11b7943e0ad516ab0f28fa6529e89c7f3e36e0b556d1c48894c6f

See more details on using hashes here.

Provenance

The following attestation bundles were made for formalizer-0.2.0.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.0-py3-none-any.whl.

File metadata

  • Download URL: formalizer-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 11.4 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.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8e4426617ab7194473d0926620d45f0b763281d1056bbad58bd2bb166aefdf5d
MD5 b8b7553efdf53f724bb69463c9f53f14
BLAKE2b-256 f35702e96e5ae115e33bab699842d7fae8c8154ce9a537af8c71d9ecbeef3fff

See more details on using hashes here.

Provenance

The following attestation bundles were made for formalizer-0.2.0-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