[gtk/wip/matthiasc/popup5: 104/128] popover: Make Escape to close work again



commit 8ddb13aaf7e673907b87f7db58fb59f6ec8949a6
Author: Matthias Clasen <mclasen redhat com>
Date:   Sat May 4 16:45:12 2019 +0000

    popover: Make Escape to close work again

 gtk/gtkpopover.c | 35 ++++++++++++++++-------------------
 gtk/gtkpopover.h |  6 ------
 2 files changed, 16 insertions(+), 25 deletions(-)
---
diff --git a/gtk/gtkpopover.c b/gtk/gtkpopover.c
index cd63c134c8..52e8a346dd 100644
--- a/gtk/gtkpopover.c
+++ b/gtk/gtkpopover.c
@@ -144,7 +144,6 @@ typedef struct {
 } GtkPopoverPrivate;
 
 enum {
-  CLOSE,
   CLOSED,
   LAST_SIGNAL
 };
@@ -293,6 +292,21 @@ gtk_popover_focus_out (GtkWidget *widget)
 {
 }
 
+static gboolean
+gtk_popover_key_pressed (GtkWidget       *widget,
+                         guint            keyval,
+                         guint            keycode,
+                         GdkModifierType  state)
+{
+  if (keyval == GDK_KEY_Escape)
+    {
+      gtk_popover_popdown (GTK_POPOVER (widget));
+      return TRUE;
+    }
+
+  return FALSE;
+}
+
 static void
 ensure_state_flag_backdrop (GtkWidget *widget)
 {
@@ -438,6 +452,7 @@ gtk_popover_init (GtkPopover *popover)
   controller = gtk_event_controller_key_new ();
   g_signal_connect_swapped (controller, "focus-in", G_CALLBACK (gtk_popover_focus_in), popover);
   g_signal_connect_swapped (controller, "focus-out", G_CALLBACK (gtk_popover_focus_out), popover);
+  g_signal_connect_swapped (controller, "key-pressed", G_CALLBACK (gtk_popover_key_pressed), popover);
   gtk_widget_add_controller (GTK_WIDGET (popover), controller);
 
   priv->contents_widget = gtk_gizmo_new ("contents",
@@ -774,12 +789,6 @@ gtk_popover_get_property (GObject      *object,
     }
 }
 
-static void
-gtk_popover_close (GtkPopover *popover)
-{
-  gtk_widget_hide (GTK_WIDGET (popover));
-}
-
 static void
 gtk_popover_add (GtkContainer *container,
                  GtkWidget    *child)
@@ -831,8 +840,6 @@ gtk_popover_class_init (GtkPopoverClass *klass)
   container_class->add = gtk_popover_add;
   container_class->remove = gtk_popover_remove;
 
-  klass->close = gtk_popover_close;
-
   properties[PROP_RELATIVE_TO] =
       g_param_spec_object ("relative-to",
                            P_("Relative to"),
@@ -870,16 +877,6 @@ gtk_popover_class_init (GtkPopoverClass *klass)
 
   g_object_class_install_properties (object_class, NUM_PROPERTIES, properties);
 
-  signals[CLOSE] =
-    g_signal_new (I_("close"),
-                  G_TYPE_FROM_CLASS (object_class),
-                  G_SIGNAL_RUN_LAST | G_SIGNAL_ACTION,
-                  G_STRUCT_OFFSET (GtkPopoverClass, close),
-                  NULL, NULL,
-                  NULL,
-                  G_TYPE_NONE,
-                  0);
-
   signals[CLOSED] =
     g_signal_new (I_("closed"),
                   G_TYPE_FROM_CLASS (object_class),
diff --git a/gtk/gtkpopover.h b/gtk/gtkpopover.h
index e9456bd7cb..f3a069b474 100644
--- a/gtk/gtkpopover.h
+++ b/gtk/gtkpopover.h
@@ -48,12 +48,6 @@ struct _GtkPopoverClass
 {
   GtkBinClass parent_class;
 
-  /* keybinding signals */
-
-  void     (* close)            (GtkPopover *popover);
-
-  /* signals */
-
   void     (* closed)           (GtkPopover *popover);
 };
 


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]