diff options
author | Aqua Deus <95978183+aquadeus@users.noreply.github.com> | 2024-12-01 14:29:46 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-12-01 14:29:46 +0100 |
commit | 7231f6722ff7854b8c8bf8cbe2dd83f64ef2b5e0 (patch) | |
tree | 7fdf6e455618d9a1c7eba633954836d172c0f49a | |
parent | 9c6a9d031ef0227093d42360e6acd9d17e07ab0c (diff) |
Scripts/Spells: Implement demon hunter talent "Chaotic Transformation" (#30471)
-rw-r--r-- | sql/updates/world/master/2024_12_01_02_world.sql | 3 | ||||
-rw-r--r-- | src/server/scripts/Spells/spell_dh.cpp | 39 |
2 files changed, 42 insertions, 0 deletions
diff --git a/sql/updates/world/master/2024_12_01_02_world.sql b/sql/updates/world/master/2024_12_01_02_world.sql new file mode 100644 index 00000000000..4588bd5c44b --- /dev/null +++ b/sql/updates/world/master/2024_12_01_02_world.sql @@ -0,0 +1,3 @@ +DELETE FROM `spell_script_names` WHERE `ScriptName`='spell_dh_chaotic_transformation'; +INSERT INTO `spell_script_names` (`spell_id`, `ScriptName`) VALUES +(191427, 'spell_dh_chaotic_transformation'); diff --git a/src/server/scripts/Spells/spell_dh.cpp b/src/server/scripts/Spells/spell_dh.cpp index f7b8bc4d5b8..61336178a2b 100644 --- a/src/server/scripts/Spells/spell_dh.cpp +++ b/src/server/scripts/Spells/spell_dh.cpp @@ -23,6 +23,7 @@ #include "AreaTrigger.h" #include "AreaTriggerAI.h" +#include "DB2Stores.h" #include "Player.h" #include "ScriptMgr.h" #include "SpellAuraEffects.h" @@ -55,6 +56,7 @@ enum DemonHunterSpells SPELL_DH_CHAOS_STRIKE_ENERGIZE = 193840, SPELL_DH_CHAOS_STRIKE_MH = 222031, SPELL_DH_CHAOS_STRIKE_OH = 199547, + SPELL_DH_CHAOTIC_TRANSFORMATION = 388112, SPELL_DH_CHARRED_WARBLADES_HEAL = 213011, SPELL_DH_CONSUME_SOUL_HAVOC = 228542, SPELL_DH_CONSUME_SOUL_HAVOC_DEMON = 228556, @@ -176,6 +178,12 @@ enum DemonHunterSpells SPELL_DH_VENGEFUL_RETREAT_TRIGGER = 198793, }; +enum DemonHunterSpellCategories +{ + SPELL_CATEGORY_DH_EYE_BEAM = 1582, + SPELL_CATEGORY_DH_BLADE_DANCE = 1640 +}; + // 197125 - Chaos Strike class spell_dh_chaos_strike : public AuraScript { @@ -199,6 +207,36 @@ class spell_dh_chaos_strike : public AuraScript } }; +// Called by 191427 - Metamorphosis +class spell_dh_chaotic_transformation : public SpellScript +{ + bool Validate(SpellInfo const* /*spellInfo*/) override + { + return ValidateSpellInfo({ SPELL_DH_CHAOTIC_TRANSFORMATION }) + && sSpellCategoryStore.LookupEntry(SPELL_CATEGORY_DH_EYE_BEAM) + && sSpellCategoryStore.LookupEntry(SPELL_CATEGORY_DH_BLADE_DANCE); + } + + bool Load() override + { + return GetCaster()->HasAura(SPELL_DH_CHAOTIC_TRANSFORMATION); + } + + void HandleCooldown() const + { + GetCaster()->GetSpellHistory()->ResetCooldowns([](SpellHistory::CooldownStorageType::iterator itr) + { + uint32 category = sSpellMgr->AssertSpellInfo(itr->first, DIFFICULTY_NONE)->CategoryId; + return category == SPELL_CATEGORY_DH_EYE_BEAM || category == SPELL_CATEGORY_DH_BLADE_DANCE; + }, true); + } + + void Register() override + { + AfterCast += SpellCastFn(spell_dh_chaotic_transformation::HandleCooldown); + } +}; + // 213010 - Charred Warblades class spell_dh_charred_warblades : public AuraScript { @@ -595,6 +633,7 @@ class spell_dh_vengeful_retreat_damage : public SpellScript void AddSC_demon_hunter_spell_scripts() { RegisterSpellScript(spell_dh_chaos_strike); + RegisterSpellScript(spell_dh_chaotic_transformation); RegisterSpellScript(spell_dh_charred_warblades); RegisterSpellScript(spell_dh_eye_beam); RegisterSpellScript(spell_dh_sigil_of_chains); |