[gtk+] combobox: Use element names



commit d229ea3de163fa92a94bc921f5eb6db11939e9e8
Author: Matthias Clasen <mclasen redhat com>
Date:   Mon Nov 2 13:15:05 2015 -0500

    combobox: Use element names
    
    Use combobox as the element name for the main CSS nodes of
    GtkComboBox and GtkComboBoxText. Add the .combo style class
    to the button and entry. in a GtkComboBox or GtkComboBoxText.

 gtk/gtkcombobox.c     |   16 +++++++++++++++-
 gtk/ui/gtkcombobox.ui |    3 ---
 2 files changed, 15 insertions(+), 4 deletions(-)
---
diff --git a/gtk/gtkcombobox.c b/gtk/gtkcombobox.c
index 39339e0..008cd37 100644
--- a/gtk/gtkcombobox.c
+++ b/gtk/gtkcombobox.c
@@ -87,6 +87,11 @@
  * can be a bit overwhelming. In this case, #GtkComboBoxText offers a
  * simple alternative. Both GtkComboBox and #GtkComboBoxText can contain
  * an entry.
+ *
+ * # CSS nodes
+ *
+ * GtkComboBox has a single CSS node with name combobox. It adds the
+ * .combo style class to the button (and entry) that it contains.
  */
 
 
@@ -1066,6 +1071,7 @@ gtk_combo_box_class_init (GtkComboBoxClass *klass)
   gtk_widget_class_bind_template_callback (widget_class, gtk_combo_box_button_toggled);
 
   gtk_widget_class_set_accessible_type (widget_class, GTK_TYPE_COMBO_BOX_ACCESSIBLE);
+  gtk_widget_class_set_css_name (widget_class, "combobox");
 }
 
 static void
@@ -1094,6 +1100,7 @@ static void
 gtk_combo_box_init (GtkComboBox *combo_box)
 {
   GtkComboBoxPrivate *priv;
+  GtkStyleContext *context;
 
   combo_box->priv = gtk_combo_box_get_instance_private (combo_box);
   priv = combo_box->priv;
@@ -1123,6 +1130,10 @@ gtk_combo_box_init (GtkComboBox *combo_box)
   gtk_widget_init_template (GTK_WIDGET (combo_box));
 
   gtk_widget_add_events (priv->button, GDK_SCROLL_MASK);
+
+  context = gtk_widget_get_style_context (priv->button);
+  gtk_style_context_remove_class (context, "toggle");
+  gtk_style_context_add_class (context, "combo");
 }
 
 static void
@@ -4400,8 +4411,11 @@ gtk_combo_box_constructed (GObject *object)
       gtk_widget_show (entry);
       gtk_container_add (GTK_CONTAINER (combo_box), entry);
 
+      context = gtk_widget_get_style_context (GTK_WIDGET (entry));
+      gtk_style_context_add_class (context, "combo");
+
       context = gtk_widget_get_style_context (GTK_WIDGET (combo_box));
-      gtk_style_context_add_class (context, GTK_STYLE_CLASS_COMBOBOX_ENTRY);
+      gtk_style_context_add_class (context, "linked");
 
       priv->text_renderer = gtk_cell_renderer_text_new ();
       gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (combo_box),
diff --git a/gtk/ui/gtkcombobox.ui b/gtk/ui/gtkcombobox.ui
index 90ae27b..ad4d5bd 100644
--- a/gtk/ui/gtkcombobox.ui
+++ b/gtk/ui/gtkcombobox.ui
@@ -6,9 +6,6 @@
       <object class="GtkToggleButton" id="button">
         <property name="visible">1</property>
         <signal name="toggled" handler="gtk_combo_box_button_toggled" swapped="no"/>
-        <style>
-          <class name="the-button-in-the-combobox"/>
-        </style>
         <child>
           <object class="GtkBox">
             <property name="visible">1</property>


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