summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/CMakeLists.txt2
-rw-r--r--src/Makefile.am2
-rw-r--r--src/actions/windows.cpp7
-rw-r--r--src/actions/windows.h1
-rw-r--r--src/game.cpp3
-rw-r--r--src/gui/models/extendednamesmodel.h3
-rw-r--r--src/gui/windowmenu.cpp4
-rw-r--r--src/gui/windows/mailwindow.cpp101
-rw-r--r--src/gui/windows/mailwindow.h63
-rw-r--r--src/input/inputaction.h1
-rw-r--r--src/input/inputactionmap.h9
11 files changed, 196 insertions, 0 deletions
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
index 3033074da..30d91da55 100644
--- a/src/CMakeLists.txt
+++ b/src/CMakeLists.txt
@@ -383,6 +383,8 @@ SET(SRCS
gui/windows/killstats.h
gui/windows/logindialog.cpp
gui/windows/logindialog.h
+ gui/windows/mailwindow.cpp
+ gui/windows/mailwindow.h
gui/windows/minimap.cpp
gui/windows/minimap.h
gui/windows/ministatuswindow.cpp
diff --git a/src/Makefile.am b/src/Makefile.am
index 8f6f457e7..997f3ad15 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -521,6 +521,8 @@ manaplus_SOURCES += gui/widgets/avatarlistbox.cpp \
gui/windows/killstats.h \
gui/windows/logindialog.cpp \
gui/windows/logindialog.h \
+ gui/windows/mailwindow.cpp \
+ gui/windows/mailwindow.h \
gui/windows/minimap.cpp \
gui/windows/minimap.h \
gui/windows/ministatuswindow.cpp \
diff --git a/src/actions/windows.cpp b/src/actions/windows.cpp
index 4008245fa..168409366 100644
--- a/src/actions/windows.cpp
+++ b/src/actions/windows.cpp
@@ -44,6 +44,7 @@
#include "gui/windows/helpwindow.h"
#include "gui/windows/inventorywindow.h"
#include "gui/windows/killstats.h"
+#include "gui/windows/mailwindow.h"
#include "gui/windows/minimap.h"
#include "gui/windows/outfitwindow.h"
#include "gui/windows/setupwindow.h"
@@ -332,4 +333,10 @@ impHandler0(quickWindowShow)
return false;
}
+impHandler0(mailWindowShow)
+{
+ showHideWindow(mailWindow);
+ return true;
+}
+
} // namespace Actions
diff --git a/src/actions/windows.h b/src/actions/windows.h
index 59ffc502e..01727055c 100644
--- a/src/actions/windows.h
+++ b/src/actions/windows.h
@@ -54,6 +54,7 @@ namespace Actions
decHandler(bankWindowShow);
decHandler(cartWindowShow);
decHandler(quickWindowShow);
+ decHandler(mailWindowShow);
} // namespace Actions
#undef decHandler
diff --git a/src/game.cpp b/src/game.cpp
index 921c69cc3..2693cec1d 100644
--- a/src/game.cpp
+++ b/src/game.cpp
@@ -64,6 +64,7 @@
#ifdef EATHENA_SUPPORT
#include "gui/windows/bankwindow.h"
+#include "gui/windows/mailwindow.h"
#endif
#include "gui/windows/botcheckerwindow.h"
#include "gui/windows/chatwindow.h"
@@ -240,6 +241,7 @@ static void createGuiWindows()
#ifdef EATHENA_SUPPORT
bankWindow = new BankWindow;
+ mailWindow = new MailWindow;
#endif
botCheckerWindow = new BotCheckerWindow;
whoIsOnline = new WhoIsOnline;
@@ -351,6 +353,7 @@ static void destroyGuiWindows()
delete2(spellShortcutWindow);
#ifdef EATHENA_SUPPORT
delete2(bankWindow);
+ delete2(mailWindow);
#endif
delete2(botCheckerWindow);
delete2(questsWindow);
diff --git a/src/gui/models/extendednamesmodel.h b/src/gui/models/extendednamesmodel.h
index 76f30bf8f..dc0ee770d 100644
--- a/src/gui/models/extendednamesmodel.h
+++ b/src/gui/models/extendednamesmodel.h
@@ -49,6 +49,9 @@ class ExtendedNamesModel notfinal : public ExtendedListModel
size_t size() A_WARN_UNUSED
{ return mNames.size(); }
+ void add(const std::string &str)
+ { mNames.push_back(str); }
+
void clear();
protected:
diff --git a/src/gui/windowmenu.cpp b/src/gui/windowmenu.cpp
index 7fc8be84c..9a48fec7c 100644
--- a/src/gui/windowmenu.cpp
+++ b/src/gui/windowmenu.cpp
@@ -148,6 +148,10 @@ WindowMenu::WindowMenu(const Widget2 *const widget) :
addButton(N_("BA"),
// TRANSLATORS: full button name
_("Bank"), x, h, InputAction::WINDOW_BANK, false);
+ // TRANSLATORS: short button name for mail window.
+ addButton(N_("MA"),
+ // TRANSLATORS: full button name
+ _("Mail"), x, h, InputAction::WINDOW_MAIL, false),
// TRANSLATORS: short button name for debug window.
addButton(N_("DBG"),
// TRANSLATORS: full button name
diff --git a/src/gui/windows/mailwindow.cpp b/src/gui/windows/mailwindow.cpp
new file mode 100644
index 000000000..774ea655c
--- /dev/null
+++ b/src/gui/windows/mailwindow.cpp
@@ -0,0 +1,101 @@
+/*
+ * The ManaPlus Client
+ * Copyright (C) 2011-2015 The ManaPlus Developers
+ *
+ * This file is part of The ManaPlus Client.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "gui/windows/mailwindow.h"
+
+#include "net/mailhandler.h"
+
+#include "gui/models/extendednamesmodel.h"
+
+#include "gui/windows/setupwindow.h"
+
+#include "gui/widgets/button.h"
+#include "gui/widgets/containerplacer.h"
+#include "gui/widgets/extendedlistbox.h"
+#include "gui/widgets/label.h"
+#include "gui/widgets/layout.h"
+#include "gui/widgets/layouttype.h"
+
+#include "utils/gettext.h"
+#include "utils/stringutils.h"
+
+#include "debug.h"
+
+MailWindow *mailWindow = nullptr;
+
+MailWindow::MailWindow() :
+ // TRANSLATORS: mail window name
+ Window(_("Mail"), false, nullptr, "mail.xml"),
+ ActionListener(),
+ mMailModel(new ExtendedNamesModel),
+ mListBox(new ExtendedListBox(this, mMailModel, "extendedlistbox.xml")),
+ // TRANSLATORS: mail window button
+ mRefreshButton(new Button(this, _("Refresh"), "refresh", this)),
+ // TRANSLATORS: mail window button
+ mNewButton(new Button(this, _("New"), "new", this)),
+ // TRANSLATORS: mail window button
+ mDeleteButton(new Button(this, _("Delete"), "delete", this)),
+ // TRANSLATORS: mail window button
+ mOpenButton(new Button(this, _("Open"), "open", this))
+{
+ mListBox->postInit();
+ setWindowName("Mail");
+ setCloseButton(true);
+ setResizable(true);
+ setCloseButton(true);
+ setSaveVisible(true);
+ setStickyButtonLock(true);
+
+ if (setupWindow)
+ setupWindow->registerWindowForReset(this);
+
+ setDefaultSize(387, 307, ImageRect::CENTER);
+ setMinWidth(310);
+ setMinHeight(179);
+ center();
+
+ ContainerPlacer placer;
+ placer = getPlacer(0, 0);
+
+ placer(0, 0, mListBox, 4, 4).setPadding(3);
+ placer(4, 0, mRefreshButton);
+ placer(4, 1, mOpenButton);
+ placer(4, 2, mNewButton);
+ placer(4, 3, mDeleteButton);
+
+ Layout &layout = getLayout();
+ layout.setRowHeight(0, LayoutType::SET);
+
+ loadWindowState();
+ enableVisibleSound(true);
+}
+
+MailWindow::~MailWindow()
+{
+}
+
+void MailWindow::action(const ActionEvent &event)
+{
+ const std::string &eventId = event.getId();
+ if (eventId == "refresh")
+ {
+ mailHandler->refresh();
+ }
+}
diff --git a/src/gui/windows/mailwindow.h b/src/gui/windows/mailwindow.h
new file mode 100644
index 000000000..5bab5bbd7
--- /dev/null
+++ b/src/gui/windows/mailwindow.h
@@ -0,0 +1,63 @@
+/*
+ * The ManaPlus Client
+ * Copyright (C) 2011-2015 The ManaPlus Developers
+ *
+ * This file is part of The ManaPlus Client.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef GUI_WINDOWS_MAILWINDOW_H
+#define GUI_WINDOWS_MAILWINDOW_H
+
+#ifdef EATHENA_SUPPORT
+
+#include "gui/widgets/window.h"
+
+#include "listeners/actionlistener.h"
+
+class Button;
+class ExtendedListBox;
+class ExtendedNamesModel;
+
+/**
+ * A dialog to choose between buying or selling at a shop.
+ *
+ * \ingroup Interface
+ */
+class MailWindow final : public Window,
+ public ActionListener
+{
+ public:
+ MailWindow();
+
+ A_DELETE_COPY(MailWindow)
+
+ ~MailWindow();
+
+ void action(const ActionEvent &event) override final;
+
+ private:
+ ExtendedNamesModel *mMailModel;
+ ExtendedListBox *mListBox;
+ Button *mRefreshButton;
+ Button *mNewButton;
+ Button *mDeleteButton;
+ Button *mOpenButton;
+};
+
+extern MailWindow *mailWindow;
+
+#endif // EATHENA_SUPPORT
+#endif // GUI_WINDOWS_MAILWINDOW_H
diff --git a/src/input/inputaction.h b/src/input/inputaction.h
index d5bad5483..2f4bdcb3c 100644
--- a/src/input/inputaction.h
+++ b/src/input/inputaction.h
@@ -595,6 +595,7 @@ namespace InputAction
JOIN_ROOM,
LEAVE_ROOM,
WINDOW_QUICK_SETTINGS,
+ WINDOW_MAIL,
TOTAL
};
} // namespace InputAction
diff --git a/src/input/inputactionmap.h b/src/input/inputactionmap.h
index 54a15e806..edd75851a 100644
--- a/src/input/inputactionmap.h
+++ b/src/input/inputactionmap.h
@@ -4460,6 +4460,15 @@ static const InputActionData inputActionData[InputAction::TOTAL] = {
InputCondition::GAME | InputCondition::NOTARGET,
"yellowbar|quickoptions",
false},
+ {"keyWindowMail",
+ emptyKey,
+ emptyKey,
+ Input::GRP_DEFAULT | Input::GRP_GUI,
+ &Actions::mailWindowShow,
+ InputAction::NO_VALUE, 50,
+ InputCondition::GAME | InputCondition::NOTARGET,
+ "mailwindow|mail",
+ false},
};
#undef defaultAction