summaryrefslogtreecommitdiff
path: root/src/nautilus-window-slot.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/nautilus-window-slot.c')
-rw-r--r--src/nautilus-window-slot.c23
1 files changed, 22 insertions, 1 deletions
diff --git a/src/nautilus-window-slot.c b/src/nautilus-window-slot.c
index 7c1daf9e1..f87b14b99 100644
--- a/src/nautilus-window-slot.c
+++ b/src/nautilus-window-slot.c
@@ -385,7 +385,7 @@ nautilus_window_slot_set_search_visible (NautilusWindowSlot *slot,
}
if (active_slot) {
- nautilus_window_grab_focus (slot->details->window);
+ gtk_widget_grab_focus (GTK_WIDGET (slot->details->window));
}
/* Now hide the editor and clear its state */
@@ -2376,9 +2376,28 @@ nautilus_window_slot_dispose (GObject *object)
}
static void
+nautilus_window_slot_grab_focus (GtkWidget *widget)
+{
+ NautilusWindowSlot *slot;
+
+ slot = NAUTILUS_WINDOW_SLOT (widget);
+
+ GTK_WIDGET_CLASS (nautilus_window_slot_parent_class)->grab_focus (widget);
+
+ if (slot->details->search_visible) {
+ gtk_widget_grab_focus (GTK_WIDGET (slot->details->query_editor));
+ } else if (slot->details->content_view) {
+ gtk_widget_grab_focus (GTK_WIDGET (slot->details->content_view));
+ } else if (slot->details->new_content_view) {
+ gtk_widget_grab_focus (GTK_WIDGET (slot->details->new_content_view));
+ }
+}
+
+static void
nautilus_window_slot_class_init (NautilusWindowSlotClass *klass)
{
GObjectClass *oclass = G_OBJECT_CLASS (klass);
+ GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
klass->active = real_active;
klass->inactive = real_inactive;
@@ -2388,6 +2407,8 @@ nautilus_window_slot_class_init (NautilusWindowSlotClass *klass)
oclass->set_property = nautilus_window_slot_set_property;
oclass->get_property = nautilus_window_slot_get_property;
+ widget_class->grab_focus = nautilus_window_slot_grab_focus;
+
signals[ACTIVE] =
g_signal_new ("active",
G_TYPE_FROM_CLASS (klass),