mirror of
				https://github.com/pagefaultgames/pokerogue.git
				synced 2025-10-26 22:15:52 +01:00 
			
		
		
		
	* Add abilityAttr.is methods * [WIP] move modifier stuff around * Untangle circular deps from modifiers * Move unlockables to own file * Untangle all circular deps outside of MEs * Move constants in MEs to their own files * Re-add missing import to battle.ts * Add necessary overload for getTag * Add missing type import in weather.ts * Init modifier types and pools in loading-scene * Remove stray commented code * Apply kev's suggestions from code review Co-authored-by: NightKev <34855794+DayKev@users.noreply.github.com> --------- Co-authored-by: NightKev <34855794+DayKev@users.noreply.github.com>
		
			
				
	
	
		
			90 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| // -- start tsdoc imports --
 | |
| // biome-ignore lint/correctness/noUnusedImports: TSDoc import
 | |
| import type { globalScene } from "#app/global-scene";
 | |
| // -- end tsdoc imports --
 | |
| 
 | |
| import type { BattlerIndex } from "#enums/battler-index";
 | |
| import type { Ability } from "#app/data/abilities/ability";
 | |
| import { allAbilities } from "#app/data/data-lists";
 | |
| import type Pokemon from "#app/field/pokemon";
 | |
| import type { EnemyPokemon, PlayerPokemon } from "#app/field/pokemon";
 | |
| import type { AbilityId } from "#enums/ability-id";
 | |
| import type { PokemonType } from "#enums/pokemon-type";
 | |
| import { Stat } from "#enums/stat";
 | |
| import { GameManagerHelper } from "#test/testUtils/helpers/gameManagerHelper";
 | |
| import { expect, type MockInstance, vi } from "vitest";
 | |
| 
 | |
| /** Helper to manage pokemon */
 | |
| export class FieldHelper extends GameManagerHelper {
 | |
|   /**
 | |
|    * Passthrough for {@linkcode globalScene.getPlayerPokemon} that adds an `undefined` check for
 | |
|    * the Pokemon so that the return type for the function doesn't have `undefined`.
 | |
|    * This removes the need to add a `!` like when calling `game.scene.getPlayerPokemon()!`.
 | |
|    * @param includeSwitching - Whether a pokemon that is currently switching out is valid, default `true`
 | |
|    * @returns The first {@linkcode PlayerPokemon} that is {@linkcode globalScene.getPlayerField | on the field}
 | |
|    * and {@linkcode PlayerPokemon.isActive | is active}
 | |
|    * (aka {@linkcode PlayerPokemon.isAllowedInBattle is allowed in battle}).
 | |
|    */
 | |
|   public getPlayerPokemon(includeSwitching = true): PlayerPokemon {
 | |
|     const pokemon = this.game.scene.getPlayerPokemon(includeSwitching);
 | |
|     expect(pokemon).toBeDefined();
 | |
|     return pokemon!;
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Passthrough for {@linkcode globalScene.getEnemyPokemon} that adds an `undefined` check for
 | |
|    * the Pokemon so that the return type for the function doesn't have `undefined`.
 | |
|    * This removes the need to add a `!` like when calling `game.scene.getEnemyPokemon()!`.
 | |
|    * @param includeSwitching Whether a pokemon that is currently switching out is valid, default `true`
 | |
|    * @returns The first {@linkcode EnemyPokemon} that is {@linkcode globalScene.getEnemyField | on the field}
 | |
|    * and {@linkcode EnemyPokemon.isActive | is active}
 | |
|    * (aka {@linkcode EnemyPokemon.isAllowedInBattle | is allowed in battle}).
 | |
|    */
 | |
|   public getEnemyPokemon(includeSwitching = true): EnemyPokemon {
 | |
|     const pokemon = this.game.scene.getEnemyPokemon(includeSwitching);
 | |
|     expect(pokemon).toBeDefined();
 | |
|     return pokemon!;
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * @returns The {@linkcode BattlerIndex | indexes} of Pokemon on the field in order of decreasing Speed.
 | |
|    * Speed ties are returned in increasing order of index.
 | |
|    *
 | |
|    * @remarks
 | |
|    * This does not account for Trick Room as it does not modify the _speed_ of Pokemon on the field,
 | |
|    * only their turn order.
 | |
|    */
 | |
|   public getSpeedOrder(): BattlerIndex[] {
 | |
|     return this.game.scene
 | |
|       .getField(true)
 | |
|       .sort((pA, pB) => pB.getEffectiveStat(Stat.SPD) - pA.getEffectiveStat(Stat.SPD))
 | |
|       .map(p => p.getBattlerIndex());
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Mocks a pokemon's ability, overriding its existing ability (takes precedence over global overrides).
 | |
|    * Useful for giving exactly 1 Pokemon in a double battle a certain ability (rather than all pokemon).
 | |
|    * @param pokemon - The pokemon to mock the ability of
 | |
|    * @param ability - The ability to be mocked
 | |
|    * @returns A {@linkcode MockInstance} object
 | |
|    * @see {@linkcode vi.spyOn}
 | |
|    * @see https://vitest.dev/api/mock#mockreturnvalue
 | |
|    */
 | |
|   public mockAbility(pokemon: Pokemon, ability: AbilityId): MockInstance<(baseOnly?: boolean) => Ability> {
 | |
|     return vi.spyOn(pokemon, "getAbility").mockReturnValue(allAbilities[ability]);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Force a given Pokemon to be terastallized to the given type.
 | |
|    *
 | |
|    * @param pokemon - The pokemon to terastallize.
 | |
|    * @param teraType - The {@linkcode PokemonType} to terastallize into; defaults to the pokemon's primary type.
 | |
|    * @remarks
 | |
|    * This function only mocks the Pokemon's tera-related variables; it does NOT activate any tera-related abilities.
 | |
|    */
 | |
|   public forceTera(pokemon: Pokemon, teraType: PokemonType = pokemon.getSpeciesForm(true).type1): void {
 | |
|     vi.spyOn(pokemon, "isTerastallized", "get").mockReturnValue(true);
 | |
|     vi.spyOn(pokemon, "teraType", "get").mockReturnValue(teraType);
 | |
|   }
 | |
| }
 |