From fb917713e55147c6b0de514924c4867d9e8d5894 Mon Sep 17 00:00:00 2001 From: Felix Morgner Date: Sat, 17 Aug 2024 11:41:43 +0200 Subject: ui: add participant shading color preferences --- ui/src/widgets/preferences.cpp | 68 ++++++++++++++++++++++++++++++++++++++ ui/src/windows/tracker.cpp | 6 +++- ui/src/windows/tracker/actions.cpp | 13 ++++++++ 3 files changed, 86 insertions(+), 1 deletion(-) create mode 100644 ui/src/widgets/preferences.cpp (limited to 'ui/src') diff --git a/ui/src/widgets/preferences.cpp b/ui/src/widgets/preferences.cpp new file mode 100644 index 0000000..24de613 --- /dev/null +++ b/ui/src/widgets/preferences.cpp @@ -0,0 +1,68 @@ +#include "turns/ui/widgets/preferences.hpp" + +#include "turns/adw/actionrow.hpp" +#include "turns/ui/widgets/template_widget.hpp" + +#include +#include + +#include + +#include +#include + +#include + +namespace turns::ui::widgets +{ + namespace + { + auto constexpr static TYPE_NAME = "preferences"; + auto constexpr static TEMPLATE = "/widgets/preferences.ui"; + } // namespace + + preferences::preferences(Glib::RefPtr settings) + : Glib::ObjectBase{TYPE_NAME} + , template_widget{TEMPLATE} + , m_settings{settings} + , m_friendly{get_widget("friendly")} + , m_hostile{get_widget("hostile")} + , m_secret{get_widget("secret")} + { + if (!m_settings) + { + return; + } + + m_friendly->add_suffix(m_friendly_button); + m_friendly->set_activatable_widget(m_friendly_button); + m_friendly_button.set_dialog(Gtk::ColorDialog::create()); + m_friendly_button.set_valign(Gtk::Align::CENTER); + m_settings->bind("disposition-color-friendly", + m_friendly_button.property_rgba(), + Gio::Settings::BindFlags::DEFAULT, + [](auto value) { return Gdk::RGBA{value}; }, + [](auto color) { return color.to_string(); }); + + m_hostile->add_suffix(m_hostile_button); + m_hostile->set_activatable_widget(m_hostile_button); + m_hostile_button.set_dialog(Gtk::ColorDialog::create()); + m_hostile_button.set_valign(Gtk::Align::CENTER); + m_settings->bind("disposition-color-hostile", + m_hostile_button.property_rgba(), + Gio::Settings::BindFlags::DEFAULT, + [](auto value) { return Gdk::RGBA{value}; }, + [](auto color) { return color.to_string(); }); + + m_secret->add_suffix(m_secret_button); + m_secret->set_activatable_widget(m_secret_button); + m_secret_button.set_dialog(Gtk::ColorDialog::create()); + m_secret_button.set_valign(Gtk::Align::CENTER); + m_settings->bind("disposition-color-secret", + m_secret_button.property_rgba(), + Gio::Settings::BindFlags::DEFAULT, + [](auto value) { return Gdk::RGBA{value}; }, + [](auto color) { return color.to_string(); }); + } + +} // namespace turns::ui::widgets \ No newline at end of file diff --git a/ui/src/windows/tracker.cpp b/ui/src/windows/tracker.cpp index c6dc731..b9a55c0 100644 --- a/ui/src/windows/tracker.cpp +++ b/ui/src/windows/tracker.cpp @@ -4,6 +4,7 @@ #include "turns/adw/toastoverlay.hpp" #include "turns/core/turn_order.hpp" #include "turns/lang/messages.hpp" +#include "turns/ui/widgets/preferences.hpp" #include "turns/ui/widgets/turn_order_view.hpp" #include @@ -15,6 +16,7 @@ #include #include #include +#include #include #include @@ -53,9 +55,9 @@ namespace turns::ui::windows , m_title{builder->get_widget("title")} , m_turn_order{core::turn_order::create()} , m_turn_order_view{Gtk::make_managed(m_turn_order)} + , m_settings{Gio::Settings::create("ch.arknet.Turns")} , m_subtitle{m_title, "subtitle"} , m_css{Gtk::CssProvider::create()} - , m_settings{Gio::Settings::create("ch.arknet.Turns")} { setup_colors(); setup_actions(); @@ -141,10 +143,12 @@ namespace turns::ui::windows // win.delete // win.edit // win.open + // win.preferences { add_action_with_parameter("delete", Glib::VARIANT_TYPE_INT32, sigc::mem_fun(*this, &tracker::delete_participant)); add_action_with_parameter("edit", Glib::VARIANT_TYPE_INT32, sigc::mem_fun(*this, &tracker::edit_participant)); add_action("open", sigc::mem_fun(*this, &tracker::open)); + add_action("preferences", sigc::mem_fun(*this, &tracker::preferences)); } // win.save diff --git a/ui/src/windows/tracker/actions.cpp b/ui/src/windows/tracker/actions.cpp index 3210089..c26afbf 100644 --- a/ui/src/windows/tracker/actions.cpp +++ b/ui/src/windows/tracker/actions.cpp @@ -1,6 +1,8 @@ +#include "turns/adw/preferencesdialog.hpp" #include "turns/core/participant.hpp" #include "turns/core/turn_order.hpp" #include "turns/lang/messages.hpp" +#include "turns/ui/widgets/preferences.hpp" #include "turns/ui/windows/participant_editor.hpp" #include "turns/ui/windows/tracker.hpp" @@ -14,10 +16,12 @@ #include #include +#include #include #include #include +#include #include #include @@ -89,6 +93,15 @@ namespace turns::ui::windows dialog->open(sigc::bind(sigc::mem_fun(*this, &tracker::on_open_response), dialog)); } + auto tracker::preferences() -> void + { + auto preferences = Gtk::make_managed(m_settings); + auto dialog = Gtk::make_managed(); + dialog->add(*preferences); + adw_preferences_dialog_set_visible_page(Glib::unwrap(dialog), Glib::unwrap(preferences)); + dialog->present(this); + } + auto tracker::save(bool force_ask) -> void { if (m_file && !force_ask) -- cgit v1.2.3