aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/server/scripts/BrokenIsles/broken_isles_script_loader.cpp9
-rw-r--r--src/server/scripts/BrokenIsles/zone_dalaran_broken_isle.cpp164
2 files changed, 171 insertions, 2 deletions
diff --git a/src/server/scripts/BrokenIsles/broken_isles_script_loader.cpp b/src/server/scripts/BrokenIsles/broken_isles_script_loader.cpp
index aba5c241fac..29108f9f2c9 100644
--- a/src/server/scripts/BrokenIsles/broken_isles_script_loader.cpp
+++ b/src/server/scripts/BrokenIsles/broken_isles_script_loader.cpp
@@ -17,6 +17,9 @@
// This is where scripts' loading functions should be declared:
+void AddSC_zone_dalaran_broken_isle();
+void AddSC_zone_mardum();
+
// Maw of Souls
void AddSC_boss_ymiron_the_fallen_king();
void AddSC_instance_maw_of_souls();
@@ -27,12 +30,14 @@ void AddSC_instance_trial_of_valor();
// Orderhalls
void AddSC_orderhall_warrior();
-void AddSC_zone_mardum();
// The name of this function should match:
// void Add${NameOfDirectory}Scripts()
void AddBrokenIslesScripts()
{
+ AddSC_zone_dalaran_broken_isle();
+ AddSC_zone_mardum();
+
// Maw of Souls
AddSC_boss_ymiron_the_fallen_king();
AddSC_instance_maw_of_souls();
@@ -41,6 +46,6 @@ void AddBrokenIslesScripts()
AddSC_boss_guarm();
AddSC_instance_trial_of_valor();
+ // Orderhalls
AddSC_orderhall_warrior();
- AddSC_zone_mardum();
}
diff --git a/src/server/scripts/BrokenIsles/zone_dalaran_broken_isle.cpp b/src/server/scripts/BrokenIsles/zone_dalaran_broken_isle.cpp
new file mode 100644
index 00000000000..829e566c6d3
--- /dev/null
+++ b/src/server/scripts/BrokenIsles/zone_dalaran_broken_isle.cpp
@@ -0,0 +1,164 @@
+/*
+ * This file is part of the TrinityCore Project. See AUTHORS file for Copyright information
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by the
+ * Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
+ * more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "ScriptMgr.h"
+#include "ObjectAccessor.h"
+#include "Player.h"
+#include "SpellAuras.h"
+#include "SpellScript.h"
+
+enum OrderCampaignDalaranIntro
+{
+ // Quest
+ QUEST_AN_IMPORTANT_MISSION = 42814,
+ QUEST_A_DESPERATE_PLEA = 41052,
+ QUEST_FELSTORMS_PLEA = 41035,
+ QUEST_NEEDS_OF_THE_HUNTER = 40384,
+ QUEST_CALL_OF_THE_UNCROWNED = 40832,
+ QUEST_PRIESTLY_MATTERS = 40705,
+ QUEST_THE_SIXTH = 40716,
+ QUEST_AN_URGENT_GATHERING = 38710,
+ QUEST_A_SUMMONS_FROM_MOONGLADE = 40643,
+ QUEST_BEFORE_THE_STORM = 12103,
+ QUEST_CALL_OF_THE_ILLIDARI_ALTRUIS = 39047,
+ QUEST_CALL_OF_THE_ILLIDARI_JAYCE = 39261,
+ QUEST_THE_CALL_TO_WAR = 40714,
+
+ // Tracking Quests DH
+ QUEST_A_NEW_DIRECTION_ALTRUIS = 40375,
+ QUEST_A_NEW_DIRECTION_JAYCE = 40374,
+
+ // Mage
+ SPELL_MAGE_ORDER_FORMATION = 195356,
+
+ // Death Knight
+ SPELL_AN_AUDIENCE_WITH_THE_KING = 200023,
+
+ // Summon Spells
+ SPELL_SUMMON_DALTON_WARRIOR = 216497,
+ SPELL_SUMMON_EITRIGG_WARRIOR = 216443,
+ SPELL_SUMMON_SNOWFEATHER_HUNTER = 196908,
+ SPELL_SUMMON_RAVENHOLDT_COURIER_ROGUE = 201208,
+ SPELL_A_SUMMON_MESSENGER_PRIEST = 202051,
+ SPELL_H_SUMMON_MESSENGER_PRIEST = 226409,
+ SPELL_SUMMON_RYSSTINS_PORTAL_WARLOCK = 204858,
+ SPELL_SUMMON_RYSSTINS_WARLOCK = 204860,
+ SPELL_SUMMON_MAXWELL_TYROSUS_PALADIN = 190886,
+ SPELL_SUMMON_DA_NEL_MONK = 193978,
+ SPELL_SUMMON_KORVAS_DH = 195286,
+ SPELL_SUMMON_RUNETOTEM_DRUID = 199277
+};
+
+// 224240 - 7.0 Order Campaign - Dalaran Aura
+class spell_dalaran_order_campaign_intro_aura : public AuraScript
+{
+ void HandlePeriodic(AuraEffect const* /*aurEff*/)
+ {
+ Player* player = Object::ToPlayer(GetCaster());
+ if (!player)
+ return;
+
+ switch (player->GetClass())
+ {
+ case CLASS_WARRIOR:
+ {
+ if (player->GetTeamId() == TEAM_ALLIANCE && player->GetQuestStatus(QUEST_AN_IMPORTANT_MISSION) == QUEST_STATUS_NONE)
+ player->CastSpell(nullptr, SPELL_SUMMON_DALTON_WARRIOR, true);
+ else if (player->GetTeamId() == TEAM_HORDE && player->GetQuestStatus(QUEST_A_DESPERATE_PLEA) == QUEST_STATUS_NONE)
+ player->CastSpell(nullptr, SPELL_SUMMON_EITRIGG_WARRIOR, true);
+ break;
+ }
+ case CLASS_HUNTER:
+ {
+ if (player->GetQuestStatus(QUEST_NEEDS_OF_THE_HUNTER) == QUEST_STATUS_NONE)
+ player->CastSpell(nullptr, SPELL_SUMMON_SNOWFEATHER_HUNTER, true);
+ break;
+ }
+ case CLASS_MAGE:
+ {
+ if (player->GetQuestStatus(QUEST_FELSTORMS_PLEA) == QUEST_STATUS_NONE)
+ player->CastSpell(nullptr, SPELL_MAGE_ORDER_FORMATION, true);
+ break;
+ }
+ case CLASS_ROGUE:
+ {
+ if (player->GetQuestStatus(QUEST_CALL_OF_THE_UNCROWNED) == QUEST_STATUS_NONE)
+ player->CastSpell(nullptr, SPELL_SUMMON_RAVENHOLDT_COURIER_ROGUE, true);
+ break;
+ }
+ case CLASS_PRIEST:
+ {
+ if (player->GetTeamId() == TEAM_ALLIANCE && player->GetQuestStatus(QUEST_PRIESTLY_MATTERS) == QUEST_STATUS_NONE)
+ player->CastSpell(nullptr, SPELL_A_SUMMON_MESSENGER_PRIEST, true);
+ else if (player->GetTeamId() == TEAM_HORDE && player->GetQuestStatus(QUEST_PRIESTLY_MATTERS) == QUEST_STATUS_NONE)
+ player->CastSpell(nullptr, SPELL_H_SUMMON_MESSENGER_PRIEST, true);
+ break;
+ }
+ case CLASS_WARLOCK:
+ {
+ if (player->GetQuestStatus(QUEST_THE_SIXTH) == QUEST_STATUS_NONE)
+ player->CastSpell(nullptr, SPELL_SUMMON_RYSSTINS_PORTAL_WARLOCK, true);
+ break;
+ }
+ case CLASS_PALADIN:
+ {
+ if (player->GetQuestStatus(QUEST_AN_URGENT_GATHERING) == QUEST_STATUS_NONE)
+ player->CastSpell(nullptr, SPELL_SUMMON_MAXWELL_TYROSUS_PALADIN, true);
+ break;
+ }
+ case CLASS_DRUID:
+ {
+ if (player->GetQuestStatus(QUEST_A_SUMMONS_FROM_MOONGLADE) == QUEST_STATUS_NONE)
+ player->CastSpell(nullptr, SPELL_SUMMON_RUNETOTEM_DRUID, true);
+ break;
+ }
+ case CLASS_MONK:
+ {
+ if (player->GetQuestStatus(QUEST_BEFORE_THE_STORM) == QUEST_STATUS_NONE)
+ player->CastSpell(nullptr, SPELL_SUMMON_DA_NEL_MONK, true);
+ break;
+ }
+ case CLASS_DEMON_HUNTER:
+ {
+ if (player->GetQuestStatus(QUEST_CALL_OF_THE_ILLIDARI_ALTRUIS) == QUEST_STATUS_NONE && player->GetQuestStatus(QUEST_A_NEW_DIRECTION_ALTRUIS) == QUEST_STATUS_REWARDED)
+ player->CastSpell(nullptr, SPELL_SUMMON_KORVAS_DH, true);
+ else if (player->GetQuestStatus(QUEST_CALL_OF_THE_ILLIDARI_JAYCE) == QUEST_STATUS_NONE && player->GetQuestStatus(QUEST_A_NEW_DIRECTION_JAYCE) == QUEST_STATUS_REWARDED)
+ player->CastSpell(nullptr, SPELL_SUMMON_KORVAS_DH, true);
+ break;
+ }
+ case CLASS_DEATH_KNIGHT:
+ {
+ if (player->GetQuestStatus(QUEST_THE_CALL_TO_WAR) == QUEST_STATUS_NONE)
+ player->CastSpell(nullptr, SPELL_AN_AUDIENCE_WITH_THE_KING, true);
+ break;
+ }
+ default:
+ break;
+ }
+ }
+
+ void Register() override
+ {
+ OnEffectPeriodic += AuraEffectPeriodicFn(spell_dalaran_order_campaign_intro_aura::HandlePeriodic, EFFECT_0, SPELL_AURA_PERIODIC_DUMMY);
+ }
+};
+
+void AddSC_zone_dalaran_broken_isle()
+{
+ // Spellscripts
+ RegisterSpellScript(spell_dalaran_order_campaign_intro_aura);
+}