summaryrefslogtreecommitdiff
path: root/gui/src
diff options
context:
space:
mode:
authorFelix Morgner <felix.morgner@gmail.com>2025-06-08 22:03:14 +0200
committerFelix Morgner <felix.morgner@gmail.com>2025-06-08 22:03:14 +0200
commit4466f721192844fe542d02aced2c8b3860e1433c (patch)
treec5e8d219b71b25d0b6a7b60b4f5a798792926b68 /gui/src
parenta9605c42349394bba021ed9f02ac512eee8c95ae (diff)
downloadturns-4466f721192844fe542d02aced2c8b3860e1433c.tar.xz
turns-4466f721192844fe542d02aced2c8b3860e1433c.zip
gui: make TurnOrderView default constructible
Diffstat (limited to 'gui/src')
-rw-r--r--gui/src/turn_order_view.cpp53
1 files changed, 37 insertions, 16 deletions
diff --git a/gui/src/turn_order_view.cpp b/gui/src/turn_order_view.cpp
index 5239269..0398351 100644
--- a/gui/src/turn_order_view.cpp
+++ b/gui/src/turn_order_view.cpp
@@ -10,12 +10,14 @@
#include "template_widget.hpp"
#include <turnsmm/participant.hpp>
+#include <turnsmm/turn-order.hpp>
#include <sigc++/functors/mem_fun.h>
#include <glibmm/binding.h>
#include <glibmm/object.h>
#include <glibmm/objectbase.h>
+#include <glibmm/propertyproxy.h>
#include <glibmm/refptr.h>
#include <gtkmm/enums.h>
#include <gtkmm/listbox.h>
@@ -33,23 +35,42 @@ namespace Turns::gui
auto constexpr static TEMPLATE = resource::turn_order_view_ui;
} // namespace
- TurnOrderView::TurnOrderView(Glib::RefPtr<model_type> model)
- : Glib::ObjectBase(TYPE_NAME)
+ TurnOrderView::TurnOrderView()
+ : Glib::ObjectBase{TYPE_NAME}
, template_widget{TEMPLATE}
- , m_model{model}
- , m_progress{get_widget<Gtk::ProgressBar>("progress")}
- , m_view{get_widget<Gtk::ListBox>("view")}
{
- if (!model)
- {
- return;
- }
-
set_orientation(Gtk::Orientation::VERTICAL);
+ }
+
+ TurnOrderView::TurnOrderView(Glib::RefPtr<TurnOrder> const & turn_order)
+ : TurnOrderView{}
+ {
+ set_turn_order(turn_order);
+ }
+
+ auto TurnOrderView::get_turn_order() const -> Glib::RefPtr<TurnOrder>
+ {
+ return m_turn_order.get_value();
+ }
- m_view->bind_model(m_model, sigc::mem_fun(*this, &TurnOrderView::handle_create_row));
- Glib::Binding::bind_property(m_model->property_round_progress(), m_progress->property_fraction(), Glib::Binding::Flags::SYNC_CREATE);
- Glib::Binding::bind_property(m_model->property_running(), m_progress->property_visible(), Glib::Binding::Flags::SYNC_CREATE);
+ auto TurnOrderView::set_turn_order(Glib::RefPtr<TurnOrder> const & turn_order) -> void
+ {
+ m_turn_order.set_value(turn_order);
+ m_view->bind_model(get_turn_order(), sigc::mem_fun(*this, &TurnOrderView::handle_create_row));
+ Glib::Binding::bind_property(get_turn_order()->property_round_progress(),
+ m_progress->property_fraction(),
+ Glib::Binding::Flags::SYNC_CREATE);
+ Glib::Binding::bind_property(get_turn_order()->property_running(), m_progress->property_visible(), Glib::Binding::Flags::SYNC_CREATE);
+ }
+
+ auto TurnOrderView::property_turn_order() -> Glib::PropertyProxy<Glib::RefPtr<TurnOrder>>
+ {
+ return m_turn_order.get_proxy();
+ }
+
+ auto TurnOrderView::property_turn_order() const -> Glib::PropertyProxy_ReadOnly<Glib::RefPtr<TurnOrder>>
+ {
+ return m_turn_order.get_proxy();
}
auto TurnOrderView::handle_create_row(Glib::RefPtr<Glib::Object> const item) -> Gtk::Widget *
@@ -57,15 +78,15 @@ namespace Turns::gui
auto participant = std::dynamic_pointer_cast<Participant>(item);
auto row = Gtk::make_managed<ParticipantRow>(participant);
- Glib::Binding::bind_property(m_model->property_running(),
+ Glib::Binding::bind_property(get_turn_order()->property_running(),
row->delete_enabled(),
Glib::Binding::Flags::SYNC_CREATE | Glib::Binding::Flags::INVERT_BOOLEAN);
- Glib::Binding::bind_property(m_model->property_running(),
+ Glib::Binding::bind_property(get_turn_order()->property_running(),
row->edit_enabled(),
Glib::Binding::Flags::SYNC_CREATE | Glib::Binding::Flags::INVERT_BOOLEAN);
return row;
}
-} // namespace Turns::gui \ No newline at end of file
+} // namespace Turns::gui