diff options
author | Travis Reitter <treitter@gmail.com> | 2010-08-14 07:49:34 +0800 |
---|---|---|
committer | Travis Reitter <treitter@gmail.com> | 2010-08-16 23:59:01 +0800 |
commit | c643efd2670c2cfa708eea02db2bb98fc05d44a3 (patch) | |
tree | 6e677ac874dca7f1bd2f6f871a2c84f9d1a69fd2 | |
parent | 7bf345fee3e9fb42b5717ed9a51fb9f466a08e8f (diff) | |
download | gsoc2013-empathy-c643efd2670c2cfa708eea02db2bb98fc05d44a3.tar gsoc2013-empathy-c643efd2670c2cfa708eea02db2bb98fc05d44a3.tar.gz gsoc2013-empathy-c643efd2670c2cfa708eea02db2bb98fc05d44a3.tar.bz2 gsoc2013-empathy-c643efd2670c2cfa708eea02db2bb98fc05d44a3.tar.lz gsoc2013-empathy-c643efd2670c2cfa708eea02db2bb98fc05d44a3.tar.xz gsoc2013-empathy-c643efd2670c2cfa708eea02db2bb98fc05d44a3.tar.zst gsoc2013-empathy-c643efd2670c2cfa708eea02db2bb98fc05d44a3.zip |
Support previous conversations in the Personas menu.
-rw-r--r-- | libempathy-gtk/empathy-individual-menu.c | 55 | ||||
-rw-r--r-- | libempathy-gtk/empathy-individual-menu.h | 3 |
2 files changed, 33 insertions, 25 deletions
diff --git a/libempathy-gtk/empathy-individual-menu.c b/libempathy-gtk/empathy-individual-menu.c index 1bb4ffa56..e84312f61 100644 --- a/libempathy-gtk/empathy-individual-menu.c +++ b/libempathy-gtk/empathy-individual-menu.c @@ -219,7 +219,7 @@ empathy_individual_menu_new (FolksIndividual *individual, /* Log */ if (features & EMPATHY_INDIVIDUAL_FEATURE_LOG) { - item = empathy_individual_log_menu_item_new (individual); + item = empathy_individual_log_menu_item_new (individual, NULL); gtk_menu_shell_append (shell, item); gtk_widget_show (item); } @@ -565,34 +565,20 @@ empathy_individual_video_call_menu_item_new (FolksIndividual *individual, } static void -individual_log_menu_item_activate_cb (FolksIndividual *individual) +empathy_individual_log_menu_item_activated (GtkMenuItem *item, + EmpathyContact *contact) { - EmpathyContact *contact; - - contact = empathy_contact_dup_from_folks_individual (individual); - g_return_if_fail (EMPATHY_IS_CONTACT (contact)); empathy_log_window_show (empathy_contact_get_account (contact), empathy_contact_get_id (contact), FALSE, NULL); - - g_object_unref (contact); } -GtkWidget * -empathy_individual_log_menu_item_new (FolksIndividual *individual) +static gboolean +contact_has_log (EmpathyContact *contact) { TplLogManager *manager; gboolean have_log; - GtkWidget *item; - GtkWidget *image; - EmpathyContact *contact; - - g_return_val_if_fail (FOLKS_IS_INDIVIDUAL (individual), NULL); - - contact = empathy_contact_dup_from_folks_individual (individual); - - g_return_val_if_fail (EMPATHY_IS_CONTACT (contact), NULL); manager = tpl_log_manager_dup_singleton (); have_log = tpl_log_manager_exists (manager, @@ -600,16 +586,37 @@ empathy_individual_log_menu_item_new (FolksIndividual *individual) FALSE); g_object_unref (manager); + return have_log; +} + +GtkWidget * +empathy_individual_log_menu_item_new (FolksIndividual *individual, + EmpathyContact *contact) +{ + GtkWidget *item; + GtkWidget *image; + + g_return_val_if_fail (FOLKS_IS_INDIVIDUAL (individual) || + EMPATHY_IS_CONTACT (contact), + NULL); + item = gtk_image_menu_item_new_with_mnemonic (_("_Previous Conversations")); image = gtk_image_new_from_icon_name (EMPATHY_IMAGE_LOG, GTK_ICON_SIZE_MENU); gtk_image_menu_item_set_image (GTK_IMAGE_MENU_ITEM (item), image); - gtk_widget_set_sensitive (item, have_log); gtk_widget_show (image); - g_signal_connect_swapped (item, "activate", - G_CALLBACK (individual_log_menu_item_activate_cb), individual); - - g_object_unref (contact); + if (contact != NULL) + { + menu_item_set_contact (item, contact, + G_CALLBACK (empathy_individual_log_menu_item_activated), + contact_has_log); + } + else + { + menu_item_set_first_contact (item, individual, + G_CALLBACK (empathy_individual_log_menu_item_activated), + contact_has_log); + } return item; } diff --git a/libempathy-gtk/empathy-individual-menu.h b/libempathy-gtk/empathy-individual-menu.h index bfafb528d..a00de3dfb 100644 --- a/libempathy-gtk/empathy-individual-menu.h +++ b/libempathy-gtk/empathy-individual-menu.h @@ -50,7 +50,8 @@ GtkWidget * empathy_individual_audio_call_menu_item_new ( GtkWidget * empathy_individual_video_call_menu_item_new ( FolksIndividual *individual, EmpathyContact *contact); -GtkWidget * empathy_individual_log_menu_item_new (FolksIndividual *individual); +GtkWidget * empathy_individual_log_menu_item_new (FolksIndividual *individual, + EmpathyContact *contact); GtkWidget * empathy_individual_info_menu_item_new (FolksIndividual *individual); GtkWidget * empathy_individual_edit_menu_item_new (FolksIndividual *individual); GtkWidget * empathy_individual_link_menu_item_new (FolksIndividual *individual); |