Card Creator Documentation
An in-depth guide for using the Card Creator tool to design custom Frosthaven class cards. This documentation covers everything from basic actions to advanced styling and token configuration.
Introduction
On this page you will find detailed explanations of all commands and syntax options available in the Card Creator.
Note: The Card Creator currently has a few issues with rendering certain elements in browsers other than Chrome. If you encounter any problems, please try using Chrome for the best experience.
Getting Started
Before you begin creating your cards, it’s recommended to set up some base info, and define some properties. These properties will be used to customise the look of your custom class. These steps aren’t strictly required, but it can help you to reinforce the thematic identity of your class.
Base Info
The base info section is where you can define all the aspects of your class that don’t involve the cards themselves, such as the info presented on the class mat.
Here is a brief overview of the properties you can define:
Property | Description |
---|---|
|
The name of your custom class. |
|
The race of your class. |
|
The HP level of your class. This can be set to Low, Medium, or High. |
|
The name of your class given to it based on its icon. |
|
The complexity of your class. This can be set to any number between 1 and 5. |
|
The melee value of your class. This can be set to any number between 1 and 5. |
|
The ranged value of your class. This can be set to any number between 1 and 5. |
|
The mobility value of your class. This can be set to any number between 1 and 5. |
|
The support value of your class. This can be set to any number between 1 and 5. |
|
The defense value of your class. This can be set to any number between 1 and 5. |
|
The control value of your class. This can be set to any number between 1 and 5. |
|
The elemental affinities of your class. This can be set to a comma-separated list of elements that your class is proficient in, or none. |
|
The size of the background image for your class on the banner in the class list. This banner can also be seen at the top of the page. This is set to a pixel amount. Note: The image that this uses will be set later, when making a TTS mod. |
|
The position of the background image for your class on the banner in the class list. This is based from the top left corner, and is set to two pixel amounts, one for the x-axis and one for the y-axis. |
|
The development status of your class. This can be set to any of the following: "Concept", "Alpha", "Beta", "Released". |
|
A link to the Discord channel for your class. |
|
Whether your class is public or not. This can be set to true or false. |
|
You can enter discord user IDs here to allow those users to edit the class. This is useful for collaborative projects. |
Creating a Deck
To create a deck, head to the "Decks" tab in the Card Creator, and click the "Add" button. This will create a new deck for your class. You can then open this deck by clicking it’s name in the list, or the "Cards" button next to the deck.
Deck Building
Once a deck is created, and you have opened it by either clicking on it, or clicking the "Cards" button next to it, you’ll be brought to the screen you’ll be spending the majority of your time in. This is the deck building screen.
Immediately, you’ll be able to see two buttons, "Show starting deck" and "Show advanced deck". Once you’ve started creating cards, you can use these buttons to see the entire level 1/X spread, and the entire level 2-9 spread, respectively.
Below that are 4 more buttons, "Show properties", "Show color properties", "Change base card", and "Elements". Clicking on any of these will show the respective section, which can be closed by clicking the button again. If it doesn’t seem like clicking a button is showing anything, try scrolling down, as the section may be below another section.
One thing to note about the following sections is that for some of the options (especially the color properties), it’ll be easier to see what they do once you’ve actually started creating cards. You can either skip to the Adding Cards section to start creating cards, or continue reading to see what each section does.
Show Properties
The "Show properties" section is where you can see, and set, various properties for the deck. This includes the name of the deck, a link to the icon of the class, various links to different class tokens, allowing you to add custom images to cards (this is explained in more detail in the Basic Actions, and the Custom Actions section), and a link to the background image for the cards in this deck. You can also set the position of this background image, the opacity, and the size of it. This will be much easier to see once you’ve actually started creating cards.
Show Color Properties
The "Show color properties" section is where you can set the color of various parts of the card. This is split into two sections, the colors for the card itself, and the colors for the various bits that go on the card.
The top line of colors are for the various parts that go onto the card. Most of these will usually want to remain default, except for the "Line color", but you can experiment with these to see what you like. The top bars are for transparency, and the bottom bars are for the colors themselves.
The actual card colors are controlled a bit differently. Here, each section of the card has access to a range of sliders, "Sepia", "Saturate", "Hue-rotation", and "Brightness". These sliders can be used to adjust the color of the card, and the various parts of the card. The "Brightness" slider is particularly useful for making the text on the card more readable. The "Hue-rotation" slider can be used to change the color of the card, and the "Saturate" slider can be used to make the card more, or less, colorful. The "Sepia" slider can be used to make the card more, or less, sepia-toned.
It can be a bit tricky to get the colors you want, but with a bit of experimentation, you should be able to settle on something like what you envisioned.
To the right of each of the rows of sliders, you’ll see a checkbox on all but the first row. Any rows that have this checkbox checked will change automatically as you change the sliders on the first row. This can be useful for keeping the colors of the card and the elements on the card in sync. If you want to change certain parts of the card, but not others, you can uncheck the checkbox on the row you want to change, and then adjust the sliders as needed.
Change Base Card
The "Change base card" section is where you can change the base card that all the cards in the deck are based on. This is useful if you want to change the base visuals of the card, outside changing colors. Most people won’t need to change this, but it’s there if you want to.
Every part of the card can be changed, and this change will be reflected across the entire deck.
Elements
The "Elements" section shows a quick overview of the elements that are present in the deck. This is useful for keeping track of how many infusions, and consumptions, are in the deck. This can be helpful for balancing the deck, and making sure that you have a balanced amount of elements in the deck.
Adding Cards
While inside the deck building screen, you can add cards to the deck by clicking the "Add Card" button. This will create a new card in the deck. You can then edit this card by clicking on it. This will bring it into focus next to the text box containing its code.
This state, where the card is in focus, doubles as the best way to see the changes you’re making in the previous properties sections. This is because the card will update in real time as you change the properties of the card.
Syntax
The syntax of the Card Creator uses simple commands to render icons and values. Commands typically follow this structure:
- command: [value]
Modifiers can be added to fine-tune placement, styling, or functionality. Sections below break down each command group. For many examples on card structure, including all the examples shown in this documentation, feel free to browse the "Example Syntax" class present in the tool.
Tab Hierarchy
The structure of a card is based on indentation. Every sub-block or modifier must be indented with exactly 2 spaces more than its parent. This tells the system which modifiers belong to which command. For the purposes of this guide, "parent" refers to the block that is one level higher in the hierarchy.
For example:
- attack: 3
margin: 5px 0px 0px 0px
In this example, the "margin" modifier is indented 2 spaces relative to the "- attack: 3" command, indicating that it applies specifically to that action.
Here is a more complex example:
- group:
- attack: 3
- divider
margin: 10px 0px
- move: 2
- divider
- optional:
- consume: [dark,light]
- heal: 2
sub:
- range: 3
- wild
noLine: true
flexDirection: column
In this example, we have utilized a "group" block to contain multiple actions. Each action is indented 2 spaces relative to the "group" command. This indicates that they all belong to that outer block. The hierarchy continues with the "divider" and "optional" blocks, each containing their own sub-blocks.
A more detailed explanation of each block type is provided in the following sections.
Remember: use 2 spaces per level of indentation to maintain the proper hierarchy.
Basic Actions
This section covers the core actions used to define a card’s abilities.
Syntax | Description | Example | Result |
---|---|---|---|
|
Creates an attack ability with a value of [value] |
|
|
|
Creates a move ability with a value of [value] |
|
|
|
Creates a teleport ability with a value of [value] |
|
|
|
Creates a shield ability with a value of [value] |
|
|
|
Creates a retaliate ability with a value of [value] |
|
|
|
Creates a loot ability with a value of [value] |
|
|
|
Creates a heal ability with a value of [value] |
|
|
|
Creates a class token ability using the token linked to the specified index. |
|
Conditions
Conditions modify abilities and can be used with or without an associated value. The available conditions are:
-
bane
-
bless
-
brittle
-
chill
-
curse
-
disarm
-
dodge
-
empower
-
enfeeble
-
immobilize
-
impair
-
infect
-
invisible
-
muddle
-
pierce
-
poison
-
pull
-
push
-
regenerate
-
rupture
-
safeguard
-
strengthen
-
stun
-
swing
-
ward
-
wound
Syntax | Description | Example | Result |
---|---|---|---|
|
Renders a condition icon. |
|
|
|
Renders a condition icon with an optional value. |
|
|
Elements
Elements represent various thematic or mechanical attributes. They support single values, consumption markers, and infuse modifiers.
Available elements include:
-
earth
-
fire
-
air (or wind)
-
ice
-
light
-
dark
-
wild
Using multiple elements separated by '/' will generate an “or” condition.
Syntax | Description | Example | Result |
---|---|---|---|
|
Renders the icon for the given element. |
|
|
|
Renders a list of element icons with an added consume marker (usually used within an optional block). |
|
|
|
Adds a mandatory box with a list of specified elements. (Note: As a modifier, do not prefix with a '-') |
|
[! |
Note: The square brackets in the consume and infuse examples are required in the syntax.
Note: For infusion, this will only work at the first indentation level. This means that either bottom:
or top:
should be its direct parent.
Custom Actions
There exists a special block for custom actions, which allows you to write any text you want. This block is useful for creating unique abilities or actions that don’t fit into the predefined categories.
Within these blocks, you are able to insert any of the common icons, such as conditions or elements, to further customize your text. This includes any class tokens that you’ve linked in the properties section.
The syntax for inserting these icons is: %iconName%
.
Here are some examples of custom actions:
Syntax | Description | Example | Result |
---|---|---|---|
|
Creates a custom action with the specified text. |
|
Text |
|
Creates a custom action with the specified text. |
|
Text with |
|
Creates a custom action with the specified text. |
|
Text with |
|
Creates a custom action with the specified text. |
|
Text with |
Any icon that has been inserted also has some special modifiers that can be applied to it. These modifiers are:
Modifier | Description | Example | Result |
---|---|---|---|
's' |
Removes the icon’s shadow. |
|
|
'i' |
Inverts the icon’s color. |
|
Sub Blocks
Sub Blocks are the blocks that house the extra properties of an action. These are things like range, target, and other modifiers that can be applied to an action. These blocks are always indented 2 spaces from their parent action, like so:
- attack: 3
sub:
target: 2
range: 3
pierce: 1
In this example, the "sub" block contains the "target", "range", and "pierce" modifiers. These are all indented 2 spaces from the "attack" command, indicating that they are all part of that action.
Alongside all existing conditions, the available attributes you can put in a sub block are:
-
target
-
range
Optional Blocks
Optional blocks represent abilities, or augments to abilities that come with a cost. The most frequent example of an optional block is an elemental consumption. This would be represented as follows:
- attack: 3
- optional:
- consume: [earth]
- custom: '+2 %attack%'
The above will render an attack 3 ability with an optional block that consumes earth and adds +2 attack. Sometimes, an optional block may be used to represent an extra ability, rather than an augment to an ability. An example of this would be:
- move: 3
- divider
- optional:
- consume: [earth]
- heal: 2
noLine: true
In this example, we have a move 3 ability with an optional block that allows the consumption of earth to perform an additional heal 2. The noLine modifier is used to prevent a line from being drawn between the move and heal abilities, since in this case they are separate abilities.
Mandatory Blocks
Mandatory blocks are used to represent abilities that must be performed if that action is being played. Outside elemental infusion (which is created automatically with the infuse modifier), mandatory blocks are most often used to force a negative action to occur. An example of this would be:
- attack: 3
- divider
- mandatory:
- curse:
sub:
- self
In this example, we have an attack 3 ability with a mandatory block that means the player has to curse themselves.
Tokens
The tokens block creates token slots. Each number in the provided array represents the XP that the token slot provides.
Syntax | Description | Example | Result |
---|---|---|---|
|
Creates token slots with XP values as defined in the array. |
|
Renders token slots accordingly. |
Token Modifiers
Modifiers for tokens allow you to control how token slots are arranged.
Modifier | Description | Example | Result |
---|---|---|---|
|
Forces tokens to render in a specific layout: either 3 or 4 tokens on 1 or 2 lines. Other numbers follow predefined arrangements (1–2 tokens on one line, 5–6 tokens on two lines). |
- tokens: [0,1,0,1] |
Renders tokens in a single line. |
Summons
Summons are a special type of action that can be created using the "summon" block. This is one of the more complex blocks, as it has a lot of properties that can be set. Here is an example of a basic summon block:
- custom: 'Summon Example Summon'
- summon:
name: 'Example Summon'
stats: [5,2,3,'-']
image:
image:
url: "https://example.com/image.png"
size: 100%
position: '0px 0px'
In this example, we have a custom action that creates a summon called "Example Summon". This summon has 5 health, 2 move, 3 attack, and no range. The summon also has an image, which is set to a URL, and has various properties to position the image in the image box.
Here are all the properties that can be set for a summon:
Property | Description | Example | Result |
---|---|---|---|
|
The name of the summon. |
|
The summon will be called "Example Summon" in TTS. |
|
The stats of the summon. This should be an array of 4 numbers, in the order of health, move, attack, range. |
|
The summon will have 5 health, 2 move, 3 attack, and no range. |
|
The image of the summon. This should be an object with the properties "url", "size", and "position". This will also be used for the TTS standee. |
|
The summon will have an image from the URL "https://example.com/image.png", with a size of 100%, and a position of 0px 0px. |
|
The possible enhancements on the summon. This should be an array of the possible enhancements, or "none" if there is no enhancement for that attribute. The array follows the same order as the stats array. |
|
The summon will have a square enhancement for health and attack, and no enhancement for move and range. |
|
The special abilities of the summon. These are things like shield, retaliate, or other abilities that the summon performs. It will show up to the right of the stats. |
|
The summon will have a shield 1 ability. |
|
The background color of the special area. This should be in rgb form as shown in the example. |
|
The background of the special area will be red with 50% opacity. |
|
The width of the special area. This should be in pixels. |
|
The special area will be 100 pixels wide. |
There are further properties that can be set for a summon. These extra properties won’t change the appearance of the card, but will change the behavior of the summon in TTS. These properties are:
Property | Description | Example | Result |
---|---|---|---|
|
The attributes of the summon. This is something like if the summon is flying, or if it has a shield. Setting this will make the attributes appear under the standees health. |
|
The summon will have a shield value of 1. |
|
The effects of the summon. This is something like if the summon wounds on their attacks. Setting this will make the effects appear under the standees health. |
|
The summon standee will show that they wound on their attacks. |
|
The text that appears on the summon standee. This can be anything you want, and will appear under the effects. This text can include icons like range and attack, but the syntax is different. To include an icon, include {e.IconName} in the text, where "iconName" is the name of the icon you want to include. |
|
The summon standee will show "This is some example text with |
|
The immunities of the summon. This is something like if the summon is immune to poison. |
|
The summon will be immune to poison. |
|
The color of the health bar on the summon standee. This should be in hex code form as shown in the example. |
|
The health bar on the summon standee will be red. |
|
The color of the health text on the summon standee. This should be in hex code form as shown in the example. |
|
The health text on the summon standee will be white. |
Named Abilities
Named ability blocks are used to create a small banner in the top left corner of the card. This is useful when you have certain keyword abilities that have special rules defined on the class mat. A starter class that uses this is Mindthief, with its "augment" abilities. Note: this block only refers to the corner containing the keyword, not the banner containing the abilities. For help with the abilities banner, see the Advanced Styling section.
In order to use this block, it should be placed at the base level of the action, with only "top:" or "bottom:" as a parent. Here is an example:
- top:
namedAbility:
name: Augment
Mode Blocks
The mode block can be used to create something akin to Blinkblade’s fast or slow abilities. Here is an example of how to use the mode block:
- mode:
- attack: 2
icon: '%classToken0%'
In this example, we have a mode block that contains an attack 2 ability, and an icon of the class token.
The mode block has a couple of special properties that can be set. These are:
Property | Description | Example | Result |
---|---|---|---|
|
The stuff that appears in the smalller box of the mode. |
|
The icon of the class token will appear in the smaller box of the mode. |
|
If set to true, the mode will be reversed. This means that the smaller box will be on the right, and the larger box will be on the left. |
|
The mode will be reversed. |
|
The background color of the left box. This will usually be in rgb form as shown in the example. |
|
The left box will have a red background with 50% opacity. |
|
The background color of the right box. This will usually be in rgb form as shown in the example. |
|
The right box will have a green background with 50% opacity. |
|
The background color of the border between the two boxes. This will usually be in rgb form as shown in the example. |
|
The border between the two boxes will be blue with 50% opacity. |
Other Common Card Properties
Before we get into more advanced styling options, here are some common properties for an action and how they can be used. Do note that all of these properties should be a direct child of the "bottom:" or "top:" block, just like the "infuse:" block.
Syntax | Description | Example | Result |
---|---|---|---|
|
Sets the duration of the action. This can be either "round" or "persistent". |
|
The |
|
Sets if the card is lost or not. This can be either "true" or "false". |
|
The action will have a |
|
Sets whether the card is unrecoverable or not. This can be either "true" or "false". |
|
The action will have a |
|
Sets the XP value of the action. This can be any number. |
|
The XP value |
Styles & Modifiers
Modifiers allow you to fine-tune the placement, size, and appearance of each block. To apply modifiers, ensure each block is defined as an object (i.e. using a colon after the block name).
These style modifiers can be applied to any block, and should not have a hyphen in front of them. For example, to apply a modifier to an attack action, you would write:
- attack: 3
margin: 5px 0px 0px 0px
fontSize: 10px
Common Style Modifiers
Modifier | Description | Example | Result |
---|---|---|---|
|
Sets the margin around the block. This has a variety of ways to be set, as shown in the following examples. |
|
The first example will set the margin to 5px on the top, 0px on the right, 0px on the bottom, and 5px on the left. The second example will set the margin to 5px on the top, 0px on the sides, and 10px on the bottom. The third example will set the margin to 5px on the top and bottom, and 0px on the sides. The last example will set the margin to 5px on all sides. |
|
Sets the padding around the block. This has a variety of ways to be set, as shown in the following examples. |
|
The first example will set the padding to 5px on the top, 0px on the right, 0px on the bottom, and 5px on the left. The second example will set the padding to 5px on the top, 0px on the sides, and 10px on the bottom. The third example will set the padding to 5px on the top and bottom, and 0px on the sides. The last example will set the padding to 5px on all sides. |
Note: Padding is similar to margin, but they have separate use cases. Taking an optional block as an example, setting padding on the block will increase the amount of space that the block itself takes up, while setting margin will increase the space between the block and the action above it. You can think of padding as the space inside the block, while margin is the space outside the block.
More Style Modifiers
There are many more style modifiers that can be applied to blocks. Here are the rest of them:
Modifier | Description | Example | Result |
---|---|---|---|
|
Sets the font size of the text in the block. This can be any number, and will be set in pixels. |
|
The font size of the text in the block will be 10px. |
|
Sets the height of the block. This can be any number, and will be set in pixels. |
|
The height of the block will be 10px. |
|
Sets the display type of the block. This can be set to anything that is valid in CSS, but in almost every case, you don’t want to change this. |
|
The block will be set to display as a flexbox. |
|
Sets the direction that the content in the block will follow. This can be set to "row" or "column". Row will put the content in a row, while column will put the content in a column. |
|
The content in the block will be set to display in a column. |
|
Sets the background color of the block. This can be set to any color that is valid in CSS, including rgb, and rgba. |
|
The background color of the block will be set to red with 50% opacity. |
|
Sets the color of the text in the block. This can be set to any color that is valid in CSS, including rgb, and rgba. |
|
The color of the text in the block will be set to red with 50% opacity. |
|
Sets the spacing between words in the block. This can be set to any number, and will be set in pixels. |
|
The spacing between words in the block will be set to 5px. |
|
Sets the height of each line in the block. This can be set to any number, and will be set in pixels. This is useful for making the text more readable. |
|
The height of each line in the block will be set to 5px. |
|
Sets the gap between the items in the block. This can be set to any number, and will be set in pixels. This is useful for more advanced blocks that we’ll get into later. |
|
The gap between the items in the block will be set to 5px. |
Position
To change a block’s position, orientation, or size, use the following modifiers:
Modifier | Description | Example | Result |
---|---|---|---|
|
Sets positioning mode: |
|
The block will be positioned absolutely. |
|
Adjusts vertical placement from the top edge of the parent or relative container. |
|
Adjusts vertical placement from the top edge, placing the block 10px down. |
|
Adjusts horizontal placement from the left edge. |
|
Adjusts horizontal placement from the left edge, placing the block 10px to the right. |
|
Applies CSS transformations (e.g., rotate, scale). Refer to https://developer.mozilla.org/en-US/docs/Web/CSS/transform for more info. |
|
Doubles the size of the block. |
Advanced Styling
This section will be dedicated to more advanced styling, to achieve the desired look for your cards. This includes things like the ability to create a banner, or a group of actions that are all part of the same action.
The main block we care about here is the "group" block. This block is used to group actions together, allowing horizontal stacking, or easy positioning of multiple actions at once. One of the easiest examples to show this off is the aforementioned banner. On official cards, there are sometimes a group of actions at the top of the card in a separate "banner" area. Here’s an advanced example of how we can recreate something like that using the group block:
top:
namedAbility:
name: Grenade
padding: 10px 10px
actions:
- group:
- attack: 2
sub:
- custom: '%range% 2, advantage'
margin: 0px -10px 0px 10px
- hex: ett_ttt_ett
marginTop: -40px
paddingTop: 20px
background: rgba(0,0,0,50%)
- regenerate:
marginTop: 10px
sub:
- self
duration: persistent
In this example, we have a group block that contains two actions, an attack and a AoE hex pattern. Group blocks default to a flexDirection of row, so the two actions will be placed next to each other. The group block also has a marginTop of -40px, which will pull the group up into the top area of the card. The paddingTop of 20px will add some space between the top of the group and the top of the card, allowing the darker background to extend seamlessly to the edge of the card. Finally, you can see the Named Ability block at the top, which is used to create the iconography in the corner of the banner group we’ve just created.
The principles shown here can be applied to many different scenarios, and using a combination of everything shown so far, there is a lot of freedom available to you to create the card you want. Remember, you are able to access the example syntax class to see some examples of how to use these blocks, and how they can be combined to create the desired effect. Otherwise, experiment a little with the blocks, and see what you can come up with!
Tabletop Simulator Mod
When the time has come to export your class to Tabletop Simulator, there are a couple of things you need to do to make sure that your class works as intended. This section will cover the steps you need to take to make sure that your class works in Tabletop Simulator.
The very first step will be to create a mod for your class on the "TTS Mods" page. This page works very similarly to the "Decks" page, but instead of creating cards, you’re creating mods for your class.
Assets
Once you have created and opened a new mod, the main brunt of the work comes down to getting the various assets for your class sorted. This is all done within the mod that you created on the site.
At the top of the mod page, there are a few things to fill in before getting to the assets.
The first thing to do is to switch on the "Active Mod" toggle. This toggle is how TTS will know which mod to use when importing the class. In some cases, you’ll have multiple mods for the same class (for example if the class has two decks), and you’ll be able to import both decks by importing one, and then changing the active mod to the other.
After this you have the Mod Name and the Deck Index. The mod name can be set to anything you want, it’s just so you know which mod is which in the list of mods on the class creator website. The deck index is the index of the deck you want to import. This is usually 0, but if you have multiple decks, you can set this to the index of the deck you want to import.
Some people like to make a new deck for every version of the class they make, so they can keep track of changes, and if you’re doing this, you’ll need to change the deck index to the index of the deck you want to import. This starts at 0, and goes up by 1 for every new deck you make, so if you have 3 decks, you’ll have deck indexes 0, 1, and 2 (in the order they appear on the "Decks" page).
Now come the assets themselves.
Starting Deck
The first thing to do is to add the starting deck to the mod. This can be done in two ways, but the second way will be covered in Third Party Card Spreads. For those who have created their class on the site, the starting deck will be created for you, and automatically saved. All you have to do is click the "Upload Image" button in the starting deck section. If you want to download an image of the starting deck, you can do so by clicking the "Download Image" button.
Note: Downloading an image of the deck can be done without uploading it first, if you want to download an image of the deck before uploading it.
You’ll notice beneath the image of the card spread two input boxes for the number of cards in each row and the number of rows. If you’re using the site to create your class, these will be filled in for you, but if you’re using a third party card spread, you’ll need to fill these in yourself.
Finally, the last input box allows you to manually set snap points on the cards. This is an advanced feature, and will not need to be used often. In order to set these, click the "Add snap" button. This will begin the process of adding snap points. From there, just click the image of the spread in the locations where you want snap points to exist. You’ll be able to see them show up as red dots. When done, click "Close add".
Note: Snap points are automatically generated for token tracks, you do not need to add these yourself.
Advanced Deck
The advanced deck section is for the level 2-9 cards of the class. All the instructions for the starting deck apply here.
The Rest of the Easy Stuff
There are a few more assets that are as simple to add as clicking "Upload Image". These are:
-
The ability card back
-
The character token bag
-
The character token
-
The tuckbox
-
The class envelope
-
The icon for the classlist
These can also be linked to manually, if you have the URLs for the images.
Manually Linked Assets
There are a few assets that need to be manually linked to. These are:
-
The class mat front
-
The class mat back
-
The standee
-
The character sheet
-
The attack modifier deck
-
The perk reminder deck
In the case of the character sheet and the perks, you can use Sammy’s tool to create these. This is linked to underneath their input boxes. For the rest, you’ll need to upload the images to a hosting site, and then link to them in the input boxes.
With the perks (both the AMD and the reminders), a list of the perks is needed. The AMD list should look something like the following, but in order of left to right reading through your specific perk cards:
Attack Modifier (+0)
Attack Modifier (+1) (Wound)
Attack Modifier (+1) (Poison)
Attack Modifier (+1) (Muddle) rolling
Attack Modifer (ice-earth) rolling
The "Attack Modifier" part is required, as is the "rolling" part if the perk is a rolling modifier. The rest is up to you, but it should communicate clearly to the player what the perk does.
The perk reminder list should look something like the following:
Perk Reminder long rest
Perk Reminder short rest
Perk Reminder refresh
The "Perk Reminder" part is required, but the rest is up to you. This should communicate clearly to the player what the perk reminder does.
Final Options
There are a few final options that can be changed.
First we have the HP bar color, HP bar text color, and HP bar placement. These are all pretty self explanatory, and are used to change the color of the health bar on the standee, the color of the text on the health bar, and the placement of the health bar on the standee. The colors can be set using hex codes, and the placement is set to a number, with the default being 320.
Then there are all the character sheet and perk LUA scripts. These can be gotten from Sammy’s tool when you make the character sheet and the perks. They should just be copy and pasted into the input boxes.
Finally, there is the option to add a custom standee script. This is for any extra scripting you want to add to the standee, such as a second HP bar. This is an advanced feature, and will not be needed for most classes.
Importing
In order to import the class into TTS, you will first need to subscribe to the following mod on the Steam Workshop: https://steamcommunity.com/sharedfiles/filedetails/?id=3163711044
Once you have subscribed to the mod, you can open TTS, and create a new game. In the game, you’ll need to go to the "Workshop" tab, and search for the mod you just subscribed to. Once you’ve found it, click the "Load" button, and the mod will be loaded into your game. Within this you will see a tile that allows you to enter a class name and generate the bag.
Enter the name of the class you want to import, and click the button. This will create a bag with all the assets you need to play the class in TTS.
To upload this bag as your own Steam Workshop mod so that others can download and play your class, follow these steps:
-
Delete the class import tile
-
Go to the "Modding" tab and then "Workshop Upload"
-
Fill in the details for your mod, including the name, and thumbnail image
-
Click "Upload"
-
This will give you a big long number, which is the ID of your mod. You can use this to share your mod with others. The link to your mod will just be https://steamcommunity.com/sharedfiles/filedetails/?id= followed by the ID of your mod.
Third Party Card Spreads
If you’re not using the site to create your class, and instead just want to use it to import your class into TTS, you can still do this. Rather than using the "Upload Image" buttons, you’ll need to manually link to the images of your assets. Ensure that the level 1/X cards are separate from the level 2-9 cards, and that you’ve inputted the correct number of rows and columns for each card spread.
Once this is done, there is one extra step needed, that normally would be done for you. This is naming all the cards for import into TTS. Next to each image of the card spread, you’ll see a large input box. This is where you need to input the name of the card. This should be the name of the card, followed by the initiative value in brackets, and then the level of the card, in square brackets. For example, "Mighty Attack (48) [1]". This should just be in a list, with each card on a new line, similar to the perk list.
Other than having to manually link all the images, and name all the cards, the process is the same as if you were using the site to create your class.
Finish
And that’s it! You’ve now created a class, and imported it into Tabletop Simulator. If you have any questions, feel free to ask in the Discord, and someone will be able to help you out. Have fun playing your new class!