aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--libempathy-gtk/empathy-chat.c130
1 files changed, 84 insertions, 46 deletions
diff --git a/libempathy-gtk/empathy-chat.c b/libempathy-gtk/empathy-chat.c
index 4b3bcb427..e0b6d8654 100644
--- a/libempathy-gtk/empathy-chat.c
+++ b/libempathy-gtk/empathy-chat.c
@@ -2963,15 +2963,23 @@ empathy_chat_get_tp_chat (EmpathyChat *chat)
return priv->tp_chat;
}
-static void display_password_info_bar (EmpathyChat *self,
- gboolean retry);
+typedef struct
+{
+ EmpathyChat *self;
+ GtkWidget *info_bar;
+ GtkWidget *button;
+ GtkWidget *label;
+ GtkWidget *entry;
+ GtkWidget *spinner;
+} PasswordData;
static void
provide_password_cb (GObject *tp_chat,
GAsyncResult *res,
gpointer user_data)
{
- EmpathyChat *self = EMPATHY_CHAT (user_data);
+ PasswordData *data = user_data;
+ EmpathyChat *self = data->self;
EmpathyChatPriv *priv = GET_PRIV (self);
GError *error = NULL;
@@ -2980,12 +2988,39 @@ provide_password_cb (GObject *tp_chat,
DEBUG ("error: %s", error->message);
/* FIXME: what should we do if that's another error? Close the channel?
* Display the raw D-Bus error to the user isn't very useful */
- if (g_error_matches (error, TP_ERRORS, TP_ERROR_AUTHENTICATION_FAILED))
- display_password_info_bar (self, TRUE);
+ if (g_error_matches (error, TP_ERRORS, TP_ERROR_AUTHENTICATION_FAILED)) {
+ /* entry */
+ gtk_entry_set_text (GTK_ENTRY (data->entry), "");
+ gtk_widget_set_sensitive (data->entry, TRUE);
+ gtk_widget_grab_focus (data->entry);
+
+ /* info bar */
+ gtk_info_bar_set_message_type (
+ GTK_INFO_BAR (data->info_bar),
+ GTK_MESSAGE_ERROR);
+
+ /* button */
+ gtk_widget_set_sensitive (data->button, TRUE);
+ gtk_button_set_label (GTK_BUTTON (data->button),
+ _("Retry"));
+
+ /* label */
+ gtk_label_set_text (GTK_LABEL (data->label),
+ _("Wrong password; please try again:"));
+
+ /* spinner */
+ gtk_spinner_stop (GTK_SPINNER (data->spinner));
+ gtk_widget_hide (data->spinner);
+ }
g_error_free (error);
return;
}
+ /* Get rid of the password info bar finally */
+ gtk_widget_destroy (data->info_bar);
+
+ g_slice_free (PasswordData, data);
+
/* Room joined */
gtk_widget_set_sensitive (priv->hpaned, TRUE);
gtk_widget_grab_focus (self->input_text_view);
@@ -2994,44 +3029,45 @@ provide_password_cb (GObject *tp_chat,
static void
password_infobar_response_cb (GtkWidget *info_bar,
gint response_id,
- EmpathyChat *self)
+ PasswordData *data)
{
- EmpathyChatPriv *priv = GET_PRIV (self);
- GtkWidget *entry;
+ EmpathyChatPriv *priv = GET_PRIV (data->self);
const gchar *password;
- if (response_id != GTK_RESPONSE_OK)
- goto out;
-
- entry = g_object_get_data (G_OBJECT (info_bar), "password-entry");
- g_assert (entry != NULL);
+ if (response_id != GTK_RESPONSE_OK) {
+ gtk_widget_destroy (info_bar);
+ g_slice_free (PasswordData, data);
+ return;
+ }
- password = gtk_entry_get_text (GTK_ENTRY (entry));
+ password = gtk_entry_get_text (GTK_ENTRY (data->entry));
empathy_tp_chat_provide_password_async (priv->tp_chat, password,
- provide_password_cb, self);
+ provide_password_cb, data);
+
+ gtk_widget_set_sensitive (data->button, FALSE);
+ gtk_widget_set_sensitive (data->entry, FALSE);
- out:
- gtk_widget_destroy (info_bar);
+ gtk_spinner_start (GTK_SPINNER (data->spinner));
+ gtk_widget_show (data->spinner);
}
static void
password_entry_activate_cb (GtkWidget *entry,
- GtkWidget *info_bar)
+ PasswordData *data)
{
- gtk_info_bar_response (GTK_INFO_BAR (info_bar), GTK_RESPONSE_OK);
+ gtk_info_bar_response (GTK_INFO_BAR (data->info_bar), GTK_RESPONSE_OK);
}
static void
passwd_join_button_cb (GtkButton *button,
- GtkWidget *info_bar)
+ PasswordData *data)
{
- gtk_info_bar_response (GTK_INFO_BAR (info_bar), GTK_RESPONSE_OK);
+ gtk_info_bar_response (GTK_INFO_BAR (data->info_bar), GTK_RESPONSE_OK);
}
static void
-display_password_info_bar (EmpathyChat *self,
- gboolean retry)
+display_password_info_bar (EmpathyChat *self)
{
EmpathyChatPriv *priv = GET_PRIV (self);
GtkWidget *info_bar;
@@ -3042,28 +3078,18 @@ display_password_info_bar (EmpathyChat *self,
GtkWidget *entry;
GtkWidget *alig;
GtkWidget *button;
- GtkMessageType type;
- const gchar *msg, *button_label;
+ GtkWidget *spinner;
+ PasswordData *data;
- if (retry) {
- /* Previous password was wrong */
- type = GTK_MESSAGE_ERROR;
- msg = _("Wrong password; please try again:");
- button_label = _("Retry");
- }
- else {
- /* First time we're trying to join */
- type = GTK_MESSAGE_QUESTION;
- msg = _("This room is protected by a password:");
- button_label = _("Join");
- }
+ data = g_slice_new0 (PasswordData);
info_bar = gtk_info_bar_new ();
- gtk_info_bar_set_message_type (GTK_INFO_BAR (info_bar), type);
+ gtk_info_bar_set_message_type (GTK_INFO_BAR (info_bar),
+ GTK_MESSAGE_QUESTION);
content_area = gtk_info_bar_get_content_area (GTK_INFO_BAR (info_bar));
- hbox = gtk_hbox_new (FALSE, 3);
+ hbox = gtk_hbox_new (FALSE, 5);
gtk_container_add (GTK_CONTAINER (content_area), hbox);
/* Add image */
@@ -3072,7 +3098,7 @@ display_password_info_bar (EmpathyChat *self,
gtk_box_pack_start (GTK_BOX (hbox), image, FALSE, FALSE, 0);
/* Add message */
- label = gtk_label_new (msg);
+ label = gtk_label_new (_("This room is protected by a password:"));
gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
/* Add password entry */
@@ -3081,7 +3107,7 @@ display_password_info_bar (EmpathyChat *self,
gtk_box_pack_start (GTK_BOX (hbox), entry, TRUE, TRUE, 0);
g_signal_connect (entry, "activate",
- G_CALLBACK (password_entry_activate_cb), info_bar);
+ G_CALLBACK (password_entry_activate_cb), data);
/* Focus the password entry once it's realized */
g_signal_connect (entry, "realize", G_CALLBACK (gtk_widget_grab_focus), NULL);
@@ -3089,23 +3115,35 @@ display_password_info_bar (EmpathyChat *self,
/* Add 'Join' button */
alig = gtk_alignment_new (0, 0.5, 0, 0);
- button = gtk_button_new_with_label (button_label);
+ button = gtk_button_new_with_label (_("Join"));
gtk_container_add (GTK_CONTAINER (alig), button);
gtk_box_pack_start (GTK_BOX (hbox), alig, FALSE, FALSE, 0);
g_signal_connect (button, "clicked", G_CALLBACK (passwd_join_button_cb),
- info_bar);
+ data);
+
+ /* Add spinner */
+ spinner = gtk_spinner_new ();
+ gtk_box_pack_end (GTK_BOX (hbox), spinner, TRUE, TRUE, 0);
- g_object_set_data (G_OBJECT (info_bar), "password-entry", entry);
+ /* Save some data for messing around with later */
+ data->self = self;
+ data->info_bar = info_bar;
+ data->button = button;
+ data->label = label;
+ data->entry = entry;
+ data->spinner = spinner;
gtk_box_pack_start (GTK_BOX (priv->info_bar_vbox), info_bar,
FALSE, FALSE, 3);
gtk_widget_show_all (hbox);
g_signal_connect (info_bar, "response",
- G_CALLBACK (password_infobar_response_cb), self);
+ G_CALLBACK (password_infobar_response_cb), data);
gtk_widget_show_all (info_bar);
+ /* ... but hide the spinner */
+ gtk_widget_hide (spinner);
}
static void
@@ -3114,7 +3152,7 @@ chat_password_needed_changed_cb (EmpathyChat *self)
EmpathyChatPriv *priv = GET_PRIV (self);
if (empathy_tp_chat_password_needed (priv->tp_chat)) {
- display_password_info_bar (self, FALSE);
+ display_password_info_bar (self);
gtk_widget_set_sensitive (priv->hpaned, FALSE);
}
}