aboutsummaryrefslogtreecommitdiff
path: root/src/base_tab
diff options
context:
space:
mode:
authorLoic Guegan <manzerbredes@mailbox.org>2022-12-24 12:46:59 +0100
committerLoic Guegan <manzerbredes@mailbox.org>2022-12-24 12:46:59 +0100
commit2d9730e216976103daea64a8df047d5f0dffd5f7 (patch)
tree894454165b388167c077619c0a0388338c828c05 /src/base_tab
parent273610cb0f848fd99f9b9769f0d60b6e2df590ed (diff)
Update tab management system
Diffstat (limited to 'src/base_tab')
-rw-r--r--src/base_tab/BaseGameTab.cpp11
-rw-r--r--src/base_tab/BaseGameTab.hpp2
-rw-r--r--src/base_tab/BaseManageTab.cpp1
-rw-r--r--src/base_tab/BaseTab.cpp11
-rw-r--r--src/base_tab/BaseTab.hpp10
5 files changed, 28 insertions, 7 deletions
diff --git a/src/base_tab/BaseGameTab.cpp b/src/base_tab/BaseGameTab.cpp
index 79f28c1..dafa71a 100644
--- a/src/base_tab/BaseGameTab.cpp
+++ b/src/base_tab/BaseGameTab.cpp
@@ -2,6 +2,9 @@
#include "AppendGameDialog.hpp"
#include <wx/filename.h>
+wxDEFINE_EVENT(OPEN_GAME_EVENT, wxCommandEvent);
+
+
BaseGameTab::BaseGameTab(wxFrame *parent, std::string base_file)
: TabBase_TabGames(parent), base_file(base_file),
base(NULL) {
@@ -72,10 +75,10 @@ void BaseGameTab::OnOpenGame(wxListEvent &event) {
edited.push_back(*g);
deleted.push_back(id);
game_list->SetItemBackgroundColour(event.GetIndex(), *wxGREEN);
- wxCommandEvent newGameEvent(NEW_GAME_EVENT, GetId());
- newGameEvent.SetEventObject(this);
- newGameEvent.SetClientData(g);
- ProcessEvent(newGameEvent);
+ wxCommandEvent openGameEvent(OPEN_GAME_EVENT, GetId());
+ openGameEvent.SetEventObject(this);
+ openGameEvent.SetClientData(g);
+ ProcessEvent(openGameEvent);
}
}
diff --git a/src/base_tab/BaseGameTab.hpp b/src/base_tab/BaseGameTab.hpp
index d90163f..f93903c 100644
--- a/src/base_tab/BaseGameTab.hpp
+++ b/src/base_tab/BaseGameTab.hpp
@@ -4,7 +4,7 @@
#include "ochess.hpp"
// Foreign events
-wxDECLARE_EVENT(NEW_GAME_EVENT, wxCommandEvent);
+wxDECLARE_EVENT(OPEN_GAME_EVENT, wxCommandEvent);
wxDECLARE_EVENT(REFRESH_TAB_TITLE, wxCommandEvent);
class BaseGameTab : public TabBase_TabGames {
diff --git a/src/base_tab/BaseManageTab.cpp b/src/base_tab/BaseManageTab.cpp
index 46306df..db42b8b 100644
--- a/src/base_tab/BaseManageTab.cpp
+++ b/src/base_tab/BaseManageTab.cpp
@@ -6,3 +6,4 @@ TabBase_TabManage(parent)
{
}
+
diff --git a/src/base_tab/BaseTab.cpp b/src/base_tab/BaseTab.cpp
index a76ba38..a2b7207 100644
--- a/src/base_tab/BaseTab.cpp
+++ b/src/base_tab/BaseTab.cpp
@@ -16,6 +16,17 @@ BaseTab::BaseTab(wxFrame *parent, std::string base_file)
notebook->AddPage(manage_tab, "Manage database");
RefreshLabel();
+ this->Bind(OPEN_GAME_EVENT, &BaseTab::OnNewGame, this, wxID_ANY);
+}
+
+
+void BaseTab::OnNewGame(wxCommandEvent &event){
+ std::shared_ptr<Game> *g = (std::shared_ptr<Game>*)event.GetClientData();
+ this->game=*g;
+ wxCommandEvent newGameEvent(NEW_GAME_EVENT, GetId());
+ newGameEvent.SetEventObject(this);
+ newGameEvent.SetClientData((TabInfos*)this);
+ ProcessEvent(newGameEvent);
}
void BaseTab::ApplyPreferences() {}
diff --git a/src/base_tab/BaseTab.hpp b/src/base_tab/BaseTab.hpp
index 6136eed..788ba45 100644
--- a/src/base_tab/BaseTab.hpp
+++ b/src/base_tab/BaseTab.hpp
@@ -5,16 +5,22 @@
#include "BaseImportTab.hpp"
#include "BaseManageTab.hpp"
+wxDECLARE_EVENT(NEW_GAME_EVENT, wxCommandEvent);
+
+
class BaseTab : public TabBase, public TabInfos {
std::shared_ptr<GameBase> base;
+ std::shared_ptr<Game> game;
BaseGameTab *games_tab;
BaseImportTab *import_tab;
- BaseManageTab * manage_tab;
+ BaseManageTab *manage_tab;
+
+ void OnNewGame(wxCommandEvent &event);
public:
BaseTab(wxFrame *parent, std::string base_file);
void ApplyPreferences();
void RefreshLabel();
- std::shared_ptr<Game> GetGame() { return (std::shared_ptr<Game>(NULL)); }
+ std::shared_ptr<Game> GetGame() { return (std::shared_ptr<Game>(game)); }
std::shared_ptr<GameBase> GetBase() { return (std::shared_ptr<GameBase>(base)); };
}; \ No newline at end of file