mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-06 19:00:12 +00:00
entry, spinbutton: Finish css node conversion
This commit creates entry and button subnodes for the buttons in GtkSpinButton. The nodes are ordered like this for horizontal spinbutton + entry + image.left + image.right + progress + button.down + button.up and like this for vertical ones: spinbutton + button.down + entry + button.up This arrangement requires cooperation from GtkEntry to place the entry subnodes correctly, and some small changes in the theme. This commit also fixes progress rendering in vertical spin buttons.
This commit is contained in:
parent
ebcad63e31
commit
bb7d7851ac
@ -3197,6 +3197,37 @@ get_entry_node (GtkWidget *widget)
|
||||
return gtk_widget_get_css_node (widget);
|
||||
}
|
||||
|
||||
static void
|
||||
update_node_ordering (GtkEntry *entry)
|
||||
{
|
||||
GtkEntryPrivate *priv = entry->priv;
|
||||
EntryIconInfo *icon_info;
|
||||
GtkEntryIconPosition icon_pos;
|
||||
GtkCssNode *sibling, *parent;
|
||||
|
||||
if (priv->progress_node)
|
||||
{
|
||||
parent = gtk_css_node_get_parent (priv->progress_node);
|
||||
sibling = gtk_css_node_get_last_child (parent);
|
||||
if (priv->progress_node != sibling)
|
||||
gtk_css_node_insert_after (parent, priv->progress_node, sibling);
|
||||
}
|
||||
|
||||
if (gtk_widget_get_direction (GTK_WIDGET (entry)) == GTK_TEXT_DIR_RTL)
|
||||
icon_pos = GTK_ENTRY_ICON_SECONDARY;
|
||||
else
|
||||
icon_pos = GTK_ENTRY_ICON_PRIMARY;
|
||||
|
||||
icon_info = priv->icons[icon_pos];
|
||||
if (icon_info && icon_info->css_node)
|
||||
{
|
||||
parent = gtk_css_node_get_parent (icon_info->css_node);
|
||||
sibling = gtk_css_node_get_first_child (parent);
|
||||
if (icon_info->css_node != sibling)
|
||||
gtk_css_node_insert_before (parent, icon_info->css_node, sibling);
|
||||
}
|
||||
}
|
||||
|
||||
static EntryIconInfo*
|
||||
construct_icon_info (GtkWidget *widget,
|
||||
GtkEntryIconPosition icon_pos)
|
||||
@ -3222,6 +3253,8 @@ construct_icon_info (GtkWidget *widget,
|
||||
update_icon_style (widget, icon_pos);
|
||||
g_object_unref (icon_info->css_node);
|
||||
|
||||
update_node_ordering (entry);
|
||||
|
||||
if (gtk_widget_get_realized (widget))
|
||||
realize_icon_info (widget, icon_pos);
|
||||
|
||||
@ -3827,14 +3860,14 @@ get_progress_area (GtkWidget *widget,
|
||||
context = gtk_widget_get_style_context (widget);
|
||||
_gtk_entry_get_borders (entry, &entry_borders);
|
||||
get_text_area_size (entry,
|
||||
NULL, NULL,
|
||||
x, y,
|
||||
&text_area_width, &text_area_height);
|
||||
get_frame_size (entry, FALSE,
|
||||
NULL, NULL,
|
||||
&frame_width, NULL);
|
||||
|
||||
*x = 0;
|
||||
*y = 0;
|
||||
*x -= entry_borders.left;
|
||||
*y -= entry_borders.top;
|
||||
*width = text_area_width + entry_borders.left + entry_borders.right;
|
||||
*height = text_area_height + entry_borders.top + entry_borders.bottom;
|
||||
|
||||
@ -5022,6 +5055,8 @@ gtk_entry_direction_changed (GtkWidget *widget,
|
||||
update_icon_style (widget, GTK_ENTRY_ICON_PRIMARY);
|
||||
update_icon_style (widget, GTK_ENTRY_ICON_SECONDARY);
|
||||
|
||||
update_node_ordering (entry);
|
||||
|
||||
GTK_WIDGET_CLASS (gtk_entry_parent_class)->direction_changed (widget, previous_dir);
|
||||
}
|
||||
|
||||
@ -10674,6 +10709,8 @@ gtk_entry_ensure_progress_node (GtkEntry *entry)
|
||||
gtk_css_node_set_parent (priv->progress_node, widget_node);
|
||||
gtk_css_node_set_state (priv->progress_node, gtk_css_node_get_state (widget_node));
|
||||
g_object_unref (priv->progress_node);
|
||||
|
||||
update_node_ordering (entry);
|
||||
}
|
||||
|
||||
static void
|
||||
|
@ -80,6 +80,14 @@
|
||||
* See the #GtkAdjustment section for more details about an adjustment's
|
||||
* properties.
|
||||
*
|
||||
* # CSS nodes
|
||||
*
|
||||
* GtkSpinButtons main CSS node has the name spinbutton. It creates subnodes
|
||||
* for the entry and the two buttons, with these names. The button nodes have
|
||||
* the style classes .up and .down. The GtkEntry subnodes (if present) are put
|
||||
* below the entry node. The orientation of the spin button is reflected in
|
||||
* the .vertical or .horizontal style class on the main node.
|
||||
*
|
||||
* ## Using a GtkSpinButton to get an integer
|
||||
*
|
||||
* |[<!-- language="C" -->
|
||||
@ -750,7 +758,6 @@ gtk_spin_button_init (GtkSpinButton *spin_button)
|
||||
{
|
||||
GtkSpinButtonPrivate *priv;
|
||||
GtkCssNode *widget_node;
|
||||
GtkStyleContext *context;
|
||||
|
||||
spin_button->priv = gtk_spin_button_get_instance_private (spin_button);
|
||||
priv = spin_button->priv;
|
||||
@ -774,11 +781,11 @@ gtk_spin_button_init (GtkSpinButton *spin_button)
|
||||
|
||||
priv->orientation = GTK_ORIENTATION_HORIZONTAL;
|
||||
|
||||
context = gtk_widget_get_style_context (GTK_WIDGET (spin_button));
|
||||
gtk_style_context_add_class (context, GTK_STYLE_CLASS_SPINBUTTON);
|
||||
_gtk_orientable_set_style_classes (GTK_ORIENTABLE (spin_button));
|
||||
|
||||
widget_node = gtk_widget_get_css_node (GTK_WIDGET (spin_button));
|
||||
gtk_css_node_add_class (widget_node, g_quark_from_static_string (GTK_STYLE_CLASS_ENTRY));
|
||||
|
||||
priv->entry_node = gtk_css_node_new ();
|
||||
gtk_css_node_set_name (priv->entry_node, I_("entry"));
|
||||
gtk_css_node_set_parent (priv->entry_node, widget_node);
|
||||
@ -788,16 +795,16 @@ gtk_spin_button_init (GtkSpinButton *spin_button)
|
||||
|
||||
priv->down_node = gtk_css_node_new ();
|
||||
gtk_css_node_set_name (priv->down_node, I_("button"));
|
||||
gtk_css_node_add_class (priv->down_node, g_quark_from_static_string (GTK_STYLE_CLASS_BUTTON));
|
||||
gtk_css_node_set_parent (priv->down_node, widget_node);
|
||||
gtk_css_node_add_class (priv->down_node, g_quark_from_static_string ("down"));
|
||||
gtk_css_node_set_state (priv->down_node, gtk_css_node_get_state (widget_node));
|
||||
g_signal_connect_object (priv->down_node, "style-changed", G_CALLBACK (node_style_changed_cb), spin_button, 0);
|
||||
g_object_unref (priv->down_node);
|
||||
|
||||
priv->up_node = gtk_css_node_new ();
|
||||
gtk_css_node_set_name (priv->up_node, I_("button"));
|
||||
gtk_css_node_add_class (priv->up_node, g_quark_from_static_string (GTK_STYLE_CLASS_BUTTON));
|
||||
gtk_css_node_set_parent (priv->up_node, widget_node);
|
||||
gtk_css_node_add_class (priv->up_node, g_quark_from_static_string ("up"));
|
||||
gtk_css_node_set_state (priv->up_node, gtk_css_node_get_state (widget_node));
|
||||
g_signal_connect_object (priv->up_node, "style-changed", G_CALLBACK (node_style_changed_cb), spin_button, 0);
|
||||
g_object_unref (priv->up_node);
|
||||
@ -1266,12 +1273,8 @@ gtk_spin_button_get_preferred_width (GtkWidget *widget,
|
||||
GtkSpinButton *spin_button = GTK_SPIN_BUTTON (widget);
|
||||
GtkSpinButtonPrivate *priv = spin_button->priv;
|
||||
GtkEntry *entry = GTK_ENTRY (widget);
|
||||
GtkStyleContext *context;
|
||||
|
||||
context = gtk_widget_get_style_context (widget);
|
||||
gtk_style_context_save_to_node (context, priv->entry_node);
|
||||
GTK_WIDGET_CLASS (gtk_spin_button_parent_class)->get_preferred_width (widget, minimum, natural);
|
||||
gtk_style_context_restore (context);
|
||||
|
||||
if (gtk_entry_get_width_chars (entry) < 0)
|
||||
{
|
||||
@ -1329,15 +1332,11 @@ gtk_spin_button_get_preferred_height_and_baseline_for_width (GtkWidget *widget,
|
||||
{
|
||||
GtkSpinButton *spin_button = GTK_SPIN_BUTTON (widget);
|
||||
GtkSpinButtonPrivate *priv = spin_button->priv;
|
||||
GtkStyleContext *context;
|
||||
|
||||
context = gtk_widget_get_style_context (widget);
|
||||
gtk_style_context_save_to_node (context, priv->entry_node);
|
||||
GTK_WIDGET_CLASS (gtk_spin_button_parent_class)->get_preferred_height_and_baseline_for_width (widget, width,
|
||||
minimum, natural,
|
||||
minimum_baseline,
|
||||
natural_baseline);
|
||||
gtk_style_context_restore (context);
|
||||
|
||||
if (priv->orientation == GTK_ORIENTATION_VERTICAL)
|
||||
{
|
||||
@ -1372,14 +1371,10 @@ gtk_spin_button_size_allocate (GtkWidget *widget,
|
||||
GtkSpinButton *spin = GTK_SPIN_BUTTON (widget);
|
||||
GtkSpinButtonPrivate *priv = spin->priv;
|
||||
GtkAllocation down_panel_allocation, up_panel_allocation;
|
||||
GtkStyleContext *context;
|
||||
|
||||
gtk_widget_set_allocation (widget, allocation);
|
||||
|
||||
context = gtk_widget_get_style_context (widget);
|
||||
gtk_style_context_save_to_node (context, priv->entry_node);
|
||||
GTK_WIDGET_CLASS (gtk_spin_button_parent_class)->size_allocate (widget, allocation);
|
||||
gtk_style_context_restore (context);
|
||||
|
||||
gtk_spin_button_panel_get_allocations (spin, &down_panel_allocation, &up_panel_allocation);
|
||||
|
||||
@ -1407,13 +1402,8 @@ gtk_spin_button_draw (GtkWidget *widget,
|
||||
{
|
||||
GtkSpinButton *spin = GTK_SPIN_BUTTON (widget);
|
||||
GtkSpinButtonPrivate *priv = spin->priv;
|
||||
GtkStyleContext *context;
|
||||
|
||||
context = gtk_widget_get_style_context (widget);
|
||||
|
||||
gtk_style_context_save_to_node (context, priv->entry_node);
|
||||
GTK_WIDGET_CLASS (gtk_spin_button_parent_class)->draw (widget, cr);
|
||||
gtk_style_context_restore (context);
|
||||
|
||||
/* Draw the buttons */
|
||||
gtk_spin_button_panel_draw (spin, cr, priv->down_panel);
|
||||
|
@ -219,7 +219,7 @@ spinner {
|
||||
* Text Entries *
|
||||
****************/
|
||||
|
||||
entry {
|
||||
entry, .entry {
|
||||
border: 1px solid;
|
||||
padding: 5px 8px 6px;
|
||||
|
||||
@ -360,7 +360,7 @@ $_dot_color: if($variant=='light', $selected_bg_color,
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
button,
|
||||
.button {
|
||||
|
||||
$_button_transition: all 200ms $ease-out-quad;
|
||||
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user