diff options
| -rw-r--r-- | sql/updates/world/master/2025_01_14_02_world.sql | 11 | ||||
| -rw-r--r-- | src/server/scripts/Spells/spell_evoker.cpp | 36 |
2 files changed, 47 insertions, 0 deletions
diff --git a/sql/updates/world/master/2025_01_14_02_world.sql b/sql/updates/world/master/2025_01_14_02_world.sql new file mode 100644 index 00000000000..361cb303de8 --- /dev/null +++ b/sql/updates/world/master/2025_01_14_02_world.sql @@ -0,0 +1,11 @@ +DELETE FROM `areatrigger_template` WHERE (`Id`=27633 AND `IsCustom`=0); +INSERT INTO `areatrigger_template` (`Id`, `IsCustom`, `Flags`, `VerifiedBuild`) VALUES +(27633, 0, 0, 58187); + +DELETE FROM `areatrigger_create_properties` WHERE (`Id`=23318 AND `IsCustom`=0); +INSERT INTO `areatrigger_create_properties` (`Id`, `IsCustom`, `AreaTriggerId`, `IsAreatriggerCustom`, `Flags`, `MoveCurveId`, `ScaleCurveId`, `MorphCurveId`, `FacingCurveId`, `AnimId`, `AnimKitId`, `DecalPropertiesId`, `SpellForVisuals`, `TimeToTargetScale`, `Shape`, `ShapeData0`, `ShapeData1`, `ShapeData2`, `ShapeData3`, `ShapeData4`, `ShapeData5`, `ShapeData6`, `ShapeData7`, `ScriptName`, `VerifiedBuild`) VALUES +(23318, 0, 27633, 0, 0, 0, 0, 0, 0, -1, 0, 0, NULL, 1500, 0, 3, 3, 0, 0, 0, 0, 0, 0, 'at_evo_emerald_blossom', 58187); -- Spell: 355913 (Emerald Blossom) + +DELETE FROM `spell_script_names` WHERE `ScriptName`='spell_evo_emerald_blossom_heal'; +INSERT INTO `spell_script_names` (`spell_id`, `ScriptName`) VALUES +(355916, 'spell_evo_emerald_blossom_heal'); diff --git a/src/server/scripts/Spells/spell_evoker.cpp b/src/server/scripts/Spells/spell_evoker.cpp index 6db4eb3c441..aa9daff5ca1 100644 --- a/src/server/scripts/Spells/spell_evoker.cpp +++ b/src/server/scripts/Spells/spell_evoker.cpp @@ -51,6 +51,7 @@ enum EvokerSpells SPELL_EVOKER_BLESSING_OF_THE_BRONZE_SHAMAN = 381756, SPELL_EVOKER_BLESSING_OF_THE_BRONZE_WARLOCK = 381757, SPELL_EVOKER_BLESSING_OF_THE_BRONZE_WARRIOR = 381758, + SPELL_EVOKER_EMERALD_BLOSSOM_HEAL = 355916, SPELL_EVOKER_ENERGIZING_FLAME = 400006, SPELL_EVOKER_ESSENCE_BURST = 359618, SPELL_EVOKER_FIRESTORM_DAMAGE = 369374, @@ -162,6 +163,39 @@ class spell_evo_charged_blast : public AuraScript } }; +// 355913 - Emerald Blossom (Green) +// ID - 23318 +struct at_evo_emerald_blossom : AreaTriggerAI +{ + using AreaTriggerAI::AreaTriggerAI; + + void OnRemove() override + { + if (Unit* caster = at->GetCaster()) + caster->CastSpell(at->GetPosition(), SPELL_EVOKER_EMERALD_BLOSSOM_HEAL, TRIGGERED_IGNORE_CAST_IN_PROGRESS | TRIGGERED_DONT_REPORT_CAST_ERROR); + } +}; + +// 355916 - Emerald Blossom (Green) +class spell_evo_emerald_blossom_heal : public SpellScript +{ + bool Validate(SpellInfo const* spellInfo) override + { + return ValidateSpellEffect({ { spellInfo->Id, EFFECT_1 } }); + } + + void FilterTargets(std::list<WorldObject*>& targets) const + { + uint32 const maxTargets = uint32(GetSpellInfo()->GetEffect(EFFECT_1).CalcValue(GetCaster())); + Trinity::SelectRandomInjuredTargets(targets, maxTargets, true); + } + + void Register() override + { + OnObjectAreaTargetSelect += SpellObjectAreaTargetSelectFn(spell_evo_emerald_blossom_heal::FilterTargets, EFFECT_0, TARGET_UNIT_DEST_AREA_ALLY); + } +}; + // Called by 362969 - Azure Strike // Called by 361469 - Living Flame (Red) class spell_evo_essence_burst_trigger : public SpellScript @@ -588,6 +622,8 @@ void AddSC_evoker_spell_scripts() RegisterSpellScript(spell_evo_azure_strike); RegisterSpellScript(spell_evo_blessing_of_the_bronze); RegisterSpellScript(spell_evo_charged_blast); + RegisterAreaTriggerAI(at_evo_emerald_blossom); + RegisterSpellScript(spell_evo_emerald_blossom_heal); RegisterSpellScriptWithArgs(spell_evo_essence_burst_trigger, "spell_evo_azure_essence_burst", SPELL_EVOKER_AZURE_ESSENCE_BURST); RegisterSpellScriptWithArgs(spell_evo_essence_burst_trigger, "spell_evo_ruby_essence_burst", SPELL_EVOKER_RUBY_ESSENCE_BURST); RegisterAreaTriggerAI(at_evo_firestorm); |
