diff options
author | Danielle Madeley <danielle.madeley@collabora.co.uk> | 2011-10-20 12:48:49 +0800 |
---|---|---|
committer | Danielle Madeley <danielle.madeley@collabora.co.uk> | 2011-10-20 12:48:49 +0800 |
commit | 9cad8740eb8aec46bc896ccbf53bd8d23d632ac5 (patch) | |
tree | c3240ad33a7197c05d1c884feb3367663316f2fd | |
parent | 1358b8ae4551e659e3a61a7d1dc41b768cab46ea (diff) | |
download | gsoc2013-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
-rw-r--r-- | libempathy-gtk/empathy-contact-chooser.c | 56 |
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 (); |