diff options
Diffstat (limited to 'src/cc-empathy-accounts-panel.c')
-rw-r--r-- | src/cc-empathy-accounts-panel.c | 171 |
1 files changed, 128 insertions, 43 deletions
diff --git a/src/cc-empathy-accounts-panel.c b/src/cc-empathy-accounts-panel.c index e22dc0c11..d62b3d2f3 100644 --- a/src/cc-empathy-accounts-panel.c +++ b/src/cc-empathy-accounts-panel.c @@ -26,90 +26,170 @@ #include <gio/gio.h> #include <glib/gi18n-lib.h> +#include <telepathy-glib/telepathy-glib.h> #include <gconf/gconf-client.h> +#include <libempathy/empathy-utils.h> +#include <libempathy/empathy-connection-managers.h> +#include <libempathy-gtk/empathy-ui-utils.h> #define DEBUG_FLAG EMPATHY_DEBUG_ACCOUNT #include <libempathy/empathy-debug.h> +#include "empathy-accounts-common.h" +#include "empathy-account-assistant.h" +#include "empathy-accounts-dialog.h" + #include "cc-empathy-accounts-panel.h" -#include "cc-empathy-accounts-page.h" #define CC_EMPATHY_ACCOUNTS_PANEL_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), CC_TYPE_EMPATHY_ACCOUNTS_PANEL, CcEmpathyAccountsPanelPrivate)) struct CcEmpathyAccountsPanelPrivate { - CcPage *empathy_accounts_page; + /* the original window holding the dialog content; it needs to be retained and + * destroyed in our finalize(), since it invalidates its children (even if + * they've already been reparented by the time it is destroyed) */ + GtkWidget *accounts_window; + + GtkWidget *assistant; }; G_DEFINE_DYNAMIC_TYPE (CcEmpathyAccountsPanel, cc_empathy_accounts_panel, CC_TYPE_PANEL) static void -setup_panel (CcEmpathyAccountsPanel *panel) +panel_pack_with_accounts_dialog (CcEmpathyAccountsPanel *panel) { - panel->priv->empathy_accounts_page = cc_empathy_accounts_page_new (); + GtkWidget *content; + GtkWidget *action_area; + + if (panel->priv->accounts_window != NULL) + { + gtk_widget_destroy (panel->priv->accounts_window); + gtk_container_remove (GTK_CONTAINER (panel), + gtk_bin_get_child (GTK_BIN (panel))); + } - gtk_container_add (GTK_CONTAINER (panel), - GTK_WIDGET (panel->priv->empathy_accounts_page)); + panel->priv->accounts_window = empathy_accounts_dialog_show (NULL, NULL); + gtk_widget_hide (panel->priv->accounts_window); - gtk_widget_show (GTK_WIDGET (panel->priv->empathy_accounts_page)); + content = gtk_dialog_get_content_area ( + GTK_DIALOG (panel->priv->accounts_window)); + action_area = gtk_dialog_get_action_area ( + GTK_DIALOG (panel->priv->accounts_window)); + gtk_widget_set_no_show_all (action_area, TRUE); + gtk_widget_hide (action_area); - g_object_set (panel, - "current-page", panel->priv->empathy_accounts_page, - NULL); + gtk_widget_reparent (content, GTK_WIDGET (panel)); } static void -cc_empathy_accounts_panel_active_changed (CcPanel *self, - gboolean is_active) +account_assistant_closed_cb (GtkWidget *widget, + gpointer user_data) { - DEBUG ("%s: active = %i", G_STRLOC, is_active); + CcEmpathyAccountsPanel *panel = CC_EMPATHY_ACCOUNTS_PANEL (user_data); + + if (empathy_accounts_dialog_is_creating ( + EMPATHY_ACCOUNTS_DIALOG (panel->priv->accounts_window))) + { + empathy_account_dialog_cancel ( + EMPATHY_ACCOUNTS_DIALOG (panel->priv->accounts_window)); + } + + gtk_widget_set_sensitive (GTK_WIDGET (panel), TRUE); + panel->priv->assistant = NULL; +} + +static void +connection_managers_prepare (GObject *source, + GAsyncResult *result, + gpointer user_data) +{ + EmpathyConnectionManagers *cm_mgr = EMPATHY_CONNECTION_MANAGERS (source); + TpAccountManager *account_mgr; + CcEmpathyAccountsPanel *panel = CC_EMPATHY_ACCOUNTS_PANEL (user_data); + + account_mgr = TP_ACCOUNT_MANAGER (g_object_get_data (G_OBJECT (cm_mgr), + "account-manager")); + + if (!empathy_connection_managers_prepare_finish (cm_mgr, result, NULL)) + goto out; + + panel_pack_with_accounts_dialog (panel); + + empathy_accounts_import (account_mgr, cm_mgr); - if (!is_active) + if (!empathy_accounts_has_non_salut_accounts (account_mgr)) { - /* why doesn't control-center call active-changed on the Page? */ - cc_empathy_accounts_page_destroy_dialogs ( - CC_EMPATHY_ACCOUNTS_PAGE ( - CC_EMPATHY_ACCOUNTS_PANEL (self)->priv->empathy_accounts_page)); + GtkWindow *parent; + + parent = empathy_get_toplevel_window (GTK_WIDGET (panel)); + panel->priv->assistant = empathy_account_assistant_show (parent, cm_mgr); + + gtk_widget_set_sensitive (GTK_WIDGET (panel), FALSE); + + tp_g_signal_connect_object (panel->priv->assistant, "hide", + G_CALLBACK (account_assistant_closed_cb), + panel, 0); } - CC_PANEL_CLASS (cc_empathy_accounts_panel_parent_class)->active_changed ( - self, is_active); +out: + /* remove ref from active_changed() */ + g_object_unref (account_mgr); + g_object_unref (cm_mgr); } -static GObject * -cc_empathy_accounts_panel_constructor (GType type, - guint n_construct_properties, - GObjectConstructParam *construct_properties) +static void +account_manager_ready_for_accounts_cb (GObject *source_object, + GAsyncResult *result, + gpointer user_data) { - CcEmpathyAccountsPanel *empathy_accounts_panel; + TpAccountManager *account_mgr = TP_ACCOUNT_MANAGER (source_object); + CcEmpathyAccountsPanel *panel = CC_EMPATHY_ACCOUNTS_PANEL (user_data); + GError *error = NULL; - empathy_accounts_panel = CC_EMPATHY_ACCOUNTS_PANEL ( - G_OBJECT_CLASS (cc_empathy_accounts_panel_parent_class)->constructor ( - type, n_construct_properties, construct_properties)); + if (!tp_account_manager_prepare_finish (account_mgr, result, &error)) + { + g_warning ("Failed to prepare account manager: %s", error->message); + g_error_free (error); + return; + } - g_object_set (empathy_accounts_panel, - "display-name", _("Messaging and VoIP Accounts"), - "id", "empathy-accounts.desktop", - NULL); + if (empathy_accounts_has_non_salut_accounts (account_mgr)) + { + panel_pack_with_accounts_dialog (panel); - setup_panel (empathy_accounts_panel); + /* remove ref from active_changed() */ + g_object_unref (account_mgr); + } + else + { + EmpathyConnectionManagers *cm_mgr; - return G_OBJECT (empathy_accounts_panel); + cm_mgr = empathy_connection_managers_dup_singleton (); + + g_object_set_data_full (G_OBJECT (cm_mgr), "account-manager", + g_object_ref (account_mgr), (GDestroyNotify) g_object_unref); + + empathy_connection_managers_prepare_async (cm_mgr, + connection_managers_prepare, panel); + } } static void cc_empathy_accounts_panel_finalize (GObject *object) { - CcEmpathyAccountsPanel *empathy_accounts_panel; + CcEmpathyAccountsPanel *panel; g_return_if_fail (object != NULL); g_return_if_fail (CC_IS_EMPATHY_ACCOUNTS_PANEL (object)); - empathy_accounts_panel = CC_EMPATHY_ACCOUNTS_PANEL (object); + panel = CC_EMPATHY_ACCOUNTS_PANEL (object); + + g_return_if_fail (panel->priv != NULL); - g_return_if_fail (empathy_accounts_panel->priv != NULL); + gtk_widget_destroy (panel->priv->accounts_window); - g_object_unref (empathy_accounts_panel->priv->empathy_accounts_page); + if (panel->priv->assistant != NULL) + gtk_widget_destroy (panel->priv->assistant); G_OBJECT_CLASS (cc_empathy_accounts_panel_parent_class)->finalize (object); } @@ -117,12 +197,8 @@ cc_empathy_accounts_panel_finalize (GObject *object) static void cc_empathy_accounts_panel_class_init (CcEmpathyAccountsPanelClass *klass) { - CcPanelClass *panel_class = CC_PANEL_CLASS (klass); GObjectClass *object_class = G_OBJECT_CLASS (klass); - panel_class->active_changed = cc_empathy_accounts_panel_active_changed; - - object_class->constructor = cc_empathy_accounts_panel_constructor; object_class->finalize = cc_empathy_accounts_panel_finalize; g_type_class_add_private (klass, sizeof (CcEmpathyAccountsPanelPrivate)); @@ -137,15 +213,24 @@ static void cc_empathy_accounts_panel_init (CcEmpathyAccountsPanel *panel) { GConfClient *client; + TpAccountManager *account_manager; panel->priv = CC_EMPATHY_ACCOUNTS_PANEL_GET_PRIVATE (panel); + empathy_gtk_init (); + client = gconf_client_get_default (); gconf_client_add_dir (client, "/desktop/gnome/peripherals/empathy_accounts", GCONF_CLIENT_PRELOAD_ONELEVEL, NULL); gconf_client_add_dir (client, "/desktop/gnome/interface", GCONF_CLIENT_PRELOAD_ONELEVEL, NULL); g_object_unref (client); + + /* unref'd in final endpoint callbacks */ + account_manager = tp_account_manager_dup (); + + tp_account_manager_prepare_async (account_manager, NULL, + account_manager_ready_for_accounts_cb, panel); } void @@ -156,6 +241,6 @@ cc_empathy_accounts_panel_register (GIOModule *module) bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8"); cc_empathy_accounts_panel_register_type (G_TYPE_MODULE (module)); - g_io_extension_point_implement (CC_PANEL_EXTENSION_POINT_NAME, + g_io_extension_point_implement (CC_SHELL_PANEL_EXTENSION_POINT, CC_TYPE_EMPATHY_ACCOUNTS_PANEL, "empathy-accounts", 10); } |