diff options
author | Jason Conti <jason.conti@gmail.com> | 2012-02-29 13:38:00 -0500 |
---|---|---|
committer | Jason Conti <jason.conti@gmail.com> | 2012-02-29 13:38:00 -0500 |
commit | ddc4a145f926715a94ca01f5dc3a96f6e12b0332 (patch) | |
tree | 072411e5316149fe84b620fa8ec6f3f518a34b48 | |
parent | 1ac07febc480f49dc9aaa308b1d17215ccf83da2 (diff) | |
download | ayatana-indicator-notifications-ddc4a145f926715a94ca01f5dc3a96f6e12b0332.tar.gz ayatana-indicator-notifications-ddc4a145f926715a94ca01f5dc3a96f6e12b0332.tar.bz2 ayatana-indicator-notifications-ddc4a145f926715a94ca01f5dc3a96f6e12b0332.zip |
* Implement secondary-activate to dismiss or reactivate the unread icon
on middle click.
-rw-r--r-- | src/indicator-notifications.c | 52 |
1 files changed, 42 insertions, 10 deletions
diff --git a/src/indicator-notifications.c b/src/indicator-notifications.c index 03b9099..ac9b016 100644 --- a/src/indicator-notifications.c +++ b/src/indicator-notifications.c @@ -104,12 +104,17 @@ static void indicator_notifications_finalize(GObject *object); static GtkImage *get_image(IndicatorObject *io); static GtkMenu *get_menu(IndicatorObject *io); static const gchar *get_accessible_desc(IndicatorObject *io); +static void indicator_notifications_middle_click(IndicatorObject *io, + IndicatorObjectEntry *entry, + guint time, + gpointer user_data); /* Utility Functions */ static void clear_menuitems(IndicatorNotifications *self); static void insert_menuitem(IndicatorNotifications *self, GtkWidget *item); static void remove_menuitem(IndicatorNotifications *self, GtkWidget *item); static GdkPixbuf *load_icon(const gchar *name, gint size); +static void set_unread(IndicatorNotifications *self, gboolean unread); static void update_clear_item_markup(IndicatorNotifications *self); /* Callbacks */ @@ -140,6 +145,7 @@ indicator_notifications_class_init(IndicatorNotificationsClass *klass) io_class->get_image = get_image; io_class->get_menu = get_menu; io_class->get_accessible_desc = get_accessible_desc; + io_class->secondary_activate = indicator_notifications_middle_click; return; } @@ -231,8 +237,6 @@ indicator_notifications_dispose(GObject *object) static void indicator_notifications_finalize(GObject *object) { - /*IndicatorNotifications *self = INDICATOR_NOTIFICATIONS(object);*/ - G_OBJECT_CLASS (indicator_notifications_parent_class)->finalize (object); return; } @@ -285,6 +289,16 @@ get_accessible_desc(IndicatorObject *io) return self->priv->accessible_desc; } +static void +indicator_notifications_middle_click(IndicatorObject *io, IndicatorObjectEntry *entry, + guint time, gpointer user_data) +{ + IndicatorNotifications *self = INDICATOR_NOTIFICATIONS(io); + + if(g_list_length(self->priv->visible_items) > 0) + set_unread(self, !self->priv->have_unread); +} + /** * clear_menuitems: * @self: the indicator @@ -433,6 +447,30 @@ load_icon(const gchar *name, gint size) } /** + * set_unread: + * @self: the indicator object + * @unread: the unread status + * + * Sets the unread status of the indicator and updates the icons. + **/ +static void +set_unread(IndicatorNotifications *self, gboolean unread) +{ + g_return_if_fail(IS_INDICATOR_NOTIFICATIONS(self)); + + if(unread) { + if(self->priv->pixbuf_unread != NULL) + gtk_image_set_from_pixbuf(self->priv->image, self->priv->pixbuf_unread); + } + else { + if(self->priv->pixbuf_read != NULL) + gtk_image_set_from_pixbuf(self->priv->image, self->priv->pixbuf_read); + } + + self->priv->have_unread = unread; +} + +/** * update_clear_item_markup: * @self: the indicator object * @@ -492,10 +530,7 @@ menu_visible_notify_cb(GtkWidget *menu, G_GNUC_UNUSED GParamSpec *pspec, gpointe gboolean visible; g_object_get(G_OBJECT(menu), "visible", &visible, NULL); if(!visible) { - if(self->priv->pixbuf_read != NULL) { - self->priv->have_unread = FALSE; - gtk_image_set_from_pixbuf(self->priv->image, self->priv->pixbuf_read); - } + set_unread(self, FALSE); } } @@ -527,10 +562,7 @@ message_received_cb(DBusSpy *spy, Notification *note, gpointer user_data) insert_menuitem(self, item); - if(self->priv->pixbuf_unread != NULL) { - self->priv->have_unread = TRUE; - gtk_image_set_from_pixbuf(self->priv->image, self->priv->pixbuf_unread); - } + set_unread(self, TRUE); } /** |