From 6dab3791ae7c810114ac1d5dbdd3b018813e2a97 Mon Sep 17 00:00:00 2001 From: ModoX Date: Thu, 24 Oct 2024 23:49:56 +0200 Subject: Scripts/Spells: Implemented Demon Hunter Vengeful Bonds Closes #30345 --- src/server/scripts/Spells/spell_dh.cpp | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) (limited to 'src/server/scripts') diff --git a/src/server/scripts/Spells/spell_dh.cpp b/src/server/scripts/Spells/spell_dh.cpp index bd6dab20f36..091bd7be669 100644 --- a/src/server/scripts/Spells/spell_dh.cpp +++ b/src/server/scripts/Spells/spell_dh.cpp @@ -169,6 +169,7 @@ enum DemonHunterSpells SPELL_DH_SPIRIT_BOMB_VISUAL = 218678, SPELL_DH_THROW_GLAIVE = 185123, SPELL_DH_UNCONTAINED_FEL = 209261, + SPELL_DH_VENGEFUL_BONDS = 320635, SPELL_DH_VENGEFUL_RETREAT = 198813, SPELL_DH_VENGEFUL_RETREAT_TRIGGER = 198793, }; @@ -519,6 +520,26 @@ class spell_dh_soul_furnace_conduit : public AuraScript } }; +// 198813 - Vengeful Retreat +class spell_dh_vengeful_retreat_damage : public SpellScript +{ + bool Validate(SpellInfo const* /*spellInfo*/) override + { + return ValidateSpellInfo({ SPELL_DH_VENGEFUL_BONDS }); + } + + void HandleVengefulBonds(std::list& targets) + { + if (!GetCaster()->HasAura(SPELL_DH_VENGEFUL_BONDS)) + targets.clear(); + } + + void Register() override + { + OnObjectAreaTargetSelect += SpellObjectAreaTargetSelectFn(spell_dh_vengeful_retreat_damage::HandleVengefulBonds, EFFECT_0, TARGET_UNIT_SRC_AREA_ENEMY); + } +}; + void AddSC_demon_hunter_spell_scripts() { RegisterSpellScript(spell_dh_chaos_strike); @@ -529,6 +550,7 @@ void AddSC_demon_hunter_spell_scripts() new areatrigger_dh_generic_sigil("areatrigger_dh_sigil_of_flame"); RegisterAreaTriggerAI(areatrigger_dh_sigil_of_chains); RegisterSpellScript(spell_dh_sigil_of_chains); + RegisterSpellScript(spell_dh_vengeful_retreat_damage); // Havoc -- cgit v1.2.3