Skip to content

Latest commit

 

History

History
91 lines (64 loc) · 3.13 KB

README.md

File metadata and controls

91 lines (64 loc) · 3.13 KB

Kelsin's 18xx Prototyping React Library

This is a small pet project to help layout and print 18xx games.

Important Note: A small version of the site is up and running on 18xx.kelsin.net. This version only has a few games on it. If you want to see all games included in the data files you'll need to download the app and run it yourself (or run the public docker image). If any designers/publishers would like to add their games to this public site just let me know!

This project was bootstrapped with Create React App.

Donation

I've been asked about donation buttons, if you find this software usefull to you and would like to donate money towards it's development you can do so via paypal or square cash.

Usage

This node app uses yarn as it's package managing. Installing with npm is not supported as I can't guaruntee proper package versions.

First install node.js and yarn for your operating system. I recommend using the LTS version of node (current 10.x). The version I'm currently developing with will always be listed in .node-version.

Download the app (either using git or just downloading the zip file from github), and then (from the folder that you downloaded into) run the following:

# Install the dependencies
yarn

# Run the app
yarn start

Printing

Please check out the docs for how to print pdf's from the command line.

Board18

Please check out the docs for information on how to output a full board18 game box .zip file from the command line.

Developing

Adding a game

  1. Copy one of the game files you feel should be closest to the game you're entering from the src/data/games folder. Rename it and edit it as much as needed.

  2. In order for this new game to show up in the UI, please add it to the exported object in the src/data/games/index.js file.

  3. Before opening a PR please run yarn validate and correct any errors.

Docker

If you have docker installed (or available) you can run a public docker image that includes all games. Run the following command and the site should be available at http://localhost (you might need to edit the port depending on your OS and other running apps):

docker run -it --rm -p 80:80 --name 18xx kelsin/18xx

Persistant Docker Volume

If you want to use docker to hack on the site, you can use a docker volume to keep a persistant image of the game code. Knowledge of how to manage docker volumes is important to use this properly.

docker run -it --rm -p 3000:3000 --name 18xx-develop -v 18xx:/home/18xx kelsin/18xx:develop

This will run the react-development server that will live update if you edit files, and store anything edited (starting with the current code) on the volume named 18xx.