[gtk/prop-list: 31/32] columnview: Allow to cancel reorder with Escape
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/prop-list: 31/32] columnview: Allow to cancel reorder with Escape
- Date: Sat, 21 Dec 2019 05:29:49 +0000 (UTC)
commit c80875b674384f44a4b641a21ef1f1185c7a6212
Author: Matthias Clasen <mclasen redhat com>
Date: Fri Dec 20 19:24:01 2019 -0500
columnview: Allow to cancel reorder with Escape
The treeview does this too.
gtk/gtkcolumnview.c | 47 +++++++++++++++++++++++++++++++++++++++++++++--
1 file changed, 45 insertions(+), 2 deletions(-)
---
diff --git a/gtk/gtkcolumnview.c b/gtk/gtkcolumnview.c
index 8ef51560d9..8681878848 100644
--- a/gtk/gtkcolumnview.c
+++ b/gtk/gtkcolumnview.c
@@ -38,6 +38,7 @@
#include "gtkadjustment.h"
#include "gtkgesturedrag.h"
#include "gtkeventcontrollermotion.h"
+#include "gtkeventcontrollerkey.h"
#include "gtkdnd.h"
/**
@@ -77,6 +78,8 @@ struct _GtkColumnView
int drag_x;
int drag_offset;
int drag_column_x;
+
+ GtkGesture *drag_gesture;
};
struct _GtkColumnViewClass
@@ -609,6 +612,8 @@ header_drag_begin (GtkGestureDrag *gesture,
int size;
gtk_gesture_set_state (GTK_GESTURE (gesture), GTK_EVENT_SEQUENCE_CLAIMED);
+ if (!gtk_widget_has_focus (GTK_WIDGET (self)))
+ gtk_widget_grab_focus (GTK_WIDGET (self));
gtk_column_view_column_get_allocation (column, NULL, &size);
gtk_column_view_column_set_fixed_width (column, size);
@@ -656,14 +661,24 @@ header_drag_end (GtkGestureDrag *gesture,
}
else if (self->in_column_reorder)
{
+ GdkEventSequence *sequence;
GtkColumnViewColumn *column;
GtkWidget *header;
int i;
+ self->in_column_reorder = FALSE;
+
+ if (self->drag_pos == -1)
+ return;
+
column = g_list_model_get_item (G_LIST_MODEL (self->columns), self->drag_pos);
header = gtk_column_view_column_get_header (column);
gtk_style_context_remove_class (gtk_widget_get_style_context (header), "dnd");
+ sequence = gtk_gesture_single_get_current_sequence (GTK_GESTURE_SINGLE (gesture));
+ if (!gtk_gesture_handles_sequence (GTK_GESTURE (gesture), sequence))
+ return;
+
for (i = 0; i < g_list_model_get_n_items (G_LIST_MODEL (self->columns)); i++)
{
GtkColumnViewColumn *col = g_list_model_get_item (G_LIST_MODEL (self->columns), i);
@@ -685,8 +700,6 @@ header_drag_end (GtkGestureDrag *gesture,
}
g_object_unref (column);
-
- self->in_column_reorder = FALSE;
}
}
@@ -696,9 +709,14 @@ header_drag_update (GtkGestureDrag *gesture,
double offset_y,
GtkColumnView *self)
{
+ GdkEventSequence *sequence;
GtkColumnViewColumn *column;
double start_x, x;
+ sequence = gtk_gesture_single_get_current_sequence (GTK_GESTURE_SINGLE (gesture));
+ if (!gtk_gesture_handles_sequence (GTK_GESTURE (gesture), sequence))
+ return;
+
if (self->drag_pos == -1)
return;
@@ -714,6 +732,9 @@ header_drag_update (GtkGestureDrag *gesture,
gtk_style_context_add_class (gtk_widget_get_style_context (header), "dnd");
gtk_gesture_set_state (GTK_GESTURE (gesture), GTK_EVENT_SEQUENCE_CLAIMED);
+ if (!gtk_widget_has_focus (GTK_WIDGET (self)))
+ gtk_widget_grab_focus (GTK_WIDGET (self));
+
self->in_column_reorder = TRUE;
}
}
@@ -770,6 +791,23 @@ header_motion (GtkEventControllerMotion *controller,
gtk_widget_set_cursor (self->header, NULL);
}
+static gboolean
+header_key_pressed (GtkEventControllerKey *controller,
+ guint keyval,
+ guint keycode,
+ GdkModifierType modifiers,
+ GtkColumnView *self)
+{
+ if (self->in_column_reorder)
+ {
+ if (keyval == GDK_KEY_Escape)
+ gtk_gesture_set_state (self->drag_gesture, GTK_EVENT_SEQUENCE_DENIED);
+ return TRUE;
+ }
+
+ return FALSE;
+}
+
static void
gtk_column_view_init (GtkColumnView *self)
{
@@ -788,11 +826,16 @@ gtk_column_view_init (GtkColumnView *self)
g_signal_connect (controller, "drag-end", G_CALLBACK (header_drag_end), self);
gtk_event_controller_set_propagation_phase (controller, GTK_PHASE_CAPTURE);
gtk_widget_add_controller (self->header, controller);
+ self->drag_gesture = GTK_GESTURE (controller);
controller = gtk_event_controller_motion_new ();
g_signal_connect (controller, "motion", G_CALLBACK (header_motion), self);
gtk_widget_add_controller (self->header, controller);
+ controller = gtk_event_controller_key_new ();
+ g_signal_connect (controller, "key-pressed", G_CALLBACK (header_key_pressed), self);
+ gtk_widget_add_controller (GTK_WIDGET (self), controller);
+
self->sorter = gtk_column_view_sorter_new ();
self->factory = gtk_column_list_item_factory_new (self);
self->listview = GTK_LIST_VIEW (gtk_list_view_new_with_factory (
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]