[empathy] Add 'favorite' checkbox to the contact menu
- From: Guillaume Desmottes <gdesmott src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [empathy] Add 'favorite' checkbox to the contact menu
- Date: Mon, 15 Mar 2010 08:29:55 +0000 (UTC)
commit 8df2cf237283de1b049b4c24b0906384e45c4320
Author: Guillaume Desmottes <guillaume desmottes collabora co uk>
Date: Tue Mar 9 11:20:33 2010 +0100
Add 'favorite' checkbox to the contact menu
libempathy-gtk/empathy-contact-menu.c | 49 +++++++++++++++++++++++++++++++++
libempathy-gtk/empathy-contact-menu.h | 1 +
2 files changed, 50 insertions(+), 0 deletions(-)
---
diff --git a/libempathy-gtk/empathy-contact-menu.c b/libempathy-gtk/empathy-contact-menu.c
index 54bb4b2..47f68e8 100644
--- a/libempathy-gtk/empathy-contact-menu.c
+++ b/libempathy-gtk/empathy-contact-menu.c
@@ -112,6 +112,13 @@ empathy_contact_menu_new (EmpathyContact *contact,
gtk_menu_shell_append (shell, item);
gtk_widget_show (item);
+#if HAVE_FAVOURITE_CONTACTS
+ /* Favorite checkbox */
+ item = empathy_contact_favourite_menu_item_new (contact);
+ gtk_menu_shell_append (shell, item);
+ gtk_widget_show (item);
+#endif
+
/* Separator */
if (features & (EMPATHY_CONTACT_FEATURE_EDIT |
EMPATHY_CONTACT_FEATURE_INFO)) {
@@ -396,6 +403,48 @@ empathy_contact_share_my_desktop_menu_item_new (EmpathyContact *contact)
return item;
}
+#if HAVE_FAVOURITE_CONTACTS
+static void
+favourite_menu_item_toggled_cb (GtkCheckMenuItem *item,
+ EmpathyContact *contact)
+{
+ EmpathyContactManager *manager;
+ EmpathyContactList *list;
+
+ manager = empathy_contact_manager_dup_singleton ();
+ list = EMPATHY_CONTACT_LIST (manager);
+
+ if (gtk_check_menu_item_get_active (item)) {
+ empathy_contact_list_add_to_favourites (list, contact);
+ } else {
+ empathy_contact_list_remove_from_favourites (list, contact);
+ }
+
+ g_object_unref (manager);
+}
+
+GtkWidget *
+empathy_contact_favourite_menu_item_new (EmpathyContact *contact)
+{
+ GtkWidget *item;
+ EmpathyContactManager *manager;
+
+ item = gtk_check_menu_item_new_with_label (_("Favorite"));
+
+ manager = empathy_contact_manager_dup_singleton ();
+ gtk_check_menu_item_set_active (GTK_CHECK_MENU_ITEM (item),
+ empathy_contact_list_is_favourite (EMPATHY_CONTACT_LIST (manager),
+ contact));
+
+ g_signal_connect (item, "toggled",
+ G_CALLBACK (favourite_menu_item_toggled_cb),
+ contact);
+
+ g_object_unref (manager);
+ return item;
+}
+#endif
+
static void
contact_info_menu_item_activate_cb (EmpathyContact *contact)
{
diff --git a/libempathy-gtk/empathy-contact-menu.h b/libempathy-gtk/empathy-contact-menu.h
index 2c623e6..25f18e0 100644
--- a/libempathy-gtk/empathy-contact-menu.h
+++ b/libempathy-gtk/empathy-contact-menu.h
@@ -50,6 +50,7 @@ GtkWidget * empathy_contact_edit_menu_item_new (EmpathyContact *cont
GtkWidget * empathy_contact_invite_menu_item_new (EmpathyContact *contact);
GtkWidget * empathy_contact_file_transfer_menu_item_new (EmpathyContact *contact);
GtkWidget * empathy_contact_share_my_desktop_menu_item_new (EmpathyContact *contact);
+GtkWidget * empathy_contact_favourite_menu_item_new (EmpathyContact *contact);
G_END_DECLS
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]