Skip to content

Commit

Permalink
Merge pull request #13694 from vince-roll20/PF_Community_Source
Browse files Browse the repository at this point in the history
Pf Community
  • Loading branch information
nmbradley authored Jan 21, 2025
2 parents 53520b8 + 33bb2bd commit d8f21aa
Show file tree
Hide file tree
Showing 64 changed files with 65,645 additions and 29 deletions.
10 changes: 10 additions & 0 deletions Pathfinder Community/dev/.babelrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{
"presets": [
[
"@babel/preset-env",
{
"targets": ">0.25%"
}
]
]
}
9 changes: 9 additions & 0 deletions Pathfinder Community/dev/.prettierrc.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
{
"singleQuote": false,
"arrowParens": "always",
"useTabs": true,
"tabWidth": 2,
"endOfLine": "lf",
"semi": true,
"bracketSpacing": false
}
37 changes: 37 additions & 0 deletions Pathfinder Community/dev/HtmlWorkerScriptPlugin.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
class HtmlWorkerScriptPlugin {
apply(compiler) {
compiler.hooks.compilation.tap('HtmlWorkerScriptPlugin', (compilation) => {
// Hook into HtmlWebpackPlugin's emit stage
const HtmlWebpackPlugin = compiler.options.plugins.find((plugin) => plugin.constructor.name === 'HtmlWebpackPlugin');

if (HtmlWebpackPlugin) {
HtmlWebpackPlugin.constructor.getHooks(compilation).beforeEmit.tapAsync('HtmlWorkerScriptPlugin', (data, callback) => {
console.log('HtmlWorkerScriptPlugin modifying HTML asset');
const jsAsset = compilation.assets['index.js'];

if (jsAsset) {
const jsCode = jsAsset.source();
// Append inline script to the end of the html
data.html += `\n<script type="text/worker">${jsCode}</script>`;

// Replace placeholders and clean up
const currentDate = new Date().toUTCString();
data.html = data.html.replace('$$CURRENTRELEASEDATE$$', currentDate);

if (process.env.NODE_ENV === 'production') {
data.html = data.html.replace(/^\s*<!--DEVELOPMENT CODE\. NOT READY FOR PRODUCTION YET-->\s*\r?\n?/gm, '');
}
} else {
console.error('HtmlWorkerScriptPlugin: JavaScript asset not found.');
}

callback(null, data);
});
} else {
console.error('HtmlWorkerScriptPlugin: HtmlWebpackPlugin not found.');
}
});
}
}

