From 1a6f06d4863f61b652f91f703b491bb6663d1c7a Mon Sep 17 00:00:00 2001 From: Xavier Claessens Date: Wed, 2 May 2007 14:06:37 +0000 Subject: [darcs-to-svn @ Replace the launcher by the main program with tray icon] svn path=/trunk/; revision=25 --- src/Makefile.am | 20 ++++++ src/empathy-main.c | 185 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 205 insertions(+) create mode 100644 src/Makefile.am create mode 100644 src/empathy-main.c (limited to 'src') diff --git a/src/Makefile.am b/src/Makefile.am new file mode 100644 index 000000000..4fe517deb --- /dev/null +++ b/src/Makefile.am @@ -0,0 +1,20 @@ +AM_CPPFLAGS = \ + -I$(top_srcdir) \ + -DPREFIX="\"$(prefix)"\" \ + -DSYSCONFDIR=\""$(sysconfdir)"\" \ + -DDATADIR=\""$(datadir)"\" \ + -DLIBDIR=\""$(libdir)"\" \ + $(EMPATHY_CFLAGS) \ + $(WARN_CFLAGS) + +bin_PROGRAMS = empathy + +empathy_SOURCES = \ + empathy-main.c + +empathy_LDADD = \ + $(top_builddir)/libempathy/libempathy.la \ + $(top_builddir)/libempathy-gtk/libempathy-gtk.la \ + $(EMPATHY_LIBS) + + diff --git a/src/empathy-main.c b/src/empathy-main.c new file mode 100644 index 000000000..15f4c504f --- /dev/null +++ b/src/empathy-main.c @@ -0,0 +1,185 @@ +/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */ +/* + * Copyright (C) 2007 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: Xavier Claessens + */ + +#include + +#include + +#include +#include + +#include + +#include +#include +#include + +#include +#include +#include +#include +#include + +#define DEBUG_DOMAIN "Empathy" + +static void error_cb (MissionControl *mc, + GError *error, + gpointer data); +static void service_ended_cb (MissionControl *mc, + gpointer user_data); +static void start_mission_control (MissionControl *mc); +static void destroy_cb (GtkWidget *window, + gpointer user_data); +static void icon_activate_cb (GtkStatusIcon *status_icon, + GtkWidget *window); + +static void +error_cb (MissionControl *mc, + GError *error, + gpointer data) +{ + if (error) { + gossip_debug (DEBUG_DOMAIN, "Error: %s", error->message); + } +} + +static void +service_ended_cb (MissionControl *mc, + gpointer user_data) +{ + gossip_debug (DEBUG_DOMAIN, "Mission Control stopped"); +} + +static void +account_enabled_cb (McAccountMonitor *monitor, + gchar *unique_name, + MissionControl *mc) +{ + gossip_debug (DEBUG_DOMAIN, "Account enabled: %s", unique_name); + start_mission_control (mc); +} + +static void +start_mission_control (MissionControl *mc) +{ + McPresence presence; + + presence = mission_control_get_presence_actual (mc, NULL); + + if (presence != MC_PRESENCE_UNSET && + presence != MC_PRESENCE_OFFLINE) { + /* MC is already running and online, nothing to do */ + return; + } + + gossip_debug (DEBUG_DOMAIN, "Starting Mission Control..."); + + /* FIXME: Save/Restore status message */ + mission_control_set_presence (mc, MC_PRESENCE_AVAILABLE, + NULL, + (McCallback) error_cb, + NULL); + + mission_control_connect_all_with_default_presence (mc, + (McCallback) error_cb, + NULL); +} + +static void +destroy_cb (GtkWidget *window, + gpointer user_data) +{ + gossip_stock_finalize (); + empathy_session_finalize (); + gtk_main_quit (); +} + +static void +icon_activate_cb (GtkStatusIcon *status_icon, + GtkWidget *window) +{ + if (GTK_WIDGET_VISIBLE (window)) { + gtk_widget_hide (window); + } else { + gtk_widget_show (window); + } +} + +int +main (int argc, char *argv[]) +{ + GList *accounts; + GtkStatusIcon *icon; + GtkWidget *window; + MissionControl *mc; + McAccountMonitor *monitor; + + gtk_init (&argc, &argv); + + /* FIXME: This is a horrible hack */ + gossip_stock_init (gtk_window_new (GTK_WINDOW_TOPLEVEL)); + + /* Setting up the main window */ + window = empathy_main_window_show (); + g_signal_connect (window, "destroy", + G_CALLBACK (destroy_cb), + NULL); + g_signal_connect (window, "delete-event", + G_CALLBACK (gtk_widget_hide_on_delete), + NULL); + + /* Setting up the tray icon */ + icon = gtk_status_icon_new_from_stock (GOSSIP_STOCK_AVAILABLE); + gtk_status_icon_set_tooltip (icon, "Empathy - click here to show/hide the main window"); + gtk_status_icon_set_visible (icon, TRUE); + g_signal_connect (icon, "activate", + G_CALLBACK (icon_activate_cb), + window); + + /* Show the accounts dialog if there is no enabled accounts */ + accounts = mc_accounts_list_by_enabled (TRUE); + if (accounts) { + mc_accounts_list_free (accounts); + } else { + gossip_accounts_dialog_show (); + } + + /* Setting up MC */ + monitor = mc_account_monitor_new (); + mc = mission_control_new (tp_get_bus ()); + g_signal_connect (monitor, "account-enabled", + G_CALLBACK (account_enabled_cb), + mc); + g_signal_connect (mc, "ServiceEnded", + G_CALLBACK (service_ended_cb), + NULL); + start_mission_control (mc); + + gtk_main (); + + g_object_unref (monitor); + g_object_unref (mc); + g_object_unref (icon); + + return EXIT_SUCCESS; +} + -- cgit v1.2.3