diff options
Diffstat (limited to 'ui/src/widgets/turn_order_view.cpp')
| -rw-r--r-- | ui/src/widgets/turn_order_view.cpp | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/ui/src/widgets/turn_order_view.cpp b/ui/src/widgets/turn_order_view.cpp new file mode 100644 index 0000000..9456cbe --- /dev/null +++ b/ui/src/widgets/turn_order_view.cpp @@ -0,0 +1,49 @@ +#include "turns/ui/widgets/turn_order_view.hpp" + +#include "turns/ui/widgets/participant_row.hpp" +#include "turns/core/participant.hpp" +#include "turns/core/turn_order.hpp" + +#include <sigc++/functors/mem_fun.h> + +#include <glibmm/binding.h> + +#include <memory> + +namespace turns::app::widgets +{ + namespace + { + auto constexpr static TYPE_NAME = "turn_order_view"; + auto constexpr static TEMPLATE = "/widgets/turn_order_view.ui"; + } // namespace + + turn_order_view::turn_order_view(Glib::RefPtr<model_type> model) + : Glib::ObjectBase(TYPE_NAME) + , template_widget<turn_order_view, Gtk::ScrolledWindow>{TEMPLATE} + , m_model{model} + , m_view{get_widget<Gtk::ListBox>("view")} + { + if (model) + { + m_view->bind_model(m_model, sigc::mem_fun(*this, &turn_order_view::handle_create_row)); + } + } + + auto turn_order_view::handle_create_row(Glib::RefPtr<Glib::Object> const item) -> Gtk::Widget * + { + auto participant = std::dynamic_pointer_cast<core::participant>(item); + auto row = Gtk::make_managed<widgets::participant_row>(participant); + + Glib::Binding::bind_property(m_model->is_running(), + row->property_delete_enabled(), + Glib::Binding::Flags::SYNC_CREATE | Glib::Binding::Flags::INVERT_BOOLEAN); + + Glib::Binding::bind_property(m_model->is_running(), + row->property_edit_enabled(), + Glib::Binding::Flags::SYNC_CREATE | Glib::Binding::Flags::INVERT_BOOLEAN); + + return row; + } + +} // namespace turns::app::widgets
\ No newline at end of file |
