summaryrefslogtreecommitdiff
path: root/app/src
diff options
context:
space:
mode:
authorFelix Morgner <felix.morgner@gmail.com>2024-07-15 00:22:07 +0200
committerFelix Morgner <felix.morgner@gmail.com>2024-07-15 00:22:07 +0200
commit85e1761f3a1107b0b5988de3225d69b586a1c71b (patch)
tree1b47475950fb8658ea94964077f3a9ab87b50140 /app/src
parent081627fcfb9076ce243a9adde4743117bc48a767 (diff)
downloadturns-85e1761f3a1107b0b5988de3225d69b586a1c71b.tar.xz
turns-85e1761f3a1107b0b5988de3225d69b586a1c71b.zip
app/ui: enable participant editing
Diffstat (limited to 'app/src')
-rw-r--r--app/src/windows/main.cpp14
-rw-r--r--app/src/windows/participant_editor.cpp19
2 files changed, 31 insertions, 2 deletions
diff --git a/app/src/windows/main.cpp b/app/src/windows/main.cpp
index d217e9f..d654a3b 100644
--- a/app/src/windows/main.cpp
+++ b/app/src/windows/main.cpp
@@ -44,6 +44,7 @@ namespace turns::app::windows
auto index = Glib::VariantBase::cast_dynamic<Glib::Variant<int>>(param);
m_participants->remove(index.get());
});
+ add_action_with_parameter("edit", Glib::VARIANT_TYPE_INT32, sigc::mem_fun(*this, &main::handle_edit_participant));
}
auto main::handle_create_list_row(Glib::RefPtr<Glib::Object> const item) -> Gtk::Widget *
@@ -65,4 +66,17 @@ namespace turns::app::windows
dialog->signal_finished().connect([this](auto name, auto priority) { m_participants->append(name, priority); });
}
+ auto main::handle_edit_participant(Glib::VariantBase param) -> void
+ {
+ auto index = Glib::VariantBase::cast_dynamic<Glib::Variant<int>>(param);
+ auto participant = m_participants->get_item(index.get());
+
+ auto builder = Gtk::Builder::create_from_resource("/ch/arknet/Turns/windows/participant_editor.ui");
+ auto dialog = Gtk::Builder::get_widget_derived<windows::participant_editor>(builder, "participant_editor", participant);
+
+ dialog->set_title(_("Add participant"));
+ dialog->present(this);
+ dialog->signal_finished().connect([this](auto name, auto priority) { m_participants->append(name, priority); });
+ }
+
} // namespace turns::app::windows
diff --git a/app/src/windows/participant_editor.cpp b/app/src/windows/participant_editor.cpp
index f89fc20..bab7731 100644
--- a/app/src/windows/participant_editor.cpp
+++ b/app/src/windows/participant_editor.cpp
@@ -8,15 +8,22 @@
namespace turns::app::windows
{
- participant_editor::participant_editor(BaseObjectType * base, Glib::RefPtr<Gtk::Builder> const builder)
+ participant_editor::participant_editor(BaseObjectType * base, Glib::RefPtr<Gtk::Builder> const builder, Glib::RefPtr<domain::participant> obj)
: Gtk::Widget{base}
, m_adw{ADW_DIALOG(gobj())}
, m_finish{builder->get_widget<Gtk::Button>("finish")}
+ , m_participant{obj}
{
m_disposition = ADW_COMBO_ROW(builder->get_widget<Gtk::ListBoxRow>("disposition")->gobj());
m_name = ADW_ENTRY_ROW(builder->get_widget<Gtk::ListBoxRow>("name")->gobj());
m_priority = ADW_SPIN_ROW(builder->get_widget<Gtk::ListBoxRow>("priority")->gobj());
+ if (obj)
+ {
+ gtk_editable_set_text(GTK_EDITABLE(m_name), m_participant->property_name().get_value().c_str());
+ adw_spin_row_set_value(m_priority, m_participant->property_priority().get_value());
+ }
+
m_finish->signal_clicked().connect(sigc::mem_fun(*this, &participant_editor::handle_finish_clicked));
}
@@ -39,7 +46,15 @@ namespace turns::app::windows
{
auto name = gtk_editable_get_text(GTK_EDITABLE(m_name));
auto priority = adw_spin_row_get_value(m_priority);
- m_signal_finished.emit(name, priority);
+ if (m_participant)
+ {
+ m_participant->property_name().set_value(name);
+ m_participant->property_priority().set_value(priority);
+ }
+ else
+ {
+ m_signal_finished.emit(name, priority);
+ }
adw_dialog_close(m_adw);
}
} // namespace turns::app::windows \ No newline at end of file