Thanks for considering contributing to Phanary's continuing development!
There are all kinds of contributions that the project could benefit from, even minor changes like catching spelling and formatting errors.
Please consider submitting bug reports and feature requests and writing code to offer optimizations, new functionality, and improvements.
- Ensure cross-browser compatibility and mobile responsiveness for every change that's accepted. Chrome, Firefox, and Safari, at the very least.
- Open a new issue for any major change and enhancement that you wish to make. Discuss things transparently and get community feedback.
- Avoid adding any classes to the codebase unless absolutely needed. Err on the side of using functions.
- Be welcoming to newcomers and encourage diverse new contributors from all backgrounds. See the Contributor Covenant.
- Create your own fork of the repository.
- Clone the repository.
- Ensure that you have a recent version of Node.js installed locally.
- From the repository's root folder, run
npm install
to install package dependencies. - Install Handlebars template precompiler:
npm install -g handlebars@^4.7.3
. - If not already installed, install the Gulp Command Line Utility.
- Set up database:
- Install MongoDB and run it (Note: on Windows, running
./mongod
may be required, or double-clickingmongod.exe
). - From the repository's root folder, run the following commands to import the most recent backups of the database (after inserting the correct path to MongoDB for your system, which on Windows should look something like
/c/Program\ Files/MongoDB/Server/4.2/bin/
):
[/Path/To/MongoDB/Server/4.2/bin/]mongoimport.exe -d phanary -c atmospheres --drop --file db_backups/atmospheres.js [/Path/To/MongoDB/Server/4.2/bin/]mongoimport.exe -d phanary -c tracks --drop --file db_backups/tracks.js [/Path/To/MongoDB/Server/4.2/bin/]mongoimport.exe -d phanary -c oneshots --drop --file db_backups/oneshots.js
- Install MongoDB and run it (Note: on Windows, running
- Run
npm start
from the repository's root directory to connect to MongoDB, and open up a live-updating preview of the site in your browser. - Make your changes.
- Submit a pull request for review.
Note: You'll only be able to play tracks and one-shots that have been added to the database and have been processed using the
gulp audio
command. After being processed, output is placed in thepublic/audio/converted
directory.
Note: You can expect a response from a maintainer within 7 days. If you haven’t heard anything by then, feel free to send an email to [email protected].
Note: Please avoid using the issue tracker for support questions.
Until an FAQ page is created, we'd be happy to field questions about using Phanary at [email protected].
Note: If you find anything you think could be a security vulnerability, please do NOT open an issue. E-mail [email protected] instead.
When opening an issue, make sure to answer all relevant questions in the issue template.
Phanary was designed and built to be a powerful, fast, and free option for RPG game masters to use to provide atmospheric music and sound effects.
Its primary utility lies in its effectiveness at searching and playing relevant sounds as quickly as possible.
The success of this project can be measured by how well it can be used unobtrusively in a game session to maintain pacing, flow, and immersion.
Phanary has an extensive to-do list of features to add and enhancements to make, many of which have been born directly from user suggestions and ideas. Open an issue that describes the feature you would like to see, why you need it, and how it should work.
- CamelCase should be used for class and variable names.
- JavaScript class names should start with a Capital.
- CSS classes should be named using The BEM Approach.