aboutsummaryrefslogtreecommitdiffstats
path: root/libempathy-gtk
diff options
context:
space:
mode:
authorDanielle Madeley <danielle.madeley@collabora.co.uk>2011-10-20 12:48:49 +0800
committerDanielle Madeley <danielle.madeley@collabora.co.uk>2011-10-20 12:48:49 +0800
commit9cad8740eb8aec46bc896ccbf53bd8d23d632ac5 (patch)
treec3240ad33a7197c05d1c884feb3367663316f2fd /libempathy-gtk
parent1358b8ae4551e659e3a61a7d1dc41b768cab46ea (diff)
downloadgsoc2013-empathy-9cad8740eb8aec46bc896ccbf53bd8d23d632ac5.tar
gsoc2013-empathy-9cad8740eb8aec46bc896ccbf53bd8d23d632ac5.tar.gz
gsoc2013-empathy-9cad8740eb8aec46bc896ccbf53bd8d23d632ac5.tar.bz2
gsoc2013-empathy-9cad8740eb8aec46bc896ccbf53bd8d23d632ac5.tar.lz
gsoc2013-empathy-9cad8740eb8aec46bc896ccbf53bd8d23d632ac5.tar.xz
gsoc2013-empathy-9cad8740eb8aec46bc896ccbf53bd8d23d632ac5.tar.zst
gsoc2013-empathy-9cad8740eb8aec46bc896ccbf53bd8d23d632ac5.zip
[contact-chooser] Move the selection up/down without defocusing the entry
Diffstat (limited to 'libempathy-gtk')
-rw-r--r--libempathy-gtk/empathy-contact-chooser.c56
1 files changed, 56 insertions, 0 deletions
diff --git a/libempathy-gtk/empathy-contact-chooser.c b/libempathy-gtk/empathy-contact-chooser.c
index 5444ff5ad..2b568fc58 100644
--- a/libempathy-gtk/empathy-contact-chooser.c
+++ b/libempathy-gtk/empathy-contact-chooser.c
@@ -309,6 +309,60 @@ view_activate_cb (GtkTreeView *view,
g_signal_emit (self, signals[SIG_ACTIVATE], 0);
}
+static gboolean
+search_key_press_cb (GtkEntry *entry,
+ GdkEventKey *event,
+ EmpathyContactChooser *self)
+{
+ GtkTreeSelection *selection;
+ GtkTreeModel *model;
+ GtkTreeIter iter;
+
+ if (event->state != 0)
+ return FALSE;
+
+ switch (event->keyval)
+ {
+ case GDK_KEY_Down:
+ case GDK_KEY_KP_Down:
+ case GDK_KEY_Up:
+ case GDK_KEY_KP_Up:
+ break;
+
+ default:
+ return FALSE;
+ }
+
+ selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (self->priv->view));
+
+ if (!gtk_tree_selection_get_selected (selection, &model, &iter))
+ return TRUE;
+
+ switch (event->keyval)
+ {
+ case GDK_KEY_Down:
+ case GDK_KEY_KP_Down:
+ if (!gtk_tree_model_iter_next (model, &iter))
+ return TRUE;
+
+ break;
+
+ case GDK_KEY_Up:
+ case GDK_KEY_KP_Up:
+ if (!gtk_tree_model_iter_previous (model, &iter))
+ return TRUE;
+
+ break;
+
+ default:
+ g_assert_not_reached ();
+ }
+
+ gtk_tree_selection_select_iter (selection, &iter);
+
+ return TRUE;
+}
+
static void
empathy_contact_chooser_init (EmpathyContactChooser *self)
{
@@ -337,6 +391,8 @@ empathy_contact_chooser_init (EmpathyContactChooser *self)
G_CALLBACK (search_text_changed), self);
g_signal_connect (self->priv->search_entry, "activate",
G_CALLBACK (search_activate_cb), self);
+ g_signal_connect (self->priv->search_entry, "key-press-event",
+ G_CALLBACK (search_key_press_cb), self);
/* Add the treeview */
mgr = empathy_individual_manager_dup_singleton ();