1 /* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
3 * Copyright (C) 2006-2007 Imendio AB
4 * Copyright (C) 2007-2008 Collabora Ltd.
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License as
8 * published by the Free Software Foundation; either version 2 of the
9 * License, or (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * General Public License for more details.
16 * You should have received a copy of the GNU General Public
17 * License along with this program; if not, write to the
18 * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
19 * Boston, MA 02110-1301 USA
21 * Authors: Martyn Russell <martyn@imendio.com>
22 * Xavier Claessens <xclaesse@gmail.com>
30 #include <glib/gi18n-lib.h>
33 #include <telepathy-glib/account-manager.h>
35 #include <libempathy/empathy-log-manager.h>
36 #include <libempathy/empathy-chatroom-manager.h>
37 #include <libempathy/empathy-chatroom.h>
38 #include <libempathy/empathy-message.h>
39 #include <libempathy/empathy-utils.h>
40 #include <libempathy/empathy-time.h>
42 #include "empathy-log-window.h"
43 #include "empathy-account-chooser.h"
44 #include "empathy-chat-view.h"
45 #include "empathy-theme-manager.h"
46 #include "empathy-ui-utils.h"
48 #define DEBUG_FLAG EMPATHY_DEBUG_OTHER
49 #include <libempathy/empathy-debug.h>
56 GtkWidget *entry_find;
57 GtkWidget *button_find;
58 GtkWidget *treeview_find;
59 GtkWidget *scrolledwindow_find;
60 EmpathyChatView *chatview_find;
61 GtkWidget *button_previous;
62 GtkWidget *button_next;
64 GtkWidget *vbox_chats;
65 GtkWidget *account_chooser_chats;
66 GtkWidget *entry_chats;
67 GtkWidget *calendar_chats;
68 GtkWidget *treeview_chats;
69 GtkWidget *scrolledwindow_chats;
70 EmpathyChatView *chatview_chats;
74 EmpathyLogManager *log_manager;
76 /* Those are only used while waiting for the account chooser to be ready */
77 TpAccount *selected_account;
78 gchar *selected_chat_id;
79 gboolean selected_is_chatroom;
82 static void log_window_destroy_cb (GtkWidget *widget,
83 EmpathyLogWindow *window);
84 static void log_window_entry_find_changed_cb (GtkWidget *entry,
85 EmpathyLogWindow *window);
86 static void log_window_find_changed_cb (GtkTreeSelection *selection,
87 EmpathyLogWindow *window);
88 static void log_window_find_populate (EmpathyLogWindow *window,
89 const gchar *search_criteria);
90 static void log_window_find_setup (EmpathyLogWindow *window);
91 static void log_window_button_find_clicked_cb (GtkWidget *widget,
92 EmpathyLogWindow *window);
93 static void log_window_button_next_clicked_cb (GtkWidget *widget,
94 EmpathyLogWindow *window);
95 static void log_window_button_previous_clicked_cb (GtkWidget *widget,
96 EmpathyLogWindow *window);
97 static void log_window_chats_changed_cb (GtkTreeSelection *selection,
98 EmpathyLogWindow *window);
99 static void log_window_chats_populate (EmpathyLogWindow *window);
100 static void log_window_chats_setup (EmpathyLogWindow *window);
101 static void log_window_chats_accounts_changed_cb (GtkWidget *combobox,
102 EmpathyLogWindow *window);
103 static void log_window_chats_set_selected (EmpathyLogWindow *window,
105 const gchar *chat_id,
106 gboolean is_chatroom);
107 static gboolean log_window_chats_get_selected (EmpathyLogWindow *window,
110 gboolean *is_chatroom);
111 static void log_window_chats_get_messages (EmpathyLogWindow *window,
112 const gchar *date_to_show);
113 static void log_window_calendar_chats_day_selected_cb (GtkWidget *calendar,
114 EmpathyLogWindow *window);
115 static void log_window_calendar_chats_month_changed_cb (GtkWidget *calendar,
116 EmpathyLogWindow *window);
117 static void log_window_entry_chats_changed_cb (GtkWidget *entry,
118 EmpathyLogWindow *window);
119 static void log_window_entry_chats_activate_cb (GtkWidget *entry,
120 EmpathyLogWindow *window);
123 COL_FIND_ACCOUNT_ICON,
124 COL_FIND_ACCOUNT_NAME,
128 COL_FIND_IS_CHATROOM,
130 COL_FIND_DATE_READABLE,
139 COL_CHAT_IS_CHATROOM,
144 account_manager_prepared_cb (GObject *source_object,
145 GAsyncResult *result,
148 TpAccountManager *account_manager = TP_ACCOUNT_MANAGER (source_object);
149 EmpathyLogWindow *window = user_data;
152 GError *error = NULL;
154 if (!tp_account_manager_prepare_finish (account_manager, result, &error)) {
155 DEBUG ("Failed to prepare account manager: %s", error->message);
156 g_error_free (error);
160 accounts = tp_account_manager_get_valid_accounts (account_manager);
161 account_num = g_list_length (accounts);
162 g_list_free (accounts);
164 if (account_num > 1) {
165 gtk_widget_show (window->vbox_chats);
166 gtk_widget_show (window->account_chooser_chats);
168 gtk_widget_hide (window->vbox_chats);
169 gtk_widget_hide (window->account_chooser_chats);
174 account_chooser_ready_cb (EmpathyAccountChooser *chooser,
175 EmpathyLogWindow *window)
177 gtk_notebook_set_current_page (GTK_NOTEBOOK (window->notebook), 1);
178 log_window_chats_set_selected (window, window->selected_account,
179 window->selected_chat_id, window->selected_is_chatroom);
183 empathy_log_window_show (TpAccount *account,
184 const gchar *chat_id,
185 gboolean is_chatroom,
188 static EmpathyLogWindow *window = NULL;
189 EmpathyAccountChooser *account_chooser;
190 TpAccountManager *account_manager;
195 gtk_window_present (GTK_WINDOW (window->window));
197 if (account && chat_id) {
198 gtk_notebook_set_current_page (GTK_NOTEBOOK (window->notebook), 1);
199 log_window_chats_set_selected (window, account,
200 chat_id, is_chatroom);
203 return window->window;
206 window = g_new0 (EmpathyLogWindow, 1);
207 window->log_manager = empathy_log_manager_dup_singleton ();
209 filename = empathy_file_lookup ("empathy-log-window.ui",
211 gui = empathy_builder_get_file (filename,
212 "log_window", &window->window,
213 "notebook", &window->notebook,
214 "entry_find", &window->entry_find,
215 "button_find", &window->button_find,
216 "treeview_find", &window->treeview_find,
217 "scrolledwindow_find", &window->scrolledwindow_find,
218 "button_previous", &window->button_previous,
219 "button_next", &window->button_next,
220 "entry_chats", &window->entry_chats,
221 "calendar_chats", &window->calendar_chats,
222 "vbox_chats", &window->vbox_chats,
223 "treeview_chats", &window->treeview_chats,
224 "scrolledwindow_chats", &window->scrolledwindow_chats,
228 empathy_builder_connect (gui, window,
229 "log_window", "destroy", log_window_destroy_cb,
230 "entry_find", "changed", log_window_entry_find_changed_cb,
231 "button_previous", "clicked", log_window_button_previous_clicked_cb,
232 "button_next", "clicked", log_window_button_next_clicked_cb,
233 "button_find", "clicked", log_window_button_find_clicked_cb,
234 "entry_chats", "changed", log_window_entry_chats_changed_cb,
235 "entry_chats", "activate", log_window_entry_chats_activate_cb,
238 g_object_unref (gui);
240 g_object_add_weak_pointer (G_OBJECT (window->window),
243 /* We set this up here so we can block it when needed. */
244 g_signal_connect (window->calendar_chats, "day-selected",
245 G_CALLBACK (log_window_calendar_chats_day_selected_cb),
247 g_signal_connect (window->calendar_chats, "month-changed",
248 G_CALLBACK (log_window_calendar_chats_month_changed_cb),
251 /* Configure Search EmpathyChatView */
252 window->chatview_find = empathy_theme_manager_create_view (empathy_theme_manager_get ());
253 gtk_container_add (GTK_CONTAINER (window->scrolledwindow_find),
254 GTK_WIDGET (window->chatview_find));
255 gtk_widget_show (GTK_WIDGET (window->chatview_find));
257 /* Configure Contacts EmpathyChatView */
258 window->chatview_chats = empathy_theme_manager_create_view (empathy_theme_manager_get ());
259 gtk_container_add (GTK_CONTAINER (window->scrolledwindow_chats),
260 GTK_WIDGET (window->chatview_chats));
261 gtk_widget_show (GTK_WIDGET (window->chatview_chats));
263 /* Account chooser for chats */
264 window->account_chooser_chats = empathy_account_chooser_new ();
265 account_chooser = EMPATHY_ACCOUNT_CHOOSER (window->account_chooser_chats);
267 gtk_box_pack_start (GTK_BOX (window->vbox_chats),
268 window->account_chooser_chats,
271 g_signal_connect (window->account_chooser_chats, "changed",
272 G_CALLBACK (log_window_chats_accounts_changed_cb),
276 account_manager = tp_account_manager_dup ();
277 tp_account_manager_prepare_async (account_manager, NULL,
278 account_manager_prepared_cb, window);
279 g_object_unref (account_manager);
282 log_window_find_setup (window);
285 log_window_chats_setup (window);
286 log_window_chats_populate (window);
288 /* Chat will be selected once the account chooser is ready */
289 if (account && chat_id) {
290 g_signal_connect (account_chooser, "ready",
291 G_CALLBACK (account_chooser_ready_cb), window);
292 window->selected_account = account;
293 window->selected_chat_id = g_strdup (chat_id);
294 window->selected_is_chatroom = is_chatroom;
298 gtk_window_set_transient_for (GTK_WINDOW (window->window),
299 GTK_WINDOW (parent));
302 gtk_widget_show (window->window);
304 return window->window;
308 log_window_destroy_cb (GtkWidget *widget,
309 EmpathyLogWindow *window)
311 g_free (window->last_find);
312 g_object_unref (window->log_manager);
313 g_free (window->selected_chat_id);
322 log_window_entry_find_changed_cb (GtkWidget *entry,
323 EmpathyLogWindow *window)
326 gboolean is_sensitive = TRUE;
328 str = gtk_entry_get_text (GTK_ENTRY (window->entry_find));
330 is_sensitive &= !EMP_STR_EMPTY (str);
332 !window->last_find ||
333 (window->last_find && strcmp (window->last_find, str) != 0);
335 gtk_widget_set_sensitive (window->button_find, is_sensitive);
339 log_window_find_changed_cb (GtkTreeSelection *selection,
340 EmpathyLogWindow *window)
347 gboolean is_chatroom;
349 EmpathyMessage *message;
352 gboolean can_do_previous;
353 gboolean can_do_next;
355 /* Get selected information */
356 view = GTK_TREE_VIEW (window->treeview_find);
357 model = gtk_tree_view_get_model (view);
359 if (!gtk_tree_selection_get_selected (selection, NULL, &iter)) {
360 gtk_widget_set_sensitive (window->button_previous, FALSE);
361 gtk_widget_set_sensitive (window->button_next, FALSE);
363 empathy_chat_view_clear (window->chatview_find);
368 gtk_widget_set_sensitive (window->button_previous, TRUE);
369 gtk_widget_set_sensitive (window->button_next, TRUE);
371 gtk_tree_model_get (model, &iter,
372 COL_FIND_ACCOUNT, &account,
373 COL_FIND_CHAT_ID, &chat_id,
374 COL_FIND_IS_CHATROOM, &is_chatroom,
375 COL_FIND_DATE, &date,
378 /* Clear all current messages shown in the textview */
379 empathy_chat_view_clear (window->chatview_find);
381 /* Turn off scrolling temporarily */
382 empathy_chat_view_scroll (window->chatview_find, FALSE);
385 messages = empathy_log_manager_get_messages_for_date (window->log_manager,
390 g_object_unref (account);
394 for (l = messages; l; l = l->next) {
396 empathy_chat_view_append_message (window->chatview_find, message);
397 g_object_unref (message);
399 g_list_free (messages);
401 /* Scroll to the most recent messages */
402 empathy_chat_view_scroll (window->chatview_find, TRUE);
404 /* Highlight and find messages */
405 empathy_chat_view_highlight (window->chatview_find,
407 empathy_chat_view_find_next (window->chatview_find,
410 empathy_chat_view_find_abilities (window->chatview_find,
414 gtk_widget_set_sensitive (window->button_previous, can_do_previous);
415 gtk_widget_set_sensitive (window->button_next, can_do_next);
416 gtk_widget_set_sensitive (window->button_find, FALSE);
420 log_window_find_populate (EmpathyLogWindow *window,
421 const gchar *search_criteria)
427 GtkTreeSelection *selection;
431 view = GTK_TREE_VIEW (window->treeview_find);
432 model = gtk_tree_view_get_model (view);
433 selection = gtk_tree_view_get_selection (view);
434 store = GTK_LIST_STORE (model);
436 empathy_chat_view_clear (window->chatview_find);
438 gtk_list_store_clear (store);
440 if (EMP_STR_EMPTY (search_criteria)) {
441 /* Just clear the search. */
445 hits = empathy_log_manager_search_new (window->log_manager, search_criteria);
447 for (l = hits; l; l = l->next) {
448 EmpathyLogSearchHit *hit;
449 const gchar *account_name;
450 const gchar *account_icon;
451 gchar *date_readable;
455 /* Protect against invalid data (corrupt or old log files. */
456 if (!hit->account || !hit->chat_id) {
460 date_readable = empathy_log_manager_get_date_readable (hit->date);
461 account_name = tp_account_get_display_name (hit->account);
462 account_icon = tp_account_get_icon_name (hit->account);
464 gtk_list_store_append (store, &iter);
465 gtk_list_store_set (store, &iter,
466 COL_FIND_ACCOUNT_ICON, account_icon,
467 COL_FIND_ACCOUNT_NAME, account_name,
468 COL_FIND_ACCOUNT, hit->account,
469 COL_FIND_CHAT_NAME, hit->chat_id, /* FIXME */
470 COL_FIND_CHAT_ID, hit->chat_id,
471 COL_FIND_IS_CHATROOM, hit->is_chatroom,
472 COL_FIND_DATE, hit->date,
473 COL_FIND_DATE_READABLE, date_readable,
476 g_free (date_readable);
478 /* FIXME: Update COL_FIND_CHAT_NAME */
479 if (hit->is_chatroom) {
485 empathy_log_manager_search_free (hits);
490 log_window_find_setup (EmpathyLogWindow *window)
494 GtkTreeSelection *selection;
495 GtkTreeSortable *sortable;
496 GtkTreeViewColumn *column;
498 GtkCellRenderer *cell;
501 view = GTK_TREE_VIEW (window->treeview_find);
502 selection = gtk_tree_view_get_selection (view);
505 store = gtk_list_store_new (COL_FIND_COUNT,
506 G_TYPE_STRING, /* account icon name */
507 G_TYPE_STRING, /* account name */
508 TP_TYPE_ACCOUNT, /* account */
509 G_TYPE_STRING, /* chat name */
510 G_TYPE_STRING, /* chat id */
511 G_TYPE_BOOLEAN, /* is chatroom */
512 G_TYPE_STRING, /* date */
513 G_TYPE_STRING); /* date_readable */
515 model = GTK_TREE_MODEL (store);
516 sortable = GTK_TREE_SORTABLE (store);
518 gtk_tree_view_set_model (view, model);
521 column = gtk_tree_view_column_new ();
523 cell = gtk_cell_renderer_pixbuf_new ();
524 gtk_tree_view_column_pack_start (column, cell, FALSE);
525 gtk_tree_view_column_add_attribute (column, cell,
527 COL_FIND_ACCOUNT_ICON);
529 cell = gtk_cell_renderer_text_new ();
530 gtk_tree_view_column_pack_start (column, cell, TRUE);
531 gtk_tree_view_column_add_attribute (column, cell,
533 COL_FIND_ACCOUNT_NAME);
535 gtk_tree_view_column_set_title (column, _("Account"));
536 gtk_tree_view_append_column (view, column);
538 gtk_tree_view_column_set_resizable (column, TRUE);
539 gtk_tree_view_column_set_clickable (column, TRUE);
541 cell = gtk_cell_renderer_text_new ();
542 offset = gtk_tree_view_insert_column_with_attributes (view, -1, _("Conversation"),
543 cell, "text", COL_FIND_CHAT_NAME,
546 column = gtk_tree_view_get_column (view, offset - 1);
547 gtk_tree_view_column_set_sort_column_id (column, COL_FIND_CHAT_NAME);
548 gtk_tree_view_column_set_resizable (column, TRUE);
549 gtk_tree_view_column_set_clickable (column, TRUE);
551 cell = gtk_cell_renderer_text_new ();
552 offset = gtk_tree_view_insert_column_with_attributes (view, -1, _("Date"),
553 cell, "text", COL_FIND_DATE_READABLE,
556 column = gtk_tree_view_get_column (view, offset - 1);
557 gtk_tree_view_column_set_sort_column_id (column, COL_FIND_DATE);
558 gtk_tree_view_column_set_resizable (column, TRUE);
559 gtk_tree_view_column_set_clickable (column, TRUE);
561 /* Set up treeview properties */
562 gtk_tree_selection_set_mode (selection, GTK_SELECTION_SINGLE);
563 gtk_tree_sortable_set_sort_column_id (sortable,
568 g_signal_connect (selection, "changed",
569 G_CALLBACK (log_window_find_changed_cb),
572 g_object_unref (store);
576 log_window_button_find_clicked_cb (GtkWidget *widget,
577 EmpathyLogWindow *window)
581 str = gtk_entry_get_text (GTK_ENTRY (window->entry_find));
583 /* Don't find the same crap again */
584 if (window->last_find && strcmp (window->last_find, str) == 0) {
588 g_free (window->last_find);
589 window->last_find = g_strdup (str);
591 log_window_find_populate (window, str);
595 log_window_button_next_clicked_cb (GtkWidget *widget,
596 EmpathyLogWindow *window)
598 if (window->last_find) {
599 gboolean can_do_previous;
600 gboolean can_do_next;
602 empathy_chat_view_find_next (window->chatview_find,
605 empathy_chat_view_find_abilities (window->chatview_find,
609 gtk_widget_set_sensitive (window->button_previous, can_do_previous);
610 gtk_widget_set_sensitive (window->button_next, can_do_next);
615 log_window_button_previous_clicked_cb (GtkWidget *widget,
616 EmpathyLogWindow *window)
618 if (window->last_find) {
619 gboolean can_do_previous;
620 gboolean can_do_next;
622 empathy_chat_view_find_previous (window->chatview_find,
625 empathy_chat_view_find_abilities (window->chatview_find,
629 gtk_widget_set_sensitive (window->button_previous, can_do_previous);
630 gtk_widget_set_sensitive (window->button_next, can_do_next);
639 log_window_chats_changed_cb (GtkTreeSelection *selection,
640 EmpathyLogWindow *window)
642 /* Use last date by default */
643 gtk_calendar_clear_marks (GTK_CALENDAR (window->calendar_chats));
645 log_window_chats_get_messages (window, NULL);
649 log_window_chats_populate (EmpathyLogWindow *window)
651 EmpathyAccountChooser *account_chooser;
657 GtkTreeSelection *selection;
661 account_chooser = EMPATHY_ACCOUNT_CHOOSER (window->account_chooser_chats);
662 account = empathy_account_chooser_dup_account (account_chooser);
664 view = GTK_TREE_VIEW (window->treeview_chats);
665 model = gtk_tree_view_get_model (view);
666 selection = gtk_tree_view_get_selection (view);
667 store = GTK_LIST_STORE (model);
669 if (account == NULL) {
670 gtk_list_store_clear (store);
674 /* Block signals to stop the logs being retrieved prematurely */
675 g_signal_handlers_block_by_func (selection,
676 log_window_chats_changed_cb,
679 gtk_list_store_clear (store);
681 chats = empathy_log_manager_get_chats (window->log_manager, account);
682 for (l = chats; l; l = l->next) {
683 EmpathyLogSearchHit *hit;
687 gtk_list_store_append (store, &iter);
688 gtk_list_store_set (store, &iter,
689 COL_CHAT_ICON, "empathy-available", /* FIXME */
690 COL_CHAT_NAME, hit->chat_id,
691 COL_CHAT_ACCOUNT, account,
692 COL_CHAT_ID, hit->chat_id,
693 COL_CHAT_IS_CHATROOM, hit->is_chatroom,
696 /* FIXME: Update COL_CHAT_ICON/NAME */
697 if (hit->is_chatroom) {
701 empathy_log_manager_search_free (chats);
703 /* Unblock signals */
704 g_signal_handlers_unblock_by_func (selection,
705 log_window_chats_changed_cb,
709 g_object_unref (account);
713 log_window_chats_setup (EmpathyLogWindow *window)
717 GtkTreeSelection *selection;
718 GtkTreeSortable *sortable;
719 GtkTreeViewColumn *column;
721 GtkCellRenderer *cell;
723 view = GTK_TREE_VIEW (window->treeview_chats);
724 selection = gtk_tree_view_get_selection (view);
727 store = gtk_list_store_new (COL_CHAT_COUNT,
728 G_TYPE_STRING, /* icon */
729 G_TYPE_STRING, /* name */
730 TP_TYPE_ACCOUNT, /* account */
731 G_TYPE_STRING, /* id */
732 G_TYPE_BOOLEAN); /* is chatroom */
734 model = GTK_TREE_MODEL (store);
735 sortable = GTK_TREE_SORTABLE (store);
737 gtk_tree_view_set_model (view, model);
740 column = gtk_tree_view_column_new ();
742 cell = gtk_cell_renderer_pixbuf_new ();
743 gtk_tree_view_column_pack_start (column, cell, FALSE);
744 gtk_tree_view_column_add_attribute (column, cell,
748 cell = gtk_cell_renderer_text_new ();
749 g_object_set (cell, "ellipsize", PANGO_ELLIPSIZE_END, NULL);
750 gtk_tree_view_column_pack_start (column, cell, TRUE);
751 gtk_tree_view_column_add_attribute (column, cell,
755 gtk_tree_view_append_column (view, column);
757 /* set up treeview properties */
758 gtk_tree_selection_set_mode (selection, GTK_SELECTION_SINGLE);
759 gtk_tree_sortable_set_sort_column_id (sortable,
764 g_signal_connect (selection, "changed",
765 G_CALLBACK (log_window_chats_changed_cb),
768 g_object_unref (store);
772 log_window_chats_accounts_changed_cb (GtkWidget *combobox,
773 EmpathyLogWindow *window)
775 /* Clear all current messages shown in the textview */
776 empathy_chat_view_clear (window->chatview_chats);
778 log_window_chats_populate (window);
782 log_window_chats_set_selected (EmpathyLogWindow *window,
784 const gchar *chat_id,
785 gboolean is_chatroom)
787 EmpathyAccountChooser *account_chooser;
790 GtkTreeSelection *selection;
795 account_chooser = EMPATHY_ACCOUNT_CHOOSER (window->account_chooser_chats);
796 empathy_account_chooser_set_account (account_chooser, account);
798 view = GTK_TREE_VIEW (window->treeview_chats);
799 model = gtk_tree_view_get_model (view);
800 selection = gtk_tree_view_get_selection (view);
802 if (!gtk_tree_model_get_iter_first (model, &iter)) {
806 for (ok = TRUE; ok; ok = gtk_tree_model_iter_next (model, &iter)) {
807 TpAccount *this_account;
809 gboolean this_is_chatroom;
811 gtk_tree_model_get (model, &iter,
812 COL_CHAT_ACCOUNT, &this_account,
813 COL_CHAT_ID, &this_chat_id,
814 COL_CHAT_IS_CHATROOM, &this_is_chatroom,
817 if (this_account == account &&
818 strcmp (this_chat_id, chat_id) == 0 &&
819 this_is_chatroom == is_chatroom) {
820 gtk_tree_selection_select_iter (selection, &iter);
821 path = gtk_tree_model_get_path (model, &iter);
822 gtk_tree_view_scroll_to_cell (view, path, NULL, TRUE, 0.5, 0.0);
823 gtk_tree_path_free (path);
824 g_object_unref (this_account);
825 g_free (this_chat_id);
829 g_object_unref (this_account);
830 g_free (this_chat_id);
835 log_window_chats_get_selected (EmpathyLogWindow *window,
838 gboolean *is_chatroom)
842 GtkTreeSelection *selection;
845 TpAccount *acc = NULL;
846 gboolean room = FALSE;
848 view = GTK_TREE_VIEW (window->treeview_chats);
849 model = gtk_tree_view_get_model (view);
850 selection = gtk_tree_view_get_selection (view);
852 if (!gtk_tree_selection_get_selected (selection, NULL, &iter)) {
856 gtk_tree_model_get (model, &iter,
857 COL_CHAT_ACCOUNT, &acc,
859 COL_CHAT_IS_CHATROOM, &room,
870 g_object_unref (acc);
880 log_window_chats_get_messages (EmpathyLogWindow *window,
881 const gchar *date_to_show)
885 gboolean is_chatroom;
886 EmpathyMessage *message;
894 guint month_selected;
897 if (!log_window_chats_get_selected (window, &account,
898 &chat_id, &is_chatroom)) {
902 g_signal_handlers_block_by_func (window->calendar_chats,
903 log_window_calendar_chats_day_selected_cb,
906 /* Either use the supplied date or get the last */
909 gboolean day_selected = FALSE;
911 /* Get a list of dates and show them on the calendar */
912 dates = empathy_log_manager_get_dates (window->log_manager,
916 for (l = dates; l; l = l->next) {
924 sscanf (str, "%4d%2d%2d", &year, &month, &day);
925 gtk_calendar_get_date (GTK_CALENDAR (window->calendar_chats),
936 if (year != year_selected || month != month_selected) {
941 DEBUG ("Marking date:'%s'", str);
942 gtk_calendar_mark_day (GTK_CALENDAR (window->calendar_chats), day);
950 gtk_calendar_select_day (GTK_CALENDAR (window->calendar_chats), day);
954 /* Unselect the day in the calendar */
955 gtk_calendar_select_day (GTK_CALENDAR (window->calendar_chats), 0);
958 sscanf (date, "%4d%2d%2d", &year, &month, &day);
959 gtk_calendar_get_date (GTK_CALENDAR (window->calendar_chats),
966 if (year != year_selected && month != month_selected) {
970 gtk_calendar_select_day (GTK_CALENDAR (window->calendar_chats), day);
973 g_signal_handlers_unblock_by_func (window->calendar_chats,
974 log_window_calendar_chats_day_selected_cb,
981 /* Clear all current messages shown in the textview */
982 empathy_chat_view_clear (window->chatview_chats);
984 /* Turn off scrolling temporarily */
985 empathy_chat_view_scroll (window->chatview_find, FALSE);
988 messages = empathy_log_manager_get_messages_for_date (window->log_manager,
993 for (l = messages; l; l = l->next) {
996 empathy_chat_view_append_message (window->chatview_chats,
998 g_object_unref (message);
1000 g_list_free (messages);
1002 /* Turn back on scrolling */
1003 empathy_chat_view_scroll (window->chatview_find, TRUE);
1005 /* Give the search entry main focus */
1006 gtk_widget_grab_focus (window->entry_chats);
1009 g_list_foreach (dates, (GFunc) g_free, NULL);
1010 g_list_free (dates);
1011 g_object_unref (account);
1016 log_window_calendar_chats_day_selected_cb (GtkWidget *calendar,
1017 EmpathyLogWindow *window)
1025 gtk_calendar_get_date (GTK_CALENDAR (calendar), &year, &month, &day);
1027 /* We need this hear because it appears that the months start from 0 */
1030 date = g_strdup_printf ("%4.4d%2.2d%2.2d", year, month, day);
1032 DEBUG ("Currently selected date is:'%s'", date);
1034 log_window_chats_get_messages (window, date);
1040 log_window_calendar_chats_month_changed_cb (GtkWidget *calendar,
1041 EmpathyLogWindow *window)
1045 gboolean is_chatroom;
1046 guint year_selected;
1047 guint month_selected;
1052 gtk_calendar_clear_marks (GTK_CALENDAR (calendar));
1054 if (!log_window_chats_get_selected (window, &account,
1055 &chat_id, &is_chatroom)) {
1056 DEBUG ("No chat selected to get dates for...");
1060 g_object_get (calendar,
1061 "month", &month_selected,
1062 "year", &year_selected,
1065 /* We need this hear because it appears that the months start from 0 */
1068 /* Get the log object for this contact */
1069 dates = empathy_log_manager_get_dates (window->log_manager, account,
1070 chat_id, is_chatroom);
1071 g_object_unref (account);
1074 for (l = dates; l; l = l->next) {
1085 sscanf (str, "%4d%2d%2d", &year, &month, &day);
1087 if (year == year_selected && month == month_selected) {
1088 DEBUG ("Marking date:'%s'", str);
1089 gtk_calendar_mark_day (GTK_CALENDAR (window->calendar_chats), day);
1093 g_list_foreach (dates, (GFunc) g_free, NULL);
1094 g_list_free (dates);
1096 DEBUG ("Currently showing month %d and year %d", month_selected,
1101 log_window_entry_chats_changed_cb (GtkWidget *entry,
1102 EmpathyLogWindow *window)
1106 str = gtk_entry_get_text (GTK_ENTRY (window->entry_chats));
1107 empathy_chat_view_highlight (window->chatview_chats, str);
1110 empathy_chat_view_find_next (window->chatview_chats,
1117 log_window_entry_chats_activate_cb (GtkWidget *entry,
1118 EmpathyLogWindow *window)
1122 str = gtk_entry_get_text (GTK_ENTRY (window->entry_chats));
1125 empathy_chat_view_find_next (window->chatview_chats,