Refactor ability hook functions to remove code duplication
parent
6391e05508
commit
0b5adbb43c
|
@ -51,6 +51,7 @@ export class Ability {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type AbAttrApplyFunc<TAttr extends AbAttr> = (attr: TAttr) => boolean | Promise<boolean>;
|
||||||
type AbAttrCondition = (pokemon: Pokemon) => boolean;
|
type AbAttrCondition = (pokemon: Pokemon) => boolean;
|
||||||
|
|
||||||
export abstract class AbAttr {
|
export abstract class AbAttr {
|
||||||
|
@ -443,7 +444,7 @@ export class BattleStatMultiplierAbAttr extends AbAttr {
|
||||||
private multiplier: number;
|
private multiplier: number;
|
||||||
|
|
||||||
constructor(battleStat: BattleStat, multiplier: number) {
|
constructor(battleStat: BattleStat, multiplier: number) {
|
||||||
super();
|
super(false);
|
||||||
|
|
||||||
this.battleStat = battleStat;
|
this.battleStat = battleStat;
|
||||||
this.multiplier = multiplier;
|
this.multiplier = multiplier;
|
||||||
|
@ -902,6 +903,10 @@ export class RunSuccessAbAttr extends AbAttr {
|
||||||
}
|
}
|
||||||
|
|
||||||
export class CheckTrappedAbAttr extends AbAttr {
|
export class CheckTrappedAbAttr extends AbAttr {
|
||||||
|
constructor() {
|
||||||
|
super(false);
|
||||||
|
}
|
||||||
|
|
||||||
applyCheckTrapped(pokemon: Pokemon, trapped: Utils.BooleanHolder, args: any[]): boolean | Promise<boolean> {
|
applyCheckTrapped(pokemon: Pokemon, trapped: Utils.BooleanHolder, args: any[]): boolean | Promise<boolean> {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -942,13 +947,14 @@ export class WeightMultiplierAbAttr extends AbAttr {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export function applyAbAttrs(attrType: { new(...args: any[]): AbAttr }, pokemon: Pokemon, cancelled: Utils.BooleanHolder, ...args: any[]): Promise<void> {
|
function applyAbAttrsInternal<TAttr extends AbAttr>(attrType: { new(...args: any[]): TAttr },
|
||||||
|
pokemon: Pokemon, applyFunc: AbAttrApplyFunc<TAttr>, isAsync?: boolean, showAbilityInstant?: boolean): Promise<void> {
|
||||||
return new Promise(resolve => {
|
return new Promise(resolve => {
|
||||||
if (!pokemon.canApplyAbility())
|
if (!pokemon.canApplyAbility())
|
||||||
return resolve();
|
return resolve();
|
||||||
|
|
||||||
const ability = pokemon.getAbility();
|
const ability = pokemon.getAbility();
|
||||||
const attrs = ability.getAttrs(attrType) as AbAttr[];
|
const attrs = ability.getAttrs(attrType) as TAttr[];
|
||||||
|
|
||||||
const clearSpliceQueueAndResolve = () => {
|
const clearSpliceQueueAndResolve = () => {
|
||||||
pokemon.scene.clearPhaseQueueSplice();
|
pokemon.scene.clearPhaseQueueSplice();
|
||||||
|
@ -960,18 +966,26 @@ export function applyAbAttrs(attrType: { new(...args: any[]): AbAttr }, pokemon:
|
||||||
else
|
else
|
||||||
clearSpliceQueueAndResolve();
|
clearSpliceQueueAndResolve();
|
||||||
};
|
};
|
||||||
const applyAbAttr = (attr: AbAttr) => {
|
const applyAbAttr = (attr: TAttr) => {
|
||||||
if (!canApplyAttr(pokemon, attr))
|
if (!canApplyAttr(pokemon, attr))
|
||||||
return applyNextAbAttr();
|
return applyNextAbAttr();
|
||||||
pokemon.scene.setPhaseQueueSplice();
|
pokemon.scene.setPhaseQueueSplice();
|
||||||
const onApplySuccess = () => {
|
const onApplySuccess = () => {
|
||||||
if (attr.showAbility)
|
if (attr.showAbility) {
|
||||||
|
if (showAbilityInstant)
|
||||||
|
pokemon.scene.abilityBar.showAbility(pokemon);
|
||||||
|
else
|
||||||
queueShowAbility(pokemon);
|
queueShowAbility(pokemon);
|
||||||
|
}
|
||||||
const message = attr.getTriggerMessage(pokemon);
|
const message = attr.getTriggerMessage(pokemon);
|
||||||
if (message)
|
if (message) {
|
||||||
|
if (isAsync)
|
||||||
|
pokemon.scene.ui.showText(message, null, () => pokemon.scene.ui.showText(null, 0), null, true);
|
||||||
|
else
|
||||||
pokemon.scene.queueMessage(message);
|
pokemon.scene.queueMessage(message);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
const result = attr.apply(pokemon, cancelled, args);
|
const result = applyFunc(attr);
|
||||||
if (result instanceof Promise) {
|
if (result instanceof Promise) {
|
||||||
result.then(success => {
|
result.then(success => {
|
||||||
if (success)
|
if (success)
|
||||||
|
@ -988,614 +1002,73 @@ export function applyAbAttrs(attrType: { new(...args: any[]): AbAttr }, pokemon:
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function applyAbAttrs(attrType: { new(...args: any[]): AbAttr }, pokemon: Pokemon, cancelled: Utils.BooleanHolder, ...args: any[]): Promise<void> {
|
||||||
|
return applyAbAttrsInternal<AbAttr>(attrType, pokemon, attr => attr.apply(pokemon, cancelled, args));
|
||||||
|
}
|
||||||
|
|
||||||
export function applyPreDefendAbAttrs(attrType: { new(...args: any[]): PreDefendAbAttr },
|
export function applyPreDefendAbAttrs(attrType: { new(...args: any[]): PreDefendAbAttr },
|
||||||
pokemon: Pokemon, attacker: Pokemon, move: PokemonMove, cancelled: Utils.BooleanHolder, ...args: any[]): Promise<void> {
|
pokemon: Pokemon, attacker: Pokemon, move: PokemonMove, cancelled: Utils.BooleanHolder, ...args: any[]): Promise<void> {
|
||||||
return new Promise(resolve => {
|
return applyAbAttrsInternal<PreDefendAbAttr>(attrType, pokemon, attr => attr.applyPreDefend(pokemon, attacker, move, cancelled, args));
|
||||||
if (!pokemon.canApplyAbility())
|
|
||||||
return resolve();
|
|
||||||
|
|
||||||
const ability = pokemon.getAbility();
|
|
||||||
const attrs = ability.getAttrs(attrType) as PreDefendAbAttr[];
|
|
||||||
|
|
||||||
const clearSpliceQueueAndResolve = () => {
|
|
||||||
pokemon.scene.clearPhaseQueueSplice();
|
|
||||||
resolve();
|
|
||||||
};
|
|
||||||
const applyNextAbAttr = () => {
|
|
||||||
if (attrs.length)
|
|
||||||
applyAbAttr(attrs.shift());
|
|
||||||
else
|
|
||||||
clearSpliceQueueAndResolve();
|
|
||||||
};
|
|
||||||
const applyAbAttr = (attr: PreDefendAbAttr) => {
|
|
||||||
if (!canApplyAttr(pokemon, attr))
|
|
||||||
return applyNextAbAttr();
|
|
||||||
pokemon.scene.setPhaseQueueSplice();
|
|
||||||
const onApplySuccess = () => {
|
|
||||||
if (attr.showAbility)
|
|
||||||
queueShowAbility(pokemon);
|
|
||||||
const message = attr.getTriggerMessage(pokemon);
|
|
||||||
if (message)
|
|
||||||
pokemon.scene.queueMessage(message);
|
|
||||||
};
|
|
||||||
const result = attr.applyPreDefend(pokemon, attacker, move, cancelled, args);
|
|
||||||
if (result instanceof Promise) {
|
|
||||||
result.then(success => {
|
|
||||||
if (success)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if (result)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function applyPostDefendAbAttrs(attrType: { new(...args: any[]): PostDefendAbAttr },
|
export function applyPostDefendAbAttrs(attrType: { new(...args: any[]): PostDefendAbAttr },
|
||||||
pokemon: Pokemon, attacker: Pokemon, move: PokemonMove, hitResult: HitResult, ...args: any[]): Promise<void> {
|
pokemon: Pokemon, attacker: Pokemon, move: PokemonMove, hitResult: HitResult, ...args: any[]): Promise<void> {
|
||||||
return new Promise(resolve => {
|
return applyAbAttrsInternal<PostDefendAbAttr>(attrType, pokemon, attr => attr.applyPostDefend(pokemon, attacker, move, hitResult, args));
|
||||||
if (!pokemon.canApplyAbility())
|
|
||||||
return resolve();
|
|
||||||
|
|
||||||
const ability = pokemon.getAbility();
|
|
||||||
const attrs = ability.getAttrs(attrType) as PostDefendAbAttr[];
|
|
||||||
|
|
||||||
const clearSpliceQueueAndResolve = () => {
|
|
||||||
pokemon.scene.clearPhaseQueueSplice();
|
|
||||||
resolve();
|
|
||||||
};
|
|
||||||
const applyNextAbAttr = () => {
|
|
||||||
if (attrs.length)
|
|
||||||
applyAbAttr(attrs.shift());
|
|
||||||
else
|
|
||||||
clearSpliceQueueAndResolve();
|
|
||||||
};
|
|
||||||
const applyAbAttr = (attr: PostDefendAbAttr) => {
|
|
||||||
if (!canApplyAttr(pokemon, attr))
|
|
||||||
return applyNextAbAttr();
|
|
||||||
pokemon.scene.setPhaseQueueSplice();
|
|
||||||
const onApplySuccess = () => {
|
|
||||||
if (attr.showAbility)
|
|
||||||
queueShowAbility(pokemon);
|
|
||||||
const message = attr.getTriggerMessage(pokemon);
|
|
||||||
if (message)
|
|
||||||
pokemon.scene.queueMessage(message);
|
|
||||||
};
|
|
||||||
const result = attr.applyPostDefend(pokemon, attacker, move, hitResult, args);
|
|
||||||
if (result instanceof Promise) {
|
|
||||||
result.then(success => {
|
|
||||||
if (success)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if (result)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function applyBattleStatMultiplierAbAttrs(attrType: { new(...args: any[]): BattleStatMultiplierAbAttr },
|
export function applyBattleStatMultiplierAbAttrs(attrType: { new(...args: any[]): BattleStatMultiplierAbAttr },
|
||||||
pokemon: Pokemon, battleStat: BattleStat, statValue: Utils.NumberHolder, ...args: any[]): Promise<void> {
|
pokemon: Pokemon, battleStat: BattleStat, statValue: Utils.NumberHolder, ...args: any[]): Promise<void> {
|
||||||
return new Promise(resolve => {
|
return applyAbAttrsInternal<BattleStatMultiplierAbAttr>(attrType, pokemon, attr => attr.applyBattleStat(pokemon, battleStat, statValue, args));
|
||||||
if (!pokemon.canApplyAbility())
|
|
||||||
return resolve();
|
|
||||||
|
|
||||||
const ability = pokemon.getAbility();
|
|
||||||
const attrs = ability.getAttrs(attrType) as BattleStatMultiplierAbAttr[];
|
|
||||||
|
|
||||||
const clearSpliceQueueAndResolve = () => {
|
|
||||||
pokemon.scene.clearPhaseQueueSplice();
|
|
||||||
resolve();
|
|
||||||
};
|
|
||||||
const applyNextAbAttr = () => {
|
|
||||||
if (attrs.length)
|
|
||||||
applyAbAttr(attrs.shift());
|
|
||||||
else
|
|
||||||
clearSpliceQueueAndResolve();
|
|
||||||
};
|
|
||||||
const applyAbAttr = (attr: BattleStatMultiplierAbAttr) => {
|
|
||||||
if (!canApplyAttr(pokemon, attr))
|
|
||||||
return applyNextAbAttr();
|
|
||||||
pokemon.scene.setPhaseQueueSplice();
|
|
||||||
const onApplySuccess = () => {
|
|
||||||
const message = attr.getTriggerMessage(pokemon);
|
|
||||||
if (message)
|
|
||||||
pokemon.scene.queueMessage(message);
|
|
||||||
};
|
|
||||||
const result = attr.applyBattleStat(pokemon, battleStat, statValue, args);
|
|
||||||
if (result instanceof Promise) {
|
|
||||||
result.then(success => {
|
|
||||||
if (success)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if (result)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function applyPreAttackAbAttrs(attrType: { new(...args: any[]): PreAttackAbAttr },
|
export function applyPreAttackAbAttrs(attrType: { new(...args: any[]): PreAttackAbAttr },
|
||||||
pokemon: Pokemon, defender: Pokemon, move: PokemonMove, ...args: any[]): Promise<void> {
|
pokemon: Pokemon, defender: Pokemon, move: PokemonMove, ...args: any[]): Promise<void> {
|
||||||
return new Promise(resolve => {
|
return applyAbAttrsInternal<PreAttackAbAttr>(attrType, pokemon, attr => attr.applyPreAttack(pokemon, defender, move, args));
|
||||||
if (!pokemon.canApplyAbility())
|
|
||||||
return resolve();
|
|
||||||
|
|
||||||
const ability = pokemon.getAbility();
|
|
||||||
const attrs = ability.getAttrs(attrType) as PreAttackAbAttr[];
|
|
||||||
|
|
||||||
const clearSpliceQueueAndResolve = () => {
|
|
||||||
pokemon.scene.clearPhaseQueueSplice();
|
|
||||||
resolve();
|
|
||||||
};
|
|
||||||
const applyNextAbAttr = () => {
|
|
||||||
if (attrs.length)
|
|
||||||
applyAbAttr(attrs.shift());
|
|
||||||
else
|
|
||||||
clearSpliceQueueAndResolve();
|
|
||||||
};
|
|
||||||
const applyAbAttr = (attr: PreAttackAbAttr) => {
|
|
||||||
if (!canApplyAttr(pokemon, attr))
|
|
||||||
return applyNextAbAttr();
|
|
||||||
pokemon.scene.setPhaseQueueSplice();
|
|
||||||
const onApplySuccess = () => {
|
|
||||||
if (attr.showAbility)
|
|
||||||
queueShowAbility(pokemon);
|
|
||||||
const message = attr.getTriggerMessage(pokemon);
|
|
||||||
if (message)
|
|
||||||
pokemon.scene.queueMessage(message);
|
|
||||||
};
|
|
||||||
const result = attr.applyPreAttack(pokemon, defender, move, args);
|
|
||||||
if (result instanceof Promise) {
|
|
||||||
result.then(success => {
|
|
||||||
if (success)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if (result)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function applyPostAttackAbAttrs(attrType: { new(...args: any[]): PostAttackAbAttr },
|
export function applyPostAttackAbAttrs(attrType: { new(...args: any[]): PostAttackAbAttr },
|
||||||
pokemon: Pokemon, defender: Pokemon, move: PokemonMove, hitResult: HitResult, ...args: any[]): Promise<void> {
|
pokemon: Pokemon, defender: Pokemon, move: PokemonMove, hitResult: HitResult, ...args: any[]): Promise<void> {
|
||||||
return new Promise(resolve => {
|
return applyAbAttrsInternal<PostAttackAbAttr>(attrType, pokemon, attr => attr.applyPostAttack(pokemon, defender, move, hitResult, args));
|
||||||
if (!pokemon.canApplyAbility())
|
|
||||||
return resolve();
|
|
||||||
|
|
||||||
const ability = pokemon.getAbility();
|
|
||||||
const attrs = ability.getAttrs(attrType) as PostAttackAbAttr[];
|
|
||||||
|
|
||||||
const clearSpliceQueueAndResolve = () => {
|
|
||||||
pokemon.scene.clearPhaseQueueSplice();
|
|
||||||
resolve();
|
|
||||||
};
|
|
||||||
const applyNextAbAttr = () => {
|
|
||||||
if (attrs.length)
|
|
||||||
applyAbAttr(attrs.shift());
|
|
||||||
else
|
|
||||||
clearSpliceQueueAndResolve();
|
|
||||||
};
|
|
||||||
const applyAbAttr = (attr: PostAttackAbAttr) => {
|
|
||||||
if (!canApplyAttr(pokemon, attr))
|
|
||||||
return applyNextAbAttr();
|
|
||||||
pokemon.scene.setPhaseQueueSplice();
|
|
||||||
const onApplySuccess = () => {
|
|
||||||
if (attr.showAbility)
|
|
||||||
queueShowAbility(pokemon);
|
|
||||||
const message = attr.getTriggerMessage(pokemon);
|
|
||||||
if (message)
|
|
||||||
pokemon.scene.queueMessage(message);
|
|
||||||
};
|
|
||||||
const result = attr.applyPostAttack(pokemon, defender, move, hitResult, args);
|
|
||||||
if (result instanceof Promise) {
|
|
||||||
result.then(success => {
|
|
||||||
if (success)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if (result)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function applyPostSummonAbAttrs(attrType: { new(...args: any[]): PostSummonAbAttr },
|
export function applyPostSummonAbAttrs(attrType: { new(...args: any[]): PostSummonAbAttr },
|
||||||
pokemon: Pokemon, ...args: any[]): Promise<void> {
|
pokemon: Pokemon, ...args: any[]): Promise<void> {
|
||||||
return new Promise(resolve => {
|
return applyAbAttrsInternal<PostSummonAbAttr>(attrType, pokemon, attr => attr.applyPostSummon(pokemon, args));
|
||||||
if (!pokemon.canApplyAbility())
|
|
||||||
return resolve();
|
|
||||||
|
|
||||||
const ability = pokemon.getAbility();
|
|
||||||
const attrs = ability.getAttrs(attrType) as PostSummonAbAttr[];
|
|
||||||
|
|
||||||
const clearSpliceQueueAndResolve = () => {
|
|
||||||
pokemon.scene.clearPhaseQueueSplice();
|
|
||||||
resolve();
|
|
||||||
};
|
|
||||||
const applyNextAbAttr = () => {
|
|
||||||
if (attrs.length)
|
|
||||||
applyAbAttr(attrs.shift());
|
|
||||||
else
|
|
||||||
clearSpliceQueueAndResolve();
|
|
||||||
};
|
|
||||||
const applyAbAttr = (attr: PostSummonAbAttr) => {
|
|
||||||
if (!canApplyAttr(pokemon, attr))
|
|
||||||
return applyNextAbAttr();
|
|
||||||
pokemon.scene.setPhaseQueueSplice();
|
|
||||||
const onApplySuccess = () => {
|
|
||||||
if (attr.showAbility)
|
|
||||||
queueShowAbility(pokemon);
|
|
||||||
const message = attr.getTriggerMessage(pokemon);
|
|
||||||
if (message)
|
|
||||||
pokemon.scene.queueMessage(message);
|
|
||||||
};
|
|
||||||
const result = attr.applyPostSummon(pokemon, args);
|
|
||||||
if (result instanceof Promise) {
|
|
||||||
result.then(success => {
|
|
||||||
if (success)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if (result)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function applyPreStatChangeAbAttrs(attrType: { new(...args: any[]): PreStatChangeAbAttr },
|
export function applyPreStatChangeAbAttrs(attrType: { new(...args: any[]): PreStatChangeAbAttr },
|
||||||
pokemon: Pokemon, stat: BattleStat, cancelled: Utils.BooleanHolder, ...args: any[]): Promise<void> {
|
pokemon: Pokemon, stat: BattleStat, cancelled: Utils.BooleanHolder, ...args: any[]): Promise<void> {
|
||||||
return new Promise(resolve => {
|
return applyAbAttrsInternal<PreStatChangeAbAttr>(attrType, pokemon, attr => attr.applyPreStatChange(pokemon, stat, cancelled, args));
|
||||||
if (!pokemon.canApplyAbility())
|
|
||||||
return resolve();
|
|
||||||
|
|
||||||
const ability = pokemon.getAbility();
|
|
||||||
const attrs = ability.getAttrs(attrType) as PreStatChangeAbAttr[];
|
|
||||||
|
|
||||||
const clearSpliceQueueAndResolve = () => {
|
|
||||||
pokemon.scene.clearPhaseQueueSplice();
|
|
||||||
resolve();
|
|
||||||
};
|
|
||||||
const applyNextAbAttr = () => {
|
|
||||||
if (attrs.length)
|
|
||||||
applyAbAttr(attrs.shift());
|
|
||||||
else
|
|
||||||
clearSpliceQueueAndResolve();
|
|
||||||
};
|
|
||||||
const applyAbAttr = (attr: PreStatChangeAbAttr) => {
|
|
||||||
if (!canApplyAttr(pokemon, attr))
|
|
||||||
return applyNextAbAttr();
|
|
||||||
pokemon.scene.setPhaseQueueSplice();
|
|
||||||
const onApplySuccess = () => {
|
|
||||||
if (attr.showAbility)
|
|
||||||
queueShowAbility(pokemon);
|
|
||||||
const message = attr.getTriggerMessage(pokemon);
|
|
||||||
if (message)
|
|
||||||
pokemon.scene.queueMessage(message);
|
|
||||||
};
|
|
||||||
const result = attr.applyPreStatChange(pokemon, stat, cancelled, args);
|
|
||||||
if (result instanceof Promise) {
|
|
||||||
result.then(success => {
|
|
||||||
if (success)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if (result)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function applyPreSetStatusAbAttrs(attrType: { new(...args: any[]): PreSetStatusAbAttr },
|
export function applyPreSetStatusAbAttrs(attrType: { new(...args: any[]): PreSetStatusAbAttr },
|
||||||
pokemon: Pokemon, effect: StatusEffect, cancelled: Utils.BooleanHolder, ...args: any[]): Promise<void> {
|
pokemon: Pokemon, effect: StatusEffect, cancelled: Utils.BooleanHolder, ...args: any[]): Promise<void> {
|
||||||
return new Promise(resolve => {
|
return applyAbAttrsInternal<PreSetStatusAbAttr>(attrType, pokemon, attr => attr.applyPreSetStatus(pokemon, effect, cancelled, args));
|
||||||
if (!pokemon.canApplyAbility())
|
|
||||||
return resolve();
|
|
||||||
|
|
||||||
const ability = pokemon.getAbility();
|
|
||||||
const attrs = ability.getAttrs(attrType) as PreSetStatusAbAttr[];
|
|
||||||
|
|
||||||
const clearSpliceQueueAndResolve = () => {
|
|
||||||
pokemon.scene.clearPhaseQueueSplice();
|
|
||||||
resolve();
|
|
||||||
};
|
|
||||||
const applyNextAbAttr = () => {
|
|
||||||
if (attrs.length)
|
|
||||||
applyAbAttr(attrs.shift());
|
|
||||||
else
|
|
||||||
clearSpliceQueueAndResolve();
|
|
||||||
};
|
|
||||||
const applyAbAttr = (attr: PreSetStatusAbAttr) => {
|
|
||||||
if (!canApplyAttr(pokemon, attr))
|
|
||||||
return applyNextAbAttr();
|
|
||||||
pokemon.scene.setPhaseQueueSplice();
|
|
||||||
const onApplySuccess = () => {
|
|
||||||
if (attr.showAbility)
|
|
||||||
queueShowAbility(pokemon);
|
|
||||||
const message = attr.getTriggerMessage(pokemon);
|
|
||||||
if (message)
|
|
||||||
pokemon.scene.queueMessage(message);
|
|
||||||
};
|
|
||||||
const result = attr.applyPreSetStatus(pokemon, effect, cancelled, args);
|
|
||||||
if (result instanceof Promise) {
|
|
||||||
result.then(success => {
|
|
||||||
if (success)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if (result)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function applyPreApplyBattlerTagAbAttrs(attrType: { new(...args: any[]): PreApplyBattlerTagAbAttr },
|
export function applyPreApplyBattlerTagAbAttrs(attrType: { new(...args: any[]): PreApplyBattlerTagAbAttr },
|
||||||
pokemon: Pokemon, tag: BattlerTag, cancelled: Utils.BooleanHolder, ...args: any[]): Promise<void> {
|
pokemon: Pokemon, tag: BattlerTag, cancelled: Utils.BooleanHolder, ...args: any[]): Promise<void> {
|
||||||
return new Promise(resolve => {
|
return applyAbAttrsInternal<PreApplyBattlerTagAbAttr>(attrType, pokemon, attr => attr.applyPreApplyBattlerTag(pokemon, tag, cancelled, args));
|
||||||
if (!pokemon.canApplyAbility())
|
|
||||||
return resolve();
|
|
||||||
|
|
||||||
const ability = pokemon.getAbility();
|
|
||||||
const attrs = ability.getAttrs(attrType) as PreApplyBattlerTagAbAttr[];
|
|
||||||
|
|
||||||
const clearSpliceQueueAndResolve = () => {
|
|
||||||
pokemon.scene.clearPhaseQueueSplice();
|
|
||||||
resolve();
|
|
||||||
};
|
|
||||||
const applyNextAbAttr = () => {
|
|
||||||
if (attrs.length)
|
|
||||||
applyAbAttr(attrs.shift());
|
|
||||||
else
|
|
||||||
clearSpliceQueueAndResolve();
|
|
||||||
};
|
|
||||||
const applyAbAttr = (attr: PreApplyBattlerTagAbAttr) => {
|
|
||||||
if (!canApplyAttr(pokemon, attr))
|
|
||||||
return applyNextAbAttr();
|
|
||||||
pokemon.scene.setPhaseQueueSplice();
|
|
||||||
const onApplySuccess = () => {
|
|
||||||
if (attr.showAbility)
|
|
||||||
queueShowAbility(pokemon);
|
|
||||||
const message = attr.getTriggerMessage(pokemon);
|
|
||||||
if (message)
|
|
||||||
pokemon.scene.queueMessage(message);
|
|
||||||
};
|
|
||||||
const result = attr.applyPreApplyBattlerTag(pokemon, tag, cancelled, args);
|
|
||||||
if (result instanceof Promise) {
|
|
||||||
result.then(success => {
|
|
||||||
if (success)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if (result)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function applyPreWeatherEffectAbAttrs(attrType: { new(...args: any[]): PreWeatherEffectAbAttr },
|
export function applyPreWeatherEffectAbAttrs(attrType: { new(...args: any[]): PreWeatherEffectAbAttr },
|
||||||
pokemon: Pokemon, weather: Weather, cancelled: Utils.BooleanHolder, ...args: any[]): Promise<void> {
|
pokemon: Pokemon, weather: Weather, cancelled: Utils.BooleanHolder, ...args: any[]): Promise<void> {
|
||||||
return new Promise(resolve => {
|
return applyAbAttrsInternal<PreWeatherDamageAbAttr>(attrType, pokemon, attr => attr.applyPreWeatherEffect(pokemon, weather, cancelled, args), false, true);
|
||||||
if (!pokemon.canApplyAbility())
|
|
||||||
return resolve();
|
|
||||||
|
|
||||||
const ability = pokemon.getAbility();
|
|
||||||
const attrs = ability.getAttrs(attrType) as PreWeatherEffectAbAttr[];
|
|
||||||
|
|
||||||
const clearSpliceQueueAndResolve = () => {
|
|
||||||
pokemon.scene.clearPhaseQueueSplice();
|
|
||||||
resolve();
|
|
||||||
};
|
|
||||||
const applyNextAbAttr = () => {
|
|
||||||
if (attrs.length)
|
|
||||||
applyAbAttr(attrs.shift());
|
|
||||||
else
|
|
||||||
clearSpliceQueueAndResolve();
|
|
||||||
};
|
|
||||||
const applyAbAttr = (attr: PreWeatherEffectAbAttr) => {
|
|
||||||
if (!canApplyAttr(pokemon, attr))
|
|
||||||
return applyNextAbAttr();
|
|
||||||
pokemon.scene.setPhaseQueueSplice();
|
|
||||||
const onApplySuccess = () => {
|
|
||||||
pokemon.scene.abilityBar.showAbility(pokemon);
|
|
||||||
const message = attr.getTriggerMessage(pokemon);
|
|
||||||
if (message)
|
|
||||||
pokemon.scene.queueMessage(message);
|
|
||||||
};
|
|
||||||
const result = attr.applyPreWeatherEffect(pokemon, weather, cancelled, args);
|
|
||||||
if (result instanceof Promise) {
|
|
||||||
result.then(success => {
|
|
||||||
if (success)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if (result)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function applyPostTurnAbAttrs(attrType: { new(...args: any[]): PostTurnAbAttr },
|
export function applyPostTurnAbAttrs(attrType: { new(...args: any[]): PostTurnAbAttr },
|
||||||
pokemon: Pokemon, ...args: any[]): Promise<void> {
|
pokemon: Pokemon, ...args: any[]): Promise<void> {
|
||||||
return new Promise(resolve => {
|
return applyAbAttrsInternal<PostTurnAbAttr>(attrType, pokemon, attr => attr.applyPostTurn(pokemon, args));
|
||||||
if (!pokemon.canApplyAbility())
|
|
||||||
return resolve();
|
|
||||||
|
|
||||||
const ability = pokemon.getAbility();
|
|
||||||
const attrs = ability.getAttrs(attrType) as PostTurnAbAttr[];
|
|
||||||
|
|
||||||
const clearSpliceQueueAndResolve = () => {
|
|
||||||
pokemon.scene.clearPhaseQueueSplice();
|
|
||||||
resolve();
|
|
||||||
};
|
|
||||||
const applyNextAbAttr = () => {
|
|
||||||
if (attrs.length)
|
|
||||||
applyAbAttr(attrs.shift());
|
|
||||||
else
|
|
||||||
clearSpliceQueueAndResolve();
|
|
||||||
};
|
|
||||||
const applyAbAttr = (attr: PostTurnAbAttr) => {
|
|
||||||
if (!canApplyAttr(pokemon, attr))
|
|
||||||
return applyNextAbAttr();
|
|
||||||
pokemon.scene.setPhaseQueueSplice();
|
|
||||||
const onApplySuccess = () => {
|
|
||||||
if (attr.showAbility)
|
|
||||||
queueShowAbility(pokemon);
|
|
||||||
const message = attr.getTriggerMessage(pokemon);
|
|
||||||
if (message)
|
|
||||||
pokemon.scene.queueMessage(message);
|
|
||||||
};
|
|
||||||
const result = attr.applyPostTurn(pokemon, args);
|
|
||||||
if (result instanceof Promise) {
|
|
||||||
result.then(success => {
|
|
||||||
if (success)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if (result)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function applyPostWeatherLapseAbAttrs(attrType: { new(...args: any[]): PostWeatherLapseAbAttr },
|
export function applyPostWeatherLapseAbAttrs(attrType: { new(...args: any[]): PostWeatherLapseAbAttr },
|
||||||
pokemon: Pokemon, weather: Weather, ...args: any[]): Promise<void> {
|
pokemon: Pokemon, weather: Weather, ...args: any[]): Promise<void> {
|
||||||
return new Promise(resolve => {
|
return applyAbAttrsInternal<PostWeatherLapseAbAttr>(attrType, pokemon, attr => attr.applyPostWeatherLapse(pokemon, weather, args));
|
||||||
if (!pokemon.canApplyAbility())
|
|
||||||
return resolve();
|
|
||||||
|
|
||||||
if (weather.isEffectSuppressed(pokemon.scene))
|
|
||||||
return resolve();
|
|
||||||
|
|
||||||
const ability = pokemon.getAbility();
|
|
||||||
const attrs = ability.getAttrs(attrType) as PostWeatherLapseAbAttr[];
|
|
||||||
|
|
||||||
const clearSpliceQueueAndResolve = () => {
|
|
||||||
pokemon.scene.clearPhaseQueueSplice();
|
|
||||||
resolve();
|
|
||||||
};
|
|
||||||
const applyNextAbAttr = () => {
|
|
||||||
if (attrs.length)
|
|
||||||
applyAbAttr(attrs.shift());
|
|
||||||
else
|
|
||||||
clearSpliceQueueAndResolve();
|
|
||||||
};
|
|
||||||
const applyAbAttr = (attr: PostWeatherLapseAbAttr) => {
|
|
||||||
if (!canApplyAttr(pokemon, attr))
|
|
||||||
return applyNextAbAttr();
|
|
||||||
pokemon.scene.setPhaseQueueSplice();
|
|
||||||
const onApplySuccess = () => {
|
|
||||||
if (attr.showAbility)
|
|
||||||
queueShowAbility(pokemon);
|
|
||||||
const message = attr.getTriggerMessage(pokemon);
|
|
||||||
if (message)
|
|
||||||
pokemon.scene.queueMessage(message);
|
|
||||||
};
|
|
||||||
const result = attr.applyPostWeatherLapse(pokemon, weather, args);
|
|
||||||
if (result instanceof Promise) {
|
|
||||||
result.then(success => {
|
|
||||||
if (success)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if (result)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export function applyCheckTrappedAbAttrs(attrType: { new(...args: any[]): CheckTrappedAbAttr },
|
export function applyCheckTrappedAbAttrs(attrType: { new(...args: any[]): CheckTrappedAbAttr },
|
||||||
pokemon: Pokemon, trapped: Utils.BooleanHolder, ...args: any[]): Promise<void> {
|
pokemon: Pokemon, trapped: Utils.BooleanHolder, ...args: any[]): Promise<void> {
|
||||||
return new Promise(resolve => {
|
return applyAbAttrsInternal<CheckTrappedAbAttr>(attrType, pokemon, attr => attr.applyCheckTrapped(pokemon, trapped, args), true);
|
||||||
if (!pokemon.canApplyAbility())
|
|
||||||
return resolve();
|
|
||||||
|
|
||||||
const ability = pokemon.getAbility();
|
|
||||||
const attrs = ability.getAttrs(attrType) as CheckTrappedAbAttr[];
|
|
||||||
|
|
||||||
const clearSpliceQueueAndResolve = () => {
|
|
||||||
pokemon.scene.clearPhaseQueueSplice();
|
|
||||||
resolve();
|
|
||||||
};
|
|
||||||
const applyNextAbAttr = () => {
|
|
||||||
if (attrs.length)
|
|
||||||
applyAbAttr(attrs.shift());
|
|
||||||
else
|
|
||||||
clearSpliceQueueAndResolve();
|
|
||||||
};
|
|
||||||
const applyAbAttr = (attr: CheckTrappedAbAttr) => {
|
|
||||||
if (!canApplyAttr(pokemon, attr))
|
|
||||||
return applyNextAbAttr();
|
|
||||||
pokemon.scene.setPhaseQueueSplice();
|
|
||||||
const onApplySuccess = () => {
|
|
||||||
// Don't show ability bar because this call is asynchronous
|
|
||||||
const message = attr.getTriggerMessage(pokemon);
|
|
||||||
if (message)
|
|
||||||
pokemon.scene.ui.showText(message, null, () => pokemon.scene.ui.showText(null, 0), null, true);
|
|
||||||
};
|
|
||||||
const result = attr.applyCheckTrapped(pokemon, trapped, args);
|
|
||||||
if (result instanceof Promise) {
|
|
||||||
result.then(success => {
|
|
||||||
if (success)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
if (result)
|
|
||||||
onApplySuccess();
|
|
||||||
applyNextAbAttr();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
applyNextAbAttr();
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function canApplyAttr(pokemon: Pokemon, attr: AbAttr): boolean {
|
function canApplyAttr(pokemon: Pokemon, attr: AbAttr): boolean {
|
||||||
|
|
Loading…
Reference in New Issue