From 5a79b50f1dca55cad11605381c7d52698bf5cb0d Mon Sep 17 00:00:00 2001 From: Felix Staud Date: Thu, 11 Jul 2024 10:30:26 -0700 Subject: [PATCH] lost at sea encounter finishing touches --- .../dialogue/lost-at-sea-dialogue.ts | 9 +-- .../encounters/lost-at-sea-encounter.ts | 77 ++++++++++++++----- .../en/mystery-encounters/lost-at-sea.ts | 3 +- 3 files changed, 61 insertions(+), 28 deletions(-) diff --git a/src/data/mystery-encounters/dialogue/lost-at-sea-dialogue.ts b/src/data/mystery-encounters/dialogue/lost-at-sea-dialogue.ts index 1bfea19d83e..3e0e69c1a97 100644 --- a/src/data/mystery-encounters/dialogue/lost-at-sea-dialogue.ts +++ b/src/data/mystery-encounters/dialogue/lost-at-sea-dialogue.ts @@ -5,8 +5,8 @@ const namepsace = "mysteryEncounter:lostAtSea"; export const LostAtSeaDialogue: MysteryEncounterDialogue = { intro: [ { - text: `${namepsace}:intro` - } + text: `${namepsace}:intro`, + }, ], encounterOptionsDialogue: { title: `${namepsace}:title`, @@ -42,9 +42,4 @@ export const LostAtSeaDialogue: MysteryEncounterDialogue = { }, ], }, - outro: [ - { - text: `${namepsace}:outro`, - }, - ], }; diff --git a/src/data/mystery-encounters/encounters/lost-at-sea-encounter.ts b/src/data/mystery-encounters/encounters/lost-at-sea-encounter.ts index 28a8c572872..fb902bb9958 100644 --- a/src/data/mystery-encounters/encounters/lost-at-sea-encounter.ts +++ b/src/data/mystery-encounters/encounters/lost-at-sea-encounter.ts @@ -8,7 +8,11 @@ import MysteryEncounter, { MysteryEncounterTier, } from "../mystery-encounter"; import { MysteryEncounterOptionBuilder } from "../mystery-encounter-option"; -import { leaveEncounterWithoutBattle } from "../mystery-encounter-utils"; +import { + applyDamageToPokemon, + leaveEncounterWithoutBattle, + setEncounterExp, +} from "../mystery-encounter-utils"; /** * Damage percentage taken when wandering aimlessly. @@ -17,9 +21,12 @@ import { leaveEncounterWithoutBattle } from "../mystery-encounter-utils"; */ const DAMAGE_PERCENTAGE: number = 30; // 0 - 100 +let waterPkm: PlayerPokemon; +let flyingPkm: PlayerPokemon; + /** * Lost at sea encounter. - * @see {@link https://github.com/AsdarDevelops/PokeRogue-Events/issues/9|GitHub Issue #9} + * @see {@link https://github.com/AsdarDevelops/PokeRogue-Events/issues/9 | GitHub Issue #9} * @see For biome requirements check [mysteryEncountersByBiome](../mystery-encounters.ts) */ export const LostAtSeaEncounter: MysteryEncounter = @@ -39,7 +46,9 @@ export const LostAtSeaEncounter: MysteryEncounter = ]) .withSceneWaveRangeRequirement(11, 179) .withOnInit((scene: BattleScene) => { - const party = scene.getParty(); + const allowedPokemon = scene + .getParty() + .filter((p) => p.isAllowedInBattle()); const { mysteryEncounter } = scene.currentBattle; mysteryEncounter.setDialogueToken( @@ -48,11 +57,11 @@ export const LostAtSeaEncounter: MysteryEncounter = ); // check for water pokemon - const waterPkm = findPokemonByType(party, Type.WATER); + waterPkm = findPokemonByType(allowedPokemon, Type.WATER); mysteryEncounter.setDialogueToken("waterPkm", waterPkm?.name ?? ""); // check for flying pokemon - const flyingPkm = findPokemonByType(party, Type.FLYING); + flyingPkm = findPokemonByType(allowedPokemon, Type.FLYING); mysteryEncounter.setDialogueToken( "flyingPkm", flyingPkm?.name ?? "" @@ -67,10 +76,9 @@ export const LostAtSeaEncounter: MysteryEncounter = .withOption( new MysteryEncounterOptionBuilder() .withPokemonTypeRequirement(Type.WATER, true, 1) - .withOptionPhase(async (scene: BattleScene) => { - console.debug("Lost at sea: Option 1 - Water Pokemon"); - leaveEncounterWithoutBattle(scene); - }) + .withOptionPhase(async (scene: BattleScene) => + handleGuidingOption(scene, waterPkm) + ) .build() ) /** @@ -80,26 +88,57 @@ export const LostAtSeaEncounter: MysteryEncounter = .withOption( new MysteryEncounterOptionBuilder() .withPokemonTypeRequirement(Type.FLYING, true, 1) - .withOptionPhase(async (scene: BattleScene) => { - console.debug("Lost at sea: Option 2 - Flying Pokemon"); - leaveEncounterWithoutBattle(scene); - }) + .withOptionPhase(async (scene: BattleScene) => + handleGuidingOption(scene, flyingPkm) + ) .build() ) /** * Option 3: Wander aimlessly. All pokemons lose 30% of their HP (or KO on 0 HP). */ .withOptionPhase(async (scene: BattleScene) => { - const party = scene.getParty().filter((p) => !p.isFainted()); - party.forEach((pkm) => { - const damage = Math.round(pkm.getMaxHp() / (DAMAGE_PERCENTAGE / 100)); - pkm.hp = Math.min(pkm.hp, damage); + const allowedPokemon = scene + .getParty() + .filter((p) => p.isAllowedInBattle()); + + allowedPokemon.forEach((pkm) => { + const percentage = DAMAGE_PERCENTAGE / 100; + const damage = Math.floor(pkm.getMaxHp() * percentage); + return applyDamageToPokemon(pkm, damage); }); leaveEncounterWithoutBattle(scene); return true; }) .build(); -const findPokemonByType = (party: PlayerPokemon[], type: Type) => { +/** + * Find a pokemon inside the given party by a given type + * + * @param party player pokemon party + * @param type type to search for + * @returns + */ +function findPokemonByType(party: PlayerPokemon[], type: Type) { return party.find((p) => p.getTypes(true).includes(type)); -}; +} + +/** + * Generic handler for using a guiding pokemon to guide you back. + * + * @param scene Battle scene + * @param guidePokemon pokemon choosen as a guide + */ +function handleGuidingOption(scene: BattleScene, guidePokemon: PlayerPokemon) { + /** Base EXP value for guiding pokemon. Currently Lapras base-value */ + const baseExpValue: number = 187; + + if (guidePokemon) { + setEncounterExp(scene, guidePokemon.id, baseExpValue, true); + } else { + console.warn( + "Lost at sea: No guide pokemon found but pokemon guides player. huh!?" + ); + } + + leaveEncounterWithoutBattle(scene); +} diff --git a/src/locales/en/mystery-encounters/lost-at-sea.ts b/src/locales/en/mystery-encounters/lost-at-sea.ts index a5846acf058..e4ea07c77ad 100644 --- a/src/locales/en/mystery-encounters/lost-at-sea.ts +++ b/src/locales/en/mystery-encounters/lost-at-sea.ts @@ -12,7 +12,7 @@ export const lostAtSea = { selected: "@ec{waterPkm} guides you back and earns EXP.", }, 2: { - label: "Use @ec{flyingPkm}", // pkm has to be of type water + label: "Use @ec{flyingPkm}", // pkm has to be of type flying tooltip: "Use @ec{flyingPkm} to guide you back. @ec{flyingPkm} earns EXP as if having defeated a Lapras.", selected: "@ec{flyingPkm} guides you back and earns EXP.", @@ -25,5 +25,4 @@ export const lostAtSea = { "You wander aimlessly around. After hours of wandering, you find your way back. You and your team take the toll.", }, }, - // outro: "TBA: OUTRO MESSAGE", };