aboutsummaryrefslogtreecommitdiffstats
path: root/libempathy-gtk/empathy-private-chat.c
diff options
context:
space:
mode:
Diffstat (limited to 'libempathy-gtk/empathy-private-chat.c')
-rw-r--r--libempathy-gtk/empathy-private-chat.c365
1 files changed, 0 insertions, 365 deletions
diff --git a/libempathy-gtk/empathy-private-chat.c b/libempathy-gtk/empathy-private-chat.c
deleted file mode 100644
index 950f168a5..000000000
--- a/libempathy-gtk/empathy-private-chat.c
+++ /dev/null
@@ -1,365 +0,0 @@
-/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
-/*
- * Copyright (C) 2002-2007 Imendio AB
- * Copyright (C) 2007-2008 Collabora Ltd.
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License as
- * published by the Free Software Foundation; either version 2 of the
- * License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * General Public License for more details.
- *
- * You should have received a copy of the GNU General Public
- * License along with this program; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- *
- * Authors: Mikael Hallendal <micke@imendio.com>
- * Richard Hult <richard@imendio.com>
- * Martyn Russell <martyn@imendio.com>
- * Geert-Jan Van den Bogaerde <geertjan@gnome.org>
- * Xavier Claessens <xclaesse@gmail.com>
- */
-
-#include "config.h"
-
-#include <string.h>
-
-#include <gtk/gtk.h>
-#include <glade/glade.h>
-#include <glib/gi18n.h>
-
-#include <libmissioncontrol/mission-control.h>
-#include <telepathy-glib/util.h>
-
-#include <libempathy/empathy-debug.h>
-#include <libempathy/empathy-tp-chat.h>
-#include <libempathy/empathy-tp-contact-list.h>
-#include <libempathy/empathy-contact-factory.h>
-#include <libempathy/empathy-utils.h>
-
-#include "empathy-private-chat.h"
-#include "empathy-chat-view.h"
-#include "empathy-chat.h"
-//#include "empathy-sound.h"
-#include "empathy-images.h"
-#include "empathy-ui-utils.h"
-
-#define DEBUG_DOMAIN "PrivateChat"
-
-#define GET_PRIV(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), EMPATHY_TYPE_PRIVATE_CHAT, EmpathyPrivateChatPriv))
-
-struct _EmpathyPrivateChatPriv {
- EmpathyContactFactory *factory;
- EmpathyContact *contact;
- gchar *name;
- gboolean is_online;
- GtkWidget *widget;
- GtkWidget *text_view_sw;
-};
-
-static void empathy_private_chat_class_init (EmpathyPrivateChatClass *klass);
-static void empathy_private_chat_init (EmpathyPrivateChat *chat);
-static void private_chat_finalize (GObject *object);
-static void private_chat_create_ui (EmpathyPrivateChat *chat);
-static void private_chat_contact_presence_updated_cb (EmpathyContact *contact,
- GParamSpec *param,
- EmpathyPrivateChat *chat);
-static void private_chat_contact_updated_cb (EmpathyContact *contact,
- GParamSpec *param,
- EmpathyPrivateChat *chat);
-static void private_chat_widget_destroy_cb (GtkWidget *widget,
- EmpathyPrivateChat *chat);
-static const gchar * private_chat_get_name (EmpathyChat *chat);
-static gchar * private_chat_get_tooltip (EmpathyChat *chat);
-static const gchar * private_chat_get_status_icon_name (EmpathyChat *chat);
-static GtkWidget * private_chat_get_widget (EmpathyChat *chat);
-
-G_DEFINE_TYPE (EmpathyPrivateChat, empathy_private_chat, EMPATHY_TYPE_CHAT);
-
-
-static GObject *
-private_chat_constructor (GType type,
- guint n_props,
- GObjectConstructParam *props)
-{
- GObject *chat;
- EmpathyPrivateChatPriv *priv;
- EmpathyTpChat *tp_chat;
- TpChan *tp_chan;
- McAccount *account;
-
- chat = G_OBJECT_CLASS (empathy_private_chat_parent_class)->constructor (type, n_props, props);
-
- priv = GET_PRIV (chat);
-
- g_object_get (chat, "tp-chat", &tp_chat, NULL);
- tp_chan = empathy_tp_chat_get_channel (tp_chat);
- account = empathy_tp_chat_get_account (tp_chat);
-
- priv->factory = empathy_contact_factory_new ();
- priv->contact = empathy_contact_factory_get_from_handle (priv->factory,
- account,
- tp_chan->handle);
-
- priv->name = g_strdup (empathy_contact_get_name (priv->contact));
-
- g_signal_connect (priv->contact,
- "notify::name",
- G_CALLBACK (private_chat_contact_updated_cb),
- chat);
- g_signal_connect (priv->contact,
- "notify::presence",
- G_CALLBACK (private_chat_contact_presence_updated_cb),
- chat);
-
- priv->is_online = empathy_contact_is_online (priv->contact);
-
- g_object_unref (tp_chat);
-
- return chat;
-}
-
-static void
-empathy_private_chat_class_init (EmpathyPrivateChatClass *klass)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
- EmpathyChatClass *chat_class = EMPATHY_CHAT_CLASS (klass);
-
- object_class->finalize = private_chat_finalize;
- object_class->constructor = private_chat_constructor;
-
- chat_class->get_name = private_chat_get_name;
- chat_class->get_tooltip = private_chat_get_tooltip;
- chat_class->get_status_icon_name = private_chat_get_status_icon_name;
- chat_class->get_widget = private_chat_get_widget;
- chat_class->set_tp_chat = NULL;
-
- g_type_class_add_private (object_class, sizeof (EmpathyPrivateChatPriv));
-}
-
-static void
-empathy_private_chat_init (EmpathyPrivateChat *chat)
-{
- private_chat_create_ui (chat);
-}
-
-static void
-private_chat_finalize (GObject *object)
-{
- EmpathyPrivateChat *chat;
- EmpathyPrivateChatPriv *priv;
-
- chat = EMPATHY_PRIVATE_CHAT (object);
- priv = GET_PRIV (chat);
-
- g_signal_handlers_disconnect_by_func (priv->contact,
- private_chat_contact_updated_cb,
- chat);
- g_signal_handlers_disconnect_by_func (priv->contact,
- private_chat_contact_presence_updated_cb,
- chat);
-
- if (priv->contact) {
- g_object_unref (priv->contact);
- }
- if (priv->factory) {
- g_object_unref (priv->factory);
- }
- g_free (priv->name);
-
- G_OBJECT_CLASS (empathy_private_chat_parent_class)->finalize (object);
-}
-
-static void
-private_chat_create_ui (EmpathyPrivateChat *chat)
-{
- GladeXML *glade;
- EmpathyPrivateChatPriv *priv;
- GtkWidget *input_text_view_sw;
- gchar *filename;
-
- priv = GET_PRIV (chat);
-
- filename = empathy_file_lookup ("empathy-chat.glade", "libempathy-gtk");
- glade = empathy_glade_get_file (filename,
- "chat_widget",
- NULL,
- "chat_widget", &priv->widget,
- "chat_view_sw", &priv->text_view_sw,
- "input_text_view_sw", &input_text_view_sw,
- NULL);
- g_free (filename);
-
- empathy_glade_connect (glade,
- chat,
- "chat_widget", "destroy", private_chat_widget_destroy_cb,
- NULL);
-
- g_object_unref (glade);
-
- g_object_set_data (G_OBJECT (priv->widget), "chat", g_object_ref (chat));
-
- gtk_container_add (GTK_CONTAINER (priv->text_view_sw),
- GTK_WIDGET (EMPATHY_CHAT (chat)->view));
- gtk_widget_show (GTK_WIDGET (EMPATHY_CHAT (chat)->view));
-
- gtk_container_add (GTK_CONTAINER (input_text_view_sw),
- EMPATHY_CHAT (chat)->input_text_view);
- gtk_widget_show (EMPATHY_CHAT (chat)->input_text_view);
-}
-
-static void
-private_chat_contact_presence_updated_cb (EmpathyContact *contact,
- GParamSpec *param,
- EmpathyPrivateChat *chat)
-{
- EmpathyPrivateChatPriv *priv;
-
- priv = GET_PRIV (chat);
-
- empathy_debug (DEBUG_DOMAIN, "Presence update for contact: %s",
- empathy_contact_get_id (contact));
-
- if (!empathy_contact_is_online (contact)) {
- if (priv->is_online && !EMPATHY_CHAT (chat)->block_events) {
- gchar *msg;
-
- msg = g_strdup_printf (_("%s went offline"),
- empathy_contact_get_name (priv->contact));
- empathy_chat_view_append_event (EMPATHY_CHAT (chat)->view, msg);
- g_free (msg);
- }
-
- priv->is_online = FALSE;
-
- g_signal_emit_by_name (chat, "composing", FALSE);
-
- } else {
- if (!priv->is_online && !EMPATHY_CHAT (chat)->block_events) {
- gchar *msg;
-
- msg = g_strdup_printf (_("%s has come online"),
- empathy_contact_get_name (priv->contact));
- empathy_chat_view_append_event (EMPATHY_CHAT (chat)->view, msg);
- g_free (msg);
- }
-
- priv->is_online = TRUE;
-
- /* If offline message is not supported by CM we need to
- * request a new Text Channel. */
- if (!empathy_chat_is_connected (EMPATHY_CHAT (chat))) {
- empathy_chat_with_contact (contact);
- }
- }
-
- g_signal_emit_by_name (chat, "status-changed");
-}
-
-static void
-private_chat_contact_updated_cb (EmpathyContact *contact,
- GParamSpec *param,
- EmpathyPrivateChat *chat)
-{
- EmpathyPrivateChatPriv *priv;
-
- priv = GET_PRIV (chat);
-
- if (tp_strdiff (priv->name, empathy_contact_get_name (contact))) {
- g_free (priv->name);
- priv->name = g_strdup (empathy_contact_get_name (contact));
- g_signal_emit_by_name (chat, "name-changed", priv->name);
- }
-}
-
-static void
-private_chat_widget_destroy_cb (GtkWidget *widget,
- EmpathyPrivateChat *chat)
-{
- empathy_debug (DEBUG_DOMAIN, "Destroyed");
-
- g_object_unref (chat);
-}
-
-static const gchar *
-private_chat_get_name (EmpathyChat *chat)
-{
- EmpathyPrivateChatPriv *priv;
-
- g_return_val_if_fail (EMPATHY_IS_PRIVATE_CHAT (chat), NULL);
-
- priv = GET_PRIV (chat);
-
- return priv->name;
-}
-
-static gchar *
-private_chat_get_tooltip (EmpathyChat *chat)
-{
- EmpathyPrivateChatPriv *priv;
- const gchar *status;
-
- g_return_val_if_fail (EMPATHY_IS_PRIVATE_CHAT (chat), NULL);
-
- priv = GET_PRIV (chat);
-
- status = empathy_contact_get_status (priv->contact);
-
- return g_strdup_printf ("%s\n%s",
- empathy_contact_get_id (priv->contact),
- status);
-}
-
-static const gchar *
-private_chat_get_status_icon_name (EmpathyChat *chat)
-{
- EmpathyPrivateChatPriv *priv;
-
- g_return_val_if_fail (EMPATHY_IS_PRIVATE_CHAT (chat), NULL);
-
- priv = GET_PRIV (chat);
-
- return empathy_icon_name_for_contact (priv->contact);
-}
-
-EmpathyContact *
-empathy_private_chat_get_contact (EmpathyPrivateChat *chat)
-{
- EmpathyPrivateChatPriv *priv;
-
- g_return_val_if_fail (EMPATHY_IS_PRIVATE_CHAT (chat), NULL);
-
- priv = GET_PRIV (chat);
-
- return priv->contact;
-}
-
-static GtkWidget *
-private_chat_get_widget (EmpathyChat *chat)
-{
- EmpathyPrivateChatPriv *priv;
-
- priv = GET_PRIV (chat);
-
- return priv->widget;
-}
-
-EmpathyPrivateChat *
-empathy_private_chat_new (EmpathyTpChat *tp_chat)
-{
- EmpathyPrivateChat *chat;
-
- g_return_val_if_fail (EMPATHY_IS_TP_CHAT (tp_chat), NULL);
-
- chat = g_object_new (EMPATHY_TYPE_PRIVATE_CHAT,
- "tp-chat", tp_chat,
- NULL);
-
- return chat;
-}
-