Skip to content

Latest commit

 

History

History
223 lines (156 loc) · 15.5 KB

README.md

File metadata and controls

223 lines (156 loc) · 15.5 KB

PurseStrings

Changes in version 6.0:

  1. Removed PotionManager and GearManager integration, replacing those scripts with ItemDB for adding purchased items to character sheets.
  2. Added conversion function to enable consolidation of coins into higher denominations.
  3. Updated sheet detection to allow manual setting of the sheet in cases where character sheets may contain conflicting attributes. If script output in chat is empty, use !ps --sheet to detect the sheet from a current PC character.

This Roll20 script handles currency and currency exchanges for characters in games using the default SRD monetary system. It manages a character's currency and will add/subtract appropriately when collecting loot, paying for goods/services, etc. This script also includes an Inventory system, allowing a dynamic Merchant experience. You can create any number of Merchant NPCs with an Inventory that is updated with every purchase.

This script is for use with the D&D 5th Edition OGL Sheet and the 5e Shaped Sheet.

Coinage

PurseStrings is fairly flexible in the way it accepts coinage through the various commands. It can be sent as either a list of amounts & denominations (commas and spaces between numbers and denominations are accepted), or as a shorthand list with a colon separating the amounts in denominational order from smallest to largest (cp, sp, ep, gp, pp) with zeros for placeholders.

All of the examples below represent 30cp and 4gp:

  • 30cp 4gp
  • 30 cp 4 gp
  • 30cp, 4gp
  • 30:0:0:4:0

Merchant Setup

Merchants are NPCs that have items or services to sell. A Merchant has two requirements:

  1. It must be a token that contains the Merchant's Inventory (below) in the token's GM Notes, and
  2. The token must represent a Character that has been set up with PurseStrings.

As it is not required for the Merchant token to be the default token of the character, you have more flexibility and fewer character sheets to load. You can create a generic Merchant character and use it with multiple tokens - they will all have different Inventory but use the same pool of money for transactions. If you wish to use a character as a Merchant, see below.

You can allow a Merchant's Inventory to override the default setting by adding "show-stock" or "hide-stock" to the first Bar 1 box on the token. This allows you to mix up inventory "types" such as a restaurant menu and a shopkeeper's stock.

To create a Merchant, follow the instructions below.

  1. Select and Edit a token you wish to represent your Merchant.
  2. Add "show-stock" or "hide-stock" to the first Bar 1 box, if desired.
  3. Edit the token's GM Notes field.
  4. The first line of Inventory must be either "PurseStrings Inventory" or "PurseStrings Menu" and nothing else. The dialog displayed through the --invlist command will give the name of the Merchant token along with either "Inventory" or "Menu" as you provide here.
  5. Enter each item on its own line in the following manner:
    Item Name|price|quantity
    If you wish to have an item that is "infinitely available" such as ale or services of any kind, leave the quantity blank:
    Item Name|price|
    Price must be a single denomination, i.e. "2cp" or "1200gp" and not "2cp, 1200gp".
  6. If you have multiple categories, you may add category headers by simply giving the category name its own line above the items of that category.
  7. The PurseStrings inventory data must be the only data in the token's GM Notes field!
  8. Click the 'Save Changes' button.

Here is an example GM Note for a small town blacksmith Merchant:

PurseStrings Inventory
Services
Sword Sharpening|2gp|
Armor Polishing|5gp|
Weapons
Dagger|2gp|5
Handaxe|5gp|3
Shortsword|10gp|1
Adventuring Gear
Potion of Healing|50gp|4
Alchemist's Fire|50gp|2

If a Merchant buys an item from a player that is not already in their inventory, it will be added to the list. It is assumed that Merchants will buy at half their selling cost, so the inventory price on new items will be double the amount at which it was purchased. Updates to inventory outside of purchases may be done by editing the GM Notes field. See the --buy command for options and information.

