aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLars Uebernickel <lars.uebernickel@canonical.com>2012-08-27 11:53:58 +0200
committerLars Uebernickel <lars.uebernickel@canonical.com>2012-08-27 11:53:58 +0200
commit98f03a9d7d29ba2531d098f99c7f72b844f8213e (patch)
tree2ccb7536820a7132b47dedb309c123918bd9fa45 /src
parentca5c4991f7815f9b5190b370bfa70c651facaf72 (diff)
downloadayatana-indicator-messages-98f03a9d7d29ba2531d098f99c7f72b844f8213e.tar.gz
ayatana-indicator-messages-98f03a9d7d29ba2531d098f99c7f72b844f8213e.tar.bz2
ayatana-indicator-messages-98f03a9d7d29ba2531d098f99c7f72b844f8213e.zip
Bring back the blue icon when a source is drawing attention
Diffstat (limited to 'src')
-rw-r--r--src/indicator-messages.c27
1 files changed, 26 insertions, 1 deletions
diff --git a/src/indicator-messages.c b/src/indicator-messages.c
index f211ff8..4f5a012 100644
--- a/src/indicator-messages.c
+++ b/src/indicator-messages.c
@@ -90,6 +90,10 @@ static void menu_items_changed (GMenuModel *menu,
gint removed,
gint added,
gpointer user_data);
+static void messages_state_changed (GActionGroup *action_group,
+ gchar *action_name,
+ GVariant *value,
+ gpointer user_data);
G_DEFINE_TYPE (IndicatorMessages, indicator_messages, INDICATOR_OBJECT_TYPE);
@@ -172,7 +176,10 @@ static void service_connection_changed (IndicatorServiceManager *sm,
GDBusConnection *bus;
GError *error = NULL;
- g_clear_object (&self->actions);
+ if (self->actions != NULL) {
+ g_signal_handlers_disconnect_by_func (self->actions, messages_state_changed, self);
+ g_clear_object (&self->actions);
+ }
if (self->menu != NULL) {
g_signal_handlers_disconnect_by_func (self->menu, menu_items_changed, self);
g_clear_object (&self->menu);
@@ -196,6 +203,8 @@ static void service_connection_changed (IndicatorServiceManager *sm,
gtk_widget_insert_action_group (self->gtkmenu,
get_name_hint (INDICATOR_OBJECT (self)),
self->actions);
+ g_signal_connect (self->actions, "action-state-changed::messages",
+ G_CALLBACK (messages_state_changed), self);
self->menu = G_MENU_MODEL (g_dbus_menu_model_get (bus,
INDICATOR_MESSAGES_DBUS_NAME,
@@ -323,3 +332,19 @@ menu_items_changed (GMenuModel *menu,
update_menu (self);
}
}
+
+static void
+messages_state_changed (GActionGroup *action_group,
+ gchar *action_name,
+ GVariant *value,
+ gpointer user_data)
+{
+ IndicatorMessages *self = user_data;
+
+ g_return_if_fail (g_variant_is_of_type (value, G_VARIANT_TYPE_BOOLEAN));
+
+ if (g_variant_get_boolean (value))
+ gtk_image_set_from_icon_name (GTK_IMAGE (self->image), "indicator-messages-new", GTK_ICON_SIZE_MENU);
+ else
+ gtk_image_set_from_icon_name (GTK_IMAGE (self->image), "indicator-messages", GTK_ICON_SIZE_MENU);
+}