lost at sea encounter finishing touches
This commit is contained in:
parent
85df834811
commit
5a79b50f1d
|
@ -5,8 +5,8 @@ const namepsace = "mysteryEncounter:lostAtSea";
|
||||||
export const LostAtSeaDialogue: MysteryEncounterDialogue = {
|
export const LostAtSeaDialogue: MysteryEncounterDialogue = {
|
||||||
intro: [
|
intro: [
|
||||||
{
|
{
|
||||||
text: `${namepsace}:intro`
|
text: `${namepsace}:intro`,
|
||||||
}
|
},
|
||||||
],
|
],
|
||||||
encounterOptionsDialogue: {
|
encounterOptionsDialogue: {
|
||||||
title: `${namepsace}:title`,
|
title: `${namepsace}:title`,
|
||||||
|
@ -42,9 +42,4 @@ export const LostAtSeaDialogue: MysteryEncounterDialogue = {
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
outro: [
|
|
||||||
{
|
|
||||||
text: `${namepsace}:outro`,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -8,7 +8,11 @@ import MysteryEncounter, {
|
||||||
MysteryEncounterTier,
|
MysteryEncounterTier,
|
||||||
} from "../mystery-encounter";
|
} from "../mystery-encounter";
|
||||||
import { MysteryEncounterOptionBuilder } from "../mystery-encounter-option";
|
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.
|
* Damage percentage taken when wandering aimlessly.
|
||||||
|
@ -17,6 +21,9 @@ import { leaveEncounterWithoutBattle } from "../mystery-encounter-utils";
|
||||||
*/
|
*/
|
||||||
const DAMAGE_PERCENTAGE: number = 30; // 0 - 100
|
const DAMAGE_PERCENTAGE: number = 30; // 0 - 100
|
||||||
|
|
||||||
|
let waterPkm: PlayerPokemon;
|
||||||
|
let flyingPkm: PlayerPokemon;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Lost at sea encounter.
|
* 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}
|
||||||
|
@ -39,7 +46,9 @@ export const LostAtSeaEncounter: MysteryEncounter =
|
||||||
])
|
])
|
||||||
.withSceneWaveRangeRequirement(11, 179)
|
.withSceneWaveRangeRequirement(11, 179)
|
||||||
.withOnInit((scene: BattleScene) => {
|
.withOnInit((scene: BattleScene) => {
|
||||||
const party = scene.getParty();
|
const allowedPokemon = scene
|
||||||
|
.getParty()
|
||||||
|
.filter((p) => p.isAllowedInBattle());
|
||||||
const { mysteryEncounter } = scene.currentBattle;
|
const { mysteryEncounter } = scene.currentBattle;
|
||||||
|
|
||||||
mysteryEncounter.setDialogueToken(
|
mysteryEncounter.setDialogueToken(
|
||||||
|
@ -48,11 +57,11 @@ export const LostAtSeaEncounter: MysteryEncounter =
|
||||||
);
|
);
|
||||||
|
|
||||||
// check for water pokemon
|
// check for water pokemon
|
||||||
const waterPkm = findPokemonByType(party, Type.WATER);
|
waterPkm = findPokemonByType(allowedPokemon, Type.WATER);
|
||||||
mysteryEncounter.setDialogueToken("waterPkm", waterPkm?.name ?? "<NONE>");
|
mysteryEncounter.setDialogueToken("waterPkm", waterPkm?.name ?? "<NONE>");
|
||||||
|
|
||||||
// check for flying pokemon
|
// check for flying pokemon
|
||||||
const flyingPkm = findPokemonByType(party, Type.FLYING);
|
flyingPkm = findPokemonByType(allowedPokemon, Type.FLYING);
|
||||||
mysteryEncounter.setDialogueToken(
|
mysteryEncounter.setDialogueToken(
|
||||||
"flyingPkm",
|
"flyingPkm",
|
||||||
flyingPkm?.name ?? "<NONE>"
|
flyingPkm?.name ?? "<NONE>"
|
||||||
|
@ -67,10 +76,9 @@ export const LostAtSeaEncounter: MysteryEncounter =
|
||||||
.withOption(
|
.withOption(
|
||||||
new MysteryEncounterOptionBuilder()
|
new MysteryEncounterOptionBuilder()
|
||||||
.withPokemonTypeRequirement(Type.WATER, true, 1)
|
.withPokemonTypeRequirement(Type.WATER, true, 1)
|
||||||
.withOptionPhase(async (scene: BattleScene) => {
|
.withOptionPhase(async (scene: BattleScene) =>
|
||||||
console.debug("Lost at sea: Option 1 - Water Pokemon");
|
handleGuidingOption(scene, waterPkm)
|
||||||
leaveEncounterWithoutBattle(scene);
|
)
|
||||||
})
|
|
||||||
.build()
|
.build()
|
||||||
)
|
)
|
||||||
/**
|
/**
|
||||||
|
@ -80,26 +88,57 @@ export const LostAtSeaEncounter: MysteryEncounter =
|
||||||
.withOption(
|
.withOption(
|
||||||
new MysteryEncounterOptionBuilder()
|
new MysteryEncounterOptionBuilder()
|
||||||
.withPokemonTypeRequirement(Type.FLYING, true, 1)
|
.withPokemonTypeRequirement(Type.FLYING, true, 1)
|
||||||
.withOptionPhase(async (scene: BattleScene) => {
|
.withOptionPhase(async (scene: BattleScene) =>
|
||||||
console.debug("Lost at sea: Option 2 - Flying Pokemon");
|
handleGuidingOption(scene, flyingPkm)
|
||||||
leaveEncounterWithoutBattle(scene);
|
)
|
||||||
})
|
|
||||||
.build()
|
.build()
|
||||||
)
|
)
|
||||||
/**
|
/**
|
||||||
* Option 3: Wander aimlessly. All pokemons lose 30% of their HP (or KO on 0 HP).
|
* Option 3: Wander aimlessly. All pokemons lose 30% of their HP (or KO on 0 HP).
|
||||||
*/
|
*/
|
||||||
.withOptionPhase(async (scene: BattleScene) => {
|
.withOptionPhase(async (scene: BattleScene) => {
|
||||||
const party = scene.getParty().filter((p) => !p.isFainted());
|
const allowedPokemon = scene
|
||||||
party.forEach((pkm) => {
|
.getParty()
|
||||||
const damage = Math.round(pkm.getMaxHp() / (DAMAGE_PERCENTAGE / 100));
|
.filter((p) => p.isAllowedInBattle());
|
||||||
pkm.hp = Math.min(pkm.hp, damage);
|
|
||||||
|
allowedPokemon.forEach((pkm) => {
|
||||||
|
const percentage = DAMAGE_PERCENTAGE / 100;
|
||||||
|
const damage = Math.floor(pkm.getMaxHp() * percentage);
|
||||||
|
return applyDamageToPokemon(pkm, damage);
|
||||||
});
|
});
|
||||||
leaveEncounterWithoutBattle(scene);
|
leaveEncounterWithoutBattle(scene);
|
||||||
return true;
|
return true;
|
||||||
})
|
})
|
||||||
.build();
|
.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));
|
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);
|
||||||
|
}
|
||||||
|
|
|
@ -12,7 +12,7 @@ export const lostAtSea = {
|
||||||
selected: "@ec{waterPkm} guides you back and earns EXP.",
|
selected: "@ec{waterPkm} guides you back and earns EXP.",
|
||||||
},
|
},
|
||||||
2: {
|
2: {
|
||||||
label: "Use @ec{flyingPkm}", // pkm has to be of type water
|
label: "Use @ec{flyingPkm}", // pkm has to be of type flying
|
||||||
tooltip:
|
tooltip:
|
||||||
"Use @ec{flyingPkm} to guide you back. @ec{flyingPkm} earns EXP as if having defeated a Lapras.",
|
"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.",
|
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.",
|
"You wander aimlessly around. After hours of wandering, you find your way back. You and your team take the toll.",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
// outro: "TBA: OUTRO MESSAGE",
|
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue