mirror of
https://github.com/TrinityCore/TrinityCore.git
synced 2026-01-24 02:46:33 +01:00
Core/Scripts: Added missing spells in Skeram (#18486)
This commit is contained in:
3
sql/updates/world/3.3.5/2016_12_27_10_world.sql
Normal file
3
sql/updates/world/3.3.5/2016_12_27_10_world.sql
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
DELETE FROM `spell_script_names` WHERE `ScriptName`='spell_skeram_true_fulfillment';
|
||||||
|
INSERT INTO `spell_script_names` (`spell_id`, `ScriptName`) VALUES
|
||||||
|
(785,'spell_skeram_true_fulfillment');
|
||||||
@@ -34,8 +34,10 @@ enum Spells
|
|||||||
SPELL_ARCANE_EXPLOSION = 26192,
|
SPELL_ARCANE_EXPLOSION = 26192,
|
||||||
SPELL_EARTH_SHOCK = 26194,
|
SPELL_EARTH_SHOCK = 26194,
|
||||||
SPELL_TRUE_FULFILLMENT = 785,
|
SPELL_TRUE_FULFILLMENT = 785,
|
||||||
|
SPELL_TRUE_FULFILLMENT_2 = 2313,
|
||||||
SPELL_INITIALIZE_IMAGE = 3730,
|
SPELL_INITIALIZE_IMAGE = 3730,
|
||||||
SPELL_SUMMON_IMAGES = 747
|
SPELL_SUMMON_IMAGES = 747,
|
||||||
|
SPELL_GENERIC_DISMOUNT = 61286
|
||||||
};
|
};
|
||||||
|
|
||||||
enum Events
|
enum Events
|
||||||
@@ -158,9 +160,8 @@ class boss_skeram : public CreatureScript
|
|||||||
events.ScheduleEvent(EVENT_ARCANE_EXPLOSION, urand(8000, 18000));
|
events.ScheduleEvent(EVENT_ARCANE_EXPLOSION, urand(8000, 18000));
|
||||||
break;
|
break;
|
||||||
case EVENT_FULLFILMENT:
|
case EVENT_FULLFILMENT:
|
||||||
/// @todo For some weird reason boss does not cast this
|
if (Unit* target = SelectTarget(SELECT_TARGET_RANDOM, 1, 45.0f, true))
|
||||||
// Spell actually works, tested in duel
|
DoCast(target, SPELL_TRUE_FULFILLMENT);
|
||||||
DoCast(SelectTarget(SELECT_TARGET_RANDOM, 0, 0.0f, true), SPELL_TRUE_FULFILLMENT, true);
|
|
||||||
events.ScheduleEvent(EVENT_FULLFILMENT, urand(20000, 30000));
|
events.ScheduleEvent(EVENT_FULLFILMENT, urand(20000, 30000));
|
||||||
break;
|
break;
|
||||||
case EVENT_BLINK:
|
case EVENT_BLINK:
|
||||||
@@ -218,6 +219,7 @@ class PlayerOrPetCheck
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// 26192 - Arcane Explosion
|
||||||
class spell_skeram_arcane_explosion : public SpellScriptLoader
|
class spell_skeram_arcane_explosion : public SpellScriptLoader
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@@ -244,8 +246,44 @@ class spell_skeram_arcane_explosion : public SpellScriptLoader
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// 785 - True Fulfillment
|
||||||
|
class spell_skeram_true_fulfillment : public SpellScriptLoader
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
spell_skeram_true_fulfillment() : SpellScriptLoader("spell_skeram_true_fulfillment") { }
|
||||||
|
|
||||||
|
class spell_skeram_true_fulfillment_SpellScript : public SpellScript
|
||||||
|
{
|
||||||
|
PrepareSpellScript(spell_skeram_true_fulfillment_SpellScript);
|
||||||
|
|
||||||
|
bool Validate(SpellInfo const* /*spell*/) override
|
||||||
|
{
|
||||||
|
if (!sSpellMgr->GetSpellInfo(SPELL_TRUE_FULFILLMENT_2))
|
||||||
|
return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void HandleEffect(SpellEffIndex /*effIndex*/)
|
||||||
|
{
|
||||||
|
GetCaster()->CastSpell(GetHitUnit(), SPELL_GENERIC_DISMOUNT, true);
|
||||||
|
GetCaster()->CastSpell(GetHitUnit(), SPELL_TRUE_FULFILLMENT_2, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Register() override
|
||||||
|
{
|
||||||
|
OnEffectHitTarget += SpellEffectFn(spell_skeram_true_fulfillment_SpellScript::HandleEffect, EFFECT_0, SPELL_AURA_MOD_CHARM);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
SpellScript* GetSpellScript() const override
|
||||||
|
{
|
||||||
|
return new spell_skeram_true_fulfillment_SpellScript();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
void AddSC_boss_skeram()
|
void AddSC_boss_skeram()
|
||||||
{
|
{
|
||||||
new boss_skeram();
|
new boss_skeram();
|
||||||
new spell_skeram_arcane_explosion();
|
new spell_skeram_arcane_explosion();
|
||||||
|
new spell_skeram_true_fulfillment();
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user