mirror of
https://github.com/Dadido3/go-typst.git
synced 2025-04-11 12:13:16 +00:00
This changes the example to use the template pattern; we now have a single Typst file containing a template function. Instead of loading and rendering the template, we will now generate temporary Typst markup that will import the template function and call it with custom data. This also means that it's pretty easy to test, preview and debug the template.typ outside of go-typst. All that is needed is another Typst file which will call the template with mock data. Also, we now use Compile instead of CompileWithVariables and inject encoded Go values into our temporary markup. |
||
---|---|---|
.. | ||
main_test.go | ||
main.go | ||
output.pdf | ||
README.md | ||
template-preview.typ | ||
template.typ |
Passing values example
This example demonstrates how to pass values to Typst, which can be useful in rendering custom documents such as reports, invoices, and more.
How it works
This example follows the template pattern described in the Typst documentation. Here is a short overview of the files:
- template.typ defines a Typst template function that constructs a document based on parameters.
- main.go shows how to convert/encode Go values into Typst markup, and how to call/render the template with these converted values.
- template-preview.typ also invokes the template while providing mock data. This is useful when you want to preview, update or debug the template.