diff options
| author | Felix Morgner <felix.morgner@gmail.com> | 2024-07-15 00:22:07 +0200 |
|---|---|---|
| committer | Felix Morgner <felix.morgner@gmail.com> | 2024-07-15 00:22:07 +0200 |
| commit | 85e1761f3a1107b0b5988de3225d69b586a1c71b (patch) | |
| tree | 1b47475950fb8658ea94964077f3a9ab87b50140 /app/src | |
| parent | 081627fcfb9076ce243a9adde4743117bc48a767 (diff) | |
| download | turns-85e1761f3a1107b0b5988de3225d69b586a1c71b.tar.xz turns-85e1761f3a1107b0b5988de3225d69b586a1c71b.zip | |
app/ui: enable participant editing
Diffstat (limited to 'app/src')
| -rw-r--r-- | app/src/windows/main.cpp | 14 | ||||
| -rw-r--r-- | app/src/windows/participant_editor.cpp | 19 |
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 |
