[gtk/wip/matthiasc/popup5: 104/128] popover: Make Escape to close work again
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/wip/matthiasc/popup5: 104/128] popover: Make Escape to close work again
- Date: Sat, 18 May 2019 16:26:27 +0000 (UTC)
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]