aboutsummaryrefslogtreecommitdiffstats
path: root/src/empathy-main-window.c
diff options
context:
space:
mode:
authorDanielle Madeley <danielle.madeley@collabora.co.uk>2011-04-15 14:39:40 +0800
committerDanielle Madeley <danielle.madeley@collabora.co.uk>2011-05-05 15:12:27 +0800
commit4786fdc5f4424c88c7fcaad5357f42a27c4e24ad (patch)
tree8633df67393677578e4a3496955ca29ddaf6c6c1 /src/empathy-main-window.c
parent1038e0350d5cbe5b70f8d618b1a13d6717da8d7c (diff)
downloadgsoc2013-empathy-4786fdc5f4424c88c7fcaad5357f42a27c4e24ad.tar
gsoc2013-empathy-4786fdc5f4424c88c7fcaad5357f42a27c4e24ad.tar.gz
gsoc2013-empathy-4786fdc5f4424c88c7fcaad5357f42a27c4e24ad.tar.bz2
gsoc2013-empathy-4786fdc5f4424c88c7fcaad5357f42a27c4e24ad.tar.lz
gsoc2013-empathy-4786fdc5f4424c88c7fcaad5357f42a27c4e24ad.tar.xz
gsoc2013-empathy-4786fdc5f4424c88c7fcaad5357f42a27c4e24ad.tar.zst
gsoc2013-empathy-4786fdc5f4424c88c7fcaad5357f42a27c4e24ad.zip
Add a menu item to choose whether to show account balances in the roster
Diffstat (limited to 'src/empathy-main-window.c')
-rw-r--r--src/empathy-main-window.c30
1 files changed, 25 insertions, 5 deletions
diff --git a/src/empathy-main-window.c b/src/empathy-main-window.c
index c02fccb02..0952284e6 100644
--- a/src/empathy-main-window.c
+++ b/src/empathy-main-window.c
@@ -146,6 +146,7 @@ struct _EmpathyMainWindowPriv {
GtkWidget *edit_context_separator;
GtkActionGroup *balance_action_group;
+ GtkAction *view_balance_show_in_roster;
GtkWidget *balance_vbox;
guint size_timeout_id;
@@ -957,9 +958,6 @@ main_window_setup_balance_create_widget (EmpathyMainWindow *window,
EmpathyMainWindowPriv *priv = GET_PRIV (window);
GtkWidget *hbox, *image, *label, *button;
- if (action == NULL)
- return NULL;
-
hbox = gtk_hbox_new (FALSE, 6);
image = gtk_image_new ();
@@ -1000,6 +998,7 @@ main_window_setup_balance_conn_ready (GObject *conn,
gpointer user_data)
{
EmpathyMainWindow *window = user_data;
+ EmpathyMainWindowPriv *priv = GET_PRIV (window);
TpAccount *account = g_object_get_data (conn, "account");
GtkAction *action;
GtkWidget *widget;
@@ -1023,6 +1022,11 @@ main_window_setup_balance_conn_ready (GObject *conn,
/* create the action */
action = main_window_setup_balance_create_action (window, account);
+ if (action == NULL)
+ return;
+
+ gtk_action_set_visible (priv->view_balance_show_in_roster, TRUE);
+
/* create the display widget */
widget = main_window_setup_balance_create_widget (window, action);
@@ -1079,6 +1083,7 @@ main_window_connection_changed_cb (TpAccount *account,
if (priv->balance_action_group != NULL) {
GtkAction *action;
char *name;
+ GList *a;
name = main_window_account_to_action_name (account);
@@ -1101,6 +1106,15 @@ main_window_connection_changed_cb (TpAccount *account,
}
g_free (name);
+
+ a = gtk_action_group_list_actions (
+ priv->balance_action_group);
+
+ gtk_action_set_visible (
+ priv->view_balance_show_in_roster,
+ g_list_length (a) > 0);
+
+ g_list_free (a);
}
}
@@ -2092,6 +2106,7 @@ empathy_main_window_init (EmpathyMainWindow *window)
"notebook", &priv->notebook,
"no_entry_label", &priv->no_entry_label,
"roster_scrolledwindow", &sw,
+ "view_balance_show_in_roster", &priv->view_balance_show_in_roster,
NULL);
g_free (filename);
@@ -2252,8 +2267,13 @@ empathy_main_window_init (EmpathyMainWindow *window)
/* Set window size. */
empathy_geometry_bind (GTK_WINDOW (window), GEOMETRY_NAME);
- /* FIXME: bind balance_vbox to action */
- gtk_widget_show (priv->balance_vbox);
+ /* bind view_balance_show_in_roster */
+ g_settings_bind (priv->gsettings_ui, "show-balance-in-roster",
+ priv->view_balance_show_in_roster, "active",
+ G_SETTINGS_BIND_DEFAULT);
+ g_object_bind_property (priv->view_balance_show_in_roster, "active",
+ priv->balance_vbox, "visible",
+ G_BINDING_SYNC_CREATE);
/* Enable event handling */
priv->call_observer = empathy_call_observer_dup_singleton ();