From c17d91d81999edd94cd4417acb8e39491076098b Mon Sep 17 00:00:00 2001 From: Xavier Claessens Date: Wed, 2 Apr 2008 09:41:46 +0000 Subject: Move window's glade to empathy-chat-window.glade. Reorder empathy-chat-window.c svn path=/trunk/; revision=839 --- src/empathy-chat-window.c | 934 ++++++++++++++++++------------------------ src/empathy-chat-window.glade | 478 +++++++++++++++++++++ 2 files changed, 884 insertions(+), 528 deletions(-) create mode 100644 src/empathy-chat-window.glade (limited to 'src') diff --git a/src/empathy-chat-window.c b/src/empathy-chat-window.c index 65a706c17..898f54961 100644 --- a/src/empathy-chat-window.c +++ b/src/empathy-chat-window.c @@ -46,8 +46,6 @@ #include #include -#include -#include #include #include #include @@ -63,17 +61,15 @@ struct _EmpathyChatWindowPriv { EmpathyChatroomManager *chatroom_manager; - GList *chats; - GList *chats_new_msg; - GList *chats_composing; - + GList *chats; + GList *chats_new_msg; + GList *chats_composing; EmpathyChat *current_chat; - - gboolean page_added; - gboolean dnd_same_window; - - GtkWidget *dialog; - GtkWidget *notebook; + gboolean page_added; + gboolean dnd_same_window; + guint save_geometry_id; + GtkWidget *dialog; + GtkWidget *notebook; /* Menu items. */ GtkWidget *menu_conv_clear; @@ -105,127 +101,11 @@ struct _EmpathyChatWindowPriv { GtkWidget *menu_help_contents; GtkWidget *menu_help_about; - - guint save_geometry_id; }; -static void empathy_chat_window_class_init (EmpathyChatWindowClass *klass); -static void empathy_chat_window_init (EmpathyChatWindow *window); -static void empathy_chat_window_finalize (GObject *object); -static void chat_window_accel_cb (GtkAccelGroup *accelgroup, - GObject *object, - guint key, - GdkModifierType mod, - EmpathyChatWindow *window); -static void chat_window_close_clicked_cb (GtkWidget *button, - EmpathyChat *chat); -static GtkWidget *chat_window_create_label (EmpathyChatWindow *window, - EmpathyChat *chat); -static void chat_window_update_status (EmpathyChatWindow *window, - EmpathyChat *chat); -static void chat_window_update_title (EmpathyChatWindow *window, - EmpathyChat *chat); -static void chat_window_update_menu (EmpathyChatWindow *window); -static gboolean chat_window_save_geometry_timeout_cb (EmpathyChatWindow *window); -static gboolean chat_window_configure_event_cb (GtkWidget *widget, - GdkEventConfigure *event, - EmpathyChatWindow *window); -static void chat_window_conv_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_clear_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_info_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_add_contact_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_call_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_log_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_show_contacts_toggled_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_edit_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_insert_smiley_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_close_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_room_set_topic_activate_cb(GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_room_join_new_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_room_invite_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_room_add_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_cut_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_copy_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_paste_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_tabs_left_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_tabs_right_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_detach_activate_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_help_contents_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static void chat_window_help_about_cb (GtkWidget *menuitem, - EmpathyChatWindow *window); -static gboolean chat_window_delete_event_cb (GtkWidget *dialog, - GdkEvent *event, - EmpathyChatWindow *window); -static void chat_window_status_changed_cb (EmpathyChat *chat, - EmpathyChatWindow *window); -static void chat_window_update_tooltip (EmpathyChatWindow *window, - EmpathyChat *chat); -static void chat_window_name_changed_cb (EmpathyChat *chat, - const gchar *name, - EmpathyChatWindow *window); -static void chat_window_composing_cb (EmpathyChat *chat, - gboolean is_composing, - EmpathyChatWindow *window); -static void chat_window_new_message_cb (EmpathyChat *chat, - EmpathyMessage *message, - gboolean is_backlog, - EmpathyChatWindow *window); -static GtkNotebook* chat_window_detach_hook (GtkNotebook *source, - GtkWidget *page, - gint x, - gint y, - gpointer user_data); -static void chat_window_page_switched_cb (GtkNotebook *notebook, - GtkNotebookPage *page, - gint page_num, - EmpathyChatWindow *window); -static void chat_window_page_reordered_cb (GtkNotebook *notebook, - GtkWidget *widget, - guint page_num, - EmpathyChatWindow *window); -static void chat_window_page_added_cb (GtkNotebook *notebook, - GtkWidget *child, - guint page_num, - EmpathyChatWindow *window); -static void chat_window_page_removed_cb (GtkNotebook *notebook, - GtkWidget *child, - guint page_num, - EmpathyChatWindow *window); -static gboolean chat_window_focus_in_event_cb (GtkWidget *widget, - GdkEvent *event, - EmpathyChatWindow *window); -static void chat_window_drag_data_received (GtkWidget *widget, - GdkDragContext *context, - int x, - int y, - GtkSelectionData *selection, - guint info, - guint time, - EmpathyChatWindow *window); -static void chat_window_set_urgency_hint (EmpathyChatWindow *window, - gboolean urgent); - +static void empathy_chat_window_class_init (EmpathyChatWindowClass *klass); +static void empathy_chat_window_init (EmpathyChatWindow *window); +static void chat_window_finalize (GObject *object); static GList *chat_windows = NULL; @@ -247,374 +127,127 @@ static const GtkTargetEntry drag_types_dest[] = { G_DEFINE_TYPE (EmpathyChatWindow, empathy_chat_window, G_TYPE_OBJECT); static void -empathy_chat_window_class_init (EmpathyChatWindowClass *klass) +chat_window_accel_cb (GtkAccelGroup *accelgroup, + GObject *object, + guint key, + GdkModifierType mod, + EmpathyChatWindow *window) { - GObjectClass *object_class = G_OBJECT_CLASS (klass); + EmpathyChatWindowPriv *priv; + gint num = -1; + gint i; - object_class->finalize = empathy_chat_window_finalize; + priv = GET_PRIV (window); - g_type_class_add_private (object_class, sizeof (EmpathyChatWindowPriv)); + for (i = 0; i < G_N_ELEMENTS (tab_accel_keys); i++) { + if (tab_accel_keys[i] == key) { + num = i; + break; + } + } - /* Set up a style for the close button with no focus padding. */ - gtk_rc_parse_string ( - "style \"empathy-close-button-style\"\n" - "{\n" - " GtkWidget::focus-padding = 0\n" - " xthickness = 0\n" - " ythickness = 0\n" - "}\n" - "widget \"*.empathy-close-button\" style \"empathy-close-button-style\""); + if (num != -1) { + gtk_notebook_set_current_page (GTK_NOTEBOOK (priv->notebook), num); + } +} - gtk_notebook_set_window_creation_hook (chat_window_detach_hook, NULL, NULL); +static EmpathyChatWindow * +chat_window_find_chat (EmpathyChat *chat) +{ + EmpathyChatWindowPriv *priv; + GList *l, *ll; + + for (l = chat_windows; l; l = l->next) { + priv = GET_PRIV (l->data); + ll = g_list_find (priv->chats, chat); + if (ll) { + return l->data; + } + } + + return NULL; } static void -empathy_chat_window_init (EmpathyChatWindow *window) +chat_window_close_clicked_cb (GtkWidget *button, + EmpathyChat *chat) { - EmpathyChatWindowPriv *priv; - GladeXML *glade; - GtkAccelGroup *accel_group; - GtkWidget *image; - GClosure *closure; - GtkWidget *menu_conv; - GtkWidget *menu; - gint i; - GtkWidget *chat_vbox; - gchar *filename; + EmpathyChatWindow *window; - priv = GET_PRIV (window); + window = chat_window_find_chat (chat); + empathy_chat_window_remove_chat (window, chat); +} - filename = empathy_file_lookup ("empathy-chat.glade", "libempathy-gtk"); - glade = empathy_glade_get_file (filename, - "chat_window", - NULL, - "chat_window", &priv->dialog, - "chat_vbox", &chat_vbox, - "menu_conv", &menu_conv, - "menu_conv_clear", &priv->menu_conv_clear, - "menu_conv_insert_smiley", &priv->menu_conv_insert_smiley, - "menu_conv_call", &priv->menu_conv_call, - "menu_conv_call_separator", &priv->menu_conv_call_separator, - "menu_conv_log", &priv->menu_conv_log, - "menu_conv_separator", &priv->menu_conv_separator, - "menu_conv_add_contact", &priv->menu_conv_add_contact, - "menu_conv_info", &priv->menu_conv_info, - "menu_conv_close", &priv->menu_conv_close, - "menu_room", &priv->menu_room, - "menu_room_set_topic", &priv->menu_room_set_topic, - "menu_room_join_new", &priv->menu_room_join_new, - "menu_room_invite", &priv->menu_room_invite, - "menu_room_add", &priv->menu_room_add, - "menu_room_show_contacts", &priv->menu_room_show_contacts, - "menu_edit_cut", &priv->menu_edit_cut, - "menu_edit_copy", &priv->menu_edit_copy, - "menu_edit_paste", &priv->menu_edit_paste, - "menu_tabs_next", &priv->menu_tabs_next, - "menu_tabs_prev", &priv->menu_tabs_prev, - "menu_tabs_left", &priv->menu_tabs_left, - "menu_tabs_right", &priv->menu_tabs_right, - "menu_tabs_detach", &priv->menu_tabs_detach, - "menu_help_contents", &priv->menu_help_contents, - "menu_help_about", &priv->menu_help_about, - NULL); - g_free (filename); +static void +chat_window_close_button_style_set_cb (GtkWidget *button, + GtkStyle *previous_style, + gpointer user_data) +{ + gint h, w; - empathy_glade_connect (glade, - window, - "chat_window", "configure-event", chat_window_configure_event_cb, - "menu_conv", "activate", chat_window_conv_activate_cb, - "menu_conv_clear", "activate", chat_window_clear_activate_cb, - "menu_conv_call", "activate", chat_window_call_activate_cb, - "menu_conv_log", "activate", chat_window_log_activate_cb, - "menu_conv_add_contact", "activate", chat_window_add_contact_activate_cb, - "menu_conv_info", "activate", chat_window_info_activate_cb, - "menu_conv_close", "activate", chat_window_close_activate_cb, - "menu_room_set_topic", "activate", chat_window_room_set_topic_activate_cb, - "menu_room_join_new", "activate", chat_window_room_join_new_activate_cb, - "menu_room_invite", "activate", chat_window_room_invite_activate_cb, - "menu_room_add", "activate", chat_window_room_add_activate_cb, - "menu_edit", "activate", chat_window_edit_activate_cb, - "menu_edit_cut", "activate", chat_window_cut_activate_cb, - "menu_edit_copy", "activate", chat_window_copy_activate_cb, - "menu_edit_paste", "activate", chat_window_paste_activate_cb, - "menu_tabs_left", "activate", chat_window_tabs_left_activate_cb, - "menu_tabs_right", "activate", chat_window_tabs_right_activate_cb, - "menu_tabs_detach", "activate", chat_window_detach_activate_cb, - "menu_help_contents", "activate", chat_window_help_contents_cb, - "menu_help_about", "activate", chat_window_help_about_cb, - NULL); + gtk_icon_size_lookup_for_settings (gtk_widget_get_settings (button), + GTK_ICON_SIZE_MENU, &w, &h); - g_object_unref (glade); + gtk_widget_set_size_request (button, w, h); +} - /* Set up chatroom manager */ - priv->chatroom_manager = empathy_chatroom_manager_new (); - g_signal_connect_swapped (priv->chatroom_manager, "chatroom-added", - G_CALLBACK (chat_window_update_menu), - window); - g_signal_connect_swapped (priv->chatroom_manager, "chatroom-removed", - G_CALLBACK (chat_window_update_menu), - window); +static void +chat_window_update_tooltip (EmpathyChatWindow *window, + EmpathyChat *chat) +{ + EmpathyChatWindowPriv *priv; + GtkWidget *widget; + const gchar *tooltip; + gchar *str = NULL; - priv->notebook = gtk_notebook_new (); - gtk_notebook_set_group (GTK_NOTEBOOK (priv->notebook), "EmpathyChatWindow"); - gtk_box_pack_start (GTK_BOX (chat_vbox), priv->notebook, TRUE, TRUE, 0); - gtk_widget_show (priv->notebook); + priv = GET_PRIV (window); - /* Set up accels */ - accel_group = gtk_accel_group_new (); - gtk_window_add_accel_group (GTK_WINDOW (priv->dialog), accel_group); + tooltip = empathy_chat_get_tooltip (chat); - for (i = 0; i < G_N_ELEMENTS (tab_accel_keys); i++) { - closure = g_cclosure_new (G_CALLBACK (chat_window_accel_cb), - window, - NULL); - gtk_accel_group_connect (accel_group, - tab_accel_keys[i], - GDK_MOD1_MASK, - 0, - closure); + if (g_list_find (priv->chats_composing, chat)) { + str = g_strconcat (tooltip, "\n", _("Typing a message."), NULL); + tooltip = str; } - g_object_unref (accel_group); + widget = g_object_get_data (G_OBJECT (chat), "chat-window-tab-tooltip-widget"); + gtk_widget_set_tooltip_text (widget, tooltip); - /* Set the contact information menu item image to the Empathy - * stock image - */ - image = gtk_image_menu_item_get_image (GTK_IMAGE_MENU_ITEM (priv->menu_conv_info)); - gtk_image_set_from_icon_name (GTK_IMAGE (image), - EMPATHY_IMAGE_CONTACT_INFORMATION, - GTK_ICON_SIZE_MENU); + g_free (str); +} - /* Set up smiley menu */ - menu = empathy_chat_view_get_smiley_menu ( - G_CALLBACK (chat_window_insert_smiley_activate_cb), - window); - gtk_menu_item_set_submenu (GTK_MENU_ITEM (priv->menu_conv_insert_smiley), menu); +static GtkWidget * +chat_window_create_label (EmpathyChatWindow *window, + EmpathyChat *chat) +{ + EmpathyChatWindowPriv *priv; + GtkWidget *hbox; + GtkWidget *name_label; + GtkWidget *status_image; + GtkWidget *close_button; + GtkWidget *close_image; + GtkWidget *event_box; + GtkWidget *event_box_hbox; + PangoAttrList *attr_list; + PangoAttribute *attr; - /* Set up signals we can't do with glade since we may need to - * block/unblock them at some later stage. - */ + priv = GET_PRIV (window); - g_signal_connect (priv->dialog, - "delete_event", - G_CALLBACK (chat_window_delete_event_cb), - window); + /* The spacing between the button and the label. */ + hbox = gtk_hbox_new (FALSE, 0); - g_signal_connect (priv->menu_room_show_contacts, - "toggled", - G_CALLBACK (chat_window_show_contacts_toggled_cb), - window); + event_box = gtk_event_box_new (); + gtk_event_box_set_visible_window (GTK_EVENT_BOX (event_box), FALSE); - g_signal_connect_swapped (priv->menu_tabs_prev, - "activate", - G_CALLBACK (gtk_notebook_prev_page), - priv->notebook); - g_signal_connect_swapped (priv->menu_tabs_next, - "activate", - G_CALLBACK (gtk_notebook_next_page), - priv->notebook); + name_label = gtk_label_new (empathy_chat_get_name (chat)); + gtk_label_set_ellipsize (GTK_LABEL (name_label), PANGO_ELLIPSIZE_END); - g_signal_connect (priv->dialog, - "focus_in_event", - G_CALLBACK (chat_window_focus_in_event_cb), - window); - g_signal_connect_after (priv->notebook, - "switch_page", - G_CALLBACK (chat_window_page_switched_cb), - window); - g_signal_connect (priv->notebook, - "page_reordered", - G_CALLBACK (chat_window_page_reordered_cb), - window); - g_signal_connect (priv->notebook, - "page_added", - G_CALLBACK (chat_window_page_added_cb), - window); - g_signal_connect (priv->notebook, - "page_removed", - G_CALLBACK (chat_window_page_removed_cb), - window); - - /* Set up drag and drop */ - gtk_drag_dest_set (GTK_WIDGET (priv->notebook), - GTK_DEST_DEFAULT_ALL, - drag_types_dest, - G_N_ELEMENTS (drag_types_dest), - GDK_ACTION_MOVE); - - g_signal_connect (priv->notebook, - "drag-data-received", - G_CALLBACK (chat_window_drag_data_received), - window); - - chat_windows = g_list_prepend (chat_windows, window); - - /* Set up private details */ - priv->chats = NULL; - priv->chats_new_msg = NULL; - priv->chats_composing = NULL; - priv->current_chat = NULL; -} - -/* Returns the window to open a new tab in if there is only one window - * visble, otherwise, returns NULL indicating that a new window should - * be added. - */ -EmpathyChatWindow * -empathy_chat_window_get_default (void) -{ - GList *l; - gboolean separate_windows = TRUE; - - empathy_conf_get_bool (empathy_conf_get (), - EMPATHY_PREFS_UI_SEPARATE_CHAT_WINDOWS, - &separate_windows); - - if (separate_windows) { - /* Always create a new window */ - return NULL; - } - - for (l = chat_windows; l; l = l->next) { - EmpathyChatWindow *chat_window; - GtkWidget *dialog; - - chat_window = l->data; - - dialog = empathy_chat_window_get_dialog (chat_window); - if (empathy_window_get_is_visible (GTK_WINDOW (GTK_WINDOW (dialog)))) { - /* Found a visible window on this desktop */ - return chat_window; - } - } - - return NULL; -} - -static void -empathy_chat_window_finalize (GObject *object) -{ - EmpathyChatWindow *window; - EmpathyChatWindowPriv *priv; - - window = EMPATHY_CHAT_WINDOW (object); - priv = GET_PRIV (window); - - empathy_debug (DEBUG_DOMAIN, "Finalized: %p", object); - - if (priv->save_geometry_id != 0) { - g_source_remove (priv->save_geometry_id); - } - - chat_windows = g_list_remove (chat_windows, window); - gtk_widget_destroy (priv->dialog); - - g_signal_handlers_disconnect_by_func (priv->chatroom_manager, - chat_window_update_menu, - window); - g_object_unref (priv->chatroom_manager); - - G_OBJECT_CLASS (empathy_chat_window_parent_class)->finalize (object); -} - -static void -chat_window_accel_cb (GtkAccelGroup *accelgroup, - GObject *object, - guint key, - GdkModifierType mod, - EmpathyChatWindow *window) -{ - EmpathyChatWindowPriv *priv; - gint num = -1; - gint i; - - priv = GET_PRIV (window); - - for (i = 0; i < G_N_ELEMENTS (tab_accel_keys); i++) { - if (tab_accel_keys[i] == key) { - num = i; - break; - } - } - - if (num != -1) { - gtk_notebook_set_current_page (GTK_NOTEBOOK (priv->notebook), num); - } -} - -static EmpathyChatWindow * -chat_window_find_chat (EmpathyChat *chat) -{ - EmpathyChatWindowPriv *priv; - GList *l, *ll; - - for (l = chat_windows; l; l = l->next) { - priv = GET_PRIV (l->data); - ll = g_list_find (priv->chats, chat); - if (ll) { - return l->data; - } - } - - return NULL; -} - -static void -chat_window_close_clicked_cb (GtkWidget *button, - EmpathyChat *chat) -{ - EmpathyChatWindow *window; - - window = chat_window_find_chat (chat); - empathy_chat_window_remove_chat (window, chat); -} - -static void -chat_window_close_button_style_set_cb (GtkWidget *button, - GtkStyle *previous_style, - gpointer user_data) -{ - gint h, w; - - gtk_icon_size_lookup_for_settings (gtk_widget_get_settings (button), - GTK_ICON_SIZE_MENU, &w, &h); - - gtk_widget_set_size_request (button, w, h); -} - -static GtkWidget * -chat_window_create_label (EmpathyChatWindow *window, - EmpathyChat *chat) -{ - EmpathyChatWindowPriv *priv; - GtkWidget *hbox; - GtkWidget *name_label; - GtkWidget *status_image; - GtkWidget *close_button; - GtkWidget *close_image; - GtkWidget *event_box; - GtkWidget *event_box_hbox; - PangoAttrList *attr_list; - PangoAttribute *attr; - - priv = GET_PRIV (window); - - /* The spacing between the button and the label. */ - hbox = gtk_hbox_new (FALSE, 0); - - event_box = gtk_event_box_new (); - gtk_event_box_set_visible_window (GTK_EVENT_BOX (event_box), FALSE); - - name_label = gtk_label_new (empathy_chat_get_name (chat)); - gtk_label_set_ellipsize (GTK_LABEL (name_label), PANGO_ELLIPSIZE_END); - - attr_list = pango_attr_list_new (); - attr = pango_attr_scale_new (1/1.2); - attr->start_index = 0; - attr->end_index = -1; - pango_attr_list_insert (attr_list, attr); - gtk_label_set_attributes (GTK_LABEL (name_label), attr_list); - pango_attr_list_unref (attr_list); + attr_list = pango_attr_list_new (); + attr = pango_attr_scale_new (1/1.2); + attr->start_index = 0; + attr->end_index = -1; + pango_attr_list_insert (attr_list, attr); + gtk_label_set_attributes (GTK_LABEL (name_label), attr_list); + pango_attr_list_unref (attr_list); gtk_misc_set_padding (GTK_MISC (name_label), 2, 0); gtk_misc_set_alignment (GTK_MISC (name_label), 0.0, 0.5); @@ -672,32 +305,6 @@ chat_window_create_label (EmpathyChatWindow *window, return hbox; } -static void -chat_window_update_status (EmpathyChatWindow *window, - EmpathyChat *chat) -{ - EmpathyChatWindowPriv *priv; - GtkImage *image; - const gchar *icon_name = NULL; - - priv = GET_PRIV (window); - - if (g_list_find (priv->chats_new_msg, chat)) { - icon_name = EMPATHY_IMAGE_MESSAGE; - } - else if (g_list_find (priv->chats_composing, chat)) { - icon_name = EMPATHY_IMAGE_TYPING; - } - else { - icon_name = empathy_chat_get_status_icon_name (chat); - } - image = g_object_get_data (G_OBJECT (chat), "chat-window-tab-image"); - gtk_image_set_from_icon_name (image, icon_name, GTK_ICON_SIZE_MENU); - - chat_window_update_title (window, chat); - chat_window_update_tooltip (window, chat); -} - static void chat_window_update_title (EmpathyChatWindow *window, EmpathyChat *chat) @@ -727,6 +334,32 @@ chat_window_update_title (EmpathyChatWindow *window, } } +static void +chat_window_update_status (EmpathyChatWindow *window, + EmpathyChat *chat) +{ + EmpathyChatWindowPriv *priv; + GtkImage *image; + const gchar *icon_name = NULL; + + priv = GET_PRIV (window); + + if (g_list_find (priv->chats_new_msg, chat)) { + icon_name = EMPATHY_IMAGE_MESSAGE; + } + else if (g_list_find (priv->chats_composing, chat)) { + icon_name = EMPATHY_IMAGE_TYPING; + } + else { + icon_name = empathy_chat_get_status_icon_name (chat); + } + image = g_object_get_data (G_OBJECT (chat), "chat-window-tab-image"); + gtk_image_set_from_icon_name (image, icon_name, GTK_ICON_SIZE_MENU); + + chat_window_update_title (window, chat); + chat_window_update_tooltip (window, chat); +} + static void chat_window_update_menu (EmpathyChatWindow *window) { @@ -1292,32 +925,6 @@ chat_window_status_changed_cb (EmpathyChat *chat, chat_window_update_status (window, chat); } -static void -chat_window_update_tooltip (EmpathyChatWindow *window, - EmpathyChat *chat) -{ - EmpathyChatWindowPriv *priv; - GtkWidget *widget; - gchar *current_tooltip; - gchar *str; - - priv = GET_PRIV (window); - - current_tooltip = empathy_chat_get_tooltip (chat); - - if (g_list_find (priv->chats_composing, chat)) { - str = g_strconcat (current_tooltip, "\n", _("Typing a message."), NULL); - g_free (current_tooltip); - } else { - str = current_tooltip; - } - - widget = g_object_get_data (G_OBJECT (chat), "chat-window-tab-tooltip-widget"); - gtk_widget_set_tooltip_text (widget, str); - - g_free (str); -} - static void chat_window_name_changed_cb (EmpathyChat *chat, const gchar *name, @@ -1697,10 +1304,281 @@ chat_window_set_urgency_hint (EmpathyChatWindow *window, gtk_window_set_urgency_hint (GTK_WINDOW (priv->dialog), urgent); } -EmpathyChatWindow * -empathy_chat_window_new (void) +static void +chat_window_finalize (GObject *object) { - return EMPATHY_CHAT_WINDOW (g_object_new (EMPATHY_TYPE_CHAT_WINDOW, NULL)); + EmpathyChatWindow *window; + EmpathyChatWindowPriv *priv; + + window = EMPATHY_CHAT_WINDOW (object); + priv = GET_PRIV (window); + + empathy_debug (DEBUG_DOMAIN, "Finalized: %p", object); + + if (priv->save_geometry_id != 0) { + g_source_remove (priv->save_geometry_id); + } + + chat_windows = g_list_remove (chat_windows, window); + gtk_widget_destroy (priv->dialog); + + g_signal_handlers_disconnect_by_func (priv->chatroom_manager, + chat_window_update_menu, + window); + g_object_unref (priv->chatroom_manager); + + G_OBJECT_CLASS (empathy_chat_window_parent_class)->finalize (object); +} + +static void +empathy_chat_window_class_init (EmpathyChatWindowClass *klass) +{ + GObjectClass *object_class = G_OBJECT_CLASS (klass); + + object_class->finalize = empathy_chat_window_finalize; + + g_type_class_add_private (object_class, sizeof (EmpathyChatWindowPriv)); + + /* Set up a style for the close button with no focus padding. */ + gtk_rc_parse_string ( + "style \"empathy-close-button-style\"\n" + "{\n" + " GtkWidget::focus-padding = 0\n" + " xthickness = 0\n" + " ythickness = 0\n" + "}\n" + "widget \"*.empathy-close-button\" style \"empathy-close-button-style\""); + + gtk_notebook_set_window_creation_hook (chat_window_detach_hook, NULL, NULL); +} + +static void +empathy_chat_window_init (EmpathyChatWindow *window) +{ + EmpathyChatWindowPriv *priv; + GladeXML *glade; + GtkAccelGroup *accel_group; + GtkWidget *image; + GClosure *closure; + GtkWidget *menu_conv; + GtkWidget *menu; + gint i; + GtkWidget *chat_vbox; + gchar *filename; + + priv = GET_PRIV (window); + + filename = empathy_file_lookup ("empathy-chat-window.glade", "src"); + glade = empathy_glade_get_file (filename, + "chat_window", + NULL, + "chat_window", &priv->dialog, + "chat_vbox", &chat_vbox, + "menu_conv", &menu_conv, + "menu_conv_clear", &priv->menu_conv_clear, + "menu_conv_insert_smiley", &priv->menu_conv_insert_smiley, + "menu_conv_call", &priv->menu_conv_call, + "menu_conv_call_separator", &priv->menu_conv_call_separator, + "menu_conv_log", &priv->menu_conv_log, + "menu_conv_separator", &priv->menu_conv_separator, + "menu_conv_add_contact", &priv->menu_conv_add_contact, + "menu_conv_info", &priv->menu_conv_info, + "menu_conv_close", &priv->menu_conv_close, + "menu_room", &priv->menu_room, + "menu_room_set_topic", &priv->menu_room_set_topic, + "menu_room_join_new", &priv->menu_room_join_new, + "menu_room_invite", &priv->menu_room_invite, + "menu_room_add", &priv->menu_room_add, + "menu_room_show_contacts", &priv->menu_room_show_contacts, + "menu_edit_cut", &priv->menu_edit_cut, + "menu_edit_copy", &priv->menu_edit_copy, + "menu_edit_paste", &priv->menu_edit_paste, + "menu_tabs_next", &priv->menu_tabs_next, + "menu_tabs_prev", &priv->menu_tabs_prev, + "menu_tabs_left", &priv->menu_tabs_left, + "menu_tabs_right", &priv->menu_tabs_right, + "menu_tabs_detach", &priv->menu_tabs_detach, + "menu_help_contents", &priv->menu_help_contents, + "menu_help_about", &priv->menu_help_about, + NULL); + g_free (filename); + + empathy_glade_connect (glade, + window, + "chat_window", "configure-event", chat_window_configure_event_cb, + "menu_conv", "activate", chat_window_conv_activate_cb, + "menu_conv_clear", "activate", chat_window_clear_activate_cb, + "menu_conv_call", "activate", chat_window_call_activate_cb, + "menu_conv_log", "activate", chat_window_log_activate_cb, + "menu_conv_add_contact", "activate", chat_window_add_contact_activate_cb, + "menu_conv_info", "activate", chat_window_info_activate_cb, + "menu_conv_close", "activate", chat_window_close_activate_cb, + "menu_room_set_topic", "activate", chat_window_room_set_topic_activate_cb, + "menu_room_join_new", "activate", chat_window_room_join_new_activate_cb, + "menu_room_invite", "activate", chat_window_room_invite_activate_cb, + "menu_room_add", "activate", chat_window_room_add_activate_cb, + "menu_edit", "activate", chat_window_edit_activate_cb, + "menu_edit_cut", "activate", chat_window_cut_activate_cb, + "menu_edit_copy", "activate", chat_window_copy_activate_cb, + "menu_edit_paste", "activate", chat_window_paste_activate_cb, + "menu_tabs_left", "activate", chat_window_tabs_left_activate_cb, + "menu_tabs_right", "activate", chat_window_tabs_right_activate_cb, + "menu_tabs_detach", "activate", chat_window_detach_activate_cb, + "menu_help_contents", "activate", chat_window_help_contents_cb, + "menu_help_about", "activate", chat_window_help_about_cb, + NULL); + + g_object_unref (glade); + + /* Set up chatroom manager */ + priv->chatroom_manager = empathy_chatroom_manager_new (); + g_signal_connect_swapped (priv->chatroom_manager, "chatroom-added", + G_CALLBACK (chat_window_update_menu), + window); + g_signal_connect_swapped (priv->chatroom_manager, "chatroom-removed", + G_CALLBACK (chat_window_update_menu), + window); + + priv->notebook = gtk_notebook_new (); + gtk_notebook_set_group (GTK_NOTEBOOK (priv->notebook), "EmpathyChatWindow"); + gtk_box_pack_start (GTK_BOX (chat_vbox), priv->notebook, TRUE, TRUE, 0); + gtk_widget_show (priv->notebook); + + /* Set up accels */ + accel_group = gtk_accel_group_new (); + gtk_window_add_accel_group (GTK_WINDOW (priv->dialog), accel_group); + + for (i = 0; i < G_N_ELEMENTS (tab_accel_keys); i++) { + closure = g_cclosure_new (G_CALLBACK (chat_window_accel_cb), + window, + NULL); + gtk_accel_group_connect (accel_group, + tab_accel_keys[i], + GDK_MOD1_MASK, + 0, + closure); + } + + g_object_unref (accel_group); + + /* Set the contact information menu item image to the Empathy + * stock image + */ + image = gtk_image_menu_item_get_image (GTK_IMAGE_MENU_ITEM (priv->menu_conv_info)); + gtk_image_set_from_icon_name (GTK_IMAGE (image), + EMPATHY_IMAGE_CONTACT_INFORMATION, + GTK_ICON_SIZE_MENU); + + /* Set up smiley menu */ + menu = empathy_chat_view_get_smiley_menu ( + G_CALLBACK (chat_window_insert_smiley_activate_cb), + window); + gtk_menu_item_set_submenu (GTK_MENU_ITEM (priv->menu_conv_insert_smiley), menu); + + /* Set up signals we can't do with glade since we may need to + * block/unblock them at some later stage. + */ + + g_signal_connect (priv->dialog, + "delete_event", + G_CALLBACK (chat_window_delete_event_cb), + window); + + g_signal_connect (priv->menu_room_show_contacts, + "toggled", + G_CALLBACK (chat_window_show_contacts_toggled_cb), + window); + + g_signal_connect_swapped (priv->menu_tabs_prev, + "activate", + G_CALLBACK (gtk_notebook_prev_page), + priv->notebook); + g_signal_connect_swapped (priv->menu_tabs_next, + "activate", + G_CALLBACK (gtk_notebook_next_page), + priv->notebook); + + g_signal_connect (priv->dialog, + "focus_in_event", + G_CALLBACK (chat_window_focus_in_event_cb), + window); + g_signal_connect_after (priv->notebook, + "switch_page", + G_CALLBACK (chat_window_page_switched_cb), + window); + g_signal_connect (priv->notebook, + "page_reordered", + G_CALLBACK (chat_window_page_reordered_cb), + window); + g_signal_connect (priv->notebook, + "page_added", + G_CALLBACK (chat_window_page_added_cb), + window); + g_signal_connect (priv->notebook, + "page_removed", + G_CALLBACK (chat_window_page_removed_cb), + window); + + /* Set up drag and drop */ + gtk_drag_dest_set (GTK_WIDGET (priv->notebook), + GTK_DEST_DEFAULT_ALL, + drag_types_dest, + G_N_ELEMENTS (drag_types_dest), + GDK_ACTION_MOVE); + + g_signal_connect (priv->notebook, + "drag-data-received", + G_CALLBACK (chat_window_drag_data_received), + window); + + chat_windows = g_list_prepend (chat_windows, window); + + /* Set up private details */ + priv->chats = NULL; + priv->chats_new_msg = NULL; + priv->chats_composing = NULL; + priv->current_chat = NULL; +} + +EmpathyChatWindow * +empathy_chat_window_new (void) +{ + return EMPATHY_CHAT_WINDOW (g_object_new (EMPATHY_TYPE_CHAT_WINDOW, NULL)); +} + +/* Returns the window to open a new tab in if there is only one window + * visble, otherwise, returns NULL indicating that a new window should + * be added. + */ +EmpathyChatWindow * +empathy_chat_window_get_default (void) +{ + GList *l; + gboolean separate_windows = TRUE; + + empathy_conf_get_bool (empathy_conf_get (), + EMPATHY_PREFS_UI_SEPARATE_CHAT_WINDOWS, + &separate_windows); + + if (separate_windows) { + /* Always create a new window */ + return NULL; + } + + for (l = chat_windows; l; l = l->next) { + EmpathyChatWindow *chat_window; + GtkWidget *dialog; + + chat_window = l->data; + + dialog = empathy_chat_window_get_dialog (chat_window); + if (empathy_window_get_is_visible (GTK_WINDOW (GTK_WINDOW (dialog)))) { + /* Found a visible window on this desktop */ + return chat_window; + } + } + + return NULL; } GtkWidget * diff --git a/src/empathy-chat-window.glade b/src/empathy-chat-window.glade new file mode 100644 index 000000000..7e353f436 --- /dev/null +++ b/src/empathy-chat-window.glade @@ -0,0 +1,478 @@ + + + + + + Chat + 350 + 250 + + + True + + + True + + + True + _Conversation + True + + + + + True + C_lear + True + + + + True + gtk-clear + 1 + + + + + + + True + Insert _Smiley + True + + + + + True + + + + + True + Ca_ll + True + + + True + 1 + gnome-stock-mic + + + + + + + True + + + + + True + _View Previous Conversations + True + + + + True + 1 + document-open-recent + + + + + + + True + + + + + _Add Contact... + True + + + True + gtk-add + 1 + + + + + + + True + Contact Infor_mation + True + + + True + gtk-info + 1 + + + + + + + True + + + + + True + gtk-close + True + True + + + + + + + + + + _Room + True + + + + + True + Change _Topic... + True + + + + + True + + + + + True + Join _New... + True + + + + + True + In_vite... + True + + + + + True + + + + + True + _Add To Favorites + True + + + True + gtk-add + 1 + + + + + + + True + + + + + True + _Show Contacts + True + True + + + + + + + + + + True + _Edit + True + + + + + True + gtk-cut + True + True + + + + + + True + gtk-copy + True + True + + + + + + True + gtk-paste + True + True + + + + + + + + + + True + _Tabs + True + + + + + True + _Previous Tab + True + + + + + + True + _Next Tab + True + + + + + + True + + + + + True + Move Tab _Left + True + + + + + True + Move Tab _Right + True + + + + + True + _Detach Tab + True + + + + + + + + + True + _Help + True + + + + + True + _Contents + True + + + + True + gtk-help + 1 + + + + + + + True + gtk-about + True + True + + + + + + + + + False + False + + + + + + + + + + 5 + Invite + True + GTK_WIN_POS_CENTER_ON_PARENT + 275 + 225 + GDK_WINDOW_TYPE_HINT_DIALOG + False + + + True + + + True + 5 + 18 + + + True + 6 + + + True + 0 + Select who would you like to invite: + True + True + + + False + False + + + + + True + True + GTK_POLICY_AUTOMATIC + GTK_POLICY_AUTOMATIC + GTK_SHADOW_IN + + + True + True + False + + + + + 1 + + + + + + + True + 6 + + + True + 0 + Invitation _message: + True + True + True + entry + + + False + False + + + + + True + True + * + True + 40 + You have been invited to join a chat conference. + + + False + False + 1 + + + + + False + False + 1 + + + + + 1 + + + + + True + GTK_BUTTONBOX_END + + + True + True + True + gtk-cancel + True + -6 + + + + + True + False + True + True + True + In_vite + True + -5 + + + 1 + + + + + False + GTK_PACK_END + + + + + + -- cgit v1.2.3