diff options
| author | Felix Morgner <felix.morgner@gmail.com> | 2025-06-08 22:03:14 +0200 |
|---|---|---|
| committer | Felix Morgner <felix.morgner@gmail.com> | 2025-06-08 22:03:14 +0200 |
| commit | 4466f721192844fe542d02aced2c8b3860e1433c (patch) | |
| tree | c5e8d219b71b25d0b6a7b60b4f5a798792926b68 /gui/src | |
| parent | a9605c42349394bba021ed9f02ac512eee8c95ae (diff) | |
| download | turns-4466f721192844fe542d02aced2c8b3860e1433c.tar.xz turns-4466f721192844fe542d02aced2c8b3860e1433c.zip | |
gui: make TurnOrderView default constructible
Diffstat (limited to 'gui/src')
| -rw-r--r-- | gui/src/turn_order_view.cpp | 53 |
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 |
