From 19fb11b30039b2a63eab51e2e0fcf9e447a5dba8 Mon Sep 17 00:00:00 2001 From: Jabiertxof Date: Sun, 28 Jul 2019 21:36:35 +0200 Subject: Fix for bug https://gitlab.com/inkscape/inbox/issues/699 --- src/ui/icon-loader.cpp | 10 +++++----- src/ui/tools/tool-base.cpp | 15 +++++++++++++++ 2 files changed, 20 insertions(+), 5 deletions(-) (limited to 'src') diff --git a/src/ui/icon-loader.cpp b/src/ui/icon-loader.cpp index c3182aa8f..c73273953 100644 --- a/src/ui/icon-loader.cpp +++ b/src/ui/icon-loader.cpp @@ -44,17 +44,17 @@ Gtk::Image *sp_get_icon_image(Glib::ustring icon_name, Gtk::BuiltinIconSize icon return icon; } -GtkWidget *sp_get_icon_image(Glib::ustring icon_name, GtkIconSize icon_size) -{ - return gtk_image_new_from_icon_name(icon_name.c_str(), icon_size); -} - Gtk::Image *sp_get_icon_image(Glib::ustring icon_name, gchar const *prefs_size) { Gtk::IconSize icon_size = Inkscape::UI::ToolboxFactory::prefToSize_mm(prefs_size); return sp_get_icon_image(icon_name, icon_size); } +GtkWidget *sp_get_icon_image(Glib::ustring icon_name, GtkIconSize icon_size) +{ + return gtk_image_new_from_icon_name(icon_name.c_str(), icon_size); +} + Glib::RefPtr sp_get_icon_pixbuf(Glib::ustring icon_name, gint size) { Glib::RefPtr display = Gdk::Display::get_default(); diff --git a/src/ui/tools/tool-base.cpp b/src/ui/tools/tool-base.cpp index 1dc4ad2fb..64dbf53bc 100644 --- a/src/ui/tools/tool-base.cpp +++ b/src/ui/tools/tool-base.cpp @@ -1157,8 +1157,23 @@ void sp_event_root_menu_popup(SPDesktop *desktop, SPItem *item, GdkEvent *event) } ContextMenu* CM = new ContextMenu(desktop, item); + Gtk::Window *window = SP_ACTIVE_DESKTOP->getToplevel(); + if (window) { + if (window->get_style_context()->has_class("dark")) { + CM->get_style_context()->add_class("dark"); + } else { + CM->get_style_context()->add_class("bright"); + } + Inkscape::Preferences *prefs = Inkscape::Preferences::get(); + if (prefs->getBool("/theme/symbolicIcons", false)) { + CM->get_style_context()->add_class("symbolic"); + } else { + CM->get_style_context()->add_class("regular"); + } + } CM->show(); + switch (event->type) { case GDK_BUTTON_PRESS: case GDK_KEY_PRESS: -- cgit v1.2.3