[gtk/wip/matthiasc/popup2: 21/58] root: Add default handling
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/wip/matthiasc/popup2: 21/58] root: Add default handling
- Date: Wed, 20 Mar 2019 02:56:01 +0000 (UTC)
commit 21722ed53810272f3659f765013d1a96f298bac3
Author: Matthias Clasen <mclasen redhat com>
Date: Sun Mar 3 19:57:45 2019 -0500
root: Add default handling
Add a default-widget property with getter/setter
and a gtk_root_activate_default() function.
gtk/gtkroot.c | 90 ++++++++++++++++++++++++++++++++++++++++++++++++++++
gtk/gtkroot.h | 9 ++++++
gtk/gtkrootprivate.h | 1 +
3 files changed, 100 insertions(+)
---
diff --git a/gtk/gtkroot.c b/gtk/gtkroot.c
index 34528f8cca..2ce455b040 100644
--- a/gtk/gtkroot.c
+++ b/gtk/gtkroot.c
@@ -82,6 +82,13 @@ gtk_root_default_init (GtkRootInterface *iface)
P_("The focus widget"),
GTK_TYPE_WIDGET,
GTK_PARAM_READWRITE|G_PARAM_EXPLICIT_NOTIFY));
+
+ g_object_interface_install_property (iface,
+ g_param_spec_object ("default-widget",
+ P_("Default widget"),
+ P_("The default widget"),
+ GTK_TYPE_WIDGET,
+ GTK_PARAM_READWRITE|G_PARAM_EXPLICIT_NOTIFY));
}
GdkDisplay *
@@ -194,11 +201,94 @@ gtk_root_get_focus (GtkRoot *self)
return focus;
}
+/**
+ * gtk_root_set_default:
+ * @self: a #GtkRoot
+ * @widget: (allow-none): widget to be the default, or %NULL
+ * to unset the default widget
+ *
+ * The default widget is the widget that’s activated when the user
+ * presses Enter in a dialog (for example). This function sets or
+ * unsets the default widget for a #GtkRoot.
+ *
+ * When setting (rather than unsetting) the default widget it is
+ * generally easier to call gtk_widget_grab_default() on the widget.
+ * Before making a widget the default widget, you must call
+ * gtk_widget_set_can_default() on the widget you’d like to make
+ * the default.
+ */
+void
+gtk_root_set_default (GtkRoot *self,
+ GtkWidget *widget)
+{
+ g_return_if_fail (GTK_IS_ROOT (self));
+ g_return_if_fail (widget == NULL || GTK_IS_WIDGET (widget));
+
+ g_object_set (self, "default-widget", widget, NULL);
+}
+
+/**
+ * gtk_root_get_default:
+ * @self: a #GtkRoot
+ *
+ * Returns the default widget for @root. See
+ * gtk_root_set_default() for more details.
+ *
+ * Returns: (nullable) (transfer none): the default widget, or %NULL
+ * if there is none
+ */
+GtkWidget *
+gtk_root_get_default (GtkRoot *self)
+{
+ GtkWidget *widget;
+
+ g_return_val_if_fail (GTK_IS_ROOT (self), NULL);
+
+ g_object_get (self, "default-widget", &widget, NULL);
+
+ if (widget)
+ g_object_unref (widget);
+
+ return widget;
+}
+
+/**
+ * gtk_root_activate_default:
+ * @self: a #GtkRoot
+ *
+ * Activates the default widget for the window, unless the current
+ * focused widget has been configured to receive the default action
+ * (see gtk_widget_set_receives_default()), in which case the
+ * focused widget is activated.
+ *
+ * Returns: %TRUE if a widget got activated
+ */
+gboolean
+gtk_root_activate_default (GtkRoot *self)
+{
+ GtkWidget *default_widget;
+ GtkWidget *focus_widget;
+
+ g_return_val_if_fail (GTK_IS_ROOT (self), FALSE);
+
+ default_widget = gtk_root_get_default (self);
+ focus_widget = gtk_root_get_focus (self);
+
+ if (default_widget && gtk_widget_is_sensitive (default_widget) &&
+ (!focus_widget || !gtk_widget_get_receives_default (focus_widget)))
+ return gtk_widget_activate (default_widget);
+ else if (focus_widget && gtk_widget_is_sensitive (focus_widget))
+ return gtk_widget_activate (focus_widget);
+
+ return FALSE;
+}
+
guint
gtk_root_install_properties (GObjectClass *object_class,
guint first_prop)
{
g_object_class_override_property (object_class, first_prop + GTK_ROOT_PROP_FOCUS_WIDGET, "focus-widget");
+ g_object_class_override_property (object_class, first_prop + GTK_ROOT_PROP_DEFAULT_WIDGET,
"default-widget");
return GTK_ROOT_NUM_PROPERTIES;
}
diff --git a/gtk/gtkroot.h b/gtk/gtkroot.h
index 32a528e582..e4b0b96a71 100644
--- a/gtk/gtkroot.h
+++ b/gtk/gtkroot.h
@@ -63,6 +63,15 @@ void gtk_root_set_focus (GtkRoot *self,
GDK_AVAILABLE_IN_ALL
GtkWidget * gtk_root_get_focus (GtkRoot *self);
+GDK_AVAILABLE_IN_ALL
+void gtk_root_set_default (GtkRoot *self,
+ GtkWidget *widget);
+GDK_AVAILABLE_IN_ALL
+GtkWidget * gtk_root_get_default (GtkRoot *self);
+GDK_AVAILABLE_IN_ALL
+gboolean gtk_root_activate_default (GtkRoot *self);
+
+
G_END_DECLS
#endif /* __GTK_ROOT_H__ */
diff --git a/gtk/gtkrootprivate.h b/gtk/gtkrootprivate.h
index c7c942c203..e529e1c7c7 100644
--- a/gtk/gtkrootprivate.h
+++ b/gtk/gtkrootprivate.h
@@ -18,6 +18,7 @@ void gtk_root_stop_layout_phase (GtkRoot
enum {
GTK_ROOT_PROP_FOCUS_WIDGET,
+ GTK_ROOT_PROP_DEFAULT_WIDGET,
GTK_ROOT_NUM_PROPERTIES
} GtkRootProperties;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]