Advice on GM Notes The GM Notes field is a WYSIWYG editor, and cutting and pasting from the web or a word processor like Google Docs, Microsoft Word or Pages can carry over formatting which causes problems in processing your Inventory. If you are having problems with inventory showing in chat, try cutting from your original source (the web, word processor, etc.) and paste into a text editor first, or create the content in the text editor itself. Then cut from the text editor and past into the GM Notes field.

Characters as Merchants

If you wish to use a character as a Merchant, you must make the Merchant token the default token for the character. There are two ways to ensure the Merchant's Inventory remains up-to-date on the character:

  • If the Merchant token's name is the same as the character's name, the default token will automatically be updated whenever inventory changes. Be aware that all other token settings will be saved, including rotation, status markers, auras, etc.
  • If the names do not match, you will need to update the default token manually using the --update-merchant command before removing the token from the VTT.

Syntax

!ps <command>

Commands:


--help

Whispers a PurseStrings help dialog in the chat window. It gives relative commands depending on whether the player is GM. The GM will also get a button to display the Config Menu.

!ps --help


--config

GM Only This gives you a short dialog menu with all of the PurseStrings configuration options so you can customize it for your game. It displays a list of your Party Members with a button to add them, links to change the default settings, and a button to setup characters for PurseStrings.

!ps --config

Merchant Stock

When a merchant's inventory is displayed, you can choose to whether or not to show the quantity of each item. When you show quantities, out-of-stock items (quantity of zero) will display "out of stock." If you are hiding quantities, the out-of-stock items will not be not displayed at all. Any items that have an "infinite availability" such as services (see above) will always be shown and will never display any quantity regardless of the this setting.

You can also override this value individually on each Merchant token. To do so, simply add "show-stock" or "hide-stock" to the first Bar 1 box on the token.

Default is to show quantities.

Recording Purchases

When a player character purchases an item from a Merchant, PurseStrings can record the purchase to the character's sheet for later reference. For the 5e Shaped sheet, it is recorded in the Miscellaneous Notes field near the bottom. For the 5th Edition OGL sheet, it is recorded in the Treasure field in the Bio tab. This applies only to Inventory items that do not have an infinite availability.

The script will add a line beginning with "PURCHASED ITEMS:" followed by a list of all items purchased. Multiple items will have a number in parentheses corresponding to how many have been purchased. This function ignores all other text in the field.

The default is to record purchases.

Script Integration

PurseStrings will detect the presence of the ItemDB script and can optionally add purchased items to the buyer's character sheet according to that script's configuration. You can enable/disable this behavior is in the config dialog if you have Recording Purchases turned on.

The default is enabled.


--setup

GM Only This command ensures the proper currency attributes exist and adds a "ShowPurse" token action for calling the --show command (below) to view the character's Purse. Select each token representing the character(s) you want to setup and run the following command:

!ps --setup

IMPORTANT! Any character sheet that does not have values in each of the currency fields will break the script. The !ps --setup command is specifically created to enable the core functionality of the PurseStrings script. Make sure to use this command for every character that will use PurseStrings after installation of the script.

If you wish to add a starting amount to the selected characters, you can optionally pass the coinage parameter along with the --setup command. Keep in mind the given amount will be added to every selected character. The following adds 50cp, 20sp, and 10gp to each selected character:

!ps --setup 50:20:0:10:0

If you have already setup the selected token as a Merchant, this command will add a "ShowInventory" token action as well.


--party

GM Only You may add characters to a Party Members list. This will allow you to distribute loot (below) without needing to select player tokens. To do this, select the tokens representing the characters you wish to add and use the following command:

!ps --party

Using this command again will simply add the new token to the list. If you wish to remove characters from the Party Members list, you will essentially start over with a new group. Select the tokens you wish to keep and pass --reset along with the --party command:

!ps --party --reset

Passing the --reset command without tokens selected will remove all characters from the list.


--show

To display the contents of a character's Purse, use the --show command. It will display Purse contents for all selected tokens, and shows the total weight of all coins for encumbrance purposes:

!ps --show

