diff options
Diffstat (limited to 'gui/src/tracker_actions.cpp')
| -rw-r--r-- | gui/src/tracker_actions.cpp | 128 |
1 files changed, 0 insertions, 128 deletions
diff --git a/gui/src/tracker_actions.cpp b/gui/src/tracker_actions.cpp deleted file mode 100644 index 8c9820a..0000000 --- a/gui/src/tracker_actions.cpp +++ /dev/null @@ -1,128 +0,0 @@ -/* - * SPDX-FileCopyrightText: 2025 Felix Morgner <felix.morgner@gmail.com> - * SPDX-License-Identifier: LGPL-2.1-only - */ - -#include "messages.hpp" -#include "participant_editor.hpp" -#include "preferences.hpp" -#include "tracker.hpp" - -#include <turnsmm/participant.hpp> - -#include <sigc++/adaptors/bind.h> -#include <sigc++/functors/mem_fun.h> - -#include <gio/gio.h> -#include <gtk/gtk.h> - -#include <adwaitamm/alertdialog.hpp> -#include <adwaitamm/dialog.hpp> -#include <adwaitamm/enums.hpp> -#include <adwaitamm/preferencesdialog.hpp> -#include <giomm/liststore.h> -#include <giomm/settings.h> -#include <glibmm/i18n.h> -#include <glibmm/refptr.h> -#include <glibmm/ustring.h> -#include <glibmm/variant.h> -#include <glibmm/wrap.h> -#include <gtkmm/builder.h> -#include <gtkmm/filedialog.h> -#include <gtkmm/filefilter.h> -#include <gtkmm/object.h> - -#include <utility> - -namespace Turns::gui -{ - namespace - { - auto file_filters() - { - auto filters = Gio::ListStore<Gtk::FileFilter>::create(); - auto filter = Gtk::FileFilter::create(); - filter->set_name(_("Turns Files")); - filter->add_pattern("*.trns"); - filters->append(filter); - return filters; - } - } // namespace - - auto Tracker::add_participant() -> void - { - auto dialog = Gtk::make_managed<ParticipantEditor>(nullptr); - dialog->signal_finished().connect([this](auto n, auto p, auto d) { m_turn_order->add(Participant::create(n, p, d)); }); - dialog->present(this); - } - - auto Tracker::delete_participant(Glib::VariantBase param) -> void - { - auto index = Glib::VariantBase::cast_dynamic<Glib::Variant<int>>(param); - m_turn_order->remove_at(index.get()); - } - - auto Tracker::edit_participant(Glib::VariantBase param) -> void - { - auto index = Glib::VariantBase::cast_dynamic<Glib::Variant<int>>(param); - auto participant = m_turn_order->get_typed_object<Participant>(index.get()); - auto dialog = Gtk::make_managed<ParticipantEditor>(participant); - dialog->present(this); - } - - auto Tracker::open() -> void - { - auto dialog = Gtk::FileDialog::create(); - dialog->set_filters(file_filters()); - dialog->open(sigc::bind(sigc::mem_fun(*this, &Tracker::on_open_response), dialog)); - } - - auto Tracker::preferences() -> void - { - auto preferences = Gtk::make_managed<Preferences>(m_settings); - auto dialog = Gtk::make_managed<Adwaita::PreferencesDialog>(); - dialog->add(*preferences); - dialog->set_visible_page(*preferences); - dialog->present(this); - } - - auto Tracker::save(bool force_ask) -> void - { - if (m_file && !force_ask) - { - start_replace_content(); - } - else - { - auto dialog = Gtk::FileDialog::create(); - m_file ? dialog->set_initial_file(m_file) : dialog->set_initial_name(_(message::new_turn_order_file_name)); - dialog->set_filters(file_filters()); - dialog->save(*this, sigc::bind(sigc::mem_fun(*this, &Tracker::on_save_response), dialog)); - } - } - - auto Tracker::stop() -> void - { - auto dialog = Adwaita::AlertDialog::create(_(message::stop_turn_order), _(message::question_clear_turn_order)); - dialog->add_response("stop", _(message::stop)); - dialog->set_response_appearance("stop", Adwaita::ResponseAppearance::Suggested); - dialog->add_response("clear", _(message::stop_and_clear)); - dialog->set_response_appearance("clear", Adwaita::ResponseAppearance::Destructive); - dialog->add_response("cancel", _(message::cancel)); - dialog->set_response_appearance("cancel", Adwaita::ResponseAppearance::Default); - dialog->set_close_response("cancel"); - dialog->set_default_response("cancel"); - dialog->choose(*this, nullptr, [dialog = std::move(dialog), this](auto const & result) { - auto response = dialog->choose_finish(result); - if (response == "cancel") - { - return; - } - if (response == "clear") - { - m_turn_order->clear(); - } - // m_turn_order->stop(); - }); - } -} // namespace Turns::gui
\ No newline at end of file |
