Skip to main content

PDF generation via LaTeX — structured data in, professional documents out

Project description

English version: README.en.md

Klartex

PDF-generering via LaTeX — strukturerad data in, professionella dokument ut.

klartex.se · PyPI · GitHub

Klartex tar JSON-data + mallnamn och producerar PDF via XeLaTeX. Kan användas som Python-bibliotek, CLI-verktyg eller HTTP-tjänst.

Mallar

Mall Beskrivning
_block Universell blockmotor — agenten komponerar dokumentet fritt
protokoll Mötesprotokoll med dagordning, beslut och justerare
faktura Faktura med rader, moms och betalningsinformation
resultatrakning Resultaträkning med jämförelseår och noter
balansrakning Balansräkning med tillgångar och skulder/eget kapital
budgetrapport Budgetrapport med kontokoder, budget och utfall
sie-exportrapport Läsbar PDF av SIE4-bokföringsdata

Installation

# Som globalt CLI-verktyg
pipx install klartex

# Eller i ett projekt
pip install klartex

Kräver Python ≥ 3.12 och XeLaTeX (brew install --cask mactex eller apt install texlive-xetex).

Användning

Som Python-bibliotek

from klartex import render

pdf_bytes = render("protokoll", data)

Som CLI

# Rendera (block engine är default)
klartex -d data.json

# Pipe JSON via stdin
cat data.json | klartex

# Med explicit mall
klartex -d data.json -t protokoll

# Med extern sidmall
klartex -d data.json --page-template minforening.tex.jinja

# Lista mallar
klartex templates

# Visa JSON Schema för en mall
klartex schema protokoll

# Starta HTTP-server
klartex serve

Som HTTP-tjänst

klartex serve --port 8000
# Rendera PDF
curl -X POST http://localhost:8000/render \
  -H "Content-Type: application/json" \
  -d '{"template": "protokoll", "data": {...}}' \
  -o output.pdf

# Rendera med extern sidmall
curl -X POST http://localhost:8000/render \
  -H "Content-Type: application/json" \
  -d '{"template": "_block", "data": {...}, "page_template_source": "\\definecolor{brandprimary}{HTML}{2E5A1C}\\n..."}' \
  -o output.pdf

# Lista mallar
curl http://localhost:8000/templates

# Hämta schema
curl http://localhost:8000/templates/protokoll/schema

Sidmallar (Page Templates)

Sidmallar styr sidhuvud, sidfot, färger och logotyp. Tre inbyggda finns:

Sidmall Beskrivning
formal Organisationsnamn och kontaktinfo i sidhuvud, logotyp, sidnummer i sidfot
clean Enbart logotyp i sidhuvud, sidnummer i sidfot
none Inget sidhuvud, enbart sidnummer i sidfot

Egen sidmall

Skapa en .tex.jinja-fil som definierar \fancyhead/\fancyfoot:

\definecolor{brandprimary}{HTML}{2E5A1C}
\definecolor{brandsecondary}{HTML}{555555}
\providecommand{\orgname}{}
\renewcommand{\orgname}{Min Förening}
\makeatletter
\fancyhead[L]{\fontsize{6pt}{9pt}\selectfont\textbf{\orgname}}
\fancyhead[R]{\includegraphics[height=0.855cm]{logo.pdf}}
\fancyfoot[C]{%
    \kx@setlang%
    \fontsize{6pt}{9pt}\selectfont\color{brandsecondary}%
    \doctitle\ \textbullet\ \kx@page\ \thepage\ \kx@of\ \pageref{LastPage}%
}
\makeatother

Använd sedan --page-template minforening.tex.jinja i CLI eller "page_template_source": "..." i API-anrop. Logotyper och andra filer hittas relativt till arbetsmappen.

Arkitektur

