aboutsummaryrefslogtreecommitdiffstats
path: root/libempathy-gtk/empathy-password-dialog.c
diff options
context:
space:
mode:
authorGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2011-10-28 22:34:40 +0800
committerGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2011-11-23 20:14:30 +0800
commit80ff6670675cdfa087c92901d8d96c16f40c5613 (patch)
tree0b1b9cf5e822a9afff5da0d806b259e60efb8a41 /libempathy-gtk/empathy-password-dialog.c
parentadca8bd9665b6455879f2478e51c4bfd53af4d52 (diff)
downloadgsoc2013-empathy-80ff6670675cdfa087c92901d8d96c16f40c5613.tar
gsoc2013-empathy-80ff6670675cdfa087c92901d8d96c16f40c5613.tar.gz
gsoc2013-empathy-80ff6670675cdfa087c92901d8d96c16f40c5613.tar.bz2
gsoc2013-empathy-80ff6670675cdfa087c92901d8d96c16f40c5613.tar.lz
gsoc2013-empathy-80ff6670675cdfa087c92901d8d96c16f40c5613.tar.xz
gsoc2013-empathy-80ff6670675cdfa087c92901d8d96c16f40c5613.tar.zst
gsoc2013-empathy-80ff6670675cdfa087c92901d8d96c16f40c5613.zip
Abstract EmpathyPasswordDialog to EmpathyBasePasswordDialog
I'm going to implement a slidely different version of this dialog so best to re-use as much code as possible. https://bugzilla.gnome.org/show_bug.cgi?id=661640
Diffstat (limited to 'libempathy-gtk/empathy-password-dialog.c')
-rw-r--r--libempathy-gtk/empathy-password-dialog.c206
1 files changed, 12 insertions, 194 deletions
diff --git a/libempathy-gtk/empathy-password-dialog.c b/libempathy-gtk/empathy-password-dialog.c
index c23e0d899..339e0a146 100644
--- a/libempathy-gtk/empathy-password-dialog.c
+++ b/libempathy-gtk/empathy-password-dialog.c
@@ -28,7 +28,7 @@
#include <libempathy/empathy-utils.h>
G_DEFINE_TYPE (EmpathyPasswordDialog, empathy_password_dialog,
- GTK_TYPE_MESSAGE_DIALOG)
+ EMPATHY_TYPE_BASE_PASSWORD_DIALOG)
enum {
PROP_HANDLER = 1,
@@ -38,14 +38,6 @@ enum {
struct _EmpathyPasswordDialogPriv {
EmpathyServerSASLHandler *handler;
-
- GtkWidget *entry;
- GtkWidget *ticky;
- GtkWidget *ok_button;
-
- gboolean grabbing;
-
- gboolean dispose_run;
};
static void
@@ -92,11 +84,6 @@ empathy_password_dialog_dispose (GObject *object)
{
EmpathyPasswordDialog *self = (EmpathyPasswordDialog *) object;
- if (self->priv->dispose_run)
- return;
-
- self->priv->dispose_run = TRUE;
-
tp_clear_object (&self->priv->handler);
G_OBJECT_CLASS (empathy_password_dialog_parent_class)->dispose (object);
@@ -108,12 +95,13 @@ password_dialog_response_cb (GtkDialog *dialog,
gpointer user_data)
{
EmpathyPasswordDialog *self = (EmpathyPasswordDialog *) dialog;
+ EmpathyBasePasswordDialog *base = (EmpathyBasePasswordDialog *) dialog;
if (response == GTK_RESPONSE_OK)
{
empathy_server_sasl_handler_provide_password (self->priv->handler,
- gtk_entry_get_text (GTK_ENTRY (self->priv->entry)),
- gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (self->priv->ticky)));
+ gtk_entry_get_text (GTK_ENTRY (base->entry)),
+ gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (base->ticky)));
}
else
{
@@ -124,116 +112,6 @@ password_dialog_response_cb (GtkDialog *dialog,
}
static void
-clear_icon_released_cb (GtkEntry *entry,
- GtkEntryIconPosition icon_pos,
- GdkEvent *event,
- gpointer user_data)
-{
- gtk_entry_set_text (entry, "");
-}
-
-static void
-password_entry_changed_cb (GtkEditable *entry,
- gpointer user_data)
-{
- EmpathyPasswordDialog *self = user_data;
- const gchar *str;
-
- str = gtk_entry_get_text (GTK_ENTRY (entry));
-
- gtk_entry_set_icon_sensitive (GTK_ENTRY (entry),
- GTK_ENTRY_ICON_SECONDARY, !EMP_STR_EMPTY (str));
-
- gtk_widget_set_sensitive (self->priv->ok_button,
- !EMP_STR_EMPTY (str));
-}
-
-static void
-password_entry_activate_cb (GtkEntry *entry,
- EmpathyPasswordDialog *self)
-{
- gtk_dialog_response (GTK_DIALOG (self), GTK_RESPONSE_OK);
-}
-
-static gboolean
-password_dialog_grab_keyboard (GtkWidget *widget,
- GdkEvent *event,
- gpointer user_data)
-{
- EmpathyPasswordDialog *self = user_data;
-
- if (!self->priv->grabbing)
- {
- GdkDevice *device = gdk_event_get_device (event);
-
- if (device != NULL)
- {
- GdkGrabStatus status = gdk_device_grab (device,
- gtk_widget_get_window (widget),
- GDK_OWNERSHIP_WINDOW,
- FALSE,
- GDK_ALL_EVENTS_MASK,
- NULL,
- gdk_event_get_time (event));
-
- if (status != GDK_GRAB_SUCCESS)
- DEBUG ("Could not grab keyboard; grab status was %u", status);
- else
- self->priv->grabbing = TRUE;
- }
- else
- DEBUG ("Could not get the event device!");
- }
-
- return FALSE;
-}
-
-static gboolean
-password_dialog_ungrab_keyboard (GtkWidget *widget,
- GdkEvent *event,
- gpointer user_data)
-{
- EmpathyPasswordDialog *self = user_data;
-
- if (self->priv->grabbing)
- {
- GdkDevice *device = gdk_event_get_device (event);
-
- if (device != NULL)
- {
- gdk_device_ungrab (device, gdk_event_get_time (event));
- self->priv->grabbing = FALSE;
- }
- else
- DEBUG ("Could not get the event device!");
- }
-
- return FALSE;
-}
-
-static gboolean
-password_dialog_window_state_changed (GtkWidget *widget,
- GdkEventWindowState *event,
- gpointer data)
-{
- GdkWindowState state = gdk_window_get_state (gtk_widget_get_window (widget));
-
- if (state & GDK_WINDOW_STATE_WITHDRAWN
- || state & GDK_WINDOW_STATE_ICONIFIED
- || state & GDK_WINDOW_STATE_FULLSCREEN
- || state & GDK_WINDOW_STATE_MAXIMIZED)
- {
- password_dialog_ungrab_keyboard (widget, (GdkEvent *) event, data);
- }
- else
- {
- password_dialog_grab_keyboard (widget, (GdkEvent *) event, data);
- }
-
- return FALSE;
-}
-
-static void
password_dialog_handler_invalidated_cb (EmpathyServerSASLHandler *handler,
EmpathyPasswordDialog *dialog)
{
@@ -243,90 +121,28 @@ password_dialog_handler_invalidated_cb (EmpathyServerSASLHandler *handler,
static void
empathy_password_dialog_constructed (GObject *object)
{
- EmpathyPasswordDialog *self;
- TpAccount *account;
- GtkWidget *icon;
- GtkBox *box;
+ EmpathyPasswordDialog *self = (EmpathyPasswordDialog *) object;
+ EmpathyBasePasswordDialog *base = (EmpathyBasePasswordDialog *) object;
gchar *text;
- self = EMPATHY_PASSWORD_DIALOG (object);
-
- g_assert (self->priv->handler != NULL);
-
- self->priv->grabbing = FALSE;
-
- account = empathy_server_sasl_handler_get_account (self->priv->handler);
+ G_OBJECT_CLASS (empathy_password_dialog_parent_class)->constructed (object);
tp_g_signal_connect_object (self->priv->handler, "invalidated",
G_CALLBACK (password_dialog_handler_invalidated_cb),
object, 0);
- /* dialog */
- gtk_dialog_add_button (GTK_DIALOG (self),
- GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL);
-
- self->priv->ok_button = gtk_dialog_add_button (GTK_DIALOG (self),
- GTK_STOCK_OK, GTK_RESPONSE_OK);
- gtk_widget_set_sensitive (self->priv->ok_button, FALSE);
-
text = g_strdup_printf (_("Enter your password for account\n<b>%s</b>"),
- tp_account_get_display_name (account));
+ tp_account_get_display_name (base->account));
gtk_message_dialog_set_markup (GTK_MESSAGE_DIALOG (self), text);
g_free (text);
- gtk_window_set_icon_name (GTK_WINDOW (self),
- GTK_STOCK_DIALOG_AUTHENTICATION);
-
- box = GTK_BOX (gtk_dialog_get_content_area (GTK_DIALOG (self)));
-
- /* dialog icon */
- icon = gtk_image_new_from_icon_name (tp_account_get_icon_name (account),
- GTK_ICON_SIZE_DIALOG);
- gtk_message_dialog_set_image (GTK_MESSAGE_DIALOG (self), icon);
- gtk_widget_show (icon);
-
- /* entry */
- self->priv->entry = gtk_entry_new ();
- gtk_entry_set_visibility (GTK_ENTRY (self->priv->entry), FALSE);
-
- /* entry clear icon */
- gtk_entry_set_icon_from_stock (GTK_ENTRY (self->priv->entry),
- GTK_ENTRY_ICON_SECONDARY, GTK_STOCK_CLEAR);
- gtk_entry_set_icon_sensitive (GTK_ENTRY (self->priv->entry),
- GTK_ENTRY_ICON_SECONDARY, FALSE);
-
- g_signal_connect (self->priv->entry, "icon-release",
- G_CALLBACK (clear_icon_released_cb), NULL);
- g_signal_connect (self->priv->entry, "changed",
- G_CALLBACK (password_entry_changed_cb), self);
- g_signal_connect (self->priv->entry, "activate",
- G_CALLBACK (password_entry_activate_cb), self);
-
- gtk_box_pack_start (box, self->priv->entry, FALSE, FALSE, 0);
- gtk_widget_show (self->priv->entry);
-
- /* remember password ticky box */
- self->priv->ticky = gtk_check_button_new_with_label (_("Remember password"));
-
- gtk_box_pack_start (box, self->priv->ticky, FALSE, FALSE, 0);
-
/* only show it if we actually support it */
if (empathy_server_sasl_handler_can_save_response_somewhere (
self->priv->handler))
- gtk_widget_show (self->priv->ticky);
+ gtk_widget_show (base->ticky);
g_signal_connect (self, "response",
G_CALLBACK (password_dialog_response_cb), self);
- g_signal_connect (self, "window-state-event",
- G_CALLBACK (password_dialog_window_state_changed), self);
- g_signal_connect (self, "map-event",
- G_CALLBACK (password_dialog_grab_keyboard), self);
- g_signal_connect (self, "unmap-event",
- G_CALLBACK (password_dialog_ungrab_keyboard), self);
-
- gtk_widget_grab_focus (self->priv->entry);
-
- gtk_window_set_position (GTK_WINDOW (self), GTK_WIN_POS_CENTER_ALWAYS);
}
static void
@@ -362,5 +178,7 @@ empathy_password_dialog_new (EmpathyServerSASLHandler *handler)
g_assert (EMPATHY_IS_SERVER_SASL_HANDLER (handler));
return g_object_new (EMPATHY_TYPE_PASSWORD_DIALOG,
- "handler", handler, NULL);
+ "handler", handler,
+ "account", empathy_server_sasl_handler_get_account (handler),
+ NULL);
}