From 88808d7e67b96d3874bb8d96f41335c0d7ff795e Mon Sep 17 00:00:00 2001 From: monsta Date: Wed, 5 Jul 2017 14:17:20 +0300 Subject: refresh tray icon on icon theme change --- src/gpm-manager.c | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) (limited to 'src') diff --git a/src/gpm-manager.c b/src/gpm-manager.c index ce2b695..0445fd0 100644 --- a/src/gpm-manager.c +++ b/src/gpm-manager.c @@ -1789,6 +1789,20 @@ gpm_manager_systemd_inhibit (GDBusProxy *proxy) { return r; } +static void +on_icon_theme_change (GtkSettings *settings, + GParamSpec *pspec, + GpmManager *manager) +{ + gchar *icon = gpm_engine_get_icon (manager->priv->engine); + if (icon == NULL) { + return; + } + + gpm_tray_icon_set_icon (manager->priv->tray_icon, icon); + g_free (icon); +} + /** * gpm_manager_init: * @manager: This class instance @@ -1920,6 +1934,11 @@ gpm_manager_init (GpmManager *manager) g_signal_connect (manager->priv->engine, "charge-action", G_CALLBACK (gpm_manager_engine_charge_action_cb), manager); + g_signal_connect (gtk_settings_get_default (), + "notify::gtk-icon-theme-name", + G_CALLBACK (on_icon_theme_change), + manager); + /* update ac throttle */ gpm_manager_update_ac_throttle (manager); } @@ -1957,6 +1976,10 @@ gpm_manager_finalize (GObject *object) manager->priv->critical_alert_timeout_id = 0; } + g_signal_handlers_disconnect_by_func (gtk_settings_get_default (), + on_icon_theme_change, + manager); + g_object_unref (manager->priv->settings); g_object_unref (manager->priv->dpms); g_object_unref (manager->priv->idle); -- cgit v1.2.1