A cli for setting up and building a shapez.io mod
🏠 Homepage
To setup a shapez.io mod run the following command. Make sure all requirements are installed.
npx create-shapezio-mod init
It puts all project files in a new folder named shapezio-mods. Do not forget to move into this folder to run any other commands.
Next to running this command make sure that java is installed and added to path and when creating building textures python is installed.
When developing or updating a mod there is a chance the modloader or the cli changes to update your local shapez.io and cli you can run the following command in the shapezio-mods folder.
npx create-shapezio-mod upgrade
You can choose if you only want to update the build files or shapez.io.
To setup more mods than just the one created on init you can use the following command. Again make sure all requirements are installed.
npx create-shapezio-mod mod
This command creates a new folder inside the src
folder. There you can start working on your new mod.
When updating shapez.io a types.d.ts
file is created to add type support. If this files somehow gets currupted you can fix it by running the following command in the shapezio-mods folder.
npx create-shapezio-mod typings
If you want to test your mod while making changes you can serve the mod with shapez.io.
yarn dev
A browser tab and shapez will start. Close the browser tab and hit F5 in the shapez winow. It will automatically reload when you make a change to your mod.
If your mod is finished and you want to share it you can run the following command in the working directory.
yarn build
This will generate a build
folder with a <mod_id>@<version>.js
in it. The js file is the file you need to share it has all your images, translations, themes and css build in.
When everything is installed you should have a project with a src
folder and in there some other directories: js
, css
, translations
, themes
and res
.
The js
folder contains all the code for your script. In the js
folder there is a main.js
file this is the start of your mod. You can use the cli examples or the shapez.io examples for refence. Do note that you don't need to use shapez.
, your editor will auto recognize all the shapez imports and import them, this way you get intellisense and autocompletion. In side the javascript you can also import images. It will import the images as a base64 string. import building1 from "../res/icons/building1.png";
To change or add images or building sprites you can use the res
folder. To change building sprites put them in the sprites/buildings
folder. You can use the python script to generate the blueprint images or create them your self and put them in the sprites/blueprints
folder.
It contains a default setup for a mod. The css
folder contains a main.scss
here you can use your scss or css to add to shapez. If you want to add images you can use url("../res/icons/building1.png")
this will link to the icon in res/icons/building1.png
.
The translations folder can contain files with two letter language codes as names and ending in yaml: en.yaml
. In these files you can change translations or add translations. You can have a look at the shapez.io translations to see how it works.
Please report any bugs you find in the shapez.io modloader discord or create a new issue
- Follow the instructions on https://code.visualstudio.com/docs/setup
- Download and install nodejs from the official nodejs website: https://nodejs.org/en/blog/release/v16.16.0
- Check if nodejs is installed correctly by running
node --version
- If not try again or search on the internet
- After installing nodejs run the following command or install via yarn's official webiste: https://classic.yarnpkg.com/lang/en/docs/install
npm install --global yarn
- Download and install java from the official java website. It needs to be Node 16: https://www.oracle.com/java/technologies/downloads/
- Check if java is installed correctly by running
java -version
- If not add java to path: https://www.java.com/en/download/help/path.html
- Download and install python from the official python website: https://www.python.org/downloads/
- Follow the install instructions from github or git: https://github.com/git-guides/install-git
- Download ffmpeg: https://ffmpeg.org/download.html
- Add ffmpeg to path: https://www.java.com/en/download/help/path.html
👤 DJ1TJOO
- Github: @DJ1TJOO
Give a ⭐️ if this project helped you!