diff options
author | Ted Gould <ted@canonical.com> | 2009-03-15 10:03:28 -0500 |
---|---|---|
committer | Ted Gould <ted@canonical.com> | 2009-03-15 10:03:28 -0500 |
commit | 6793aaa5123b0390e84cbef5b27a23e8325e334c (patch) | |
tree | b918bed7e95dfe883424569b13a4d87b5b51de5a | |
parent | c9f60d213f559fdd49e5cc4229658f8b30ad8533 (diff) | |
download | ayatana-indicator-messages-6793aaa5123b0390e84cbef5b27a23e8325e334c.tar.gz ayatana-indicator-messages-6793aaa5123b0390e84cbef5b27a23e8325e334c.tar.bz2 ayatana-indicator-messages-6793aaa5123b0390e84cbef5b27a23e8325e334c.zip |
Splitting the label updating into it's own function and making that called by the other functions that adjust how that happens.
-rw-r--r-- | src/app-menu-item.c | 34 |
1 files changed, 32 insertions, 2 deletions
diff --git a/src/app-menu-item.c b/src/app-menu-item.c index e0562cb..9923075 100644 --- a/src/app-menu-item.c +++ b/src/app-menu-item.c @@ -46,6 +46,7 @@ struct _AppMenuItemPrivate gchar * type; GAppInfo * appinfo; guint unreadcount; + gboolean count_on_label; GtkWidget * name; }; @@ -62,6 +63,7 @@ static void type_cb (IndicateListener * listener, IndicateListenerServer * serve static void desktop_cb (IndicateListener * listener, IndicateListenerServer * server, gchar * value, gpointer data); static void indicator_added_cb (IndicateListener * listener, IndicateListenerServer * server, IndicateListenerIndicator * indicator, gchar * type, gpointer data); static void indicator_removed_cb (IndicateListener * listener, IndicateListenerServer * server, IndicateListenerIndicator * indicator, gchar * type, gpointer data); +static void update_label (AppMenuItem * self); @@ -100,6 +102,7 @@ app_menu_item_init (AppMenuItem *self) priv->type = NULL; priv->appinfo = NULL; priv->unreadcount = 0; + priv->count_on_label = FALSE; return; @@ -156,6 +159,28 @@ type_cb (IndicateListener * listener, IndicateListenerServer * server, gchar * v priv->type = g_strdup(value); + if (g_strcmp0(priv->type, "message.im") || g_strcmp0(priv->type, "message.micro")) { + /* For IM and Microblogging we want the individual items, not a count */ + priv->count_on_label = TRUE; + update_label(self); + } + + return; +} + +static void +update_label (AppMenuItem * self) +{ + AppMenuItemPrivate * priv = APP_MENU_ITEM_GET_PRIVATE(self); + + if (priv->count_on_label && !priv->unreadcount < 1) { + gchar * label = g_strdup_printf(_("%s (%d)"), g_app_info_get_name(priv->appinfo), priv->unreadcount); + gtk_label_set_text(GTK_LABEL(priv->name), label); + g_free(label); + } else { + gtk_label_set_text(GTK_LABEL(priv->name), g_app_info_get_name(priv->appinfo)); + } + return; } @@ -172,7 +197,7 @@ desktop_cb (IndicateListener * listener, IndicateListenerServer * server, gchar priv->appinfo = G_APP_INFO(g_desktop_app_info_new_from_filename(value)); g_return_if_fail(priv->appinfo != NULL); - gtk_label_set_text(GTK_LABEL(priv->name), g_app_info_get_name(priv->appinfo)); + update_label(self); return; } @@ -199,6 +224,7 @@ indicator_added_cb (IndicateListener * listener, IndicateListenerServer * server priv->unreadcount++; + update_label(APP_MENU_ITEM(data)); g_signal_emit(G_OBJECT(data), signals[COUNT_CHANGED], 0, TRUE); return; @@ -214,8 +240,12 @@ indicator_removed_cb (IndicateListener * listener, IndicateListenerServer * serv return; } - priv->unreadcount--; + /* Should never happen, but let's have some protection on that */ + if (priv->unreadcount > 0) { + priv->unreadcount--; + } + update_label(APP_MENU_ITEM(data)); g_signal_emit(G_OBJECT(data), signals[COUNT_CHANGED], 0, TRUE); return; |