Klartex har en trelagers-arkitektur:

  1. Dokumentnivåklartex-base.cls hanterar siduppställning och grundläggande sidhuvud/sidfot. Sidmallar (.tex.jinja) injiceras i preambeln och styr färger, logotyp och layout.
  2. Komponentnivå — Återanvändbara .sty-paket som ger strukturerade LaTeX-makron (t.ex. klartex-signatureblock.sty, klartex-klausuler.sty, klartex-agenda.sty)
  3. Receptnivå — YAML-filer som deklarerar vilka komponenter och innehållsfält som ska kombineras

Renderingsvägar

  • Recipe-mallar (protokoll, faktura) — YAML-recept som deklarerar komponenter och mappningar
  • Block engine (_block) — Agenten komponerar body[] fritt från typade block

Skapa en YAML-receptmall

Skapa en recipe.yaml i mallens katalog (t.ex. klartex/templates/min-mall/recipe.yaml):

template:
  name: min-mall
  description: "Beskrivning av mallen"
  lang: sv

document:
  title: "{{ data.title }}"
  page_template: formal
  metadata:
    - label: "Datum:"
      field: date

components:
  - type: klausuler
    data_map:
      items: agenda_items
    options:
      item_title_field: title
      item_body_field: body

schema: schema.json

Tillgängliga recept-komponenter: heading, description_list, attendees, klausuler, signatureblock, titelsida, invoice_header, invoice_recipient, invoice_table, payment_info, invoice_note.

Block engine-block: heading, text, list, table, callout, quote, title_page, parties, clause, signatures, description_list, form, columns, agenda, name_roster, resultatrakning, budgettabell, notapparat, page_break, latex.

Årsmötespaket

Blockmotorn kan komponera alla dokument som behövs för ett föreningsårsmöte:

Dokument Blocktyper
Kallelse + dagordning heading, description_list, agenda
Verksamhetsberättelse heading, name_roster, text, signatures
Ekonomisk årsredovisning heading, text, resultatrakning, notapparat, signatures
Revisionsberättelse heading, text, signatures
Budget heading, budgettabell
Valberedningens förslag heading, name_roster, signatures
Motion heading, text, clause, signatures
Styrelsens yttrande heading, text, signatures

Agenten väljer och ordnar block för varje dokument — inga separata mallar behövs. Se tests/fixtures/block_kallelse.json m.fl. för fullständiga exempel.

Licens

MIT

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

klartex-0.7.1.tar.gz (46.8 kB view details)

Uploaded Source

Built Distribution

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

klartex-0.7.1-py3-none-any.whl (70.2 kB view details)

Uploaded Python 3

File details

Details for the file klartex-0.7.1.tar.gz.

File metadata

  • Download URL: klartex-0.7.1.tar.gz
  • Upload date:
  • Size: 46.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for klartex-0.7.1.tar.gz
Algorithm Hash digest
SHA256 7caacd7321aa67b3d91a9057d2de7a9f507992380ff061f10d73c6993999ec0e
MD5 49986fc1376e7f6926ba92482c3f5929
BLAKE2b-256 c75a6dd2109975564c6210638d755bde39d5b877010c00c82689d773612c9c6c

See more details on using hashes here.

Provenance

The following attestation bundles were made for klartex-0.7.1.tar.gz:

Publisher: publish.yml on swedev/klartex

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

File details

Details for the file klartex-0.7.1-py3-none-any.whl.

File metadata

  • Download URL: klartex-0.7.1-py3-none-any.whl
  • Upload date:
  • Size: 70.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for klartex-0.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ef6d5242cb974dbf67258f0c87ec42e7ce7021f9375bf5143614d2d8d80f34f0
MD5 18a962a8e55ca270fadb7316f4690445
BLAKE2b-256 d85ebe7944fcf5ba878a0cc19b709ba6d96b03f4d1655569e5476f6079268e66

See more details on using hashes here.

Provenance

The following attestation bundles were made for klartex-0.7.1-py3-none-any.whl:

Publisher: publish.yml on swedev/klartex

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