The Nuzlocke challenges that were implemented were the following: - "No Free Heal" which consists in disabling the auto heal that occurs every 10th wave, replacing it with a normal shop phase. Changes made: - Added a new challenge "NO_AUTO_HEAL" with a challenge type "NO_HEAL_PHASE" and created a new function "applyNoHealPhase" to determine whether the Pokémon can heal if the challenge is active ("challenge.ts"). - Added a confirmation on the healing phase to check if the challenge is active or not, and if it is, it should skip the phase ("party-heal-phase.ts"). - Changed the logistic of when the shop should be displayed, so when the challenge is active the shop appears every 10th wave ("modifier-type.ts") and actually push the shop phase ("victory-phase.ts"). - "Hardcore": Challenge divided into two modes, normal and hard, where fainted Pokémon can't be revived, in addition, the hard mode deletes the fainted Pokémon so the player can't switch it's items after death. Changes made: - Added a new challenge "HARDCORE" with several challenge types with the correspondent apply functions ("challenge.ts"), each one is used as follows: - RANDOM_ITEM_BLACKLIST: filter the reward items with only the valid one's ("modifier-type.ts"). - SHOP_ITEM_BLACKLIST: filter the shop items with only the valid one's ("modifier-select-ui-handler.ts"). - MOVE_BLACKLIST: checks if the move selected is allowed and if not sends a message of no apply ("pokemon.ts"). - DELETE_POKEMON: if hard mode was selected, automatically delete the fainted Pokémon from the party ("battle-end-pahse.ts"). - SHOULD_FUSE: changed the logic of should apply function to prohibit the fusion with dead Pokémon ("modifier.ts"). - PREVENT_REVIVE: prevent the gain of hp of fainted Pokémon ("party-heal-phase.ts"). - "Limited Catch": Only the first wild Pokémon encounter of every biome can be added to the player's current party. Changes made: - Added a new challenge LIMITED_CATCH with a challenge type ADD_POKEMON_TO_PARTY and created a new function "applyAddPokemonToParty" to determine whether the Pokémon can be added to the party, which should only occur every 11th wave if it isn't a catchable mystery encounter or every 12th wave if the 11th wave was a catchable mystery encounter ("challenge.ts"). - Changed the logistic of adding a Pokémon where it can be caught so that the "pokedex" is updated but the Pokémon isn't added to the party of the player affecting specifically mystery encounters ("encounter-pokemon-utils.ts") and added the same logic to normal encounters. ("attempt-capture-phase.ts") The changes in the game AI were as follows ("pokemon.ts"): - More accurately accounts for the Pokémon's actual moves and their effectiveness against the player instead of only the pokemon type - Introduced logic to decide when a Pokémon should be sacrificed or switched based on its HP and speed. Signed-off-by: Matilde Simões <matilde.simoes@tecnico.ulisboa.pt> Co-authored-by: Fuad Ali <fuad.ali@tecnico.ulisboa.pt> |
||
---|---|---|
.github | ||
docs | ||
public | ||
scripts | ||
src | ||
test | ||
.dependency-cruiser.cjs | ||
.editorconfig | ||
.env | ||
.env.beta | ||
.env.development | ||
.env.production | ||
.env.test | ||
.gitattributes | ||
.gitignore | ||
.gitmodules | ||
.nvmrc | ||
biome.jsonc | ||
CREDITS.md | ||
dependency-graph.js | ||
eslint.config.js | ||
favicon.ico | ||
global.d.ts | ||
index.css | ||
index.html | ||
lefthook.yml | ||
LICENSE | ||
package-lock.json | ||
package.json | ||
README.md | ||
tsconfig.json | ||
update_exp_sprites.ps1 | ||
vite.config.ts | ||
vitest.config.ts | ||
vitest.workspace.ts |
PokéRogue is a browser based Pokémon fangame heavily inspired by the roguelite genre. Battle endlessly while gathering stacking items, exploring many different biomes, fighting trainers, bosses, and more!
Contributing
🛠️ Development
If you have the motivation and experience with Typescript/Javascript (or are willing to learn) please feel free to fork the repository and make pull requests with contributions. If you don't know what to work on but want to help, reference the below To-Do section or the #feature-vote channel in the discord.
💻 Environment Setup
Prerequisites
- node: 22.14.0
- npm: how to install
Running Locally
- Clone the repo and in the root directory run
npm install
- if you run into any errors, reach out in the #dev-corner channel in discord
- Run
npm run start:dev
to locally run the project inlocalhost:8000
Linting
We're using Biome as our common linter and formatter. It will run automatically during the pre-commit hook but if you would like to manually run it, use the npm run biome
script. To view the complete rules, check out the biome.jsonc file.
📚 Documentation
You can find the auto-generated documentation here. For information on enemy AI, check out the enemy-ai.md file. For detailed guidelines on documenting your code, refer to the comments.md file.
❔ FAQ
How do I test a new _______?
- In the
src/overrides.ts
file there are overrides for most values you'll need to change for testing
How do I retrieve the translations?
- The translations were moved to the dedicated translation repository and are now applied as a submodule in this project.
- The command to retrieve the translations is
git submodule update --init --recursive
. If you still struggle to get it working, please reach out to #dev-corner channel in Discord.
🪧 To Do
Check out Github Issues to see how can you help us!
📝 Credits
If this project contains assets you have produced and you do not see your name, please reach out, either here on GitHub or via Discord.
Thank you to all the wonderful people that have contributed to the PokéRogue project! You can find the credits here.