diff options
author | Aqua Deus <95978183+aquadeus@users.noreply.github.com> | 2024-12-12 23:47:26 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-12-12 23:47:26 +0100 |
commit | 4ddf42ca52a3644ec9f23fa93fe71fa89c03b71e (patch) | |
tree | e1e7e0f64347718dd58d9c81d8d74948e9ba1447 | |
parent | 8d8598de1a6dc84281267b9e0a6acfeefcc32bdb (diff) |
Scripts/Spells: Implement demon hunter talent "Felblade" (#30478)
Co-authored-by: Shauren <shauren.trinity@gmail.com>
-rw-r--r-- | sql/updates/world/master/2024_12_12_01_world.sql | 12 | ||||
-rw-r--r-- | src/server/scripts/Spells/spell_dh.cpp | 76 |
2 files changed, 84 insertions, 4 deletions
diff --git a/sql/updates/world/master/2024_12_12_01_world.sql b/sql/updates/world/master/2024_12_12_01_world.sql new file mode 100644 index 00000000000..ecb80c21633 --- /dev/null +++ b/sql/updates/world/master/2024_12_12_01_world.sql @@ -0,0 +1,12 @@ +DELETE FROM `spell_script_names` WHERE `ScriptName` IN ('spell_dh_felblade', 'spell_dh_felblade_charge','spell_dh_felblade_cooldown_reset_proc'); +INSERT INTO `spell_script_names` (`spell_id`, `ScriptName`) VALUES +(232893, 'spell_dh_felblade'), +(213241, 'spell_dh_felblade_charge'), +(203557, 'spell_dh_felblade_cooldown_reset_proc'), +(236167, 'spell_dh_felblade_cooldown_reset_proc'); + +DELETE FROM `spell_proc` WHERE `SpellId` IN (203557,236167,204497); +INSERT INTO `spell_proc` (`SpellId`,`SchoolMask`,`SpellFamilyName`,`SpellFamilyMask0`,`SpellFamilyMask1`,`SpellFamilyMask2`,`SpellFamilyMask3`,`ProcFlags`,`ProcFlags2`,`SpellTypeMask`,`SpellPhaseMask`,`HitMask`,`AttributesMask`,`DisableEffectsMask`,`ProcsPerMinute`,`Chance`,`Cooldown`,`Charges`) VALUES +(203557,0x00,107,0x00400000,0x00000000,0x00000020,0x00000000,0x0,0x0,0x1,0x2,0x0,0x0,0x0,0,0,0,0), -- Felblade +(236167,0x00,107,0x00000001,0x00001000,0x00000000,0x00000000,0x0,0x0,0x1,0x2,0x0,0x2,0x0,0,0,0,0), -- Felblade +(204497,0x00,107,0x40000000,0x00000000,0x00000000,0x00000000,0x0,0x0,0x0,0x1,0x0,0x0,0x0,0,0,0,1); -- Felblade diff --git a/src/server/scripts/Spells/spell_dh.cpp b/src/server/scripts/Spells/spell_dh.cpp index 6cf15c6587b..60d24c6d756 100644 --- a/src/server/scripts/Spells/spell_dh.cpp +++ b/src/server/scripts/Spells/spell_dh.cpp @@ -97,10 +97,10 @@ enum DemonHunterSpells SPELL_DH_FEL_RUSH_WATER_AIR = 197923, SPELL_DH_FELBLADE = 232893, SPELL_DH_FELBLADE_CHARGE = 213241, - SPELL_DH_FELBLADE_DMG = 213243, - SPELL_DH_FELBLADE_PROC = 203557, - SPELL_DH_FELBLADE_PROC_VISUAL = 204497, - SPELL_DH_FELBLADE_PROC1 = 236167, + SPELL_DH_FELBLADE_COOLDOWN_RESET_PROC_HAVOC = 236167, + SPELL_DH_FELBLADE_COOLDOWN_RESET_PROC_VENGEANCE= 203557, + SPELL_DH_FELBLADE_COOLDOWN_RESET_PROC_VISUAL = 204497, + SPELL_DH_FELBLADE_DAMAGE = 213243, SPELL_DH_FIERY_BRAND = 204021, SPELL_DH_FIERY_BRAND_DMG_REDUCTION_DEBUFF = 207744, SPELL_DH_FIERY_BRAND_DOT = 207771, @@ -469,6 +469,71 @@ class spell_dh_fel_flame_fortification : public AuraScript } }; +// 232893 - Felblade +class spell_dh_felblade : public SpellScript +{ + bool Validate(SpellInfo const* /*spellInfo*/) override + { + return ValidateSpellInfo({ SPELL_DH_FELBLADE_CHARGE }); + } + + void HandleCharge(SpellEffIndex /*effIndex*/) const + { + uint32 spellToCast = GetCaster()->IsWithinMeleeRange(GetHitUnit()) ? SPELL_DH_FELBLADE_DAMAGE : SPELL_DH_FELBLADE_CHARGE; + GetCaster()->CastSpell(GetHitUnit(), spellToCast, CastSpellExtraArgsInit{ + .TriggerFlags = TRIGGERED_IGNORE_CAST_IN_PROGRESS | TRIGGERED_DONT_REPORT_CAST_ERROR, + .TriggeringSpell = GetSpell() + }); + } + + void Register() override + { + OnEffectHitTarget += SpellEffectFn(spell_dh_felblade::HandleCharge, EFFECT_0, SPELL_EFFECT_DUMMY); + } +}; + +// 213241 - Felblade Charge +class spell_dh_felblade_charge : public SpellScript +{ + bool Validate(SpellInfo const* /*spellInfo*/) override + { + return ValidateSpellInfo({ SPELL_DH_FELBLADE_DAMAGE }); + } + + void HandleDamage(SpellEffIndex /*effIndex*/) const + { + GetCaster()->CastSpell(GetHitUnit(), SPELL_DH_FELBLADE_DAMAGE, CastSpellExtraArgsInit{ + .TriggerFlags = TRIGGERED_IGNORE_CAST_IN_PROGRESS | TRIGGERED_DONT_REPORT_CAST_ERROR, + .TriggeringSpell = GetSpell() + }); + } + + void Register() override + { + OnEffectHitTarget += SpellEffectFn(spell_dh_felblade_charge::HandleDamage, EFFECT_0, SPELL_EFFECT_CHARGE); + } +}; + +// 203557 - Felblade (Vengeance cooldow reset proc aura) +// 236167 - Felblade (Havoc cooldow reset proc aura) +class spell_dh_felblade_cooldown_reset_proc : public AuraScript +{ + bool Validate(SpellInfo const* /*spellInfo*/) override + { + return ValidateSpellInfo({ SPELL_DH_FELBLADE }); + } + + void HandleProc(AuraEffect const* /*aurEff*/, ProcEventInfo const& /*eventInfo*/) const + { + GetTarget()->GetSpellHistory()->ResetCooldown(SPELL_DH_FELBLADE, true); + } + + void Register() override + { + OnEffectProc += AuraEffectProcFn(spell_dh_felblade_cooldown_reset_proc::HandleProc, EFFECT_0, SPELL_AURA_PROC_TRIGGER_SPELL); + } +}; + // 206416 - First Blood class spell_dh_first_blood : public AuraScript { @@ -807,6 +872,9 @@ void AddSC_demon_hunter_spell_scripts() RegisterSpellScript(spell_dh_eye_beam); RegisterSpellScript(spell_dh_fel_devastation); RegisterSpellScript(spell_dh_fel_flame_fortification); + RegisterSpellScript(spell_dh_felblade); + RegisterSpellScript(spell_dh_felblade_charge); + RegisterSpellScript(spell_dh_felblade_cooldown_reset_proc); RegisterSpellScript(spell_dh_sigil_of_chains); RegisterSpellScript(spell_dh_tactical_retreat); RegisterSpellScript(spell_dh_vengeful_retreat_damage); |