Skip to content

Structured source code for generating the DCC RPG character sheet for Roll20

License

Notifications You must be signed in to change notification settings

rgould/dcc_tabbed_sheet

Repository files navigation

DccTabbedSheet

Maintain and compile the DCC Tabbed Sheet for Roll20. The original HTML file on Roll20 is 11k lines long and is difficult to maintain. This project uses some libraries from Ruby on Rails (ActionView specifically), to make it possible to build the HTML for the character sheet using ERB. This lets us break the file up into multiple files, organize it in a maintainable manner, and reuse sections without duplicating the code.

Usage

Fork this repo, then look at the files in views/ to see how the HTML is built. Make changes as you see fit, and then run ./bin/compile to compile the source files into one single HTML file. This file will then be available in the build/ directory. Copy this file into your game in roll20 to test it. If you want to publish your changes to the main roll20 repo itself, then you can copy this file into that repo, and make a pull request as normal.

Development

After checking out the repo, run bin/setup to install dependencies.

TODO

  • Separate the compilation mechanism from the DCC Tabbed Sheet specifically. This should be something any sheet can use, not just the DCC one
  • A script to quickly copy the build result into the roll20-character-sheets repo and push it to GitHub
  • A mechanism to quickly upload the build result to a game on roll20 (faster testing!)
  • An "emulator" so that you can run the character sheet locally while developing
  • A similar mechanism for compiling CSS files
  • Allow custom builds, so that it's easy for a Judge to mix their own customizations with the default template (thus easy to get upstream changes)

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/rgould/dcc_tabbed_sheet. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the code of conduct.

Cookbook

Hiding/showing elements

Two steps:

  1. Add checkbox that toggles hidden status:
<%= option_toggle("can_backstab") %>
  1. Add helpers around item to be hidden:
<%= shown_when_option_set("can_backstab") do %>
  <%= render "classes/shared/backstab" %>
<% end %>

To hide an element when an option is set, use hidden_when_option_set

License

The gem is available as open source under the terms of the MIT License.

The original code for the character sheet itself is pulled from the roll20-character-sheets repository.

Code of Conduct

Everyone interacting in the DccTabbedSheet project's codebases and issue trackers is expected to follow the code of conduct.

About

Structured source code for generating the DCC RPG character sheet for Roll20

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published