aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sql/updates/7387_world_script_texts.sql15
-rw-r--r--sql/updates/7387_world_script_waypoints.sql29
-rw-r--r--sql/updates/7387_world_scriptname.sql2
-rw-r--r--src/scripts/northrend/grizzly_hills.cpp252
4 files changed, 298 insertions, 0 deletions
diff --git a/sql/updates/7387_world_script_texts.sql b/sql/updates/7387_world_script_texts.sql
new file mode 100644
index 00000000000..57d8cbf0fe3
--- /dev/null
+++ b/sql/updates/7387_world_script_texts.sql
@@ -0,0 +1,15 @@
+DELETE FROM `script_texts` WHERE `npc_entry`=26588;
+INSERT INTO `script_texts` (`npc_entry`, `entry`, `content_default`, `content_loc1`, `content_loc2`, `content_loc3`, `content_loc4`, `content_loc5`, `content_loc6`, `content_loc7`, `content_loc8`, `sound`, `type`, `language`, `emote`, `comment`) VALUES
+(26588, -1800013, 'Thank you for helping me get back to the camp. Go tell Walter that I''m safe now!', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, '12027'),
+(26588, -1800012, 'Are you ready, Mr. Floppy? Stay close to me and watch out for those wolves!', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, '12027'),
+(26588, -1800011, 'The Ravenous Worg chomps down on Mr. Floppy', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 4, 0, 0, '12027'),
+(26588, -1800010, 'Mr. Floppy revives', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 4, 0, 0, '12027'),
+(26588, -1800009, 'I think I see the camp! We''re almost home, Mr. Floppy! Let''s go!', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, '12027'),
+(26588, -1800008, 'Mr. Floppy, you''re ok! Thank you so much for saving Mr. Floppy!', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, '12027'),
+(26588, -1800007, 'Don''t go toward the light, Mr. Floppy!', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, '12027'),
+(26588, -1800006, 'Let''s get out of here before more wolves find us!', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, '12027'),
+(26588, -1800005, 'There''s a big meanie attacking Mr. Floppy! Help! ', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, '12027'),
+(26588, -1800004, 'He''s gonna eat Mr. Floppy! You gotta help Mr. Floppy! You just gotta!', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, '12027'),
+(26588, -1800003, 'Oh, no! Look, it''s another wolf, and it''s a biiiiiig one!', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, '12027'),
+(26588, -1800002, 'He''s going for Mr. Floppy! ', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, '12027'),
+(26588, -1800001, 'Um... I think one of those wolves is back...', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, '12027');
diff --git a/sql/updates/7387_world_script_waypoints.sql b/sql/updates/7387_world_script_waypoints.sql
new file mode 100644
index 00000000000..be595a30389
--- /dev/null
+++ b/sql/updates/7387_world_script_waypoints.sql
@@ -0,0 +1,29 @@
+DELETE FROM `script_waypoint` wHERE `entry`=26588;
+INSERT INTO `script_waypoint` (`entry`, `pointid`, `location_x`, `location_y`, `location_z`, `waittime`, `point_comment`) VALUES
+(26588, 1, 4333.18, -3688.4, 263.857, 0, '0'),
+(26588, 2, 4341.38, -3683.77, 257.422, 0, '0'),
+(26588, 3, 4342.67, -3683.21, 257.218, 0, '0'),
+(26588, 4, 4346.22, -3688.72, 257.065, 0, '0'),
+(26588, 5, 4343.8, -3695.27, 257.124, 0, '0'),
+(26588, 6, 4337.74, -3707.2, 257.628, 0, '0'),
+(26588, 7, 4317.58, -3722.8, 256.941, 0, '0'),
+(26588, 8, 4306.64, -3736.46, 258.304, 0, '0'),
+(26588, 9, 4299.96, -3760.02, 254.959, 0, '0'),
+(26588, 10, 4294.21, -3777.34, 249.139, 1000, '0'),
+(26588, 11, 4294.37, -3776.97, 249.259, 10000, '0'),
+(26588, 12, 4300.22, -3794.61, 240.107, 2000, '0'),
+(26588, 13, 4307.25, -3817.76, 231.414, 2000, '0'),
+(26588, 14, 4326.31, -3883.31, 208.457, 2000, '0'),
+(26588, 15, 4346.19, -3905.41, 198.805, 2000, '0'),
+(26588, 16, 4347.39, -3916.43, 196.716, 5000, '0'),
+(26588, 17, 4350.17, -3935.03, 191.824, 1000, '0'),
+(26588, 18, 4347.24, -3939.54, 191.445, 2000, '0'),
+(26588, 19, 4347.24, -3939.54, 191.445, 2000, '0'),
+(26588, 20, 4347.24, -3939.54, 191.445, 5000, '0'),
+(26588, 21, 4347.24, -3939.54, 191.445, 7000, '0'),
+(26588, 22, 4347.24, -3939.54, 191.445, 5000, '0'),
+(26588, 23, 4347.24, -3939.54, 191.445, 5000, '0'),
+(26588, 24, 4347.24, -3939.54, 191.445, 0, '0'),
+(26588, 25, 4353.72, -3965.61, 190.154, 0, '0'),
+(26588, 26, 4363.12, -3995.61, 183.327, 0, '0'),
+(26588, 27, 4371.99, -4010.97, 181.33, 0, '0');
diff --git a/sql/updates/7387_world_scriptname.sql b/sql/updates/7387_world_scriptname.sql
new file mode 100644
index 00000000000..2ea586552d2
--- /dev/null
+++ b/sql/updates/7387_world_scriptname.sql
@@ -0,0 +1,2 @@
+UPDATE `creature_template` SET `ScriptName` = 'npc_emily' WHERE `entry`=26588;
+UPDATE `creature_template` SET `ScriptName` = 'npc_mrfloppy' WHERE `entry`=26589;
diff --git a/src/scripts/northrend/grizzly_hills.cpp b/src/scripts/northrend/grizzly_hills.cpp
index ca1301fe287..b057faf7e5f 100644
--- a/src/scripts/northrend/grizzly_hills.cpp
+++ b/src/scripts/northrend/grizzly_hills.cpp
@@ -26,6 +26,7 @@ npc_orsonn_and_kodian
EndContentData */
#include "ScriptedPch.h"
+#include "ScriptedEscortAI.h"
#define GOSSIP_ITEM1 "You're free to go Orsonn, but first tell me what's wrong with the furbolg."
#define GOSSIP_ITEM2 "What happened then?"
@@ -115,6 +116,246 @@ bool GossipSelect_npc_orsonn_and_kodian(Player* pPlayer, Creature* pCreature, ui
return true;
}
+/*######
+## Quest 12027: Mr. Floppy's Perilous Adventure
+######*/
+
+enum eFloppy
+{
+ NPC_MRFLOPPY = 26589,
+ NPC_HUNGRY_WORG = 26586,
+ NPC_RAVENOUS_WORG = 26590, //RWORG
+ NPC_EMILY = 26588,
+
+ QUEST_PERILOUS_ADVENTURE = 12027,
+
+ SPELL_MRFLOPPY = 47184, //vehicle aura
+
+ SAY_WORGHAGGRO1 = -1800001, //Um... I think one of those wolves is back...
+ SAY_WORGHAGGRO2 = -1800002, //He's going for Mr. Floppy!
+ SAY_WORGRAGGRO3 = -1800003, //Oh, no! Look, it's another wolf, and it's a biiiiiig one!
+ SAY_WORGRAGGRO4 = -1800004, //He's gonna eat Mr. Floppy! You gotta help Mr. Floppy! You just gotta!
+ SAY_RANDOMAGGRO = -1800005, //There's a big meanie attacking Mr. Floppy! Help!
+ SAY_VICTORY1 = -1800006, //Let's get out of here before more wolves find us!
+ SAY_VICTORY2 = -1800007, //Don't go toward the light, Mr. Floppy!
+ SAY_VICTORY3 = -1800008, //Mr. Floppy, you're ok! Thank you so much for saving Mr. Floppy!
+ SAY_VICTORY4 = -1800009, //I think I see the camp! We're almost home, Mr. Floppy! Let's go!
+ TEXT_EMOTE_WP1 = -1800010, //Mr. Floppy revives
+ TEXT_EMOTE_AGGRO = -1800011, //The Ravenous Worg chomps down on Mr. Floppy
+ SAY_QUEST_ACCEPT = -1800012, //Are you ready, Mr. Floppy? Stay close to me and watch out for those wolves!
+ SAY_QUEST_COMPLETE = -1800013 //Thank you for helping me get back to the camp. Go tell Walter that I'm safe now!
+};
+
+//emily
+struct npc_emilyAI : public npc_escortAI
+{
+ npc_emilyAI(Creature* pCreature) : npc_escortAI(pCreature) { }
+
+ uint32 m_uiChatTimer;
+
+ uint64 RWORGGUID;
+ uint64 MrfloppyGUID;
+
+ Creature* Mrfloppy;
+ Creature* RWORG;
+ bool Completed;
+
+
+ void JustSummoned(Creature* pSummoned)
+ {
+ if (Creature* Mrfloppy = GetClosestCreatureWithEntry(m_creature, NPC_MRFLOPPY, 50.0f))
+ pSummoned->AI()->AttackStart(Mrfloppy);
+ else
+ pSummoned->AI()->AttackStart(m_creature->getVictim());
+ }
+
+ void WaypointReached(uint32 i)
+ {
+ Player* pPlayer = GetPlayerForEscort();
+ if (!pPlayer)
+ return;
+ switch (i)
+ {
+ case 9:
+ Mrfloppy = GetClosestCreatureWithEntry(m_creature, NPC_MRFLOPPY, 100.0f);
+ break;
+ case 10:
+ if (Mrfloppy)
+ {
+ DoScriptText(SAY_WORGHAGGRO1, m_creature);
+ m_creature->SummonCreature(NPC_HUNGRY_WORG,m_creature->GetPositionX()+5,m_creature->GetPositionY()+2,m_creature->GetPositionZ()+1,3.229f,TEMPSUMMON_TIMED_OR_DEAD_DESPAWN,120000);
+ }
+ break;
+ case 11:
+ Mrfloppy->GetMotionMaster()->MoveFollow(m_creature, PET_FOLLOW_DIST, PET_FOLLOW_ANGLE);
+ break;
+ case 17:
+ Mrfloppy->GetMotionMaster()->MovePoint(0, m_creature->GetPositionX(), m_creature->GetPositionY(), m_creature->GetPositionZ());
+ DoScriptText(SAY_WORGRAGGRO3, m_creature);
+ RWORG = m_creature->SummonCreature(NPC_RAVENOUS_WORG,m_creature->GetPositionX()+10,m_creature->GetPositionY()+8,m_creature->GetPositionZ()+2,3.229f,TEMPSUMMON_TIMED_OR_DEAD_DESPAWN,120000);
+ RWORG->setFaction(35);
+ break;
+ case 18:
+ if (Mrfloppy)
+ {
+ RWORG->GetMotionMaster()->MovePoint(0, Mrfloppy->GetPositionX(), Mrfloppy->GetPositionY(), Mrfloppy->GetPositionZ());
+ DoCast(Mrfloppy,SPELL_MRFLOPPY);
+ }
+ break;
+ case 19:
+ if (Mrfloppy->HasAura(SPELL_MRFLOPPY, 0))
+ Mrfloppy->EnterVehicle(RWORG);
+ break;
+ case 20:
+ if (Mrfloppy)
+ RWORG->HandleEmoteCommand(34);
+ break;
+ case 21:
+ if (Mrfloppy)
+ {
+ RWORG->Kill(Mrfloppy);
+ Mrfloppy->ExitVehicle();
+ RWORG->setFaction(14);
+ RWORG->GetMotionMaster()->MovePoint(0, RWORG->GetPositionX()+10,RWORG->GetPositionY()+80,RWORG->GetPositionZ());
+ DoScriptText(SAY_VICTORY2, m_creature);
+ }
+ break;
+ case 22:
+ if (Mrfloppy && Mrfloppy->isDead())
+ {
+ RWORG->DisappearAndDie();
+ m_creature->GetMotionMaster()->MovePoint(0, Mrfloppy->GetPositionX(), Mrfloppy->GetPositionY(), Mrfloppy->GetPositionZ());
+ Mrfloppy->setDeathState(ALIVE);
+ Mrfloppy->GetMotionMaster()->MoveFollow(m_creature, PET_FOLLOW_DIST, PET_FOLLOW_ANGLE);
+ DoScriptText(SAY_VICTORY3, m_creature);
+ }
+ break;
+ case 24:
+ if (pPlayer)
+ {
+ Completed = true;
+ pPlayer->GroupEventHappens(QUEST_PERILOUS_ADVENTURE, m_creature);
+ DoScriptText(SAY_QUEST_COMPLETE, m_creature, pPlayer);
+ }
+ m_creature->RemoveUnitMovementFlag(MOVEMENTFLAG_WALK_MODE);
+ break;
+ case 25:
+ DoScriptText(SAY_VICTORY4, m_creature);
+ break;
+ case 27:
+ m_creature->DisappearAndDie();
+ if (Mrfloppy)
+ Mrfloppy->DisappearAndDie();
+ break;
+ }
+ }
+
+ void EnterCombat(Unit* Who)
+ {
+ DoScriptText(SAY_RANDOMAGGRO, m_creature);
+ }
+
+ void Reset()
+ {
+ m_uiChatTimer = 4000;
+ Mrfloppy = NULL;
+ RWORG = NULL;
+ }
+
+ void UpdateAI(const uint32 uiDiff)
+ {
+ npc_escortAI::UpdateAI(uiDiff);
+
+ if (HasEscortState(STATE_ESCORT_ESCORTING))
+ {
+ if (m_uiChatTimer <= uiDiff)
+ {
+ m_uiChatTimer = 12000;
+ }
+ else
+ m_uiChatTimer -= uiDiff;
+ }
+ }
+};
+
+
+bool QuestAccept_npc_emily(Player* pPlayer, Creature* pCreature, Quest const* quest)
+{
+ if (quest->GetQuestId() == QUEST_PERILOUS_ADVENTURE)
+ {
+ DoScriptText(SAY_QUEST_ACCEPT, pCreature);
+ if (Creature* Mrfloppy = GetClosestCreatureWithEntry(pCreature, NPC_MRFLOPPY, 180.0f))
+ {
+ Mrfloppy->GetMotionMaster()->MoveFollow(pCreature, PET_FOLLOW_DIST, PET_FOLLOW_ANGLE);
+ }
+
+ if (npc_escortAI* pEscortAI = CAST_AI(npc_emilyAI, (pCreature->AI())))
+ pEscortAI->Start(true, false, pPlayer->GetGUID());
+ }
+ return true;
+}
+
+CreatureAI* GetAI_npc_emily(Creature* pCreature)
+{
+ return new npc_emilyAI(pCreature);
+}
+
+//mrfloppy
+
+struct npc_mrfloppyAI : public ScriptedAI
+{
+ npc_mrfloppyAI(Creature *c) : ScriptedAI(c) {}
+
+ uint64 EmilyGUID;
+ uint64 RWORGGUID;
+ uint64 HWORGGUID;
+
+ Creature* HWORG;
+ Creature* RWORG;
+
+ Creature* Emily;
+
+ void Reset()
+ {
+ HWORG = NULL;
+ RWORG = NULL;
+ Emily = NULL;
+ }
+
+ void EnterCombat(Unit* Who)
+ {
+ if (Creature* Emily = GetClosestCreatureWithEntry(m_creature, NPC_EMILY, 50.0f))
+ {
+ switch(Who->GetEntry())
+ {
+ case NPC_HUNGRY_WORG:
+ DoScriptText(SAY_WORGHAGGRO2, Emily);
+ break;
+ case NPC_RAVENOUS_WORG:
+ DoScriptText(SAY_WORGRAGGRO4, Emily);
+ break;
+ default:
+ DoScriptText(SAY_RANDOMAGGRO, Emily);
+ }
+ }
+ }
+
+ void EnterEvadeMode() {}
+
+ void MoveInLineOfSight(Unit *who) {}
+
+ void UpdateAI(const uint32 diff)
+ {
+ if (!UpdateVictim())
+ return;
+ }
+};
+
+CreatureAI* GetAI_npc_mrfloppy(Creature* pCreature)
+{
+ return new npc_mrfloppyAI(pCreature);
+}
+
void AddSC_grizzly_hills()
{
Script* newscript;
@@ -124,4 +365,15 @@ void AddSC_grizzly_hills()
newscript->pGossipHello = &GossipHello_npc_orsonn_and_kodian;
newscript->pGossipSelect = &GossipSelect_npc_orsonn_and_kodian;
newscript->RegisterSelf();
+
+ newscript = new Script;
+ newscript->Name = "npc_emily";
+ newscript->GetAI = &GetAI_npc_emily;
+ newscript->pQuestAccept = &QuestAccept_npc_emily;
+ newscript->RegisterSelf();
+
+ newscript = new Script;
+ newscript->Name = "npc_mrfloppy";
+ newscript->GetAI = &GetAI_npc_mrfloppy;
+ newscript->RegisterSelf();
}