X-Git-Url: https://git.0d.be/?p=empathy.git;a=blobdiff_plain;f=libempathy-gtk%2Fempathy-account-chooser.c;h=f743db99e3e65ff32096c4628d34c1219e6a268f;hp=c0df6a6a60b7313558889edeadf2d3cb92bdf793;hb=3b00a09f5d1cdee956c847c664dfde21a20f952b;hpb=a6d4518c76cf1c78bd954bb2488d6f01868dd337 diff --git a/libempathy-gtk/empathy-account-chooser.c b/libempathy-gtk/empathy-account-chooser.c index c0df6a6a..f743db99 100644 --- a/libempathy-gtk/empathy-account-chooser.c +++ b/libempathy-gtk/empathy-account-chooser.c @@ -247,6 +247,14 @@ account_cmp (GtkTreeModel *model, return result; } +static void +account_connection_notify_cb (TpAccount *account, + GParamSpec *spec, + EmpathyAccountChooser *self) +{ + update_account (self, account); +} + static void account_manager_prepared_cb (GObject *source_object, GAsyncResult *result, @@ -275,6 +283,14 @@ account_manager_prepared_cb (GObject *source_object, tp_g_signal_connect_object (account, "status-changed", G_CALLBACK (account_chooser_status_changed_cb), self, 0); + + /* We generally use the TpConnection from the account to filter it so, + * just relying on the account status is not enough. In some case we the + * status change can be notified while the TpConnection is still + * preparing. */ + tp_g_signal_connect_object (account, "notify::connection", + G_CALLBACK (account_connection_notify_cb), + self, 0); } g_list_free (accounts);