aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAqua Deus <95978183+aquadeus@users.noreply.github.com>2024-12-01 14:29:46 +0100
committerGitHub <noreply@github.com>2024-12-01 14:29:46 +0100
commit7231f6722ff7854b8c8bf8cbe2dd83f64ef2b5e0 (patch)
tree7fdf6e455618d9a1c7eba633954836d172c0f49a
parent9c6a9d031ef0227093d42360e6acd9d17e07ab0c (diff)
Scripts/Spells: Implement demon hunter talent "Chaotic Transformation" (#30471)
-rw-r--r--sql/updates/world/master/2024_12_01_02_world.sql3
-rw-r--r--src/server/scripts/Spells/spell_dh.cpp39
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);