aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sql/updates/world/master/2023_07_01_00_world.sql142
-rw-r--r--src/server/scripts/ExilesReach/zone_exiles_reach.cpp610
2 files changed, 751 insertions, 1 deletions
diff --git a/sql/updates/world/master/2023_07_01_00_world.sql b/sql/updates/world/master/2023_07_01_00_world.sql
new file mode 100644
index 00000000000..cfea1c6f620
--- /dev/null
+++ b/sql/updates/world/master/2023_07_01_00_world.sql
@@ -0,0 +1,142 @@
+-- Misc
+UPDATE `conditions` SET `ElseGroup`=0 WHERE `SourceTypeOrReferenceId`=32 AND `SourceGroup`=5 AND `SourceEntry` IN (149917,156622);
+UPDATE `creature_template` SET `RegenHealth`=0 WHERE `entry` IN (149917,156622,156612,156609,156610,166784,166800,166786,166791,166796);
+UPDATE `creature_template` SET `npcflag`=2, `unit_flags`=768, `unit_flags2`=34816 WHERE entry=156626;
+
+DELETE FROM `creature_text` WHERE `CreatureID` IN (156626,166782,166787,166792,166797) AND `GroupID`=0;
+INSERT INTO `creature_text` (`CreatureID`,`GroupID`,`ID`,`Text`,`Type`,`Language`,`Probability`,`Emote`,`Duration`,`Sound`,`BroadcastTextId`,`TextRange`,`comment`) VALUES
+(156626, 0, 0, '$n! Thank the Light! Are you injured?', 12, 0, 100, 3, 0, 152736, 178506, 0, 'Captain Garrick'),
+(166782, 0, 0, '$n! You survived! We need to regroup at once.', 12, 0, 100, 3, 0, 156954, 195918, 0, 'Warlord Breka Grimaxe'),
+(166787, 0, 0, 'My thanks. We\'ll find the expedition yet.', 12, 0, 100, 0, 0, 156979, 195930, 0, 'Bo'),
+(166792, 0, 0, 'Mark my words, that storm was unnatural.', 12, 0, 100, 0, 0, 156978, 195932, 0, 'Mithdran Dawntracker'),
+(166797, 0, 0, 'Quite the storm. Probably hit the first boat, too.', 12, 0, 100, 0, 0, 155934, 195924, 0, 'Lana Jordan');
+
+UPDATE `creature_template_difficulty` SET `LevelScalingDeltaMin`=10, `LevelScalingDeltaMax`=10 WHERE `Entry`=165359;
+
+-- Questing
+
+DELETE FROM `creature_queststarter` WHERE `id`=156626 AND `quest` IN (55122,54951);
+DELETE FROM `creature_queststarter` WHERE `id`=166782 AND `quest` IN (59929,59930);
+INSERT INTO `creature_queststarter` (`id`, `quest`, `VerifiedBuild`) VALUES
+(156626, 55122, 45745), -- Alliance
+(156626, 54951, 45745),
+(166782, 59929, 46455), -- Horde
+(166782, 59930, 46455);
+
+DELETE FROM `creature_questender` WHERE `id` IN (156626,166782);
+INSERT INTO `creature_questender` (`id`, `quest`, `VerifiedBuild`) VALUES
+(156626, 55122, 45745), -- Alliance
+(156626, 54951, 45745),
+(166782, 59929, 46455), -- Horde
+(166782, 59930, 46455);
+
+DELETE FROM `quest_template_addon` WHERE `ID` IN (55122,54951,59929,59930);
+INSERT INTO `quest_template_addon` (`ID`,`NextQuestID`) VALUES
+(55122,54951), -- Alliance
+(54951,54952),
+(59929,59930), -- Horde
+(59930,59931);
+
+-- Conversations
+
+-- Alliance conversation for Captain Garrick, Kee-La, Bjorn Stouthands, Austin Huxworth
+DELETE FROM `conversation_actors` WHERE `ConversationId` IN (12043,12044,12127,11685,12128,14432,14437,12058);
+INSERT INTO `conversation_actors` (`ConversationId`,`ConversationActorId`,`ConversationActorGuid`,`Idx`,`CreatureId`,`CreatureDisplayInfoId`,`NoActorObject`,`ActivePlayerObject`,`VerifiedBuild`) VALUES
+(12043,71223,1052006,0,0,0,0,0,45745), -- Alliance
+(12044,0,0,0,0,0,0,1,45745),
+(12044,69830,0,1,0,0,0,0,45745),
+(12127,71535,1052012,1,0,0,0,0,45745),
+(11685,71536,1052013,1,0,0,0,0,45745),
+(12128,71534,1052014,1,0,0,0,0,45745),
+(14432,75904,1052015,1,0,0,0,0,45745), -- Horde
+(14437,76283,0,2,0,0,0,0,45745), -- Horde
+(12058,71297,0,0,0,0,0,0,45745), -- Alliance
+(12058,69830,0,1,0,0,0,0,45745), -- Alliance
+(12058,76284,0,2,0,0,0,0,45745), -- Horde
+(12058,76283,0,3,0,0,0,0,45745); -- Horde
+
+DELETE FROM `conversation_line_template` WHERE `Id` IN (29262,29305,29263,29559,29556,29561,29322,34645,36134,36151,36152,36153);
+INSERT INTO `conversation_line_template` (`Id`,`UiCameraID`,`ActorIdx`,`Flags`,`VerifiedBuild`) VALUES
+(29262,0,0,0,45745), -- Alliance
+(29305,0,0,0,45745),
+(29263,0,1,0,45745),
+(29559,0,1,0,45745),
+(29556,0,1,0,45745),
+(29561,0,1,0,45745),
+(29322,0,0,0,45745),
+(34645,0,1,0,45745),
+(36134,0,1,0,45745), -- Horde
+(36151,0,2,0,45745),
+(36152,0,2,0,45745),
+(36153,0,3,0,45745);
+
+DELETE FROM `conversation_template` WHERE `Id` IN (12043,12044,12127,11685,12128,14432,14437,12058);
+INSERT INTO `conversation_template` (`Id`,`FirstLineId`,`TextureKitId`,`ScriptName`,`VerifiedBuild`) VALUES
+(12043,29262,0,'',45745), -- Alliance
+(12044,29305,0,'',45745),
+(12127,29558,0,'',45745),
+(11685,29557,0,'',45745),
+(12128,29560,0,'',45745),
+(14432,36133,0,'',45745), -- Horde
+(14437,36149,0,'',45745),
+(12058,29322,0,'',45745);
+
+-- Beach alliance scripting
+UPDATE `creature_template` SET `npcflag`=2, `unit_flags`=768, `unit_flags2`=34816, AIName="",`ScriptName`="npc_captain_garrick_beach" WHERE entry=156626;
+UPDATE `creature_template` SET `ScriptName`="npc_warlord_grimaxe_beach" WHERE `entry`=166782;
+UPDATE `creature_template` SET `ScriptName`="npc_healed_by_leader_alliance_beach" WHERE `entry` IN (149917,156622);
+UPDATE `creature_template` SET `ScriptName`="npc_healed_by_leader_horde_beach" WHERE `entry` IN (166784,166800);
+UPDATE `creature_template` SET `ScriptName`="npc_bjorn_stouthands_beach_laying" WHERE `entry`=156609;
+UPDATE `creature_template` SET `ScriptName`="npc_austin_huxworth_beach_laying" WHERE `entry`=156610;
+UPDATE `creature_template` SET `ScriptName`="npc_kee_la_beach_laying" WHERE `entry`=156612;
+
+UPDATE `creature_template` SET `ScriptName`="npc_bo_beach_laying" WHERE `entry`=166786;
+UPDATE `creature_template` SET `ScriptName`="npc_mithran_dawntracker_beach_laying" WHERE `entry`=166791;
+UPDATE `creature_template` SET `ScriptName`="npc_lana_jordan_beach_laying" WHERE `entry`=166796;
+UPDATE `creature_template` SET `ScriptName`="npc_bo_beach_standing" WHERE `entry`=166787;
+UPDATE `creature_template` SET `ScriptName`="npc_mithdran_dawntracker_beach_standing" WHERE `entry`=166792;
+UPDATE `creature_template` SET `ScriptName`="npc_lana_jordan_beach_standing" WHERE `entry`=166797;
+
+UPDATE `creature_template` SET `ScriptName`="npc_murloc_spearhunter_watershaper" WHERE `entry` IN (150228,150229);
+UPDATE `creature` SET `ScriptName`='npc_murloc_spearhunter_watershaper_higher_ground' WHERE `guid` IN(1051092, 1051082, 1051068, 1051081, 1051120, 1051117, 1051094, 1051084, 1051102);
+
+DELETE FROM `spell_script_names` WHERE `spell_id` IN (305464,325136);
+INSERT INTO `spell_script_names` (`spell_id`,`ScriptName`) VALUES
+(305464,'spell_crash_landed_alliance'),
+(325136,'spell_crash_landed_horde');
+
+-- Pathing
+
+-- Pathing for Private Cole 149917 and Grunt Throg 166784 "Emergency First Aid"
+SET @PATH := 1052007 * 10;
+DELETE FROM `waypoint_data` WHERE `id` IN (@PATH);
+INSERT INTO `waypoint_data` (`id`,`point`,`position_x`,`position_y`,`position_z`,`orientation`,`delay`,`move_type`,`action`,`action_chance`,`wpguid`) VALUES
+(@PATH,1,-425.59723,-2607.6094,0.6097671,NULL,0,0,0,100,0),
+(@PATH,2,-416.96875,-2603.981,0.6097671,NULL,0,0,0,100,0),
+(@PATH,3,-405.7066,-2599.0903,1.5887985,NULL,0,0,0,100,0),
+(@PATH,4,-396.3125,-2595.6328,2.8700066,NULL,0,0,0,100,0);
+
+-- Pathing for Quartermaster Richter 156622 and Provisioner Jin'hake 166800 "Emergency First Aid"
+SET @PATH := 1052008 * 10;
+DELETE FROM `waypoint_data` WHERE `id` IN (@PATH);
+INSERT INTO `waypoint_data` (`id`,`point`,`position_x`,`position_y`,`position_z`,`orientation`,`delay`,`move_type`,`action`,`action_chance`,`wpguid`) VALUES
+(@PATH,1,-399.375,-2597.3906,2.019909,NULL,0,0,0,100,0),
+(@PATH,2,-391.84723,-2593.486,3.8800163,NULL,0,0,0,100,0);
+
+-- Pathing for Bo quest "Emergency First Aid"
+SET @PATH := 1052021 * 10;
+DELETE FROM `waypoint_data` WHERE `id` IN (@PATH);
+INSERT INTO `waypoint_data` (`id`,`point`,`position_x`,`position_y`,`position_z`,`orientation`,`delay`,`move_type`,`action`,`action_chance`,`wpguid`) VALUES
+(@PATH,1,-437.55035,-2610.1511,0.5548096,NULL,0,1,0,100,0);
+
+-- Pathing for Mithdran Dawntracker "Emergency First Aid"
+SET @PATH := 1052022 * 10;
+DELETE FROM `waypoint_data` WHERE `id` IN (@PATH);
+INSERT INTO `waypoint_data` (`id`,`point`,`position_x`,`position_y`,`position_z`,`orientation`,`delay`,`move_type`,`action`,`action_chance`,`wpguid`) VALUES
+(@PATH,1,-436.05557,-2607.8057,0.39855957,NULL,0,1,0,100,0);
+
+-- Pathing for Lana Jordan "Emergency First Aid"
+SET @PATH := 1052023 * 10;
+DELETE FROM `waypoint_data` WHERE `id` IN (@PATH);
+INSERT INTO `waypoint_data` (`id`,`point`,`position_x`,`position_y`,`position_z`,`orientation`,`delay`,`move_type`,`action`,`action_chance`,`wpguid`) VALUES
+(@PATH,1,-433.9479,-2608.7449,0.5111084,NULL,0,1,0,100,0);
diff --git a/src/server/scripts/ExilesReach/zone_exiles_reach.cpp b/src/server/scripts/ExilesReach/zone_exiles_reach.cpp
index 072861e35b4..e5b8a33aefb 100644
--- a/src/server/scripts/ExilesReach/zone_exiles_reach.cpp
+++ b/src/server/scripts/ExilesReach/zone_exiles_reach.cpp
@@ -33,6 +33,7 @@
#include "SpellScript.h"
#include "TemporarySummon.h"
#include "Transport.h"
+#include "Loot.h"
template<class privateAI, class publicAI>
CreatureAI* GetPrivatePublicPairAISelector(Creature* creature)
@@ -1042,6 +1043,596 @@ CreatureAI* CaptainGarrickShipAISelector(Creature* creature)
return new NullCreatureAI(creature);
};
+enum SpellCrashLandedData
+{
+ NPC_CAPTAIN_GARRICK_BEACH = 156626,
+ NPC_WARLORD_BREKA_GRIMAXE_BEACH = 166782
+};
+
+// 305464 - Crash Landed
+// 325136 - Crash Landed
+template<uint32 StaticCaptainNPCId>
+class spell_crash_landed_generic : public SpellScript
+{
+ PrepareSpellScript(spell_crash_landed_generic);
+
+ void HandleEffect(SpellEffIndex /*effIndex*/)
+ {
+ Player* player = GetCaster()->ToPlayer();
+ if (!player)
+ return;
+
+ if (Creature* creature = player->FindNearestCreature(StaticCaptainNPCId, 50.0f))
+ creature->SummonPersonalClone(creature->GetPosition(), TempSummonType(TEMPSUMMON_MANUAL_DESPAWN), 0s, 0, 0, player);
+ }
+
+ void Register() override
+ {
+ OnEffectHit += SpellEffectFn(spell_crash_landed_generic::HandleEffect, EFFECT_0, SPELL_EFFECT_SEND_EVENT);
+ }
+};
+
+enum ExilesReachCaptainsBeachData
+{
+ CONVERSATION_QUEST_MURLOC_MANIA_ALLIANCE = 12043,
+ CONVERSATION_QUEST_MURLOC_MANIA_HORDE = 14432,
+
+ EVENT_EMERGENCY_FIRST_AID_SCRIPT_SHEATH = 1,
+ EVENT_EMERGENCY_FIRST_AID_SCRIPT_BANDAGE,
+ EVENT_EMERGENCY_FIRST_AID_SCRIPT_MOVE_SECOND_SURVIVOR,
+ EVENT_EMERGENCY_FIRST_AID_SCRIPT_MOVE_HOME_BEACH,
+
+ POINT_SECOND_SURVIVOR = 0,
+ POINT_BEACH_HOME = 1,
+
+ QUEST_MURLOC_MANIA_ALLIANCE = 55122,
+ QUEST_EMERGENCY_FIRST_AID_ALLIANCE = 54951,
+ QUEST_MURLOC_MANIA_HORDE = 59929,
+ QUEST_EMERGENCY_FIRST_AID_HORDE = 59930,
+
+ SPELL_BANDAGING = 305584,
+
+ TALK_ARRIVED_AT_BEACH = 0
+};
+
+// 156626 - Captain Garrick
+// 166782 - Warlord Breka Grimaxe
+struct npc_captain_warlord_beach_arrive_private : public ScriptedAI
+{
+ npc_captain_warlord_beach_arrive_private(Creature* creature) : ScriptedAI(creature) { }
+
+ void IsSummonedBy(WorldObject* summonerWO) override
+ {
+ Player* summoner = summonerWO->ToPlayer();
+ if (!summoner)
+ return;
+
+ me->SetFacingToObject(summoner);
+ Talk(TALK_ARRIVED_AT_BEACH, summoner);
+ me->DespawnOrUnsummon(5s);
+ }
+};
+
+// 156626 - Captain Garrick
+// 166782 - Warlord Breka Grimaxe
+// for Emergency first aid quest 54951
+struct npc_captain_warlord_first_aid_private : public ScriptedAI
+{
+ npc_captain_warlord_first_aid_private(Creature* creature) : ScriptedAI(creature) { }
+
+ void InitializeAI() override
+ {
+ me->RemoveNpcFlag(UNIT_NPC_FLAG_QUESTGIVER);
+ }
+
+ void IsSummonedBy(WorldObject* summonerWO) override
+ {
+ Player* summoner = summonerWO->ToPlayer();
+ if (!summoner)
+ return;
+
+ _events.ScheduleEvent(EVENT_EMERGENCY_FIRST_AID_SCRIPT_SHEATH, 2s);
+ }
+
+ void MovementInform(uint32 uiType, uint32 uiId) override
+ {
+ if (uiType != POINT_MOTION_TYPE)
+ return;
+
+ switch (uiId)
+ {
+ case POINT_SECOND_SURVIVOR:
+ if (Creature* mate = ObjectAccessor::GetCreature(*me, _quartermasterGUID))
+ me->CastSpell(mate, SPELL_BANDAGING);
+ _events.ScheduleEvent(EVENT_EMERGENCY_FIRST_AID_SCRIPT_MOVE_HOME_BEACH, 6s);
+ break;
+ case POINT_BEACH_HOME:
+ me->DespawnOrUnsummon();
+ break;
+ default:
+ break;
+ }
+ }
+
+ void UpdateAI(uint32 diff) override
+ {
+ _events.Update(diff);
+
+ while (uint32 eventId = _events.ExecuteEvent())
+ {
+ switch (eventId)
+ {
+ case EVENT_EMERGENCY_FIRST_AID_SCRIPT_SHEATH:
+ me->SetSheath(SHEATH_STATE_UNARMED);
+ _events.ScheduleEvent(EVENT_EMERGENCY_FIRST_AID_SCRIPT_BANDAGE, 1s);
+ break;
+ case EVENT_EMERGENCY_FIRST_AID_SCRIPT_BANDAGE:
+ if (Creature* mate = ObjectAccessor::GetCreature(*me, _firstMateGUID))
+ me->CastSpell(mate, SPELL_BANDAGING);
+ _events.ScheduleEvent(EVENT_EMERGENCY_FIRST_AID_SCRIPT_MOVE_SECOND_SURVIVOR, 5s);
+ break;
+ case EVENT_EMERGENCY_FIRST_AID_SCRIPT_MOVE_SECOND_SURVIVOR:
+ me->GetMotionMaster()->MovePoint(POINT_SECOND_SURVIVOR, -414.15277f, -2605.2014f, 0.91079247f, false);
+ break;
+ case EVENT_EMERGENCY_FIRST_AID_SCRIPT_MOVE_HOME_BEACH:
+ me->GetMotionMaster()->MovePoint(POINT_BEACH_HOME, -435.15277f, -2610.9915f, 0.649292f, false);
+ break;
+ default:
+ break;
+ }
+ }
+ }
+
+public:
+ void SetFirstMateGUID(ObjectGuid coleGUID)
+ {
+ _firstMateGUID = coleGUID;
+ }
+
+ void SetQuartermasterGUID(ObjectGuid richterGUID)
+ {
+ _quartermasterGUID = richterGUID;
+ }
+
+private:
+ EventMap _events;
+ ObjectGuid _firstMateGUID;
+ ObjectGuid _quartermasterGUID;
+};
+
+// 156626 - Captain Garrick
+struct npc_captain_garrick_beach : public ScriptedAI
+{
+ npc_captain_garrick_beach(Creature* creature) : ScriptedAI(creature) { }
+
+ void OnQuestAccept(Player* player, Quest const* quest) override
+ {
+ switch (quest->GetQuestId())
+ {
+ case QUEST_MURLOC_MANIA_ALLIANCE:
+ Conversation::CreateConversation(CONVERSATION_QUEST_MURLOC_MANIA_ALLIANCE, player, *player, player->GetGUID(), nullptr);
+ break;
+ case QUEST_EMERGENCY_FIRST_AID_ALLIANCE:
+ {
+ Creature* cole = FindCreatureIgnorePhase(player, "private_cole_beach", 50.0f);
+ Creature* richter = FindCreatureIgnorePhase(player, "quartermaster_richter_beach", 50.0f);
+ if (!cole || !richter)
+ return;
+
+ Creature* colePersonal = cole->SummonPersonalClone(cole->GetPosition(), TEMPSUMMON_MANUAL_DESPAWN, 0s, 0, 0, player);
+ Creature* richterPersonal = richter->SummonPersonalClone(richter->GetPosition(), TEMPSUMMON_MANUAL_DESPAWN, 0s, 0, 0, player);
+ Creature* mePersonal = me->SummonPersonalClone(me->GetPosition(), TEMPSUMMON_MANUAL_DESPAWN, 0s, 0, 0, player);
+ if (!colePersonal || !richterPersonal || !mePersonal)
+ return;
+
+ if (npc_captain_warlord_first_aid_private* personalAI = CAST_AI(npc_captain_warlord_first_aid_private, mePersonal->GetAI()))
+ {
+ personalAI->SetFirstMateGUID(colePersonal->GetGUID());
+ personalAI->SetQuartermasterGUID(richterPersonal->GetGUID());
+ }
+ break;
+ }
+ default:
+ break;
+ }
+ }
+};
+
+// 166782 - Warlord Breka Grimaxe
+struct npc_warlord_grimaxe_beach : public ScriptedAI
+{
+ npc_warlord_grimaxe_beach(Creature* creature) : ScriptedAI(creature) { }
+
+ void OnQuestAccept(Player* player, Quest const* quest) override
+ {
+ switch (quest->GetQuestId())
+ {
+ case QUEST_MURLOC_MANIA_HORDE:
+ Conversation::CreateConversation(CONVERSATION_QUEST_MURLOC_MANIA_HORDE, player, *player, player->GetGUID(), nullptr);
+ break;
+ case QUEST_EMERGENCY_FIRST_AID_HORDE:
+ {
+ Creature* throg = FindCreatureIgnorePhase(player, "grunt_throg_beach", 50.0f);
+ Creature* jinhake = FindCreatureIgnorePhase(player, "jin_hake_beach", 50.0f);
+ if (!throg || !jinhake)
+ return;
+
+ Creature* throgPersonal = throg->SummonPersonalClone(throg->GetPosition(), TEMPSUMMON_MANUAL_DESPAWN, 0s, 0, 0, player);
+ Creature* jinhakePersonal = jinhake->SummonPersonalClone(jinhake->GetPosition(), TEMPSUMMON_MANUAL_DESPAWN, 0s, 0, 0, player);
+ Creature* mePersonal = me->SummonPersonalClone(me->GetPosition(), TEMPSUMMON_MANUAL_DESPAWN, 0s, 0, 0, player);
+ if (!throgPersonal || !jinhakePersonal || !mePersonal)
+ return;
+
+ if (npc_captain_warlord_first_aid_private* personalAI = CAST_AI(npc_captain_warlord_first_aid_private, mePersonal->AI()))
+ {
+ personalAI->SetFirstMateGUID(throgPersonal->GetGUID());
+ personalAI->SetQuartermasterGUID(jinhakePersonal->GetGUID());
+ }
+ break;
+ }
+ default:
+ break;
+ }
+ }
+};
+
+CreatureAI* CaptainGarrickBeachAISelector(Creature* creature)
+{
+ if (creature->IsPrivateObject())
+ {
+ if (Player* privateObjectOwner = ObjectAccessor::GetPlayer(*creature, creature->GetPrivateObjectOwner()))
+ {
+ if (privateObjectOwner->GetQuestStatus(QUEST_MURLOC_MANIA_ALLIANCE) == QUEST_STATUS_NONE)
+ return new npc_captain_warlord_beach_arrive_private(creature);
+ else
+ return new npc_captain_warlord_first_aid_private(creature);
+ }
+ }
+ return new npc_captain_garrick_beach(creature);
+};
+
+CreatureAI* WarlordGrimaxeBeachAISelector(Creature* creature)
+{
+ if (creature->IsPrivateObject())
+ {
+ if (Player* privateObjectOwner = ObjectAccessor::GetPlayer(*creature, creature->GetPrivateObjectOwner()))
+ {
+ if (privateObjectOwner->GetQuestStatus(QUEST_MURLOC_MANIA_HORDE) == QUEST_STATUS_NONE)
+ return new npc_captain_warlord_beach_arrive_private(creature);
+ else
+ return new npc_captain_warlord_first_aid_private(creature);
+ }
+ }
+ return new npc_warlord_grimaxe_beach(creature);
+};
+
+enum HealedByLeaderBeachData
+{
+ EVENT_SALUTE = 1,
+ EVENT_LEAVE_BEACH,
+
+ NPC_COLE_BEACH = 149917,
+ NPC_RICHTER_BEACH = 156622,
+ NPC_THROG_BEACH = 166784,
+ NPC_JINHAKE_BEACH = 166800,
+
+ PATH_LONG_BEACH = 10520070,
+ PATH_SHORT_BEACH = 10520080
+};
+
+// 149917 - Private Cole
+// 156622 - Quartermaster Richter
+// 166784 - Grunt Throg
+// 166800 - Provisioner Jin'hake
+// for Emergency first aid quest
+template<uint32 PathId, uint32 WaitTime>
+struct npc_survivors_healed_by_leader_beach_private : public ScriptedAI
+{
+ npc_survivors_healed_by_leader_beach_private(Creature* creature) : ScriptedAI(creature) { }
+
+ void InitializeAI() override
+ {
+ me->SetStandState(UNIT_STAND_STATE_SLEEP);
+ }
+
+ void SpellHit(WorldObject* caster, SpellInfo const* spellInfo) override
+ {
+ if (spellInfo->Id != SPELL_BANDAGING)
+ return;
+
+ _casterGUID = caster->GetGUID();
+ me->SetStandState(UNIT_STAND_STATE_STAND);
+ _events.ScheduleEvent(EVENT_SALUTE, 2s);
+ }
+
+ void UpdateAI(uint32 diff) override
+ {
+ _events.Update(diff);
+
+ while (uint32 eventId = _events.ExecuteEvent())
+ {
+ switch (eventId)
+ {
+ case EVENT_SALUTE:
+ if (Creature* caster = ObjectAccessor::GetCreature(*me, _casterGUID))
+ me->SetFacingToObject(caster);
+ me->HandleEmoteCommand(EMOTE_ONESHOT_SALUTE);
+ _events.ScheduleEvent(EVENT_LEAVE_BEACH, 2s);
+ break;
+ case EVENT_LEAVE_BEACH:
+ me->GetMotionMaster()->MovePath(PathId, false);
+ me->DespawnOrUnsummon(Milliseconds(WaitTime));
+ break;
+ default:
+ break;
+ }
+ }
+ }
+private:
+ EventMap _events;
+ ObjectGuid _casterGUID;
+};
+
+CreatureAI* HealedByLeaderAllianceAISelector(Creature* creature)
+{
+ if (creature->IsPrivateObject())
+ return new npc_survivors_healed_by_leader_beach_private<PATH_LONG_BEACH, 16 * IN_MILLISECONDS>(creature);
+ return new NullCreatureAI(creature);
+};
+
+CreatureAI* HealedByLeaderHordeAISelector(Creature* creature)
+{
+ if (creature->IsPrivateObject())
+ return new npc_survivors_healed_by_leader_beach_private<PATH_SHORT_BEACH, 9 * IN_MILLISECONDS>(creature);
+ return new NullCreatureAI(creature);
+};
+
+enum ExilesReachAllianceSurvivorsBeachData
+{
+ CONVERSATION_STOUTHANDS_BEACH = 11685,
+ CONVERSATION_HUXWORTH_BEACH = 12128,
+ CONVERSATION_KEE_LA_BEACH = 12127,
+
+ NPC_BJORN_STOUTHANDS_LAYING = 156609,
+ NPC_AUSTIN_HUXWORTH_LAYING = 156610,
+ NPC_KEE_LA_LAYING = 156612,
+ NPC_KEE_LA_STANDING = 151088,
+ NPC_BJORN_STOUTHANDS_STANDING = 151089,
+ NPC_AUSTIN_HUXWORTH_STANDING = 154170,
+
+ SPELL_BANDAGING_QUEST = 297415
+};
+
+// 156609 - Bjorn Stouthands
+// 156610 - Austin Huxworth
+// 156612 - Kee-La
+template<uint32 ConversationId>
+struct npc_alliance_survivors_beach_laying : public ScriptedAI
+{
+ npc_alliance_survivors_beach_laying(Creature* creature) : ScriptedAI(creature) { }
+
+ void SpellHit(WorldObject* caster, SpellInfo const* spellInfo) override
+ {
+ if (spellInfo->Id != SPELL_BANDAGING_QUEST)
+ return;
+
+ if (Player* player = caster->ToPlayer())
+ {
+ player->KilledMonsterCredit(me->GetEntry());
+ player->UpdateObjectVisibility();
+
+ Conversation::CreateConversation(ConversationId, player, *player, player->GetGUID(), nullptr);
+ }
+ }
+};
+
+enum ExilesReachHordeSurvivorsBeachData
+{
+ EVENT_SURVIVORS_HORDE_STAND_AND_TALK = 1,
+ EVENT_SURVIVORS_HORDE_MOVE_TO_GRIMAXE,
+
+ NPC_BO_LAYING_LAYING = 166786,
+ NPC_MITHDRAN_LAYING = 166791,
+ NPC_LANA_JORDAN_LAYING = 166796,
+ NPC_BO_STANDING = 166787,
+ NPC_MITHDRAN_STANDING = 166792,
+ NPC_LANA_JORDAN_STANDING = 166797,
+
+ PATH_BO_TO_GRIMAXE = 10520210,
+ PATH_MITHDRAN_TO_GRIMAXE = 10520220,
+ PATH_LANA_JORDAN_TO_GRIMAXE = 10520230,
+
+ TALK_HORDE_BEACH_THANK_PLAYER = 0
+};
+
+// 166786 - Bo
+struct npc_bo_beach_laying : public ScriptedAI
+{
+ npc_bo_beach_laying(Creature* creature) : ScriptedAI(creature) { }
+
+ void SpellHit(WorldObject* caster, SpellInfo const* spellInfo) override
+ {
+ if (spellInfo->Id != SPELL_BANDAGING_QUEST)
+ return;
+
+ static const Position BoCloneSpawnPosition = { -448.731f, -2606.03f, 0.602435f, 6.17441f };
+
+ if (Player* player = caster->ToPlayer())
+ {
+ player->KilledMonsterCredit(me->GetEntry());
+
+ if (Creature* survivor = player->FindNearestCreatureWithOptions(50.0f, FindCreatureOptions().SetStringId("bo_beach").SetIgnorePhases(true)))
+ survivor->SummonPersonalClone(BoCloneSpawnPosition, TEMPSUMMON_MANUAL_DESPAWN, 0s, 0, 0, player);
+ }
+ }
+};
+
+// 166791 - Mithdran Dawntracker
+struct npc_mithran_dawntracker_beach_laying : public ScriptedAI
+{
+ npc_mithran_dawntracker_beach_laying(Creature* creature) : ScriptedAI(creature) { }
+
+ void SpellHit(WorldObject* caster, SpellInfo const* spellInfo) override
+ {
+ if (spellInfo->Id != SPELL_BANDAGING_QUEST)
+ return;
+
+ static Position const MithranCloneSpawnPosition = { -428.576f, -2593.93f, 0.152832f, 4.849576f };
+
+ if (Player* player = caster->ToPlayer())
+ {
+ player->KilledMonsterCredit(me->GetEntry());
+
+ if (Creature* survivor = player->FindNearestCreatureWithOptions(50.0f, FindCreatureOptions().SetStringId("mithran_beach").SetIgnorePhases(true)))
+ survivor->SummonPersonalClone(MithranCloneSpawnPosition, TEMPSUMMON_MANUAL_DESPAWN, 0s, 0, 0, player);
+ }
+ }
+};
+
+// 166796 - Lana Jordan
+struct npc_lana_jordan_beach_laying : public ScriptedAI
+{
+ npc_lana_jordan_beach_laying(Creature* creature) : ScriptedAI(creature) { }
+
+ void SpellHit(WorldObject* caster, SpellInfo const* spellInfo) override
+ {
+ if (spellInfo->Id != SPELL_BANDAGING_QUEST)
+ return;
+
+ static Position const LanaCloneSpawnPosition = { -420.656f, -2600.28f, 0.556646f, 4.046853f };
+
+ if (Player* player = caster->ToPlayer())
+ {
+ player->KilledMonsterCredit(me->GetEntry());
+
+ if (Creature* survivor = player->FindNearestCreatureWithOptions(50.0f, FindCreatureOptions().SetStringId("lana_jordan_beach").SetIgnorePhases(true)))
+ survivor->SummonPersonalClone(LanaCloneSpawnPosition, TEMPSUMMON_MANUAL_DESPAWN, 0s, 0, 0, player);
+ }
+ }
+};
+
+// 166787 - Bo
+// 166792 - Mithdran Dawntracker
+// 166797 - Lana Jordan
+template<uint32 PathId>
+struct npc_horde_survivors_beach_q59930_private : public ScriptedAI
+{
+ npc_horde_survivors_beach_q59930_private(Creature* creature) : ScriptedAI(creature) { }
+
+ void InitializeAI() override
+ {
+ me->SetStandState(UNIT_STAND_STATE_SLEEP);
+ }
+
+ void JustAppeared() override
+ {
+ _events.ScheduleEvent(EVENT_SURVIVORS_HORDE_STAND_AND_TALK, 1s);
+ }
+
+ void WaypointPathEnded(uint32 /*nodeId*/, uint32 /*pathId*/) override
+ {
+ me->DespawnOrUnsummon();
+ }
+
+ void UpdateAI(uint32 diff) override
+ {
+ _events.Update(diff);
+
+ while (uint32 eventId = _events.ExecuteEvent())
+ {
+ switch (eventId)
+ {
+ case EVENT_SURVIVORS_HORDE_STAND_AND_TALK:
+ Talk(TALK_HORDE_BEACH_THANK_PLAYER);
+ me->SetStandState(UNIT_STAND_STATE_STAND);
+ _events.ScheduleEvent(EVENT_SURVIVORS_HORDE_MOVE_TO_GRIMAXE, 6s);
+ break;
+ case EVENT_SURVIVORS_HORDE_MOVE_TO_GRIMAXE:
+ me->GetMotionMaster()->MovePath(PathId, false);
+ break;
+ default:
+ break;
+ }
+ }
+ }
+private:
+ EventMap _events;
+};
+
+CreatureAI* BoBeachStandingAISelector(Creature* creature)
+{
+ if (creature->IsPrivateObject())
+ return new npc_horde_survivors_beach_q59930_private<PATH_BO_TO_GRIMAXE>(creature);
+
+ return new NullCreatureAI(creature);
+};
+
+CreatureAI* MithdranBeachStandingAISelector(Creature* creature)
+{
+ if (creature->IsPrivateObject())
+ return new npc_horde_survivors_beach_q59930_private<PATH_MITHDRAN_TO_GRIMAXE>(creature);
+
+ return new NullCreatureAI(creature);
+};
+
+CreatureAI* LanaJordanBeachStandingAISelector(Creature* creature)
+{
+ if (creature->IsPrivateObject())
+ return new npc_horde_survivors_beach_q59930_private<PATH_LANA_JORDAN_TO_GRIMAXE>(creature);
+
+ return new NullCreatureAI(creature);
+};
+
+enum ExilesReachMurlocsData
+{
+ ITEM_STITCHED_CLOTH_SHOES = 174791,
+ ITEM_STITCHED_LEATHER_BOOTS = 174792,
+ ITEM_LINKED_MAIL_BOOTS = 174793,
+ ITEM_DENTED_PLATE_BOOTS = 174794,
+
+ QUEST_MURLOC_HIDEAWAY_BOOTS_DROPPED = 58883
+};
+
+// 150228 - Murloc Spearhunter
+// 150229 - Murloc Watershaper
+struct npc_murloc_spearhunter_watershaper : public ScriptedAI
+{
+ npc_murloc_spearhunter_watershaper(Creature* creature) : ScriptedAI(creature) { }
+
+ void JustDied(Unit* /*killer*/) override
+ {
+ for (auto const& [playerGuid, loot] : me->m_personalLoot)
+ {
+ for (LootItem const& lootItem : loot->items)
+ {
+ if (lootItem.itemid == ITEM_STITCHED_CLOTH_SHOES || lootItem.itemid == ITEM_STITCHED_LEATHER_BOOTS || lootItem.itemid == ITEM_LINKED_MAIL_BOOTS || lootItem.itemid == ITEM_DENTED_PLATE_BOOTS)
+ if (Player* player = ObjectAccessor::GetPlayer(*me, playerGuid))
+ player->SetRewardedQuest(QUEST_MURLOC_HIDEAWAY_BOOTS_DROPPED);
+ }
+ }
+ }
+
+ void UpdateAI(uint32 /*diff*/) override
+ {
+ if (!UpdateVictim())
+ return;
+
+ DoMeleeAttackIfReady();
+ }
+};
+
+// 150228 - Murloc Spearhunter
+// 150229 - Murloc Watershaper
+struct npc_murloc_spearhunter_watershaper_higher_ground : public npc_murloc_spearhunter_watershaper
+{
+ npc_murloc_spearhunter_watershaper_higher_ground(Creature* creature) : npc_murloc_spearhunter_watershaper(creature) { }
+
+ void JustEngagedWith(Unit* who) override
+ {
+ me->GetMotionMaster()->MoveJump(who->GetPosition(), 16.0f, 6.2f);
+ }
+};
+
void AddSC_zone_exiles_reach()
{
// Ship
@@ -1059,11 +1650,28 @@ void AddSC_zone_exiles_reach()
RegisterPrivatePublicCreatureAIPair("npc_crew_ship", npc_crew_ship_private, NullCreatureAI);
RegisterPrivatePublicCreatureAIPair("npc_pet_ship", npc_pet_ship_private, NullCreatureAI);
new quest_brace_for_impact();
-
new player_exiles_reach_ship_crash();
new scene_alliance_and_horde_ship();
// Beach
RegisterSpellScript(spell_knocked_down_exiles_reach_beach);
new scene_alliance_and_horde_crash();
+ RegisterSpellScriptWithArgs(spell_crash_landed_generic<NPC_CAPTAIN_GARRICK_BEACH>, "spell_crash_landed_alliance");
+ RegisterSpellScriptWithArgs(spell_crash_landed_generic<NPC_WARLORD_BREKA_GRIMAXE_BEACH>, "spell_crash_landed_horde");
+ new FactoryCreatureScript<CreatureAI, &CaptainGarrickBeachAISelector>("npc_captain_garrick_beach");
+ new FactoryCreatureScript<CreatureAI, &WarlordGrimaxeBeachAISelector>("npc_warlord_grimaxe_beach");
+ new FactoryCreatureScript<CreatureAI, &HealedByLeaderAllianceAISelector>("npc_healed_by_leader_alliance_beach");
+ new FactoryCreatureScript<CreatureAI, &HealedByLeaderHordeAISelector>("npc_healed_by_leader_horde_beach");
+ new GenericCreatureScript<npc_alliance_survivors_beach_laying<CONVERSATION_STOUTHANDS_BEACH>>("npc_bjorn_stouthands_beach_laying");
+ new GenericCreatureScript<npc_alliance_survivors_beach_laying<CONVERSATION_HUXWORTH_BEACH>>("npc_austin_huxworth_beach_laying");
+ new GenericCreatureScript<npc_alliance_survivors_beach_laying<CONVERSATION_KEE_LA_BEACH>>("npc_kee_la_beach_laying");
+ // Note: alliance survivor do not need a script for Emergency First Aid quest
+ RegisterCreatureAI(npc_bo_beach_laying);
+ RegisterCreatureAI(npc_mithran_dawntracker_beach_laying);
+ RegisterCreatureAI(npc_lana_jordan_beach_laying);
+ new FactoryCreatureScript<CreatureAI, &BoBeachStandingAISelector>("npc_bo_beach_standing");
+ new FactoryCreatureScript<CreatureAI, &MithdranBeachStandingAISelector>("npc_mithdran_dawntracker_beach_standing");
+ new FactoryCreatureScript<CreatureAI, &LanaJordanBeachStandingAISelector>("npc_lana_jordan_beach_standing");
+ RegisterCreatureAI(npc_murloc_spearhunter_watershaper);
+ RegisterCreatureAI(npc_murloc_spearhunter_watershaper_higher_ground);
}