Skip to content

A tool to visualise the supply chain of factories to create a true Modular Factory setup for the game Satisfactory.

License

Notifications You must be signed in to change notification settings

satisfactory-factories/application

Repository files navigation

Satisfactory Factories

This web tool is designed to help players of the video game Satisfactory™ to plan a comprehensive production chain.

The tool highlights bottlenecks in the production chain, and visually tells the player that they have a problem within their designs.

The player can scale up end product factories as they see fit, and check if their production chain can handle the increased load.

Contributing

Since this is an open source project, all PR requests will be welcomed, as long as proper intent and communication with the project maintainers is maintained.


Local Development

This project has the following requirements. We highly recommend you use nvm to manage your node and p(npm) versions.

  • Node.js version >20.17.0 nvm install 20.17 && nvm use 20.17
    • You may want to make 20.17 the default version with nvm alias default 20.17
  • pnpm version >9.14.4 npm install -g pnpm
  • Docker (for the backend) Docker install docs

Frontend

cd web
pnpm install
pnpm dev

Visit http://localhost:3000 to view the project. You may need to load it twice.

Testing

There are tests for the frontend project, run them with pnpm test. Tests must pass for PRs to be accepted. Note as of writing the coverage isn't 100%.

Parsing

The parser is responsible for processing the Docs.json from the game and reconstructing a more readable version for our use, since the game's docs file is overwhelmingly large and not very human-readable. The file is located under X\steamapps\common\Satisfactory\CommunityResources on Windows. Replace X with where you have installed your steam library.

Running the parser and updating the gameData

To run the parser:

cd parsing
pnpm install
pnpm dev

When the parser is run, it outputs to file /parser/gameData.json. This file needs copying to /web/public/gameData_v1.x-xx.json. The version must directly correlate with the minor version of the game (unless a patch messes with a recipe, unlikely). e.g. v1.0-11.json would increment to v1.0-12.json. The old version needs deleting when you commit.

Once the new file has been placed, you must also edit /web/src/config/config.ts and update the version there too.

This instructs web clients to re-download the game data file with the new version upon refresh and replace their locally stored version.

Backend

Required for the login and syncing of data features, not required for local development.

  1. Start Docker service on your local machine.
cd backend
pnpm install
./start.sh

API will be available on http://localhost:3001.

There are no tests currently available for the backend project.

Deployment

New versions are trunked to main branch. Once main has been pushed, GitHub Actions will create a release then deploy the frontend to Vercel, and create a docker image of the backend to deploy to my personal server.


License

This project is licensed under the GNU License - see the LICENSE file for details.

Please kindly consider opening PRs to improve the project, and make it better for everyone rather than making a clone.

Acknowledgements

About

A tool to visualise the supply chain of factories to create a true Modular Factory setup for the game Satisfactory.

Resources

License

Stars

Watchers

Forks

Packages

No packages published