You may also send an optional --whisper command to make --show whisper the results. This is default in the "ShowPurse" token action added during character setup.

!ps --show --whisper


--dist

GM Only When the players have discovered treasure, you may use PurseStrings to distribute the coinage portion of the loot evenly among Party Members using --dist command. Coinage can be in any format above.

!ps --dist 156:280:0:666:0
!ps --dist 146sp, 398gp

--add

GM Only To add coinage to a character(s) Purse, simply pass it with the --add command. The following adds 10gp to each selected character:

!ps --add 10gp


--subt

GM Only To simply remove coinage from a character(s) Purse (without giving it to another character) you use the --subt command along with the amount of coinage you wish to remove. If the amount of the coinage is more than what that character has in their Purse, the operation will fail. The following subtracts 10gp from each selected character:

!ps --subt 10gp

Equivalences are used when determining what coins are removed. For instance, if the Purse has 50sp and 5gp and the amount to subtract is 6gp, the Purse will contain 40sp and 0gp once the subtraction is complete. A Purse with 2cp and 7sp can subtract 5cp and the script will borrow from larger denominations to make up the remainder, in this case leaving the Purse at 7cp and 6sp.


--convert

GM Only When a character has a large number of small denomination coins in their Purse, they may want to convert them into larger denominations to save space and weight. The GM can select a character's token and send the --convert command along with the acronym for the denomination you wish to convert to:

!ps --convert gp

The command above will convert all of the character's cp and sp into gp. All denominations are valid aside from 'cp' for obvious reasons.


--give

Characters can exchange money between themselves. You must send a token ID that represents both the giving character and the taking (receiving) character along with the amount being given. If you have a character that acts as a "bank" for the Party and does not have a token on the VTT, you can pass the character ID as a taker only.

!ps --give --giver|<giver_token_id> --taker|<taker_token_id> --amt|50gp

As with the --subt command (above), the exchange will fail if the amount of the coinage is more than what the giver has in their Purse, and equivalences will be used for making change.


--buy

Characters can also pay for goods & services as well. PurseStrings handles the monetary transaction along with updating the Merchant's Inventory (see above). On a successful transaction, a character who has purchased an item will have that item recorded on their sheet if the record purchases option is turned on.

To exchange money for an item or service, you use the --buy command. The IDs of tokens representing both the buyer and the seller must be included, along with the purchase amount and the name of the item.

!ps --buy --buyer|<buyer_token_id> --seller|<seller_token_id> --amt|50gp --item|Potion of Healing

You can send a category for the item by separating the name and category with a tilde symbol (~). This will allow you to categorize items that are not already in a Merchant's Inventory. If no category is sent, an "Uncategorized" category will be used.

!ps --buy --buyer|<buyer_token_id> --seller|<seller_token_id> --amt|37gp --item|Greatsword~Weapons

As with the --subt command (above), the transaction will fail if the price is more than what the buyer has in their Purse, and equivalences will be used for making change.

The Inventory dialog for Merchants (below) outputs the proper code for all purchases from a Merchant. Players will simply click the "Buy" link in the Inventory dialog to make a purchase. Once the inventory has been updated, a new inventory list dialog will automatically be generated with any quantity changes.


--invlist

GM Only You can display a Merchant's Inventory (see setup instructions above) using the --invlist command followed by the Merchant token's ID:

!ps --invlist <merchant_token_id>

This generates a dialog with the Merchant's inventory/menu and provides the item name, price, and a link the player's can use to make the purchase.


--update-merchant

GM Only For characters you wish to use as a Merchant rather than multiple Merchant tokens sharing the same character (see above), you set the character's default token as the one that contains the Merchant's Inventory. In this manner, a Merchant can be quickly moved to the VTT from the Journal. Inventory will be updated automatically if the name on the default token is the same as the character's name. To update manually, use the --update-merchant command on the selected Merchant token before it is removed from the VTT.

!ps --update-merchant

This command is not necessary if the name of the Merchant token is the same as the character's, or if you otherwise have reason not to update inventory on the character.