coljac / typst-dnd5e

A typst template for DND 5E content.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Typst DND5E template

This is a Typst template for DND 5E content, suitable for DMs Guild and the like.

The template is called "dragonling" and can be imported as: #import "@preview/dragonling:0.1.0": *

See the example which should mostly be self explanatory - it includes examples of tables, stat blocks and breakout boxes, and should serve as a good starting point for your own content.

example_img

Basic usage

The dndmodule template sets up your document for you. The arguments you may want to specify up front are as follows:

  • title: The document's title, this will be rendered as text. Omit if you already have cover art with the title.
  • subtitle: A slug line for down the bottom of the front cover.
  • author: Your name.
  • cover: An image to use on the front cover
  • fancy_author: This will put the author's name in that red flame thingy that D&D books tend to have.
  • logo: Supply an image to put the logo on the front page.
  • font_size: Defaults to 12pt.
  • paper: Defaults (sensibly) to a4 (Americans, you might want us-letter).

From there, just about everything you need can be done with basic Typst markup. Some convenience functions are provided in the template:

dnd: Prints "Dungeons & Dragons" in small caps, as required per the official style guide.

dndtab(name, columns: (1fr, 4fr), ..contents): A table with the conventional formatting. Defaults to 2 columns with ratio 1:4 as shown.

breakoutbox(title, contents): Inserts a box with coloured background, and the optional title in small caps.

statbox(stats): Accepts a dictionary with the following format. The skillblock and traits can contain arbitrary keys. After the traits, any of "Actions", "Reactions", "Limited Usage", "Equipment", or "Legendary Actions" will be subsequently shown if present.

#statbox((
  name: "Creature name",
  description: [Size creature, alignment],
  ac: [20 (natural armor)],
  hp: [29 (1d10 + 33)],
  speed: [10ft, climb 10ft.],
  stats: (STR: 13, DEX: 14, CON: 18, INT: 5, WIS: 4, CHA: 7),  // Modifiers will be auto-calculated
  skillblock: (
      Skills: [Perception +6, Stealth +5],
      Senses: [passive Perception 13],
      Languages: [Gnomish],
      Challenge: [5 (1800 XP)]
  ),
  traits: (
    ("Trait name", [Trait desription]), 
    // ..
    ("Trait name", [Trait desription])
),
  Actions: (
    ("Multiattack", [While the monster remains alive, it is a thorn in the party's side.]), 
    ("Saliva", [If a character is eaten by the monster, it takes 1d10 saliva damage per round.]), 
    ("Tentacle squeeze", [If the monster has captured an enemy, it can squeeze them for 1d12 crushing damage.])
  )
))

spell: Accepts a dictionary as follows; the properties are all optional:

#spell((
  name: "",
  spell_type: [2nd level ...],
  properties: (
    ("Casting time", []), 
    ("Range", []), 
    ("Duration", []), 
    ("Components", []), 
  ),
  description: [Spell effects description]
  )
)

Page-wide images and tables

Typst currently has one significant limitation: it is not possible in 2-column mode to include a figure that spans both columns and floats (see this issue).

I am hopeful for a fix in the near future. Apart from simply using one column throughout, the workaround for the time being is to insert a page break, start a new page with 1 column, insert a floating image, then continue with the text in a 2-column block. A helper function included, to be used like so:

// A page break will happen here.
#pagewithfig(top, image("images/my_image.png", width: 100%))[
  The text that appears on the page goes here; you can include more text that will keep flowing, up to the end of the document, but you will need to close the content block if you need another image page.
]

However, you may have best results fiddling around with it yourself manually.

The downside with this method is that you must explicitly divide the content into pages in the right amounts, so that there is not a huge amount of whitespace on the page preceding the one with the image. This is only workable once the content is more or less finalized.

When this issue is fixed in Typst, it should just work without any need for this temmplate to be updated.

Acknowledgements

Inspiration from the DND LaTeX module.

About

A typst template for DND 5E content.

License:MIT License