pokeemerald/src/mystery_gift.c

1598 lines
44 KiB
C
Raw Normal View History

2019-03-30 13:14:00 -04:00
#include "global.h"
#include "main.h"
#include "text.h"
#include "task.h"
#include "malloc.h"
2019-03-30 13:14:00 -04:00
#include "gpu_regs.h"
#include "scanline_effect.h"
#include "text_window.h"
#include "bg.h"
#include "window.h"
2019-03-30 14:36:52 -04:00
#include "strings.h"
2019-03-30 13:14:00 -04:00
#include "text_window.h"
#include "menu.h"
#include "palette.h"
#include "constants/songs.h"
#include "sound.h"
#include "mystery_gift.h"
2019-03-30 14:36:52 -04:00
#include "union_room.h"
#include "title_screen.h"
#include "ereader_screen.h"
#include "international_string_util.h"
#include "list_menu.h"
2019-03-30 20:04:30 -04:00
#include "string_util.h"
2019-03-31 11:16:19 -04:00
#include "mevent.h"
2021-10-14 12:12:16 -04:00
#include "wonder_transfer.h"
2019-03-31 12:27:36 -04:00
#include "save.h"
2019-03-31 15:50:25 -04:00
#include "link.h"
2019-04-02 14:02:13 -04:00
#include "mevent_client.h"
2019-03-31 15:50:25 -04:00
#include "event_data.h"
#include "link_rfu.h"
#include "mevent_news.h"
#include "mevent_server.h"
2020-06-08 18:16:57 -04:00
#include "constants/cable_club.h"
2019-03-30 13:14:00 -04:00
void bgid_upload_textbox_1(u8 bgId);
2021-10-14 14:10:42 -04:00
static void CreateMysteryGiftTask(void);
static void Task_MysteryGift(u8 taskId);
2019-03-30 14:36:52 -04:00
2019-03-31 18:59:52 -04:00
EWRAM_DATA u8 sDownArrowCounterAndYCoordIdx[8] = {};
EWRAM_DATA bool8 gGiftIsFromEReader = FALSE;
2019-03-30 13:14:00 -04:00
2019-03-31 18:59:52 -04:00
static const u16 gUnkTextboxBorderPal[] = INCBIN_U16("graphics/interface/unk_textbox_border.gbapal");
static const u32 gUnkTextboxBorderGfx[] = INCBIN_U32("graphics/interface/unk_textbox_border.4bpp.lz");
2019-03-30 13:14:00 -04:00
2019-03-31 12:55:27 -04:00
struct MysteryGiftTaskData
{
2019-03-31 18:59:52 -04:00
u16 curPromptWindowId;
2019-03-31 12:55:27 -04:00
u16 unk2;
u16 unk4;
u16 unk6;
2019-03-31 18:59:52 -04:00
u8 state;
u8 textState;
2019-03-31 12:55:27 -04:00
u8 unkA;
u8 unkB;
2021-10-14 14:10:42 -04:00
bool8 isWonderNews;
bool8 sourceIsFriend;
2019-03-31 18:59:52 -04:00
u8 prevPromptWindowId;
u8 * buffer;
2019-03-31 12:55:27 -04:00
};
2019-03-31 18:59:52 -04:00
static const struct BgTemplate sBGTemplates[] = {
2019-03-30 13:14:00 -04:00
{
.bg = 0,
.charBaseIndex = 2,
.mapBaseIndex = 15,
.screenSize = 0,
.paletteMode = 0,
.priority = 0,
.baseTile = 0x000
}, {
.bg = 1,
.charBaseIndex = 0,
.mapBaseIndex = 14,
.screenSize = 0,
.paletteMode = 0,
.priority = 1,
.baseTile = 0x000
}, {
.bg = 2,
.charBaseIndex = 0,
.mapBaseIndex = 13,
.screenSize = 0,
.paletteMode = 0,
.priority = 2,
.baseTile = 0x000
}, {
.bg = 3,
.charBaseIndex = 0,
.mapBaseIndex = 12,
.screenSize = 0,
.paletteMode = 0,
.priority = 3,
.baseTile = 0x000
}
};
2019-03-31 18:59:52 -04:00
static const struct WindowTemplate sMainWindows[] = {
2019-03-30 13:14:00 -04:00
{
.bg = 0x00,
.tilemapLeft = 0x00,
.tilemapTop = 0x00,
.width = 0x1e,
.height = 0x02,
.paletteNum = 0x0c,
.baseBlock = 0x0013
}, {
.bg = 0x00,
.tilemapLeft = 0x01,
.tilemapTop = 0x0f,
.width = 0x1c,
.height = 0x04,
.paletteNum = 0x0c,
.baseBlock = 0x004f
}, {
.bg = 0x00,
.tilemapLeft = 0x00,
.tilemapTop = 0x0f,
.width = 0x1e,
.height = 0x05,
.paletteNum = 0x0d,
.baseBlock = 0x004f
2021-10-14 12:12:16 -04:00
},
DUMMY_WIN_TEMPLATE
2019-03-30 13:14:00 -04:00
};
2019-03-31 18:59:52 -04:00
static const struct WindowTemplate sWindowTemplate_PromptYesOrNo_Width28 = {
2019-03-30 13:14:00 -04:00
.bg = 0x00,
.tilemapLeft = 0x01,
.tilemapTop = 0x0f,
.width = 0x1c,
.height = 0x04,
.paletteNum = 0x0c,
.baseBlock = 0x00e5
};
2019-03-31 18:59:52 -04:00
static const struct WindowTemplate sWindowTemplate_PromptYesOrNo_Width20 = {
2019-03-30 13:14:00 -04:00
.bg = 0x00,
.tilemapLeft = 0x01,
.tilemapTop = 0x0f,
.width = 0x14,
.height = 0x04,
.paletteNum = 0x0c,
.baseBlock = 0x00e5
};
2019-03-31 18:59:52 -04:00
static const struct WindowTemplate sMysteryGiftMenuWindowTemplate = {
2019-03-30 13:14:00 -04:00
.bg = 0x00,
.tilemapLeft = 0x01,
.tilemapTop = 0x0f,
.width = 0x13,
.height = 0x04,
.paletteNum = 0x0c,
.baseBlock = 0x00e5
};
2019-03-31 18:59:52 -04:00
static const struct WindowTemplate sWindowTemplate_ThreeOptions = {
2019-03-30 13:14:00 -04:00
.bg = 0x00,
.tilemapLeft = 0x08,
.tilemapTop = 0x06,
.width = 0x0e,
.height = 0x06,
.paletteNum = 0x0c,
.baseBlock = 0x0155
};
2019-03-31 18:59:52 -04:00
static const struct WindowTemplate sWindowTemplate_YesNoBox = {
2019-03-30 13:14:00 -04:00
.bg = 0x00,
.tilemapLeft = 0x17,
.tilemapTop = 0x0f,
.width = 0x06,
.height = 0x04,
.paletteNum = 0x0c,
.baseBlock = 0x0155
};
2019-03-31 18:59:52 -04:00
static const struct WindowTemplate sWindowTemplate_7by8 = {
2019-03-30 13:14:00 -04:00
.bg = 0x00,
.tilemapLeft = 0x16,
.tilemapTop = 0x0b,
.width = 0x07,
.height = 0x08,
.paletteNum = 0x0c,
.baseBlock = 0x0155
};
2019-03-31 18:59:52 -04:00
static const struct WindowTemplate sWindowTemplate_7by6 = {
2019-03-30 13:14:00 -04:00
.bg = 0x00,
.tilemapLeft = 0x16,
.tilemapTop = 0x0d,
.width = 0x07,
.height = 0x06,
.paletteNum = 0x0c,
.baseBlock = 0x0155
};
2019-03-31 18:59:52 -04:00
static const struct WindowTemplate sWindowTemplate_7by4 = {
2019-03-30 13:14:00 -04:00
.bg = 0x00,
.tilemapLeft = 0x16,
.tilemapTop = 0x0f,
.width = 0x07,
.height = 0x04,
.paletteNum = 0x0c,
.baseBlock = 0x0155
};
2019-03-31 18:59:52 -04:00
static const struct ListMenuItem sListMenuItems_CardsOrNews[] = {
2019-03-30 14:36:52 -04:00
{ gText_WonderCards, 0 },
{ gText_WonderNews, 1 },
{ gText_Exit3, -2 }
};
2019-03-31 18:59:52 -04:00
static const struct ListMenuItem sListMenuItems_WirelessOrFriend[] = {
2019-03-30 14:36:52 -04:00
{ gText_WirelessCommunication, 0 },
{ gText_Friend2, 1 },
{ gText_Cancel2, -2 }
};
2019-03-31 18:59:52 -04:00
static const struct ListMenuTemplate sListMenuTemplate_ThreeOptions = {
2019-03-30 14:36:52 -04:00
.items = NULL,
.moveCursorFunc = ListMenuDefaultCursorMoveFunc,
.itemPrintFunc = NULL,
.totalItems = 3,
.maxShowed = 3,
.windowId = 0,
.header_X = 0,
.item_X = 8,
.cursor_X = 0,
.upText_Y = 1,
.cursorPal = 2,
.fillValue = 1,
.cursorShadowPal = 3,
.lettersSpacing = 0,
.itemVerticalPadding = 0,
.scrollMultiple = 0,
.fontId = 1,
.cursorKind = 0
};
2019-03-31 18:59:52 -04:00
static const struct ListMenuItem sListMenuItems_ReceiveSendToss[] = {
2019-03-30 14:36:52 -04:00
{ gText_Receive, 0 },
{ gText_Send, 1 },
{ gText_Toss, 2 },
{ gText_Cancel2, -2 }
};
2019-03-31 18:59:52 -04:00
static const struct ListMenuItem sListMenuItems_ReceiveToss[] = {
2019-03-30 14:36:52 -04:00
{ gText_Receive, 0 },
{ gText_Toss, 2 },
{ gText_Cancel2, -2 }
};
2019-03-31 18:59:52 -04:00
static const struct ListMenuItem sListMenuItems_ReceiveSend[] = {
2019-03-30 14:36:52 -04:00
{ gText_Receive, 0 },
{ gText_Send, 1 },
{ gText_Cancel2, -2 }
};
2019-03-31 18:59:52 -04:00
static const struct ListMenuItem sListMenuItems_Receive[] = {
2019-03-30 14:36:52 -04:00
{ gText_Receive, 0 },
{ gText_Cancel2, -2 }
};
2019-03-31 18:59:52 -04:00
static const struct ListMenuTemplate sListMenu_ReceiveSendToss = {
.items = sListMenuItems_ReceiveSendToss,
2019-03-30 14:36:52 -04:00
.moveCursorFunc = ListMenuDefaultCursorMoveFunc,
.itemPrintFunc = NULL,
.totalItems = 4,
.maxShowed = 4,
.windowId = 0,
.header_X = 0,
.item_X = 8,
.cursor_X = 0,
.upText_Y = 1,
.cursorPal = 2,
.fillValue = 1,
.cursorShadowPal = 3,
.lettersSpacing = 0,
.itemVerticalPadding = 0,
.scrollMultiple = 0,
.fontId = 1,
.cursorKind = 0
};
2019-03-31 18:59:52 -04:00
static const struct ListMenuTemplate sListMenu_ReceiveToss = {
.items = sListMenuItems_ReceiveToss,
2019-03-30 14:36:52 -04:00
.moveCursorFunc = ListMenuDefaultCursorMoveFunc,
.itemPrintFunc = NULL,
.totalItems = 3,
.maxShowed = 3,
.windowId = 0,
.header_X = 0,
.item_X = 8,
.cursor_X = 0,
.upText_Y = 1,
.cursorPal = 2,
.fillValue = 1,
.cursorShadowPal = 3,
.lettersSpacing = 0,
.itemVerticalPadding = 0,
.scrollMultiple = 0,
.fontId = 1,
.cursorKind = 0
};
2019-03-31 18:59:52 -04:00
static const struct ListMenuTemplate sListMenu_ReceiveSend = {
.items = sListMenuItems_ReceiveSend,
2019-03-30 14:36:52 -04:00
.moveCursorFunc = ListMenuDefaultCursorMoveFunc,
.itemPrintFunc = NULL,
.totalItems = 3,
.maxShowed = 3,
.windowId = 0,
.header_X = 0,
.item_X = 8,
.cursor_X = 0,
.upText_Y = 1,
.cursorPal = 2,
.fillValue = 1,
.cursorShadowPal = 3,
.lettersSpacing = 0,
.itemVerticalPadding = 0,
.scrollMultiple = 0,
.fontId = 1,
.cursorKind = 0
};
2019-03-31 18:59:52 -04:00
static const struct ListMenuTemplate sListMenu_Receive = {
.items = sListMenuItems_Receive,
2019-03-30 14:36:52 -04:00
.moveCursorFunc = ListMenuDefaultCursorMoveFunc,
.itemPrintFunc = NULL,
.totalItems = 2,
.maxShowed = 2,
.windowId = 0,
.header_X = 0,
.item_X = 8,
.cursor_X = 0,
.upText_Y = 1,
.cursorPal = 2,
.fillValue = 1,
.cursorShadowPal = 3,
.lettersSpacing = 0,
.itemVerticalPadding = 0,
.scrollMultiple = 0,
.fontId = 1,
.cursorKind = 0
};
2019-03-31 18:59:52 -04:00
static const u8 *const Unref_082F0710[] = {
2019-03-30 14:36:52 -04:00
gText_VarietyOfEventsImportedWireless,
gText_WonderCardsInPossession,
gText_ReadNewsThatArrived,
gText_ReturnToTitle
};
2019-03-31 18:59:52 -04:00
ALIGNED(2) const u8 sMG_Ereader_TextColor_1[] = { 0, 1, 2 };
ALIGNED(2) const u8 sMG_Ereader_TextColor_1_Copy[] = { 0, 1, 2 };
ALIGNED(2) const u8 sMG_Ereader_TextColor_2[] = { 1, 2, 3 };
2019-03-30 14:36:52 -04:00
2021-10-14 14:10:42 -04:00
static void VBlankCB_MysteryGiftEReader(void)
2019-03-30 13:14:00 -04:00
{
ProcessSpriteCopyRequests();
LoadOam();
TransferPlttBuffer();
}
2021-10-14 14:10:42 -04:00
void CB2_MysteryGiftEReader(void)
2019-03-30 13:14:00 -04:00
{
RunTasks();
RunTextPrinters();
AnimateSprites();
BuildOamBuffer();
}
2021-10-14 14:10:42 -04:00
static bool32 HandleMysteryGiftOrEReaderSetup(s32 isEReader)
2019-03-30 13:14:00 -04:00
{
switch (gMain.state)
{
case 0:
SetVBlankCallback(NULL);
ResetPaletteFade();
ResetSpriteData();
FreeAllSpritePalettes();
ResetTasks();
ScanlineEffect_Stop();
ResetBgsAndClearDma3BusyFlags(0);
2019-03-31 18:59:52 -04:00
InitBgsFromTemplates(0, sBGTemplates, ARRAY_COUNT(sBGTemplates));
2019-03-30 13:14:00 -04:00
ChangeBgX(0, 0, 0);
ChangeBgY(0, 0, 0);
ChangeBgX(1, 0, 0);
ChangeBgY(1, 0, 0);
ChangeBgX(2, 0, 0);
ChangeBgY(2, 0, 0);
ChangeBgX(3, 0, 0);
ChangeBgY(3, 0, 0);
2021-03-29 09:38:19 -04:00
SetBgTilemapBuffer(3, Alloc(BG_SCREEN_SIZE));
SetBgTilemapBuffer(2, Alloc(BG_SCREEN_SIZE));
SetBgTilemapBuffer(1, Alloc(BG_SCREEN_SIZE));
SetBgTilemapBuffer(0, Alloc(BG_SCREEN_SIZE));
2019-03-30 13:14:00 -04:00
bgid_upload_textbox_1(3);
2019-03-31 18:59:52 -04:00
InitWindows(sMainWindows);
2019-03-30 13:14:00 -04:00
DeactivateAllTextPrinters();
ClearGpuRegBits(REG_OFFSET_DISPCNT, DISPCNT_WIN0_ON | DISPCNT_WIN1_ON);
SetGpuReg(REG_OFFSET_BLDCNT, 0);
SetGpuReg(REG_OFFSET_BLDALPHA, 0);
SetGpuReg(REG_OFFSET_BLDY, 0);
gMain.state++;
break;
case 1:
LoadPalette(gUnkTextboxBorderPal, 0, 0x20);
2020-08-07 02:00:41 -04:00
LoadPalette(GetTextWindowPalette(2), 0xd0, 0x20);
2019-03-31 18:59:52 -04:00
Menu_LoadStdPalAt(0xC0);
2019-03-30 13:14:00 -04:00
LoadUserWindowBorderGfx(0, 0xA, 0xE0);
LoadUserWindowBorderGfx_(0, 0x1, 0xF0);
FillBgTilemapBufferRect(0, 0x000, 0, 0, 32, 32, 0x11);
FillBgTilemapBufferRect(1, 0x000, 0, 0, 32, 32, 0x11);
FillBgTilemapBufferRect(2, 0x000, 0, 0, 32, 32, 0x11);
2019-03-31 18:59:52 -04:00
MG_DrawCheckerboardPattern(3);
2021-10-14 14:10:42 -04:00
PrintMysteryGiftOrEReaderTopMenu(isEReader, FALSE);
2019-03-30 13:14:00 -04:00
gMain.state++;
break;
case 2:
CopyBgTilemapBufferToVram(3);
CopyBgTilemapBufferToVram(2);
CopyBgTilemapBufferToVram(1);
CopyBgTilemapBufferToVram(0);
gMain.state++;
break;
case 3:
ShowBg(0);
ShowBg(3);
2020-08-20 18:02:00 -04:00
PlayBGM(MUS_RG_MYSTERY_GIFT);
2021-10-14 14:10:42 -04:00
SetVBlankCallback(VBlankCB_MysteryGiftEReader);
2019-03-30 13:14:00 -04:00
EnableInterrupts(INTR_FLAG_VBLANK | INTR_FLAG_VCOUNT | INTR_FLAG_TIMER3 | INTR_FLAG_SERIAL);
return TRUE;
}
return FALSE;
}
2019-03-30 14:36:52 -04:00
2021-10-14 14:10:42 -04:00
void CB2_InitMysteryGift(void)
2019-03-30 14:36:52 -04:00
{
2021-10-14 14:10:42 -04:00
if (HandleMysteryGiftOrEReaderSetup(FALSE))
2019-03-30 14:36:52 -04:00
{
2021-10-14 14:10:42 -04:00
SetMainCallback2(CB2_MysteryGiftEReader);
2019-03-31 18:59:52 -04:00
gGiftIsFromEReader = FALSE;
2021-10-14 14:10:42 -04:00
CreateMysteryGiftTask();
2019-03-30 14:36:52 -04:00
}
RunTasks();
}
2021-10-14 14:10:42 -04:00
void CB2_InitEReader(void)
2019-03-30 14:36:52 -04:00
{
2021-10-14 14:10:42 -04:00
if (HandleMysteryGiftOrEReaderSetup(TRUE))
2019-03-30 14:36:52 -04:00
{
2021-10-14 14:10:42 -04:00
SetMainCallback2(CB2_MysteryGiftEReader);
2019-03-31 18:59:52 -04:00
gGiftIsFromEReader = TRUE;
2021-10-14 14:10:42 -04:00
CreateEReaderTask();
2019-03-30 14:36:52 -04:00
}
}
2019-03-31 18:59:52 -04:00
void MainCB_FreeAllBuffersAndReturnToInitTitleScreen(void)
2019-03-30 14:36:52 -04:00
{
2019-03-31 18:59:52 -04:00
gGiftIsFromEReader = FALSE;
2019-03-30 14:36:52 -04:00
FreeAllWindowBuffers();
Free(GetBgTilemapBuffer(0));
Free(GetBgTilemapBuffer(1));
Free(GetBgTilemapBuffer(2));
Free(GetBgTilemapBuffer(3));
SetMainCallback2(CB2_InitTitleScreen);
}
2021-10-14 14:10:42 -04:00
void PrintMysteryGiftOrEReaderTopMenu(bool8 isEReader, bool32 usePickOkCancel)
2019-03-30 14:36:52 -04:00
{
const u8 * header;
const u8 * options;
FillWindowPixelBuffer(0, 0);
2021-10-14 14:10:42 -04:00
if (!isEReader)
2019-03-30 14:36:52 -04:00
{
header = gText_MysteryGift;
options = !usePickOkCancel ? gText_PickOKExit : gText_PickOKCancel;
}
else
{
header = gJPText_MysteryGift;
options = gJPText_DecideStop;
}
2019-03-31 18:59:52 -04:00
AddTextPrinterParameterized4(0, 1, 4, 1, 0, 0, sMG_Ereader_TextColor_1, -1, header);
AddTextPrinterParameterized4(0, 0, GetStringRightAlignXOffset(0, options, 0xDE), 1, 0, 0, sMG_Ereader_TextColor_1, -1, options);
2019-03-30 14:36:52 -04:00
CopyWindowToVram(0, 2);
PutWindowTilemap(0);
}
2019-03-31 18:59:52 -04:00
void MG_DrawTextBorder(u8 windowId)
2019-03-30 14:36:52 -04:00
{
2019-03-31 18:59:52 -04:00
DrawTextBorderOuter(windowId, 0x01, 0xF);
2019-03-30 14:36:52 -04:00
}
2019-03-31 18:59:52 -04:00
void MG_DrawCheckerboardPattern(u32 bg)
2019-03-30 14:36:52 -04:00
{
s32 i = 0, j;
FillBgTilemapBufferRect(bg, 0x003, 0, 0, 32, 2, 0x11);
for (i = 0; i < 18; i++)
{
for (j = 0; j < 32; j++)
{
if ((i & 1) != (j & 1))
FillBgTilemapBufferRect(bg, 1, j, i + 2, 1, 1, 0x11);
else
FillBgTilemapBufferRect(bg, 2, j, i + 2, 1, 1, 0x11);
}
}
}
2019-03-30 20:04:30 -04:00
2019-03-31 18:59:52 -04:00
void ClearScreenInBg0(bool32 ignoreTopTwoRows)
2019-03-30 20:04:30 -04:00
{
2019-03-31 18:59:52 -04:00
switch (ignoreTopTwoRows)
2019-03-30 20:04:30 -04:00
{
case 0:
FillBgTilemapBufferRect(0, 0, 0, 0, 32, 32, 0x11);
break;
case 1:
FillBgTilemapBufferRect(0, 0, 0, 2, 32, 30, 0x11);
break;
}
CopyBgTilemapBufferToVram(0);
}
2019-03-31 18:59:52 -04:00
void AddTextPrinterToWindow1(const u8 *str)
2019-03-30 20:04:30 -04:00
{
StringExpandPlaceholders(gStringVar4, str);
FillWindowPixelBuffer(1, 0x11);
2019-03-31 18:59:52 -04:00
AddTextPrinterParameterized4(1, 1, 0, 1, 0, 0, sMG_Ereader_TextColor_2, 0, gStringVar4);
DrawTextBorderOuter(1, 0x001, 0xF);
2019-03-30 20:04:30 -04:00
PutWindowTilemap(1);
CopyWindowToVram(1, 3);
}
2019-03-31 18:59:52 -04:00
static void ClearTextWindow(void)
2019-03-30 20:04:30 -04:00
{
rbox_fill_rectangle(1);
ClearWindowTilemap(1);
CopyWindowToVram(1, 1);
}
2019-03-31 18:59:52 -04:00
bool32 MG_PrintTextOnWindow1AndWaitButton(u8 *textState, const u8 *str)
2019-03-30 20:04:30 -04:00
{
switch (*textState)
{
case 0:
2019-03-31 18:59:52 -04:00
AddTextPrinterToWindow1(str);
2021-05-09 01:03:39 -04:00
(*textState)++;
break;
2019-03-30 20:04:30 -04:00
case 1:
2019-03-31 18:59:52 -04:00
DrawDownArrow(1, 0xD0, 0x14, 1, FALSE, &sDownArrowCounterAndYCoordIdx[0], &sDownArrowCounterAndYCoordIdx[1]);
2020-09-04 21:11:55 -04:00
if (({JOY_NEW(A_BUTTON | B_BUTTON);}))
2019-03-30 20:04:30 -04:00
(*textState)++;
break;
case 2:
2019-03-31 18:59:52 -04:00
DrawDownArrow(1, 0xD0, 0x14, 1, TRUE, &sDownArrowCounterAndYCoordIdx[0], &sDownArrowCounterAndYCoordIdx[1]);
2019-03-30 20:04:30 -04:00
*textState = 0;
2019-03-31 18:59:52 -04:00
ClearTextWindow();
2019-03-30 20:04:30 -04:00
return TRUE;
case 0xFF:
*textState = 2;
2021-05-09 01:03:39 -04:00
return FALSE;
2019-03-30 20:04:30 -04:00
}
return FALSE;
}
2019-03-31 18:59:52 -04:00
static void HideDownArrow(void)
2019-03-30 20:04:30 -04:00
{
2019-03-31 18:59:52 -04:00
DrawDownArrow(1, 0xD0, 0x14, 1, FALSE, &sDownArrowCounterAndYCoordIdx[0], &sDownArrowCounterAndYCoordIdx[1]);
2019-03-30 20:04:30 -04:00
}
2019-03-31 18:59:52 -04:00
static void ShowDownArrow(void)
2019-03-30 20:04:30 -04:00
{
2019-03-31 18:59:52 -04:00
DrawDownArrow(1, 0xD0, 0x14, 1, TRUE, &sDownArrowCounterAndYCoordIdx[0], &sDownArrowCounterAndYCoordIdx[1]);
2019-03-30 20:04:30 -04:00
}
2019-03-31 18:59:52 -04:00
bool32 unref_HideDownArrowAndWaitButton(u8 * textState)
2019-03-30 20:04:30 -04:00
{
switch (*textState)
{
case 0:
2019-03-31 18:59:52 -04:00
HideDownArrow();
if (JOY_NEW(A_BUTTON | B_BUTTON))
2019-03-30 20:04:30 -04:00
(*textState)++;
break;
case 1:
2019-03-31 18:59:52 -04:00
ShowDownArrow();
2019-03-30 20:04:30 -04:00
*textState = 0;
return TRUE;
}
return FALSE;
}
2019-03-31 18:59:52 -04:00
static bool32 PrintStringAndWait2Seconds(u8 * counter, const u8 * str)
2019-03-30 20:04:30 -04:00
{
if (*counter == 0)
2019-03-31 18:59:52 -04:00
AddTextPrinterToWindow1(str);
2019-03-30 20:04:30 -04:00
if (++(*counter) > 120)
{
*counter = 0;
2019-03-31 18:59:52 -04:00
ClearTextWindow();
2019-03-30 20:04:30 -04:00
return TRUE;
}
else
{
return FALSE;
}
}
2019-03-31 18:59:52 -04:00
static u32 MysteryGift_HandleThreeOptionMenu(u8 * unused0, u16 * unused1, u8 whichMenu)
2019-03-30 20:04:30 -04:00
{
2019-03-31 18:59:52 -04:00
struct ListMenuTemplate listMenuTemplate = sListMenuTemplate_ThreeOptions;
struct WindowTemplate windowTemplate = sWindowTemplate_ThreeOptions;
s32 width;
s32 response;
2019-03-30 20:04:30 -04:00
2019-03-31 18:59:52 -04:00
if (whichMenu == 0)
listMenuTemplate.items = sListMenuItems_CardsOrNews;
2019-03-30 20:04:30 -04:00
else
2019-03-31 18:59:52 -04:00
listMenuTemplate.items = sListMenuItems_WirelessOrFriend;
2019-03-31 18:59:52 -04:00
width = Intl_GetListMenuWidth(&listMenuTemplate);
if (width & 1)
width++;
2019-03-31 18:59:52 -04:00
windowTemplate.width = width;
if (width < 30)
windowTemplate.tilemapLeft = (30 - width) / 2;
2019-03-30 20:04:30 -04:00
else
windowTemplate.tilemapLeft = 0;
2019-03-31 18:59:52 -04:00
response = DoMysteryGiftListMenu(&windowTemplate, &listMenuTemplate, 1, 0x00A, 0xE0);
2021-10-14 14:10:42 -04:00
if (response != LIST_NOTHING_CHOSEN)
2019-03-30 20:04:30 -04:00
{
ClearWindowTilemap(2);
CopyWindowToVram(2, 1);
}
2019-03-31 18:59:52 -04:00
return response;
2019-03-30 20:04:30 -04:00
}
2019-03-31 10:33:27 -04:00
2021-10-14 14:10:42 -04:00
s8 DoMysteryGiftYesNo(u8 * textState, u16 * windowId, bool8 yesNoBoxPlacement, const u8 * str)
2019-03-31 10:33:27 -04:00
{
struct WindowTemplate windowTemplate;
s8 input;
switch (*textState)
{
case 0:
StringExpandPlaceholders(gStringVar4, str);
2019-03-31 18:59:52 -04:00
if (yesNoBoxPlacement == 0)
*windowId = AddWindow(&sWindowTemplate_PromptYesOrNo_Width28);
2019-03-31 10:33:27 -04:00
else
2019-03-31 18:59:52 -04:00
*windowId = AddWindow(&sWindowTemplate_PromptYesOrNo_Width20);
2019-03-31 10:33:27 -04:00
FillWindowPixelBuffer(*windowId, 0x11);
2019-03-31 18:59:52 -04:00
AddTextPrinterParameterized4(*windowId, 1, 0, 1, 0, 0, sMG_Ereader_TextColor_2, 0, gStringVar4);
DrawTextBorderOuter(*windowId, 0x001, 0x0F);
2019-03-31 10:33:27 -04:00
CopyWindowToVram(*windowId, 2);
PutWindowTilemap(*windowId);
(*textState)++;
break;
case 1:
2019-03-31 18:59:52 -04:00
windowTemplate = sWindowTemplate_YesNoBox;
if (yesNoBoxPlacement == 0)
2019-03-31 10:33:27 -04:00
windowTemplate.tilemapTop = 9;
else
windowTemplate.tilemapTop = 15;
CreateYesNoMenu(&windowTemplate, 10, 14, 0);
(*textState)++;
break;
case 2:
input = Menu_ProcessInputNoWrapClearOnChoose();
if (input == MENU_B_PRESSED || input == 0 || input == 1)
2019-03-31 10:33:27 -04:00
{
*textState = 0;
rbox_fill_rectangle(*windowId);
ClearWindowTilemap(*windowId);
CopyWindowToVram(*windowId, 1);
RemoveWindow(*windowId);
return input;
}
break;
case (u8)MENU_B_PRESSED:
2019-03-31 10:33:27 -04:00
*textState = 0;
rbox_fill_rectangle(*windowId);
ClearWindowTilemap(*windowId);
CopyWindowToVram(*windowId, 1);
RemoveWindow(*windowId);
return MENU_B_PRESSED;
2019-03-31 10:33:27 -04:00
}
return MENU_NOTHING_CHOSEN;
2019-03-31 10:33:27 -04:00
}
2019-03-31 11:16:19 -04:00
2019-03-31 18:59:52 -04:00
static s32 HandleMysteryGiftListMenu(u8 * textState, u16 * windowId, bool32 cannotToss, bool32 cannotSend)
2019-03-31 11:16:19 -04:00
{
struct WindowTemplate windowTemplate;
s32 input;
switch (*textState)
{
case 0:
2021-10-14 14:10:42 -04:00
if (!cannotToss)
2019-03-31 11:16:19 -04:00
StringExpandPlaceholders(gStringVar4, gText_WhatToDoWithCards);
else
StringExpandPlaceholders(gStringVar4, gText_WhatToDoWithNews);
2019-03-31 18:59:52 -04:00
*windowId = AddWindow(&sMysteryGiftMenuWindowTemplate);
2019-03-31 11:16:19 -04:00
FillWindowPixelBuffer(*windowId, 0x11);
2019-03-31 18:59:52 -04:00
AddTextPrinterParameterized4(*windowId, 1, 0, 1, 0, 0, sMG_Ereader_TextColor_2, 0, gStringVar4);
DrawTextBorderOuter(*windowId, 0x001, 0x0F);
2019-03-31 11:16:19 -04:00
CopyWindowToVram(*windowId, 2);
PutWindowTilemap(*windowId);
(*textState)++;
break;
case 1:
2019-03-31 18:59:52 -04:00
windowTemplate = sWindowTemplate_YesNoBox;
if (cannotSend)
2019-03-31 11:16:19 -04:00
{
2021-10-14 14:10:42 -04:00
if (!cannotToss)
2019-03-31 18:59:52 -04:00
input = DoMysteryGiftListMenu(&sWindowTemplate_7by6, &sListMenu_ReceiveToss, 1, 0x00A, 0xE0);
2019-03-31 11:16:19 -04:00
else
2019-03-31 18:59:52 -04:00
input = DoMysteryGiftListMenu(&sWindowTemplate_7by4, &sListMenu_Receive, 1, 0x00A, 0xE0);
2019-03-31 11:16:19 -04:00
}
else
{
2021-10-14 14:10:42 -04:00
if (!cannotToss)
2019-03-31 18:59:52 -04:00
input = DoMysteryGiftListMenu(&sWindowTemplate_7by8, &sListMenu_ReceiveSendToss, 1, 0x00A, 0xE0);
2019-03-31 11:16:19 -04:00
else
2019-03-31 18:59:52 -04:00
input = DoMysteryGiftListMenu(&sWindowTemplate_7by6, &sListMenu_ReceiveSend, 1, 0x00A, 0xE0);
2019-03-31 11:16:19 -04:00
}
2021-10-14 14:10:42 -04:00
if (input != LIST_NOTHING_CHOSEN)
2019-03-31 11:16:19 -04:00
{
*textState = 0;
rbox_fill_rectangle(*windowId);
ClearWindowTilemap(*windowId);
CopyWindowToVram(*windowId, 1);
RemoveWindow(*windowId);
return input;
}
break;
case 0xFF:
*textState = 0;
rbox_fill_rectangle(*windowId);
ClearWindowTilemap(*windowId);
CopyWindowToVram(*windowId, 1);
RemoveWindow(*windowId);
2021-10-14 14:10:42 -04:00
return LIST_CANCEL;
2019-03-31 11:16:19 -04:00
}
2021-10-14 14:10:42 -04:00
return LIST_NOTHING_CHOSEN;
2019-03-31 11:16:19 -04:00
}
2021-10-14 14:10:42 -04:00
static bool32 ValidateCardOrNews(bool32 isWonderNews)
2019-03-31 11:16:19 -04:00
{
2021-10-14 14:10:42 -04:00
if (!isWonderNews)
2019-03-31 18:59:52 -04:00
return ValidateReceivedWonderCard();
2019-03-31 11:16:19 -04:00
else
2019-03-31 18:59:52 -04:00
return ValidateReceivedWonderNews();
2019-03-31 11:16:19 -04:00
}
2021-10-14 14:10:42 -04:00
static bool32 HandleLoadWonderCardOrNews(u8 * state, bool32 isWonderNews)
2019-03-31 11:16:19 -04:00
{
switch (*state)
{
case 0:
2021-10-14 14:10:42 -04:00
if (!isWonderNews)
2021-10-14 12:12:16 -04:00
WonderCard_Init(GetSavedWonderCard(), sav1_get_mevent_buffer_2());
2019-03-31 11:16:19 -04:00
else
2021-10-14 12:12:16 -04:00
WonderNews_Init(GetSavedWonderNews());
2019-03-31 11:16:19 -04:00
(*state)++;
2019-03-31 12:27:36 -04:00
break;
2019-03-31 11:16:19 -04:00
case 1:
2021-10-14 14:10:42 -04:00
if (!isWonderNews)
2019-03-31 11:16:19 -04:00
{
2021-10-14 12:12:16 -04:00
if (!WonderCard_Enter())
2021-05-09 01:03:39 -04:00
return FALSE;
2019-03-31 11:16:19 -04:00
}
else
{
2021-10-14 12:12:16 -04:00
if (!WonderNews_Enter())
2021-05-09 01:03:39 -04:00
return FALSE;
2019-03-31 12:27:36 -04:00
}
*state = 0;
return TRUE;
}
return FALSE;
}
2021-10-14 14:10:42 -04:00
static bool32 DestroyNewsOrCard(bool32 isWonderNews)
2019-03-31 12:27:36 -04:00
{
2021-10-14 14:10:42 -04:00
if (!isWonderNews)
2019-03-31 18:59:52 -04:00
DestroyWonderCard();
2019-03-31 12:27:36 -04:00
else
2019-03-31 18:59:52 -04:00
DestroyWonderNews();
2019-03-31 12:27:36 -04:00
return TRUE;
}
2021-10-14 14:10:42 -04:00
static bool32 ExitWonderCardOrNews(bool32 isWonderNews, bool32 arg1)
2019-03-31 12:27:36 -04:00
{
2021-10-14 14:10:42 -04:00
if (!isWonderNews)
2019-03-31 12:27:36 -04:00
{
2021-10-14 14:10:42 -04:00
if (WonderCard_Exit(arg1))
2019-03-31 12:27:36 -04:00
{
2021-10-14 12:12:16 -04:00
WonderCard_Destroy();
2019-03-31 12:27:36 -04:00
return TRUE;
}
else
{
return FALSE;
}
}
else
{
2021-10-14 14:10:42 -04:00
if (WonderNews_Exit(arg1))
2019-03-31 12:27:36 -04:00
{
2021-10-14 12:12:16 -04:00
WonderNews_Destroy();
2019-03-31 12:27:36 -04:00
return TRUE;
}
else
{
return FALSE;
}
}
}
2021-10-14 14:10:42 -04:00
static s32 AskDiscardGift(u8 * textState, u16 * windowId, bool32 isWonderNews)
2019-03-31 12:27:36 -04:00
{
2021-10-14 14:10:42 -04:00
if (!isWonderNews)
return DoMysteryGiftYesNo(textState, windowId, TRUE, gText_IfThrowAwayCardEventWontHappen);
2019-03-31 12:27:36 -04:00
else
2021-10-14 14:10:42 -04:00
return DoMysteryGiftYesNo(textState, windowId, TRUE, gText_OkayToDiscardNews);
2019-03-31 12:27:36 -04:00
}
2021-10-14 14:10:42 -04:00
static bool32 PrintThrownAway(u8 * textState, bool32 isWonderNews)
2019-03-31 12:27:36 -04:00
{
2021-10-14 14:10:42 -04:00
if (!isWonderNews)
2019-03-31 18:59:52 -04:00
return MG_PrintTextOnWindow1AndWaitButton(textState, gText_WonderCardThrownAway);
2019-03-31 12:27:36 -04:00
else
2019-03-31 18:59:52 -04:00
return MG_PrintTextOnWindow1AndWaitButton(textState, gText_WonderNewsThrownAway);
2019-03-31 12:27:36 -04:00
}
2019-03-31 18:59:52 -04:00
static bool32 mevent_save_game(u8 * state)
2019-03-31 12:27:36 -04:00
{
switch (*state)
{
case 0:
2019-03-31 18:59:52 -04:00
AddTextPrinterToWindow1(gText_DataWillBeSaved);
2019-03-31 12:27:36 -04:00
(*state)++;
break;
case 1:
2019-11-24 16:58:40 -05:00
TrySavingData(SAVE_NORMAL);
2019-03-31 12:27:36 -04:00
(*state)++;
break;
case 2:
2019-03-31 18:59:52 -04:00
AddTextPrinterToWindow1(gText_SaveCompletedPressA);
2019-03-31 12:27:36 -04:00
(*state)++;
break;
case 3:
2020-09-04 21:11:55 -04:00
if (({JOY_NEW(A_BUTTON | B_BUTTON);}))
2019-03-31 12:27:36 -04:00
{
(*state)++;
2019-03-31 11:16:19 -04:00
}
2019-03-31 12:27:36 -04:00
break;
case 4:
2019-03-31 11:16:19 -04:00
*state = 0;
2019-03-31 18:59:52 -04:00
ClearTextWindow();
2019-03-31 11:16:19 -04:00
return TRUE;
}
return FALSE;
2019-03-31 12:27:36 -04:00
}
2019-03-31 12:36:48 -04:00
2021-10-14 14:10:42 -04:00
static const u8 * GetStdMessage(bool32 * receivedMsg, bool8 isWonderNews, bool8 sourceIsFriend, u32 msgId)
2019-03-31 12:36:48 -04:00
{
const u8 * msg = NULL;
2021-10-14 14:10:42 -04:00
*receivedMsg = FALSE;
2019-03-31 12:36:48 -04:00
2019-03-31 18:59:52 -04:00
switch (msgId)
2019-03-31 12:36:48 -04:00
{
case 0:
2021-10-14 14:10:42 -04:00
*receivedMsg = FALSE;
2019-03-31 12:36:48 -04:00
msg = gText_NothingSentOver;
break;
case 1:
2021-10-14 14:10:42 -04:00
*receivedMsg = FALSE;
2019-03-31 12:36:48 -04:00
msg = gText_RecordUploadedViaWireless;
break;
case 2:
2021-10-14 14:10:42 -04:00
*receivedMsg = TRUE;
msg = !sourceIsFriend ? gText_WonderCardReceived : gText_WonderCardReceivedFrom;
2019-03-31 12:36:48 -04:00
break;
case 3:
2021-10-14 14:10:42 -04:00
*receivedMsg = TRUE;
msg = !sourceIsFriend ? gText_WonderNewsReceived : gText_WonderNewsReceivedFrom;
2019-03-31 12:36:48 -04:00
break;
case 4:
2021-10-14 14:10:42 -04:00
*receivedMsg = TRUE;
2019-03-31 12:36:48 -04:00
msg = gText_NewStampReceived;
break;
case 5:
2021-10-14 14:10:42 -04:00
*receivedMsg = FALSE;
2019-03-31 12:36:48 -04:00
msg = gText_AlreadyHadCard;
break;
case 6:
2021-10-14 14:10:42 -04:00
*receivedMsg = FALSE;
2019-03-31 12:36:48 -04:00
msg = gText_AlreadyHadStamp;
break;
case 7:
2021-10-14 14:10:42 -04:00
*receivedMsg = FALSE;
2019-03-31 12:36:48 -04:00
msg = gText_AlreadyHadNews;
break;
case 8:
2021-10-14 14:10:42 -04:00
*receivedMsg = FALSE;
2019-03-31 12:36:48 -04:00
msg = gText_NoMoreRoomForStamps;
break;
case 9:
2021-10-14 14:10:42 -04:00
*receivedMsg = FALSE;
2019-03-31 12:36:48 -04:00
msg = gText_CommunicationCanceled;
break;
case 10:
2021-10-14 14:10:42 -04:00
*receivedMsg = FALSE;
msg = !isWonderNews ? gText_CantAcceptCardFromTrainer : gText_CantAcceptNewsFromTrainer;
2019-03-31 12:36:48 -04:00
break;
case 11:
2021-10-14 14:10:42 -04:00
*receivedMsg = FALSE;
2019-03-31 12:36:48 -04:00
msg = gText_CommunicationError;
break;
case 12:
2021-10-14 14:10:42 -04:00
*receivedMsg = TRUE;
2019-03-31 12:36:48 -04:00
msg = gText_NewTrainerReceived;
break;
case 13:
2021-10-14 14:10:42 -04:00
*receivedMsg = TRUE;
2019-03-31 12:36:48 -04:00
break;
case 14:
2021-10-14 14:10:42 -04:00
*receivedMsg = FALSE;
2019-03-31 12:36:48 -04:00
break;
}
return msg;
}
2019-03-31 12:55:27 -04:00
2021-10-14 14:10:42 -04:00
static bool32 PrintSuccessMessage(u8 * state, const u8 * msg, u16 * timer)
2019-03-31 12:55:27 -04:00
{
switch (*state)
{
case 0:
2021-10-14 14:10:42 -04:00
if (msg != NULL)
AddTextPrinterToWindow1(msg);
2020-08-20 18:02:00 -04:00
PlayFanfare(MUS_OBTAIN_ITEM);
2021-10-14 14:10:42 -04:00
*timer = 0;
2019-03-31 12:55:27 -04:00
(*state)++;
break;
case 1:
2021-10-14 14:10:42 -04:00
if (++(*timer) > 240)
2019-03-31 12:55:27 -04:00
(*state)++;
break;
case 2:
if (IsFanfareTaskInactive())
{
*state = 0;
2019-03-31 18:59:52 -04:00
ClearTextWindow();
2019-03-31 12:55:27 -04:00
return TRUE;
}
break;
}
return FALSE;
}
2019-03-31 18:59:52 -04:00
static const u8 * mevent_message_stamp_card_etc_send_status(u32 * a0, u8 unused, u32 msgId)
2019-03-31 12:55:27 -04:00
{
const u8 * result = gText_CommunicationError;
*a0 = 0;
2019-03-31 18:59:52 -04:00
switch (msgId)
2019-03-31 12:55:27 -04:00
{
case 0:
result = gText_NothingSentOver;
break;
case 1:
result = gText_RecordUploadedViaWireless;
break;
case 2:
result = gText_WonderCardSentTo;
*a0 = 1;
break;
case 3:
result = gText_WonderNewsSentTo;
*a0 = 1;
break;
case 4:
result = gText_StampSentTo;
break;
case 5:
result = gText_OtherTrainerHasCard;
break;
case 6:
result = gText_OtherTrainerHasStamp;
break;
case 7:
result = gText_OtherTrainerHasNews;
break;
case 8:
result = gText_NoMoreRoomForStamps;
break;
case 9:
result = gText_OtherTrainerCanceled;
break;
case 10:
result = gText_CantSendGiftToTrainer;
break;
case 11:
result = gText_CommunicationError;
break;
case 12:
result = gText_GiftSentTo;
break;
case 13:
result = gText_GiftSentTo;
break;
case 14:
result = gText_CantSendGiftToTrainer;
break;
}
return result;
}
2019-03-31 18:59:52 -04:00
static bool32 PrintMGSendStatus(u8 * state, u16 * arg1, u8 arg2, u32 msgId)
2019-03-31 12:55:27 -04:00
{
u32 flag;
2019-03-31 18:59:52 -04:00
const u8 * str = mevent_message_stamp_card_etc_send_status(&flag, arg2, msgId);
2019-03-31 12:55:27 -04:00
if (flag)
2021-10-14 14:10:42 -04:00
return PrintSuccessMessage(state, str, arg1);
2019-03-31 12:55:27 -04:00
else
2019-03-31 18:59:52 -04:00
return MG_PrintTextOnWindow1AndWaitButton(state, str);
2019-03-31 12:55:27 -04:00
}
2021-10-14 14:10:42 -04:00
enum {
MG_STATE_TO_MAIN_MENU,
MG_STATE_MAIN_MENU,
MG_STATE_DONT_HAVE_ANY,
MG_STATE_LINK_PROMPT,
MG_STATE_LINK_PROMPT_INPUT,
MG_STATE_LINK_START,
MG_STATE_LINK_WAIT,
MG_STATE_COMMUNICATING,
MG_STATE_COMMUNICATE,
MG_STATE_9,
MG_STATE_10,
MG_STATE_11,
MG_STATE_12,
MG_STATE_LINK_COMPLETE_WAIT,
MG_STATE_LINK_COMPLETED,
MG_STATE_LINK_RESULT_MSG,
MG_STATE_LINK_ERROR_1,
MG_STATE_SAVE_LOAD_GIFT,
MG_STATE_LOAD_GIFT,
MG_STATE_UNUSED,
MG_STATE_HANDLE_GIFT_INPUT,
MG_STATE_HANDLE_GIFT_SELECT,
MG_STATE_ASK_TOSS,
MG_STATE_ASK_TOSS_UNRECEIVED,
MG_STATE_TOSS,
MG_STATE_TOSS_SAVE,
MG_STATE_TOSSED,
MG_STATE_GIFT_INPUT_EXIT,
MG_STATE_RECEIVE,
MG_STATE_SEND,
MG_STATE_SEND_WAIT,
MG_STATE_SEND_START,
MG_STATE_SENDING,
MG_STATE_SEND_FINISH,
MG_STATE_SEND_WAIT_END,
MG_STATE_SEND_END,
MG_STATE_LINK_ERROR_2,
MG_STATE_EXIT,
};
static void CreateMysteryGiftTask(void)
2019-03-31 12:55:27 -04:00
{
2021-10-14 14:10:42 -04:00
u8 taskId = CreateTask(Task_MysteryGift, 0);
2019-03-31 12:55:27 -04:00
struct MysteryGiftTaskData * data = (void *)gTasks[taskId].data;
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_TO_MAIN_MENU;
2019-03-31 18:59:52 -04:00
data->textState = 0;
2019-03-31 12:55:27 -04:00
data->unkA = 0;
data->unkB = 0;
2021-10-14 14:10:42 -04:00
data->isWonderNews = 0;
data->sourceIsFriend = 0;
2019-03-31 18:59:52 -04:00
data->curPromptWindowId = 0;
2019-03-31 12:55:27 -04:00
data->unk2 = 0;
data->unk4 = 0;
data->unk6 = 0;
2019-03-31 18:59:52 -04:00
data->prevPromptWindowId = 0;
data->buffer = AllocZeroed(0x40);
2019-03-31 15:50:25 -04:00
}
2021-10-14 14:10:42 -04:00
static void Task_MysteryGift(u8 taskId)
2019-03-31 15:50:25 -04:00
{
2020-05-20 21:00:21 -07:00
struct MysteryGiftTaskData *data = (void *)gTasks[taskId].data;
2021-10-14 14:10:42 -04:00
u32 receivedMsg, input;
const u8 *msg;
2019-03-31 15:50:25 -04:00
2019-03-31 18:59:52 -04:00
switch (data->state)
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
case MG_STATE_TO_MAIN_MENU:
data->state = MG_STATE_MAIN_MENU;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_MAIN_MENU:
// Main Mystery Gift menu, player can select Wonder Cards or News (or exit)
2019-03-31 18:59:52 -04:00
switch (MysteryGift_HandleThreeOptionMenu(&data->textState, &data->curPromptWindowId, FALSE))
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
case 0: // "Wonder Cards"
data->isWonderNews = FALSE;
2019-03-31 18:59:52 -04:00
if (ValidateReceivedWonderCard() == TRUE)
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LOAD_GIFT;
2019-03-31 15:50:25 -04:00
else
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_DONT_HAVE_ANY;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case 1: // "Wonder News"
data->isWonderNews = TRUE;
2019-03-31 18:59:52 -04:00
if (ValidateReceivedWonderNews() == TRUE)
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LOAD_GIFT;
2019-03-31 15:50:25 -04:00
else
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_DONT_HAVE_ANY;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case LIST_CANCEL:
data->state = MG_STATE_EXIT;
2019-03-31 15:50:25 -04:00
break;
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_DONT_HAVE_ANY:
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
// Player doesn't have any Wonder Card/News
// Start prompt to ask where to read one from
if (!data->isWonderNews)
2019-03-31 15:50:25 -04:00
{
2019-03-31 18:59:52 -04:00
if (MG_PrintTextOnWindow1AndWaitButton(&data->textState, gText_DontHaveCardNewOneInput))
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LINK_PROMPT;
PrintMysteryGiftOrEReaderTopMenu(FALSE, TRUE);
2019-03-31 15:50:25 -04:00
}
}
else
{
2019-03-31 18:59:52 -04:00
if (MG_PrintTextOnWindow1AndWaitButton(&data->textState, gText_DontHaveNewsNewOneInput))
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LINK_PROMPT;
PrintMysteryGiftOrEReaderTopMenu(FALSE, TRUE);
2019-03-31 15:50:25 -04:00
}
}
break;
}
2021-10-14 14:10:42 -04:00
case MG_STATE_LINK_PROMPT:
if (!data->isWonderNews)
2019-03-31 18:59:52 -04:00
AddTextPrinterToWindow1(gText_WhereShouldCardBeAccessed);
2019-03-31 15:50:25 -04:00
else
2019-03-31 18:59:52 -04:00
AddTextPrinterToWindow1(gText_WhereShouldNewsBeAccessed);
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LINK_PROMPT_INPUT;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_LINK_PROMPT_INPUT:
// Choose where to access the Wonder Card/News from
2019-03-31 18:59:52 -04:00
switch (MysteryGift_HandleThreeOptionMenu(&data->textState, &data->curPromptWindowId, TRUE))
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
case 0: // "Wireless Communication"
2019-03-31 18:59:52 -04:00
ClearTextWindow();
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LINK_START;
data->sourceIsFriend = FALSE;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case 1: // "Friend"
2019-03-31 18:59:52 -04:00
ClearTextWindow();
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LINK_START;
data->sourceIsFriend = TRUE;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case LIST_CANCEL:
2019-03-31 18:59:52 -04:00
ClearTextWindow();
2021-10-14 14:10:42 -04:00
if (ValidateCardOrNews(data->isWonderNews))
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LOAD_GIFT;
2019-03-31 15:50:25 -04:00
}
else
{
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_TO_MAIN_MENU;
PrintMysteryGiftOrEReaderTopMenu(FALSE, FALSE);
2019-03-31 15:50:25 -04:00
}
break;
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_LINK_START:
2020-05-20 21:00:21 -07:00
*gStringVar1 = EOS;
*gStringVar2 = EOS;
*gStringVar3 = EOS;
2021-10-14 14:10:42 -04:00
switch (data->isWonderNews)
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
case FALSE:
if (data->sourceIsFriend == TRUE)
CreateTask_LinkMysteryGiftWithFriend(ACTIVITY_WONDER_CARD);
else if (data->sourceIsFriend == FALSE)
CreateTask_LinkMysteryGiftOverWireless(ACTIVITY_WONDER_CARD);
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case TRUE:
if (data->sourceIsFriend == TRUE)
CreateTask_LinkMysteryGiftWithFriend(ACTIVITY_WONDER_NEWS);
else if (data->sourceIsFriend == FALSE)
CreateTask_LinkMysteryGiftOverWireless(ACTIVITY_WONDER_NEWS);
2019-03-31 15:50:25 -04:00
break;
}
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LINK_WAIT;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_LINK_WAIT:
2019-03-31 15:50:25 -04:00
if (gReceivedRemoteLinkPlayers != 0)
{
2019-03-31 18:59:52 -04:00
ClearScreenInBg0(TRUE);
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_COMMUNICATING;
mevent_client_do_init(data->isWonderNews);
2019-03-31 15:50:25 -04:00
}
2020-06-08 18:16:57 -04:00
else if (gSpecialVar_Result == LINKUP_FAILED)
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
// Link failed, return to link start menu
2019-03-31 18:59:52 -04:00
ClearScreenInBg0(TRUE);
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LINK_PROMPT;
2019-03-31 15:50:25 -04:00
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_COMMUNICATING:
2019-03-31 18:59:52 -04:00
AddTextPrinterToWindow1(gText_Communicating);
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_COMMUNICATE;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_COMMUNICATE:
2019-04-02 14:02:13 -04:00
switch (mevent_client_do_exec(&data->curPromptWindowId))
2019-03-31 15:50:25 -04:00
{
case 6:
2020-08-13 03:09:47 -04:00
Rfu_SetCloseLinkCallback();
2019-03-31 18:59:52 -04:00
data->prevPromptWindowId = data->curPromptWindowId;
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LINK_COMPLETE_WAIT;
2019-03-31 15:50:25 -04:00
break;
case 5:
2019-04-02 14:02:13 -04:00
memcpy(data->buffer, mevent_client_get_buffer(), 0x40);
mevent_client_inc_flag();
2019-03-31 15:50:25 -04:00
break;
case 3:
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_10;
2019-03-31 15:50:25 -04:00
break;
case 2:
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_9;
2019-03-31 15:50:25 -04:00
break;
case 4:
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_11;
2019-03-31 15:50:25 -04:00
StringCopy(gStringVar1, gLinkPlayers[0].name);
break;
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_9:
input = DoMysteryGiftYesNo(&data->textState, &data->curPromptWindowId, FALSE, mevent_client_get_buffer());
switch (input)
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
case 0: // Yes
2019-04-02 14:02:13 -04:00
mevent_client_set_param(0);
mevent_client_inc_flag();
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_COMMUNICATING;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case 1: // No
case MENU_B_PRESSED:
2019-04-02 14:02:13 -04:00
mevent_client_set_param(1);
mevent_client_inc_flag();
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_COMMUNICATING;
2019-03-31 15:50:25 -04:00
break;
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_10:
2019-04-02 14:02:13 -04:00
if (MG_PrintTextOnWindow1AndWaitButton(&data->textState, mevent_client_get_buffer()))
2019-03-31 15:50:25 -04:00
{
2019-04-02 14:02:13 -04:00
mevent_client_inc_flag();
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_COMMUNICATING;
2019-03-31 15:50:25 -04:00
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_11:
input = DoMysteryGiftYesNo(&data->textState, &data->curPromptWindowId, FALSE, gText_ThrowAwayWonderCard);
switch (input)
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
case 0: // Yes
2019-03-31 18:59:52 -04:00
if (CheckReceivedGiftFromWonderCard() == TRUE)
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_12;
2019-03-31 15:50:25 -04:00
}
else
{
2019-04-02 14:02:13 -04:00
mevent_client_set_param(0);
mevent_client_inc_flag();
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_COMMUNICATING;
2019-03-31 15:50:25 -04:00
}
break;
2021-10-14 14:10:42 -04:00
case 1: // No
case MENU_B_PRESSED:
2019-04-02 14:02:13 -04:00
mevent_client_set_param(1);
mevent_client_inc_flag();
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_COMMUNICATING;
2019-03-31 15:50:25 -04:00
break;
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_12:
input = DoMysteryGiftYesNo(&data->textState, &data->curPromptWindowId, FALSE, gText_HaventReceivedCardsGift);
switch (input)
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
case 0: // Yes
2019-04-02 14:02:13 -04:00
mevent_client_set_param(0);
mevent_client_inc_flag();
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_COMMUNICATING;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case 1: // No
case MENU_B_PRESSED:
2019-04-02 14:02:13 -04:00
mevent_client_set_param(1);
mevent_client_inc_flag();
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_COMMUNICATING;
2019-03-31 15:50:25 -04:00
break;
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_LINK_COMPLETE_WAIT:
2019-03-31 15:50:25 -04:00
if (gReceivedRemoteLinkPlayers == 0)
{
2019-03-31 18:59:52 -04:00
DestroyWirelessStatusIndicatorSprite();
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LINK_COMPLETED;
2019-03-31 15:50:25 -04:00
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_LINK_COMPLETED:
2019-03-31 18:59:52 -04:00
if (PrintStringAndWait2Seconds(&data->textState, gText_CommunicationCompleted))
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
if (data->sourceIsFriend == TRUE)
2019-03-31 15:50:25 -04:00
StringCopy(gStringVar1, gLinkPlayers[0].name);
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LINK_RESULT_MSG;
2019-03-31 15:50:25 -04:00
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_LINK_RESULT_MSG:
msg = GetStdMessage(&receivedMsg, data->isWonderNews, data->sourceIsFriend, data->prevPromptWindowId);
if (msg == NULL)
msg = data->buffer;
if (receivedMsg)
input = PrintSuccessMessage(&data->textState, msg, &data->curPromptWindowId);
2019-03-31 15:50:25 -04:00
else
2021-10-14 14:10:42 -04:00
input = MG_PrintTextOnWindow1AndWaitButton(&data->textState, msg);
// input var re-used, here it is TRUE if the message is finished
if (input)
2019-03-31 15:50:25 -04:00
{
2019-03-31 18:59:52 -04:00
if (data->prevPromptWindowId == 3)
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
if (data->sourceIsFriend == TRUE)
2019-03-31 18:59:52 -04:00
GenerateRandomNews(1);
2019-03-31 15:50:25 -04:00
else
2019-03-31 18:59:52 -04:00
GenerateRandomNews(2);
2019-03-31 15:50:25 -04:00
}
2021-10-14 14:10:42 -04:00
if (!receivedMsg)
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
// Did not receive card/news, return to main menu
data->state = MG_STATE_TO_MAIN_MENU;
PrintMysteryGiftOrEReaderTopMenu(FALSE, FALSE);
2019-03-31 15:50:25 -04:00
}
else
{
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_SAVE_LOAD_GIFT;
2019-03-31 15:50:25 -04:00
}
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_SAVE_LOAD_GIFT:
2019-03-31 18:59:52 -04:00
if (mevent_save_game(&data->textState))
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LOAD_GIFT;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_LOAD_GIFT:
if (HandleLoadWonderCardOrNews(&data->textState, data->isWonderNews))
data->state = MG_STATE_HANDLE_GIFT_INPUT;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_HANDLE_GIFT_INPUT:
if (!data->isWonderNews)
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
// Handle Wonder Card input
2021-10-14 12:12:16 -04:00
if (JOY_NEW(A_BUTTON))
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_HANDLE_GIFT_SELECT;
2021-10-14 12:12:16 -04:00
if (JOY_NEW(B_BUTTON))
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_GIFT_INPUT_EXIT;
2019-03-31 15:50:25 -04:00
}
else
{
2021-10-14 12:12:16 -04:00
switch (WonderNews_GetInput(gMain.newKeys))
2019-03-31 15:50:25 -04:00
{
2021-10-14 12:12:16 -04:00
case NEWS_INPUT_A:
WonderNews_RemoveScrollIndicatorArrowPair();
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_HANDLE_GIFT_SELECT;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 12:12:16 -04:00
case NEWS_INPUT_B:
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_GIFT_INPUT_EXIT;
2019-03-31 15:50:25 -04:00
break;
}
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_HANDLE_GIFT_SELECT:
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
// A Wonder Card/News has been selected, handle its menu
2019-03-31 15:50:25 -04:00
u32 result;
2021-10-14 14:10:42 -04:00
if (!data->isWonderNews)
2019-03-31 15:50:25 -04:00
{
2019-03-31 18:59:52 -04:00
if (WonderCard_Test_Unk_08_6())
2021-10-14 14:10:42 -04:00
result = HandleMysteryGiftListMenu(&data->textState, &data->curPromptWindowId, data->isWonderNews, FALSE);
2019-03-31 15:50:25 -04:00
else
2021-10-14 14:10:42 -04:00
result = HandleMysteryGiftListMenu(&data->textState, &data->curPromptWindowId, data->isWonderNews, TRUE);
2019-03-31 15:50:25 -04:00
}
else
{
2019-03-31 18:59:52 -04:00
if (WonderNews_Test_Unk_02())
2021-10-14 14:10:42 -04:00
result = HandleMysteryGiftListMenu(&data->textState, &data->curPromptWindowId, data->isWonderNews, FALSE);
2019-03-31 15:50:25 -04:00
else
2021-10-14 14:10:42 -04:00
result = HandleMysteryGiftListMenu(&data->textState, &data->curPromptWindowId, data->isWonderNews, TRUE);
2019-03-31 15:50:25 -04:00
}
switch (result)
{
2021-10-14 14:10:42 -04:00
case 0: // Receive
data->state = MG_STATE_RECEIVE;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case 1: // Send
data->state = MG_STATE_SEND;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case 2: // Toss
data->state = MG_STATE_ASK_TOSS;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case LIST_CANCEL:
if (data->isWonderNews == TRUE)
2021-10-14 12:12:16 -04:00
WonderNews_AddScrollIndicatorArrowPair();
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_HANDLE_GIFT_INPUT;
2019-03-31 15:50:25 -04:00
break;
}
break;
}
2021-10-14 14:10:42 -04:00
case MG_STATE_ASK_TOSS:
// Player is atempting to discard a Wonder Card/News
switch (AskDiscardGift(&data->textState, &data->curPromptWindowId, data->isWonderNews))
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
case 0: // Yes
if (!data->isWonderNews && CheckReceivedGiftFromWonderCard() == TRUE)
data->state = MG_STATE_ASK_TOSS_UNRECEIVED;
2019-03-31 15:50:25 -04:00
else
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_TOSS;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case 1: // No
case MENU_B_PRESSED:
data->state = MG_STATE_HANDLE_GIFT_SELECT;
2019-03-31 15:50:25 -04:00
break;
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_ASK_TOSS_UNRECEIVED:
// Player is attempting to discard a Wonder Card that they haven't received the gift for
switch ((u32)DoMysteryGiftYesNo(&data->textState, &data->curPromptWindowId, TRUE, gText_HaventReceivedGiftOkayToDiscard))
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
case 0: // Yes
data->state = MG_STATE_TOSS;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case 1: // No
case MENU_B_PRESSED:
data->state = MG_STATE_HANDLE_GIFT_SELECT;
2019-03-31 15:50:25 -04:00
break;
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_TOSS:
if (ExitWonderCardOrNews(data->isWonderNews, 1))
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
DestroyNewsOrCard(data->isWonderNews);
data->state = MG_STATE_TOSS_SAVE;
2019-03-31 15:50:25 -04:00
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_TOSS_SAVE:
2019-03-31 18:59:52 -04:00
if (mevent_save_game(&data->textState))
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_TOSSED;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_TOSSED:
if (PrintThrownAway(&data->textState, data->isWonderNews))
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_TO_MAIN_MENU;
PrintMysteryGiftOrEReaderTopMenu(FALSE, FALSE);
2019-03-31 15:50:25 -04:00
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_GIFT_INPUT_EXIT:
if (ExitWonderCardOrNews(data->isWonderNews, 0))
data->state = MG_STATE_TO_MAIN_MENU;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_RECEIVE:
if (ExitWonderCardOrNews(data->isWonderNews, 1))
data->state = MG_STATE_LINK_PROMPT;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_SEND:
if (ExitWonderCardOrNews(data->isWonderNews, 1))
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
switch (data->isWonderNews)
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
case FALSE:
CreateTask_SendMysteryGift(ACTIVITY_WONDER_CARD);
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case TRUE:
CreateTask_SendMysteryGift(ACTIVITY_WONDER_NEWS);
2019-03-31 15:50:25 -04:00
break;
}
2021-10-14 14:10:42 -04:00
data->sourceIsFriend = TRUE;
data->state = MG_STATE_SEND_WAIT;
2019-03-31 15:50:25 -04:00
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_SEND_WAIT:
2019-03-31 15:50:25 -04:00
if (gReceivedRemoteLinkPlayers != 0)
{
2019-03-31 18:59:52 -04:00
ClearScreenInBg0(1);
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_SEND_START;
2019-03-31 15:50:25 -04:00
}
2020-06-08 18:16:57 -04:00
else if (gSpecialVar_Result == LINKUP_FAILED)
2019-03-31 15:50:25 -04:00
{
2019-03-31 18:59:52 -04:00
ClearScreenInBg0(1);
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_LOAD_GIFT;
2019-03-31 15:50:25 -04:00
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_SEND_START:
2020-05-20 21:00:21 -07:00
*gStringVar1 = EOS;
*gStringVar2 = EOS;
*gStringVar3 = EOS;
2021-10-14 14:10:42 -04:00
if (!data->isWonderNews)
2019-03-31 15:50:25 -04:00
{
2019-03-31 18:59:52 -04:00
AddTextPrinterToWindow1(gText_SendingWonderCard);
2019-03-31 15:50:25 -04:00
mevent_srv_new_wcard();
}
else
{
2019-03-31 18:59:52 -04:00
AddTextPrinterToWindow1(gText_SendingWonderNews);
2019-03-31 15:50:25 -04:00
mevent_srv_init_wnews();
}
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_SENDING;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_SENDING:
2019-03-31 18:59:52 -04:00
if (mevent_srv_common_do_exec(&data->curPromptWindowId) == 3)
2019-03-31 15:50:25 -04:00
{
2019-03-31 18:59:52 -04:00
data->prevPromptWindowId = data->curPromptWindowId;
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_SEND_FINISH;
2019-03-31 15:50:25 -04:00
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_SEND_FINISH:
2020-08-13 03:09:47 -04:00
Rfu_SetCloseLinkCallback();
2019-03-31 15:50:25 -04:00
StringCopy(gStringVar1, gLinkPlayers[1].name);
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_SEND_WAIT_END;
2019-03-31 15:50:25 -04:00
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_SEND_WAIT_END:
2019-03-31 15:50:25 -04:00
if (gReceivedRemoteLinkPlayers == 0)
{
2019-03-31 18:59:52 -04:00
DestroyWirelessStatusIndicatorSprite();
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_SEND_END;
2019-03-31 15:50:25 -04:00
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_SEND_END:
if (PrintMGSendStatus(&data->textState, &data->curPromptWindowId, data->sourceIsFriend, data->prevPromptWindowId))
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
if (data->sourceIsFriend == TRUE && data->prevPromptWindowId == 3)
2019-03-31 15:50:25 -04:00
{
2019-03-31 18:59:52 -04:00
GenerateRandomNews(3);
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_SAVE_LOAD_GIFT;
2019-03-31 15:50:25 -04:00
}
else
{
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_TO_MAIN_MENU;
PrintMysteryGiftOrEReaderTopMenu(FALSE, FALSE);
2019-03-31 15:50:25 -04:00
}
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_LINK_ERROR_1:
case MG_STATE_LINK_ERROR_2:
2019-03-31 18:59:52 -04:00
if (MG_PrintTextOnWindow1AndWaitButton(&data->textState, gText_CommunicationError))
2019-03-31 15:50:25 -04:00
{
2021-10-14 14:10:42 -04:00
data->state = MG_STATE_TO_MAIN_MENU;
PrintMysteryGiftOrEReaderTopMenu(FALSE, FALSE);
2019-03-31 15:50:25 -04:00
}
break;
2021-10-14 14:10:42 -04:00
case MG_STATE_EXIT:
2019-03-31 15:50:25 -04:00
CloseLink();
2019-03-31 18:59:52 -04:00
Free(data->buffer);
2019-03-31 15:50:25 -04:00
DestroyTask(taskId);
2019-03-31 18:59:52 -04:00
SetMainCallback2(MainCB_FreeAllBuffersAndReturnToInitTitleScreen);
2019-03-31 15:50:25 -04:00
break;
}
2019-03-31 12:55:27 -04:00
}
2019-03-31 18:59:52 -04:00
u16 GetMysteryGiftBaseBlock(void)
{
return 0x1A9;
}
void bgid_upload_textbox_1(u8 bgId)
{
DecompressAndLoadBgGfxUsingHeap(bgId, gUnkTextboxBorderGfx, 0x100, 0, 0);
}