mirror of
https://github.com/DarkflameUniverse/DarkflameServer
synced 2024-08-30 18:43:58 +00:00
6aa90ad5b2
* Breakout rest of the enums from dcommonvars so we don't have to deal with merge conflicts ePlayerFlags is not a scoped enum, yet, due to it's complexity * address feedback * make player flag types consistent * fix typo
58 lines
1.4 KiB
C++
58 lines
1.4 KiB
C++
#include "InstanceExitTransferPlayerToLastNonInstance.h"
|
|
#include "GameMessages.h"
|
|
#include "Player.h"
|
|
#include "Character.h"
|
|
#include "dServer.h"
|
|
#include "eTerminateType.h"
|
|
|
|
void InstanceExitTransferPlayerToLastNonInstance::OnUse(Entity* self, Entity* user) {
|
|
auto transferText = self->GetVar<std::u16string>(u"transferText");
|
|
if (transferText.empty())
|
|
transferText = u"DRAGON_EXIT_QUESTION";
|
|
|
|
GameMessages::SendDisplayMessageBox(
|
|
user->GetObjectID(),
|
|
true,
|
|
self->GetObjectID(),
|
|
u"Instance_Exit",
|
|
1,
|
|
transferText,
|
|
u"",
|
|
user->GetSystemAddress()
|
|
);
|
|
}
|
|
|
|
void InstanceExitTransferPlayerToLastNonInstance::OnMessageBoxResponse(Entity* self, Entity* sender, int32_t button, const std::u16string& identifier, const std::u16string& userData) {
|
|
auto* player = dynamic_cast<Player*>(sender);
|
|
if (player == nullptr)
|
|
return;
|
|
|
|
auto* character = sender->GetCharacter();
|
|
if (character != nullptr) {
|
|
if (identifier == u"Instance_Exit" && button == 1) {
|
|
auto lastInstance = character->GetLastNonInstanceZoneID();
|
|
|
|
// Sanity check
|
|
if (lastInstance == 0) {
|
|
switch (Game::server->GetZoneID()) {
|
|
case 2001:
|
|
lastInstance = 2000;
|
|
break;
|
|
case 1402:
|
|
lastInstance = 1400;
|
|
break;
|
|
default:
|
|
lastInstance = 1100;
|
|
break;
|
|
}
|
|
}
|
|
|
|
player->SendToZone(lastInstance);
|
|
}
|
|
}
|
|
|
|
GameMessages::SendTerminateInteraction(sender->GetObjectID(), eTerminateType::FROM_INTERACTION, self->GetObjectID());
|
|
}
|
|
|
|
|