diff options
-rw-r--r-- | src/CMakeLists.txt | 2 | ||||
-rw-r--r-- | src/Makefile.am | 2 | ||||
-rw-r--r-- | src/gui/windows/serverdialog.cpp | 31 | ||||
-rw-r--r-- | src/gui/windows/serverdialog.h | 1 | ||||
-rw-r--r-- | src/gui/windows/serverinfowindow.cpp | 106 | ||||
-rw-r--r-- | src/gui/windows/serverinfowindow.h | 63 |
6 files changed, 196 insertions, 9 deletions
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 47cbd4f76..8b3908a9b 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -428,6 +428,8 @@ SET(SRCS gui/widgets/selldialog.h gui/windows/serverdialog.cpp gui/windows/serverdialog.h + gui/windows/serverinfowindow.cpp + gui/windows/serverinfowindow.h gui/windows/setupwindow.cpp gui/windows/setupwindow.h gui/widgets/tabs/setup_audio.cpp diff --git a/src/Makefile.am b/src/Makefile.am index 1f9f1cc78..c4767ac47 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -1216,6 +1216,8 @@ SRC = ${BASE_SRC} \ gui/windows/setupwindow.h \ gui/windows/serverdialog.cpp \ gui/windows/serverdialog.h \ + gui/windows/serverinfowindow.cpp \ + gui/windows/serverinfowindow.h \ gui/windows/quitdialog.cpp \ gui/windows/quitdialog.h \ gui/windows/questswindow.cpp \ diff --git a/src/gui/windows/serverdialog.cpp b/src/gui/windows/serverdialog.cpp index c447bfc12..9600028b3 100644 --- a/src/gui/windows/serverdialog.cpp +++ b/src/gui/windows/serverdialog.cpp @@ -37,6 +37,7 @@ #include "gui/widgets/desktop.h" #include "gui/windows/editserverdialog.h" #include "gui/windows/logindialog.h" +#include "gui/windows/serverinfowindow.h" #include "gui/widgets/button.h" #include "gui/widgets/label.h" @@ -115,6 +116,8 @@ ServerDialog::ServerDialog(ServerInfo *const serverInfo, mDeleteButton(new Button(this, _("Delete"), "remove", this)), // TRANSLATORS: servers dialog button mLoadButton(new Button(this, _("Load"), "load", this)), + // TRANSLATORS: servers dialog button + mInfoButton(new Button(this, _("Info"), "info", this)), mServersListModel(new ServersListModel(&mServers, this)), mServersList(CREATEWIDGETR(ServersListBox, this, mServersListModel)), mDownload(nullptr), @@ -151,15 +154,16 @@ ServerDialog::ServerDialog(ServerInfo *const serverInfo, mServersList->addSelectionListener(this); usedScroll->setVerticalScrollAmount(0); - place(0, 0, usedScroll, 7, 5).setPadding(3); - place(0, 5, mDescription, 7); - place(0, 6, mPersistentIPCheckBox, 7); - place(0, 7, mAddEntryButton); - place(1, 7, mEditEntryButton); - place(2, 7, mLoadButton); - place(3, 7, mDeleteButton); - place(5, 7, mQuitButton); - place(6, 7, mConnectButton); + place(0, 0, usedScroll, 8, 5).setPadding(3); + place(0, 5, mDescription, 8); + place(0, 6, mPersistentIPCheckBox, 8); + place(0, 7, mInfoButton); + place(1, 7, mAddEntryButton); + place(2, 7, mEditEntryButton); + place(3, 7, mLoadButton); + place(4, 7, mDeleteButton); + place(6, 7, mQuitButton); + place(7, 7, mConnectButton); // Make sure the list has enough height getLayout().setRowHeight(0, 80); @@ -304,6 +308,15 @@ void ServerDialog::action(const ActionEvent &event) saveCustomServers(); } } + else if (eventId == "info") + { + const int index = mServersList->getSelected(); + if (index >= 0) + { + CREATEWIDGET(ServerInfoWindow, + mServers.at(index)); + } + } } void ServerDialog::keyPressed(KeyEvent &event) diff --git a/src/gui/windows/serverdialog.h b/src/gui/windows/serverdialog.h index 71c74f62e..b541e7f65 100644 --- a/src/gui/windows/serverdialog.h +++ b/src/gui/windows/serverdialog.h @@ -135,6 +135,7 @@ class ServerDialog final : public Window, Button *mEditEntryButton A_NONNULLPOINTER; Button *mDeleteButton A_NONNULLPOINTER; Button *mLoadButton A_NONNULLPOINTER; + Button *mInfoButton A_NONNULLPOINTER; ServersListModel *mServersListModel A_NONNULLPOINTER; ListBox *mServersList A_NONNULLPOINTER; diff --git a/src/gui/windows/serverinfowindow.cpp b/src/gui/windows/serverinfowindow.cpp new file mode 100644 index 000000000..274fd97ce --- /dev/null +++ b/src/gui/windows/serverinfowindow.cpp @@ -0,0 +1,106 @@ +/* + * The ManaPlus Client + * Copyright (C) 2017 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/serverinfowindow.h" + +#include "enums/gui/layouttype.h" + +#include "gui/gui.h" + +#include "gui/widgets/browserbox.h" +#include "gui/widgets/layout.h" +#include "gui/widgets/scrollarea.h" + +#include "utils/gettext.h" +#include "utils/process.h" +#include "utils/stringutils.h" + +#include "debug.h" + +ServerInfoWindow::ServerInfoWindow(ServerInfo &serverInfo) : + // TRANSLATORS: servers dialog name + Window(_("Server info"), Modal_false, nullptr, "server_info.xml"), + LinkHandler(), + ActionListener(), + mServerInfo(serverInfo), + mBrowserBox(new BrowserBox(this, BrowserBoxMode::AUTO_SIZE, Opaque_true, + "browserbox.xml")), + mScrollArea(new ScrollArea(this, mBrowserBox, + Opaque_true, "serverinfo_background.xml")) +{ + setMinWidth(300); + setMinHeight(220); + setContentSize(455, 350); + setWindowName("ServerInfoWindow"); + setCloseButton(true); + setResizable(true); + setStickyButtonLock(true); + + setDefaultSize(500, 400, ImagePosition::CENTER); + + mBrowserBox->setOpaque(Opaque_false); + mBrowserBox->setLinkHandler(this); + if (gui != nullptr) + mBrowserBox->setFont(gui->getHelpFont()); + mBrowserBox->setProcessVars(true); + mBrowserBox->setEnableTabs(true); + + place(0, 0, mScrollArea, 5, 3).setPadding(3); + + Layout &layout = getLayout(); + layout.setRowHeight(0, LayoutType::SET); + + loadWindowState(); + enableVisibleSound(true); + widgetResized(Event(nullptr)); +} + +void ServerInfoWindow::postInit() +{ + Window::postInit(); + setVisible(Visible_true); + showServerInfo(); +} + +ServerInfoWindow::~ServerInfoWindow() +{ +} + +void ServerInfoWindow::action(const ActionEvent &event) +{ + const std::string &eventId = event.getId(); + if (eventId == "close") + { + } +} + +void ServerInfoWindow::handleLink(const std::string &link, + MouseEvent *const event A_UNUSED) +{ + if (strStartWith(link, "http://") || + strStartWith(link, "https://")) + { + openBrowser(link); + } +} + +void ServerInfoWindow::showServerInfo() +{ +} diff --git a/src/gui/windows/serverinfowindow.h b/src/gui/windows/serverinfowindow.h new file mode 100644 index 000000000..c0cf5c786 --- /dev/null +++ b/src/gui/windows/serverinfowindow.h @@ -0,0 +1,63 @@ +/* + * The ManaPlus Client + * Copyright (C) 2017 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_SERVERINFOWINDOW_H +#define GUI_WINDOWS_SERVERINFOWINDOW_H + +#include "gui/widgets/window.h" + +#include "gui/widgets/linkhandler.h" + +#include "listeners/actionlistener.h" + +#include "net/serverinfo.h" + +class BrowserBox; +class ScrollArea; +class ServerInfo; + +class ServerInfoWindow final : public Window, + public LinkHandler, + public ActionListener +{ + public: + ServerInfoWindow(ServerInfo &serverInfo); + + A_DELETE_COPY(ServerInfoWindow) + + void postInit() override final; + + ~ServerInfoWindow(); + + void action(const ActionEvent &event) override final; + + void handleLink(const std::string &link, + MouseEvent *const event A_UNUSED) override final; + + protected: + void showServerInfo(); + + private: + ServerInfo mServerInfo; + BrowserBox *mBrowserBox A_NONNULLPOINTER; + ScrollArea *mScrollArea A_NONNULLPOINTER; +}; + +#endif // GUI_WINDOWS_SERVERINFOWINDOW_H |