Skip to content

Commit

Permalink
Merge remote-tracking branch 'upstream/master'
Browse files Browse the repository at this point in the history
  • Loading branch information
ShivaD173 committed Nov 13, 2024
2 parents 91f2993 + c32f5e2 commit 73331dc
Show file tree
Hide file tree
Showing 4 changed files with 264 additions and 15 deletions.
6 changes: 3 additions & 3 deletions play.pokemonshowdown.com/js/client-chat.js
Original file line number Diff line number Diff line change
Expand Up @@ -972,9 +972,9 @@
user: targets[0]
}, Storage.safeJSON(function (data) {
if (!data || !$.isArray(data)) return self.add('|raw|Error: corrupted ranking data');
var buffer = '<div class="ladder"><table><tr><td colspan="8">User: <strong>' + toName(targets[0]) + '</strong></td></tr>';
var buffer = '<div class="ladder"><table><tr><td colspan="9">User: <strong>' + toName(targets[0]) + '</strong></td></tr>';
if (!data.length) {
buffer += '<tr><td colspan="8"><em>This user has not played any ladder games yet.</em></td></tr>';
buffer += '<tr><td colspan="9"><em>This user has not played any ladder games yet.</em></td></tr>';
buffer += '</table></div>';
return self.add('|raw|' + buffer);
}
Expand All @@ -983,7 +983,7 @@
for (var i = 0; i < data.length; i++) {
if ('suspect' in data[i]) suspect = true;
}
if (suspect) buffer += '<th>Suspect test eligible?</th>';
if (suspect) buffer += '<th>Suspect reqs possible?</th>';
buffer += '</tr>';
var hiddenFormats = [];
for (var i = 0; i < data.length; i++) {
Expand Down
238 changes: 231 additions & 7 deletions play.pokemonshowdown.com/src/battle-animations-moves.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36393,6 +36393,237 @@ export const BattleMoveAnims: AnimTable = {
}, 'linear', 'fade', {filter: 'hue-rotate(180deg)'});
},
},
mightycleave: {
anim(scene, [attacker, defender]) {
scene.showEffect('sword', {
x: attacker.leftof(-10),
y: attacker.y - 10,
z: attacker.z,
scale: 0.5,
opacity: 1,
}, {
y: attacker.y + 10,
scale: 1,
opacity: 0.4,
time: 300,
}, 'decel', 'fade');
attacker.delay(300);
attacker.anim({
x: defender.x,
y: defender.y,
z: defender.behind(70),
time: 300,
opacity: 0.5,
}, 'accel');
attacker.anim({
x: defender.x,
y: defender.x,
z: defender.behind(100),
opacity: 0,
time: 100,
}, 'linear');
attacker.anim({
x: attacker.x,
y: attacker.y,
z: attacker.behind(70),
opacity: 0,
time: 1,
}, 'linear');
attacker.anim({
opacity: 1,
time: 500,
}, 'decel');
scene.showEffect('iceball', {
x: defender.x,
y: defender.y,
z: defender.z,
time: 500,
xscale: 1.2,
yscale: 0.4,
opacity: 0.8,
}, {
time: 760,
xscale: 1.4,
yscale: 0.6,
opacity: 0.4,
}, 'accel', 'explode', {filter: 'hue-rotate(180deg)', rotate: '-45deg'});
scene.showEffect('rightslash', {
x: defender.x,
y: defender.y,
z: defender.z,
scale: 1.5,
time: 500,
}, {
scale: 2,
opacity: 0,
time: 760,
}, 'accel', 'fade');
defender.delay(760);
defender.anim({
z: defender.behind(30),
time: 100,
}, 'swing');
defender.anim({
time: 300,
}, 'swing');
},
},
spiritbreak: {
anim(scene, [attacker, defender]) {
scene.backgroundEffect('#000000', 1000, 0.3);

scene.showEffect('mistball', {
x: defender.x,
y: defender.y,
z: defender.z,
scale: 0.4,
time: 425,
opacity: 0.2,
}, {
scale: 0.6,
time: 750,
opacity: 1,
}, 'decel', 'fade');
scene.showEffect('mistball', {
x: defender.x,
y: defender.y,
z: defender.z,
scale: 0.6,
time: 750,
opacity: 1,
}, {
time: 1000,
scale: 2.5,
opacity: 0.2,
}, 'decel', 'explode');

scene.showEffect('iceball', {
x: defender.x,
y: defender.y,
z: defender.z,
scale: 2,
time: 850,
opacity: 0.4,
}, {
time: 1000,
scale: 3,
opacity: 0.1,
}, 'decel', 'explode');

scene.showEffect('shine', {
x: defender.x,
y: defender.y,
z: defender.z,
time: 750,
scale: 0.8,
}, {
opacity: 0.4,
time: 800,
}, 'decel', 'explode', {filter: 'invert(1)'});
scene.showEffect('impact', {
x: defender.x,
y: defender.y,
z: defender.z,
time: 875,
scale: 0.8,
}, {
opacity: 0.4,
time: 925,
}, 'decel', 'explode', {filter: 'brightness(50%)'});

attacker.anim({
x: defender.leftof(20),
y: defender.y,
z: defender.behind(-20),
time: 400,
}, 'ballistic2Under');
attacker.anim({
x: defender.x,
y: defender.y,
z: defender.z,
time: 50,
});
attacker.anim({
time: 500,
}, 'ballistic2');
defender.delay(750);
defender.anim({
x: defender.leftof(15),
y: defender.y,
z: defender.behind(20),
time: 50,
}, 'swing');
defender.anim({
time: 200,
}, 'swing');
},
},
stoneaxe: {
anim(scene, [attacker, defender]) {
BattleOtherAnims.slashattack.anim(scene, [attacker, defender]);

scene.showEffect('rock1', {
x: defender.x,
y: defender.y,
z: defender.z,
scale: 0.1,
opacity: 0.5,
time: 500,
}, {
x: defender.x - 30,
y: defender.y + 15,
z: defender.z,
scale: 0.2,
opacity: 1,
time: 800,
}, 'ballistic', 'fade');
scene.showEffect('rock3', {
x: defender.x,
y: defender.y,
z: defender.z,
scale: 0.1,
opacity: 0.5,
time: 500,
}, {
x: defender.x + 36,
y: defender.y + 45,
z: defender.z,
scale: 0.2,
opacity: 1,
time: 800,
}, 'ballistic', 'fade');
scene.showEffect('rock2', {
x: defender.x,
y: defender.y,
z: defender.z,
scale: 0.1,
opacity: 0.5,
time: 500,
}, {
x: defender.x + 40,
y: defender.y - 25,
z: defender.z,
scale: 0.2,
opacity: 1,
time: 800,
}, 'ballistic', 'fade');
scene.showEffect('rock3', {
x: defender.x,
y: defender.y,
z: defender.z,
scale: 0.1,
opacity: 0.5,
time: 500,
}, {
x: defender.x - 20,
y: defender.y - 25,
z: defender.z,
scale: 0.2,
opacity: 1,
time: 800,
}, 'ballistic', 'fade');
},
},
};

