[gtk/new-style-menu: 2/14] model button: Drop centered, inverted properties
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/new-style-menu: 2/14] model button: Drop centered, inverted properties
- Date: Fri, 7 Jun 2019 15:19:45 +0000 (UTC)
commit 944b6bf2cdf1ed5cb1fb249a81a27cae282e593f
Author: Matthias Clasen <mclasen redhat com>
Date: Wed Jun 5 22:31:14 2019 +0000
model button: Drop centered, inverted properties
These properties were only useful for titles,
and we have a role for that now.
gtk/gtkmenusectionbox.c | 2 +-
gtk/gtkmodelbutton.c | 161 ++++++++++++++++--------------------------------
2 files changed, 55 insertions(+), 108 deletions(-)
---
diff --git a/gtk/gtkmenusectionbox.c b/gtk/gtkmenusectionbox.c
index ee1dd1b553..f71108e42a 100644
--- a/gtk/gtkmenusectionbox.c
+++ b/gtk/gtkmenusectionbox.c
@@ -315,7 +315,7 @@ gtk_menu_section_box_insert_func (GtkMenuTrackerItem *item,
if (box->iconic)
{
g_object_bind_property (item, "verb-icon", widget, "icon", G_BINDING_SYNC_CREATE);
- g_object_set (widget, "iconic", TRUE, "centered", TRUE, NULL);
+ g_object_set (widget, "iconic", TRUE, NULL);
}
else
g_object_bind_property (item, "icon", widget, "icon", G_BINDING_SYNC_CREATE);
diff --git a/gtk/gtkmodelbutton.c b/gtk/gtkmodelbutton.c
index 6de73b6e05..b277eab6aa 100644
--- a/gtk/gtkmodelbutton.c
+++ b/gtk/gtkmodelbutton.c
@@ -174,8 +174,6 @@ enum
PROP_USE_MARKUP,
PROP_ACTIVE,
PROP_MENU_NAME,
- PROP_INVERTED,
- PROP_CENTERED,
PROP_ICONIC,
LAST_PROPERTY
};
@@ -191,16 +189,48 @@ indicator_is_left (GtkWidget *widget)
(gtk_widget_get_direction (widget) == GTK_TEXT_DIR_LTR && button->inverted));
}
+static void
+update_node_ordering (GtkModelButton *button)
+{
+ GtkStyleContext *indicator_context;
+ GtkWidget *child;
+
+ indicator_context = gtk_widget_get_style_context (button->indicator_widget);
+
+ if (indicator_is_left (GTK_WIDGET (button)))
+ {
+ gtk_style_context_add_class (indicator_context, GTK_STYLE_CLASS_LEFT);
+ gtk_style_context_remove_class (indicator_context, GTK_STYLE_CLASS_RIGHT);
+
+ child = gtk_widget_get_first_child (GTK_WIDGET (button));
+ if (child != button->indicator_widget)
+ gtk_widget_insert_before (button->indicator_widget, GTK_WIDGET (button), child);
+ }
+ else
+ {
+ gtk_style_context_add_class (indicator_context, GTK_STYLE_CLASS_RIGHT);
+ gtk_style_context_remove_class (indicator_context, GTK_STYLE_CLASS_LEFT);
+
+ child = gtk_widget_get_first_child (GTK_WIDGET (button));
+ if (child != button->indicator_widget)
+ gtk_widget_insert_after (button->indicator_widget, GTK_WIDGET (button), child);
+ }
+}
+
static void
gtk_model_button_update_state (GtkModelButton *button)
{
GtkStateFlags state;
GtkStateFlags indicator_state;
GtkCssImageBuiltinType image_type;
+ gboolean inverted;
+ gboolean centered;
state = gtk_widget_get_state_flags (GTK_WIDGET (button));
indicator_state = state;
image_type = GTK_CSS_IMAGE_BUILTIN_NONE;
+ inverted = FALSE;
+ centered = FALSE;
switch (button->role)
{
@@ -229,10 +259,8 @@ gtk_model_button_update_state (GtkModelButton *button)
break;
case GTK_BUTTON_ROLE_TITLE:
- g_object_set (button,
- "inverted", TRUE,
- "centered", TRUE,
- NULL);
+ inverted = TRUE;
+ centered = TRUE;
/* fall through */
case GTK_BUTTON_ROLE_NORMAL:
@@ -243,13 +271,28 @@ gtk_model_button_update_state (GtkModelButton *button)
else
image_type = GTK_CSS_IMAGE_BUILTIN_ARROW_RIGHT;
}
-
+ if (!centered)
+ centered = button->iconic;
break;
default:
g_assert_not_reached ();
}
+ if (button->inverted != inverted)
+ {
+ button->inverted = inverted;
+ update_node_ordering (button);
+ gtk_widget_queue_draw (GTK_WIDGET (button));
+ }
+
+ if (button->centered != centered)
+ {
+ button->centered = centered;
+ gtk_widget_set_halign (button->box, button->centered ? GTK_ALIGN_CENTER : GTK_ALIGN_FILL);
+ gtk_widget_queue_resize (GTK_WIDGET (button));
+ }
+
gtk_icon_set_image (GTK_ICON (button->indicator_widget), image_type);
if (button->iconic)
@@ -260,34 +303,6 @@ gtk_model_button_update_state (GtkModelButton *button)
gtk_widget_set_state_flags (button->indicator_widget, indicator_state, TRUE);
}
-static void
-update_node_ordering (GtkModelButton *button)
-{
- GtkStyleContext *indicator_context;
- GtkWidget *child;
-
- indicator_context = gtk_widget_get_style_context (button->indicator_widget);
-
- if (indicator_is_left (GTK_WIDGET (button)))
- {
- gtk_style_context_add_class (indicator_context, GTK_STYLE_CLASS_LEFT);
- gtk_style_context_remove_class (indicator_context, GTK_STYLE_CLASS_RIGHT);
-
- child = gtk_widget_get_first_child (GTK_WIDGET (button));
- if (child != button->indicator_widget)
- gtk_widget_insert_before (button->indicator_widget, GTK_WIDGET (button), child);
- }
- else
- {
- gtk_style_context_add_class (indicator_context, GTK_STYLE_CLASS_RIGHT);
- gtk_style_context_remove_class (indicator_context, GTK_STYLE_CLASS_LEFT);
-
- child = gtk_widget_get_first_child (GTK_WIDGET (button));
- if (child != button->indicator_widget)
- gtk_widget_insert_after (button->indicator_widget, GTK_WIDGET (button), child);
- }
-}
-
static void
gtk_model_button_state_flags_changed (GtkWidget *widget,
GtkStateFlags previous_flags)
@@ -450,35 +465,6 @@ gtk_model_button_set_menu_name (GtkModelButton *button,
g_object_notify_by_pspec (G_OBJECT (button), properties[PROP_MENU_NAME]);
}
-static void
-gtk_model_button_set_inverted (GtkModelButton *button,
- gboolean inverted)
-{
- inverted = !!inverted;
- if (button->inverted == inverted)
- return;
-
- button->inverted = inverted;
- gtk_model_button_update_state (button);
- update_node_ordering (button);
- gtk_widget_queue_resize (GTK_WIDGET (button));
- g_object_notify_by_pspec (G_OBJECT (button), properties[PROP_INVERTED]);
-}
-
-static void
-gtk_model_button_set_centered (GtkModelButton *button,
- gboolean centered)
-{
- centered = !!centered;
- if (button->centered == centered)
- return;
-
- button->centered = centered;
- gtk_widget_set_halign (button->box, button->centered ? GTK_ALIGN_CENTER : GTK_ALIGN_FILL);
- gtk_widget_queue_draw (GTK_WIDGET (button));
- g_object_notify_by_pspec (G_OBJECT (button), properties[PROP_CENTERED]);
-}
-
static void
gtk_model_button_set_iconic (GtkModelButton *button,
gboolean iconic)
@@ -513,6 +499,10 @@ gtk_model_button_set_iconic (GtkModelButton *button,
button->menu_name == NULL);
}
+ button->centered = iconic;
+
+ gtk_widget_set_halign (button->box, button->centered ? GTK_ALIGN_CENTER : GTK_ALIGN_FILL);
+
update_visibility (button);
gtk_widget_queue_resize (GTK_WIDGET (button));
g_object_notify_by_pspec (G_OBJECT (button), properties[PROP_ICONIC]);
@@ -552,14 +542,6 @@ gtk_model_button_get_property (GObject *object,
g_value_set_string (value, button->menu_name);
break;
- case PROP_INVERTED:
- g_value_set_boolean (value, button->inverted);
- break;
-
- case PROP_CENTERED:
- g_value_set_boolean (value, button->centered);
- break;
-
case PROP_ICONIC:
g_value_set_boolean (value, button->iconic);
break;
@@ -604,14 +586,6 @@ gtk_model_button_set_property (GObject *object,
gtk_model_button_set_menu_name (button, g_value_get_string (value));
break;
- case PROP_INVERTED:
- gtk_model_button_set_inverted (button, g_value_get_boolean (value));
- break;
-
- case PROP_CENTERED:
- gtk_model_button_set_centered (button, g_value_get_boolean (value));
- break;
-
case PROP_ICONIC:
gtk_model_button_set_iconic (button, g_value_get_boolean (value));
break;
@@ -1015,33 +989,6 @@ gtk_model_button_class_init (GtkModelButtonClass *class)
NULL,
G_PARAM_READWRITE | G_PARAM_EXPLICIT_NOTIFY | G_PARAM_STATIC_STRINGS);
- /**
- * GtkModelButton:inverted:
- *
- * Whether to show the submenu indicator at the opposite side than normal.
- * This property should be set for model buttons that 'go back' to a parent
- * menu.
- */
- properties[PROP_INVERTED] =
- g_param_spec_boolean ("inverted",
- P_("Inverted"),
- P_("Whether the menu is a parent"),
- FALSE,
- G_PARAM_READWRITE | G_PARAM_EXPLICIT_NOTIFY | G_PARAM_STATIC_STRINGS);
-
- /**
- * GtkModelButton:centered:
- *
- * Whether to render the button contents centered instead of left-aligned.
- * This property should be set for title-like items.
- */
- properties[PROP_CENTERED] =
- g_param_spec_boolean ("centered",
- P_("Centered"),
- P_("Whether to center the contents"),
- FALSE,
- G_PARAM_READWRITE | G_PARAM_EXPLICIT_NOTIFY | G_PARAM_STATIC_STRINGS);
-
/**
* GtkModelButton:iconic:
*
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]