summaryrefslogtreecommitdiffhomepage
path: root/StarsEx/CmdOrdersDlg.cpp
diff options
context:
space:
mode:
authorAki <please@ignore.pl>2022-04-01 21:23:39 +0200
committerAki <please@ignore.pl>2022-04-01 21:23:39 +0200
commit3c487c5cd69c53d6fea948643c0a76df03516605 (patch)
tree72730c7b8b26a5ef8fc9a987ec4c16129efd5aac /StarsEx/CmdOrdersDlg.cpp
parent8f353abd0bfe18baddd8a8250ab7c4f2d1c83a6e (diff)
downloadstarshatter-3c487c5cd69c53d6fea948643c0a76df03516605.zip
starshatter-3c487c5cd69c53d6fea948643c0a76df03516605.tar.gz
starshatter-3c487c5cd69c53d6fea948643c0a76df03516605.tar.bz2
Moved Stars45 to StarsEx
Diffstat (limited to 'StarsEx/CmdOrdersDlg.cpp')
-rw-r--r--StarsEx/CmdOrdersDlg.cpp138
1 files changed, 138 insertions, 0 deletions
diff --git a/StarsEx/CmdOrdersDlg.cpp b/StarsEx/CmdOrdersDlg.cpp
new file mode 100644
index 0000000..7fd4183
--- /dev/null
+++ b/StarsEx/CmdOrdersDlg.cpp
@@ -0,0 +1,138 @@
+/* Starshatter: The Open Source Project
+ Copyright (c) 2021-2022, Starshatter: The Open Source Project Contributors
+ Copyright (c) 2011-2012, Starshatter OpenSource Distribution Contributors
+ Copyright (c) 1997-2006, Destroyer Studios LLC.
+
+ AUTHOR: John DiCamillo
+
+
+ OVERVIEW
+ ========
+ Operational Command Dialog (Campaign Orders Tab)
+*/
+
+#include "CmdOrdersDlg.h"
+#include "CmdDlg.h"
+#include "CmpnScreen.h"
+#include "Starshatter.h"
+#include "Campaign.h"
+#include "Combatant.h"
+#include "CombatGroup.h"
+#include "CombatUnit.h"
+#include "ShipDesign.h"
+
+#include "Game.h"
+#include "ContentBundle.h"
+#include "DataLoader.h"
+#include "Button.h"
+#include "ComboBox.h"
+#include "ListBox.h"
+#include "Slider.h"
+#include "Video.h"
+#include "Keyboard.h"
+#include "Mouse.h"
+#include "ParseUtil.h"
+#include "FormatUtil.h"
+
+// +--------------------------------------------------------------------+
+// DECLARE MAPPING FUNCTIONS:
+
+DEF_MAP_CLIENT(CmdOrdersDlg, OnMode);
+DEF_MAP_CLIENT(CmdOrdersDlg, OnSave);
+DEF_MAP_CLIENT(CmdOrdersDlg, OnExit);
+
+// +--------------------------------------------------------------------+
+
+CmdOrdersDlg::CmdOrdersDlg(Screen* s, FormDef& def, CmpnScreen* mgr)
+ : FormWindow(s, 0, 0, s->Width(), s->Height()), CmdDlg(mgr), manager(mgr),
+ lbl_orders(0), stars(0), campaign(0)
+{
+ stars = Starshatter::GetInstance();
+ campaign = Campaign::GetCampaign();
+
+ Init(def);
+}
+
+CmdOrdersDlg::~CmdOrdersDlg()
+{
+}
+
+// +--------------------------------------------------------------------+
+
+void
+CmdOrdersDlg::RegisterControls()
+{
+ lbl_orders = FindControl(400);
+
+ RegisterCmdControls(this);
+
+ if (btn_save)
+ REGISTER_CLIENT(EID_CLICK, btn_save, CmdOrdersDlg, OnSave);
+
+ if (btn_exit)
+ REGISTER_CLIENT(EID_CLICK, btn_exit, CmdOrdersDlg, OnExit);
+
+ for (int i = 0; i < 5; i++) {
+ if (btn_mode[i])
+ REGISTER_CLIENT(EID_CLICK, btn_mode[i], CmdOrdersDlg, OnMode);
+ }
+}
+
+// +--------------------------------------------------------------------+
+
+void
+CmdOrdersDlg::Show()
+{
+ mode = MODE_ORDERS;
+
+ FormWindow::Show();
+ ShowCmdDlg();
+
+ campaign = Campaign::GetCampaign();
+
+ if (campaign && lbl_orders) {
+ Text orders("<font Limerick12><color ffff80>");
+ orders += ContentBundle::GetInstance()->GetText("CmdOrdersDlg.situation");
+ orders += "\n<font Verdana><color ffffff>";
+ if (*campaign->Situation())
+ orders += campaign->Situation();
+ else
+ orders += campaign->Description();
+
+ orders += "\n\n<font Limerick12><color ffff80>";
+ orders += ContentBundle::GetInstance()->GetText("CmdOrdersDlg.orders");
+ orders += "\n<font Verdana><color ffffff>";
+ orders += campaign->Orders();
+
+ lbl_orders->SetText(orders);
+ }
+}
+
+// +--------------------------------------------------------------------+
+
+void
+CmdOrdersDlg::ExecFrame()
+{
+ CmdDlg::ExecFrame();
+}
+
+// +--------------------------------------------------------------------+
+
+void
+CmdOrdersDlg::OnSave(AWEvent* event)
+{
+ CmdDlg::OnSave(event);
+}
+
+void
+CmdOrdersDlg::OnExit(AWEvent* event)
+{
+ CmdDlg::OnExit(event);
+}
+
+void
+CmdOrdersDlg::OnMode(AWEvent* event)
+{
+ CmdDlg::OnMode(event);
+}
+