// placeholder animations
Expand Down Expand Up @@ -36716,7 +36947,6 @@ BattleMoveAnims['branchpoke'] = {anim: BattleMoveAnims['vinewhip'].anim};
BattleMoveAnims['overdrive'] = {anim: BattleMoveAnims['discharge'].anim};
BattleMoveAnims['appleacid'] = {anim: BattleMoveAnims['energyball'].anim};
BattleMoveAnims['gravapple'] = {anim: BattleMoveAnims['energyball'].anim};
BattleMoveAnims['spiritbreak'] = {anim: BattleMoveAnims['moonblast'].anim};
BattleMoveAnims['obstruct'] = {anim: BattleMoveAnims['kingsshield'].anim};
BattleMoveAnims['maxguard'] = {anim: BattleMoveAnims['banefulbunker'].anim};
BattleMoveAnims['falsesurrender'] = {anim: BattleMoveAnims['feintattack'].anim};
Expand Down Expand Up @@ -36768,12 +36998,6 @@ BattleMoveAnims['ragefist'] = {anim: BattleMoveAnims['shadowpunch'].anim};
BattleMoveAnims['ragingbull'] = {anim: BattleMoveAnims['gigaimpact'].anim};
BattleMoveAnims['shedtail'] = {anim: BattleMoveAnims['substitute'].anim};
BattleMoveAnims['shelter'] = {anim: BattleMoveAnims['withdraw'].anim};
BattleMoveAnims['stoneaxe'] = {
anim(scene, [attacker, defender]) {
BattleMoveAnims['stoneedge'].anim(scene, [attacker, defender]);
BattleOtherAnims.slashattack.anim(scene, [attacker, defender]);
},
};
BattleMoveAnims['terablast'] = {anim: BattleMoveAnims['scald'].anim};
BattleMoveAnims['terablastbug'] = {anim: BattleMoveAnims['bugbuzz'].anim};
BattleMoveAnims['terablastdark'] = {anim: BattleMoveAnims['darkpulse'].anim};
Expand Down
31 changes: 26 additions & 5 deletions play.pokemonshowdown.com/src/battle-dex-search.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1454,7 +1454,7 @@ class BattleMoveSearch extends BattleTypedSearch<'move'> {
return abilityid !== 'sheerforce';
case 'solarbeam': case 'solarblade':
return ['desolateland', 'drought', 'chlorophyll', 'orichalcumpulse'].includes(abilityid) || itemid === 'powerherb';
case 'dynamicpunch': case 'grasswhistle': case 'inferno': case 'sing': case 'zapcannon':
case 'dynamicpunch': case 'grasswhistle': case 'inferno': case 'sing':
return abilityid === 'noguard';
case 'heatcrash': case 'heavyslam': case 'slushcrush':
return species.weightkg >= (species.evos ? 75 : 130);
Expand Down Expand Up @@ -1487,6 +1487,8 @@ class BattleMoveSearch extends BattleTypedSearch<'move'> {
return true;
case 'feint':
return abilityid === 'refrigerate';
case 'futuresight':
return dex.gen > 5;
case 'grassyglide':
return abilityid === 'grassysurge';
case 'gyroball':
Expand All @@ -1503,7 +1505,8 @@ class BattleMoveSearch extends BattleTypedSearch<'move'> {
return (dex.gen < 4 && !moves.includes('firepunch')) && !moves.includes('flamethrower') &&
!moves.includes('mysticalfire') && !moves.includes('burningjealousy');
case 'hiddenpowergrass':
return !moves.includes('energyball') && !moves.includes('grassknot') && !moves.includes('gigadrain');
return (dex.gen < 4 && !moves.includes('leafblade')) ||
(dex.gen > 3 && !moves.includes('energyball') && !moves.includes('grassknot') && !moves.includes('gigadrain'));
case 'hiddenpowerice':
return !moves.includes('icebeam') && (dex.gen < 4 && !moves.includes('icepunch')) ||
(dex.gen > 5 && !moves.includes('aurorabeam') && !moves.includes('glaciate'));
Expand All @@ -1521,6 +1524,8 @@ class BattleMoveSearch extends BattleTypedSearch<'move'> {
return !moves.includes('icespinner') || ['sheerforce', 'ironfist'].includes(abilityid) || itemid === 'punchingglove';
case 'iciclecrash':
return !moves.includes('mountaingale');
case 'iciclespear':
return dex.gen > 3;
case 'icywind':
// Keldeo needs Hidden Power for Electric/Ghost
return species.baseSpecies === 'Keldeo' || this.formatType === 'doubles';
Expand All @@ -1534,24 +1539,32 @@ class BattleMoveSearch extends BattleTypedSearch<'move'> {
return !moves.includes('highjumpkick') && !moves.includes('axekick');
case 'lastresort':
return set && set.moves.length < 3;
case 'leafblade':
return dex.gen < 4;
case 'leechlife':
return dex.gen > 6;
case 'magiccoat':
return dex.gen > 3;
case 'meteorbeam':
return true;
case 'mysticalfire':
return dex.gen > 6 && !moves.includes('flamethrower');
case 'naturepower':
return dex.gen === 5;
case 'needlearm':
return dex.gen < 4;
case 'nightslash':
return !moves.includes('crunch') && !(moves.includes('knockoff') && dex.gen >= 6);
case 'outrage':
return !moves.includes('glaiverush');
return dex.gen > 3 && !moves.includes('glaiverush');
case 'petaldance':
return abilityid === 'owntempo';
case 'phantomforce':
return (!moves.includes('poltergeist') && !moves.includes('shadowclaw')) || this.formatType === 'doubles';
case 'poisonfang':
return species.types.includes('Poison') && !moves.includes('gunkshot') && !moves.includes('poisonjab');
case 'raindance':
return dex.gen < 4;
case 'relicsong':
return species.id === 'meloetta';
case 'refresh':
Expand All @@ -1566,6 +1579,8 @@ class BattleMoveSearch extends BattleTypedSearch<'move'> {
return abilityid === 'ironfist' && !moves.includes('ragefist');
case 'shelter':
return !moves.includes('acidarmor') && !moves.includes('irondefense');
case 'skyuppercut':
return dex.gen < 4;
case 'smackdown':
return species.types.includes('Ground');
case 'smartstrike':
Expand All @@ -1578,6 +1593,8 @@ class BattleMoveSearch extends BattleTypedSearch<'move'> {
return (!moves.includes('earthquake') && !moves.includes('drillrun')) || this.formatType === 'doubles';
case 'stunspore':
return !moves.includes('thunderwave');
case 'sunnyday':
return dex.gen < 4;
case 'technoblast':
return dex.gen > 5 && itemid.endsWith('drive') || itemid === 'dousedrive';
case 'teleport':
Expand All @@ -1591,10 +1608,14 @@ class BattleMoveSearch extends BattleTypedSearch<'move'> {
return dex.gen === 2;
case 'toxicspikes':
return abilityid !== 'toxicdebris';
case 'triattack':
return dex.gen > 3;
case 'trickroom':
return species.baseStats.spe <= 100;
case 'wildcharge':
return !moves.includes('supercellslam');
case 'zapcannon':
return abilityid === 'noguard' || (dex.gen < 4 && !moves.includes('thunderwave'));
}

if (this.formatType === 'doubles' && BattleMoveSearch.GOOD_DOUBLES_MOVES.includes(id)) {
Expand Down Expand Up @@ -1630,10 +1651,10 @@ class BattleMoveSearch extends BattleTypedSearch<'move'> {
'acidarmor', 'agility', 'aromatherapy', 'auroraveil', 'autotomize', 'banefulbunker', 'batonpass', 'bellydrum', 'bulkup', 'burningbulwark', 'calmmind', 'chillyreception', 'clangoroussoul', 'coil', 'cottonguard', 'courtchange', 'curse', 'defog', 'destinybond', 'detect', 'disable', 'dragondance', 'encore', 'extremeevoboost', 'filletaway', 'geomancy', 'glare', 'haze', 'healbell', 'healingwish', 'healorder', 'heartswap', 'honeclaws', 'kingsshield', 'leechseed', 'lightscreen', 'lovelykiss', 'lunardance', 'magiccoat', 'maxguard', 'memento', 'milkdrink', 'moonlight', 'morningsun', 'nastyplot', 'naturesmadness', 'noretreat', 'obstruct', 'painsplit', 'partingshot', 'perishsong', 'protect', 'quiverdance', 'recover', 'reflect', 'reflecttype', 'rest', 'revivalblessing', 'roar', 'rockpolish', 'roost', 'shedtail', 'shellsmash', 'shiftgear', 'shoreup', 'silktrap', 'slackoff', 'sleeppowder', 'sleeptalk', 'softboiled', 'spikes', 'spikyshield', 'spore', 'stealthrock', 'stickyweb', 'strengthsap', 'substitute', 'switcheroo', 'swordsdance', 'synthesis', 'tailglow', 'tailwind', 'taunt', 'thunderwave', 'tidyup', 'toxic', 'transform', 'trick', 'victorydance', 'whirlwind', 'willowisp', 'wish', 'yawn',
] as ID[] as readonly ID[];
static readonly GOOD_WEAK_MOVES = [
'accelerock', 'acrobatics', 'aquacutter', 'avalanche', 'barbbarrage', 'bonemerang', 'bouncybubble', 'bulletpunch', 'buzzybuzz', 'ceaselessedge', 'circlethrow', 'clearsmog', 'doubleironbash', 'dragondarts', 'dragontail', 'drainingkiss', 'endeavor', 'facade', 'firefang', 'flipturn', 'flowertrick', 'freezedry', 'frustration', 'geargrind', 'grassknot', 'gyroball', 'icefang', 'iceshard', 'iciclespear', 'infernalparade', 'knockoff', 'lastrespects', 'lowkick', 'machpunch', 'mortalspin', 'mysticalpower', 'naturesmadness', 'nightshade', 'nuzzle', 'pikapapow', 'populationbomb', 'psychocut', 'psyshieldbash', 'pursuit', 'quickattack', 'ragefist', 'rapidspin', 'return', 'rockblast', 'ruination', 'saltcure', 'scorchingsands', 'seismictoss', 'shadowclaw', 'shadowsneak', 'sizzlyslide', 'stoneaxe', 'storedpower', 'stormthrow', 'suckerpunch', 'superfang', 'surgingstrikes', 'tachyoncutter', 'tailslap', 'thunderclap', 'tripleaxel', 'tripledive', 'twinbeam', 'uturn', 'veeveevolley', 'voltswitch', 'watershuriken', 'weatherball',
'accelerock', 'acrobatics', 'aquacutter', 'avalanche', 'barbbarrage', 'bonemerang', 'bouncybubble', 'bulletpunch', 'buzzybuzz', 'ceaselessedge', 'circlethrow', 'clearsmog', 'doubleironbash', 'dragondarts', 'dragontail', 'drainingkiss', 'endeavor', 'facade', 'firefang', 'flipturn', 'flowertrick', 'freezedry', 'frustration', 'geargrind', 'gigadrain', 'grassknot', 'gyroball', 'icefang', 'iceshard', 'iciclespear', 'infernalparade', 'knockoff', 'lastrespects', 'lowkick', 'machpunch', 'mortalspin', 'mysticalpower', 'naturesmadness', 'nightshade', 'nuzzle', 'pikapapow', 'populationbomb', 'psychocut', 'psyshieldbash', 'pursuit', 'quickattack', 'ragefist', 'rapidspin', 'return', 'rockblast', 'ruination', 'saltcure', 'scorchingsands', 'seismictoss', 'shadowclaw', 'shadowsneak', 'sizzlyslide', 'stoneaxe', 'storedpower', 'stormthrow', 'suckerpunch', 'superfang', 'surgingstrikes', 'tachyoncutter', 'tailslap', 'thunderclap', 'tripleaxel', 'tripledive', 'twinbeam', 'uturn', 'veeveevolley', 'voltswitch', 'watershuriken', 'weatherball',
] as ID[] as readonly ID[];
static readonly BAD_STRONG_MOVES = [
'belch', 'burnup', 'crushclaw', 'dragonrush', 'dreameater', 'eggbomb', 'firepledge', 'flyingpress', 'grasspledge', 'hyperbeam', 'hyperfang', 'hyperspacehole', 'jawlock', 'landswrath', 'megakick', 'megapunch', 'mistyexplosion', 'muddywater', 'nightdaze', 'pollenpuff', 'rockclimb', 'selfdestruct', 'shelltrap', 'skyuppercut', 'slam', 'strength', 'submission', 'synchronoise', 'takedown', 'thrash', 'uproar', 'waterpledge',
'belch', 'burnup', 'crushclaw', 'dragonrush', 'dreameater', 'eggbomb', 'firepledge', 'flyingpress', 'futuresight', 'grasspledge', 'hyperbeam', 'hyperfang', 'hyperspacehole', 'jawlock', 'landswrath', 'megakick', 'megapunch', 'mistyexplosion', 'muddywater', 'nightdaze', 'pollenpuff', 'rockclimb', 'selfdestruct', 'shelltrap', 'skyuppercut', 'slam', 'strength', 'submission', 'synchronoise', 'takedown', 'thrash', 'uproar', 'waterpledge',
] as ID[] as readonly ID[];
static readonly GOOD_DOUBLES_MOVES = [
'allyswitch', 'bulldoze', 'coaching', 'electroweb', 'faketears', 'fling', 'followme', 'healpulse', 'helpinghand', 'junglehealing', 'lifedew', 'lunarblessing', 'muddywater', 'pollenpuff', 'psychup', 'ragepowder', 'safeguard', 'skillswap', 'snipeshot', 'wideguard', 'breakingswipe', 'snarl',
Expand Down
Loading

0 comments on commit 73331dc

Please sign in to comment.