module.exports = HtmlWorkerScriptPlugin;
97 changes: 97 additions & 0 deletions Pathfinder Community/dev/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,97 @@
# Pathfinder Community Sheet for Roll20.net
## Editing
Unlike most character sheets found on [Roll20's repo](https://github.com/Roll20/roll20-character-sheets), the [Pathfinder Community Sheet](https://github.com/Roll20-Pathfinder-Character-Sheet/Roll20-Pathfinder-Character-Sheet) must be edited/developed within a specific local environment. Sheetworkers have been separated into various es modules based on their specific sheet sections or function(s). It is necessary to minimally install Git and Node/NPM. The html and js must be bundle using npm commands and webpack. More details below.

In order to edit the sheet locally, complete the following sections;

## Install Git or Desktop GUI
You will need to fork and clone the [Pathfinder Community Sheet](https://github.com/Roll20-Pathfinder-Character-Sheet/Roll20-Pathfinder-Character-Sheet) using Git and/or Github Desktop Gui.

- Git for [Windows](https://gitforwindows.org/)
- Git for [Linux](https://git-scm.com/download/linux)
- Github [Desktop GUI](https://desktop.github.com/download/)

If you are going to setup with VScode [See specific instructions below](https://github.com/Roll20-Pathfinder-Character-Sheet/Roll20-Pathfinder-Character-Sheet?tab=readme-ov-file#specific-instructions-for-setting-up-with-vscode) you can skip the Limited Install steps.

## Limited Install using Node.js using NVM
This is a good option if you are not going to use VScode as your editor.
#### Windows
1. Download and install latest version of Node Version Manager(NVM): https://github.com/coreybutler/nvm-windows/releases
2. Open a **NEW** shell (Right click -> Open Git Bash Here/Git GUI Here) You can not use one which was opened before NVM is installed.
3. Run `nvm install latest` to install the latest version of node.js
4. Run `nvm list available` and note the version you want to use. The latest version should be fine.
5. Run `nvm use node <version#>` include the proper version number as noted above.
#### Linux/Mac (adjust node version as needed)
1. Run `curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.0/install.sh | bash`
2. Close and reopen your terminal
3. Run `nvm install 6.9.5`
4. Run `nvm alias default 6.9.5`
5. Run `nvm use 6.9.5`

#### Dependencies
**NPM** is distributed with Node.js - which means that when you download [Node](https://nodejs.org/en/download/package-manager), you automatically get NPM installed on your computer as well.

#### Install Curl executable (If you don't have it already)
**Curl** allows us to download [TheArronSheet.js](https://github.com/shdwjk/TheAaronSheet), instead of maintaining our own copy.
1. Go to https://curl.se/download.html and download the correct version for your OS.
2. Unzip and save to a directory on your computer ie on windows; `c:\curl` and copy curl.exe to `c:\windows\system32\`
3. You may need to add the .\Curl install directory or `curl.exe` to your windows environment PATH variable [More Info](https://www.computerhope.com/issues/ch000549.htm)

## VScode Installation
Here are some instructions for using VScode for editing the sheet.

#### Install git
1. Download the Github [Desktop GUI](https://desktop.github.com/download/) and/or install **Git** as noted above. You may also have both installed side-by-side.
2. Add the Github for Windows install directory to your windows environment [PATH](https://windowsreport.com/edit-windows-path-environment-variable/) variable.
More specific instructions; there is only a 'cmd' directory, not a bin directory, contrary to the directions. [More info](https://www.answerlookup.com/how-add-git-windows-path-environment-variable).

#### VScode and Node.js integration
1. Download and install [VScode](https://code.visualstudio.com/download)
2. Install [Node](https://nodejs.org/) using vscode's integrated terminal. ie `npm install`
3. You may want to create a unique [Workspace](https://code.visualstudio.com/docs/editor/workspaces) specifically for editing the pathfinder sheet.

#### Reccomended Vscode Extensions
- [NPM Intellisense](https://marketplace.visualstudio.com/items?itemName=christian-kohlernpm-intellisense)
- [Eslint extension](https://marketplace.visualstudio.com/items?itemName=dbaeumer.vscode-eslint)
(works with included ./eslint.config.mjs)
- [Prettier Eslint](https://marketplace.visualstudio.com/items?itemName=rvest.vs-code-prettier-eslint)
(works with included ./.prettierrc.json)
- [GetLens](https://marketplace.visualstudio.com/items?itemName=eamodio.gitlens)

#### Install Curl
**Curl** is required. [See above](https://github.com/Roll20-Pathfinder-Character-Sheet/Roll20-Pathfinder-Character-Sheet#install-curl-executable-if-you-dont-have-it-already).

### Editing and Submitting updates
1. [Fork](https://github.com/Roll20-Pathfinder-Character-Sheet/Roll20-Pathfinder-Character-Sheet/fork) the Pathfinder Community Sheet code if you haven't already done so.
2. Clone the project from within VScode or [Github Desktop](https://desktop.github.com/)
3. It's highly reccomended that you create new "working" branches based on the Development branch.
4. Submit commits to your working branch until you are done editing and then submit a pull request to Origin/Develop for approval.
5. Once the latest changes on the Develop branch are approved, they will be merged into the Origin/Master.
6. A pull request for any new changes on the Pathfinder Sheet's repo Origin/Master will need to be submitted to Roll20's repository for approval. You may need to fork and clone the [Roll20's repo](https://github.com/Roll20/roll20-character-sheets).

## Build/Compile Commands
- Run `npm run build` - Builds the project's index.html Use Case: development/testing. Output to "dist" folder.
- Run `npm run prod` - Turns **debug off** automatically. Builds the project's index.html Use Case: roll20 production. Output to "prod" folder.
- Run `npm run postinstall` - downloads [TheArronSheet.js](https://github.com/shdwjk/TheAaronSheet) and saves it to the ./src folder as TheAaronSheet.cjs "TAS" is used to handle custom logging/debugging as well as some common utility functions. To simplify bundling, the ./src/TheAaronSheet.js included in the repo is a slightly edited (ie adds module.exports) version of TAS to make it an es6 module as well.

## Viewing in Roll20
* Option 1: Use the bundled index.html from the ./dist or ./prod folder accordingly and the pathfinder.css, translation.json, and sheet.json as included in the ./src folder. These files can be copied as raw text directly into a Custom game's, "Game Settings" editor (HTML|CSS|TRANSLATION). Do not rely on the Preview tab. Always view the sheet in-game for an accurate load.
* Option 2: Sync a Sandbox game to your local files using Scott C's Chrome browser extension [Roll20 API and Sheet Autouploader](https://chromewebstore.google.com/detail/roll20-api-and-sheet-auto/hboggmcfmaakkifgifjbccnpfmnegick) You may need to create a [Symbolic link](https://www.howtogeek.com/16226/complete-guide-to-symbolic-links-symlinks-on-windows-or-linux/) for the ./src/pathfinder.css and/or the ./src/translation.json to the ./dist and ./prod folders so the extension can easily detect local changes.

## Errors/Issues
- Webpack dependencies: update webpack and dev dependencies with caution.

## Module Breakdown
Each "page" or section of the Pathfinder sheet has one or more modules associated with it. For instance, the core page has PFAbilityScores, PFInitiative, PFClassRaceGrid etc. The Defense page has PFDefense, PFSaves. The Attacks page has PFAttacks, spells page PFSpells, etc.

## Repeating sections
Pages with repeating sections will have a module for the repeating list, another module for the page-level variables (usually above it on the page), and a 3rd module for "roll options" the user has selected. For the attacks page it is :
* **PFAttacks:** the repeating_weapon list
* **PFAttackGrid:** the melee,ranged,cmb grid at the top
* **PFAttackOptions: ** the options checkboxes and how they affect macros

spells:
* **PFSpells:** the repeating_spells list
* **PFSpellCasterClasses:** The spell caster section, spells per day, spell points, etc
* **PFSpellOptions:** the spell options and updating of macros

8 changes: 8 additions & 0 deletions Pathfinder Community/dev/jsconfig.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"compilerOptions": {
"target": "ES6"
},
"exclude": [
"node_modules", "dist"
]
}
Loading

0 comments on commit d8f21aa

Please sign in to comment.