[gtk/prop-list: 31/32] columnview: Allow to cancel reorder with Escape



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]