From 82b2d498313668213d4ae884e14447f8f0d5e711 Mon Sep 17 00:00:00 2001 From: Wlowscha <54003515+Wlowscha@users.noreply.github.com> Date: Tue, 16 Sep 2025 19:44:51 +0200 Subject: [PATCH] Added gender restrictions --- src/data/challenge.ts | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/src/data/challenge.ts b/src/data/challenge.ts index 65faa900af7..79192514c5c 100644 --- a/src/data/challenge.ts +++ b/src/data/challenge.ts @@ -466,6 +466,20 @@ export class SingleGenerationChallenge extends Challenge { return false; } + applyStarterSelectModify(speciesId: SpeciesId, dexEntry: DexEntry, _starterDataEntry: StarterDataEntry): boolean { + // Ralts must be male and Snorunt must be female + if (this.value === 4) { + if (speciesId === SpeciesId.RALTS) { + dexEntry.caughtAttr &= ~DexAttr.FEMALE; + } + if (speciesId === SpeciesId.SNORUNT) { + dexEntry.caughtAttr &= ~DexAttr.MALE; + } + } + + return true; + } + applyPokemonInBattle(pokemon: Pokemon, valid: BooleanHolder): boolean { const baseGeneration = getPokemonSpecies(pokemon.species.speciesId).generation; const fusionGeneration = pokemon.isFusion() ? getPokemonSpecies(pokemon.fusionSpecies!.speciesId).generation : 0; @@ -739,6 +753,27 @@ export class SingleTypeChallenge extends Challenge { return false; } + applyStarterSelectModify(speciesId: SpeciesId, dexEntry: DexEntry, _starterDataEntry: StarterDataEntry): boolean { + const type = this.value - 1; + + if (type === PokemonType.FIGHTING && speciesId === SpeciesId.RALTS) { + dexEntry.caughtAttr &= ~DexAttr.FEMALE; + } + if (type === PokemonType.GHOST && speciesId === SpeciesId.SNORUNT) { + dexEntry.caughtAttr &= ~DexAttr.MALE; + } + if (speciesId === SpeciesId.BURMY) { + if (type === PokemonType.FLYING) { + dexEntry.caughtAttr &= ~DexAttr.FEMALE; + } + if ([PokemonType.GRASS, PokemonType.GROUND, PokemonType.STEEL].includes(type)) { + dexEntry.caughtAttr &= ~DexAttr.MALE; + } + } + + return true; + } + applyPokemonInBattle(pokemon: Pokemon, valid: BooleanHolder): boolean { if ( pokemon.isPlayer()