mirror of
https://github.com/araxiaonline/TrinityCore.git
synced 2026-06-13 03:32:28 -04:00
Scripts/Spells: Implement priest talent Divinity (#31470)
This commit is contained in:
8
sql/updates/world/master/2026_01_04_00_world.sql
Normal file
8
sql/updates/world/master/2026_01_04_00_world.sql
Normal file
@@ -0,0 +1,8 @@
|
||||
DELETE FROM `spell_script_names` WHERE `ScriptName`='spell_pri_divinity';
|
||||
INSERT INTO `spell_script_names` (`spell_id`,`ScriptName`) VALUES
|
||||
(1215241,'spell_pri_divinity');
|
||||
|
||||
DELETE FROM `spell_proc` WHERE `SpellId` IN (1215241,1216314);
|
||||
INSERT INTO `spell_proc` (`SpellId`,`SchoolMask`,`SpellFamilyName`,`SpellFamilyMask0`,`SpellFamilyMask1`,`SpellFamilyMask2`,`SpellFamilyMask3`,`ProcFlags`,`ProcFlags2`,`SpellTypeMask`,`SpellPhaseMask`,`HitMask`,`AttributesMask`,`DisableEffectsMask`,`ProcsPerMinute`,`Chance`,`Cooldown`,`Charges`) VALUES
|
||||
(1215241,0x00,6,0x00000000,0x00000000,0x00000000,0x00000000,0x0,0x0,0x0,0x2,0x0,0x8,0x0,0,0,0,0), -- Divinity
|
||||
(1216314,0x00,6,0x00000000,0x00000000,0x00000000,0x00000000,0x0,0x0,0x0,0x4,0x0,0x18,0x0,0,0,0,0); -- Divinity
|
||||
@@ -93,6 +93,8 @@ enum PriestSpells
|
||||
SPELL_PRIEST_DIVINE_STAR_SHADOW_DAMAGE = 390845,
|
||||
SPELL_PRIEST_DIVINE_STAR_SHADOW_HEAL = 390981,
|
||||
SPELL_PRIEST_DIVINE_WRATH = 40441,
|
||||
SPELL_PRIEST_DIVINITY = 1215241,
|
||||
SPELL_PRIEST_DIVINITY_AURA = 1216314,
|
||||
SPELL_PRIEST_EMPOWERED_RENEW = 391339,
|
||||
SPELL_PRIEST_EMPOWERED_RENEW_HEAL = 391359,
|
||||
SPELL_PRIEST_ENTROPIC_RIFT = 447444,
|
||||
@@ -241,6 +243,11 @@ enum PriestSpells
|
||||
SPELL_PVP_RULES_ENABLED_HARDCODED = 134735
|
||||
};
|
||||
|
||||
enum PriestSpellLabels
|
||||
{
|
||||
SPELL_LABEL_PRIEST_APOTHEOSIS = 3635,
|
||||
};
|
||||
|
||||
enum PriestSpellVisuals
|
||||
{
|
||||
SPELL_VISUAL_PRIEST_POWER_WORD_RADIANCE = 52872,
|
||||
@@ -1332,6 +1339,39 @@ private:
|
||||
std::vector<ObjectGuid> _affectedUnits;
|
||||
};
|
||||
|
||||
// 1215241 - Divinity
|
||||
class spell_pri_divinity : public AuraScript
|
||||
{
|
||||
bool Validate(SpellInfo const* spellInfo) override
|
||||
{
|
||||
return ValidateSpellEffect({ { spellInfo->Id, EFFECT_2 } })
|
||||
&& ValidateSpellInfo({ SPELL_PRIEST_APOTHEOSIS, spellInfo->GetEffect(EFFECT_2).TriggerSpell });
|
||||
}
|
||||
|
||||
static bool CheckProc(AuraScript const&, ProcEventInfo const& eventInfo)
|
||||
{
|
||||
return eventInfo.GetSpellInfo()->HasLabel(SPELL_LABEL_PRIEST_APOTHEOSIS);
|
||||
}
|
||||
|
||||
void HandleProc(AuraEffect const* aurEff, ProcEventInfo const& procInfo)
|
||||
{
|
||||
PreventDefaultAction();
|
||||
|
||||
GetTarget()->CastSpell(GetTarget(), aurEff->GetSpellEffectInfo().TriggerSpell, CastSpellExtraArgsInit{
|
||||
.TriggerFlags = TRIGGERED_IGNORE_CAST_IN_PROGRESS | TRIGGERED_DONT_REPORT_CAST_ERROR,
|
||||
.TriggeringSpell = procInfo.GetProcSpell(),
|
||||
.TriggeringAura = aurEff,
|
||||
.SpellValueOverrides = { { SPELLVALUE_AURA_STACK, int32(sSpellMgr->AssertSpellInfo(aurEff->GetSpellEffectInfo().TriggerSpell, DIFFICULTY_NONE)->StackAmount) } }
|
||||
});
|
||||
}
|
||||
|
||||
void Register() override
|
||||
{
|
||||
DoCheckProc += AuraCheckProcFn(spell_pri_divinity::CheckProc);
|
||||
OnEffectProc += AuraEffectProcFn(spell_pri_divinity::HandleProc, EFFECT_2, SPELL_AURA_PROC_TRIGGER_SPELL);
|
||||
}
|
||||
};
|
||||
|
||||
struct spell_pri_holy_words_base
|
||||
{
|
||||
static void ModifyCooldown(Unit* priest, SpellInfo const* spellInfo, Milliseconds cooldownMod)
|
||||
@@ -4539,6 +4579,7 @@ void AddSC_priest_spell_scripts()
|
||||
RegisterSpellScript(spell_pri_divine_service);
|
||||
RegisterSpellScript(spell_pri_divine_star_shadow);
|
||||
RegisterAreaTriggerAI(areatrigger_pri_divine_star);
|
||||
RegisterSpellScript(spell_pri_divinity);
|
||||
RegisterSpellScript(spell_pri_divine_procession);
|
||||
RegisterSpellScript(spell_pri_empowered_renew);
|
||||
RegisterSpellScript(spell_pri_empowered_renew_heal);
|
||||
|
||||
Reference in New Issue
Block a user