[gtk/wip/exalm/titlebuttons: 2/5] headerbar: Remove title button separators



commit 18114bafe072db969bc82b12efc2aac34217bfc2
Author: Alexander Mikhaylenko <alexm gnome org>
Date:   Fri Apr 24 20:03:12 2020 +0500

    headerbar: Remove title button separators
    
    They have had opacity: 0 for a while, just remove them.

 gtk/gtkheaderbar.c             | 74 ++----------------------------------------
 gtk/theme/Adwaita/_common.scss |  2 --
 2 files changed, 2 insertions(+), 74 deletions(-)
---
diff --git a/gtk/gtkheaderbar.c b/gtk/gtkheaderbar.c
index eb3945b614..7703311ce4 100644
--- a/gtk/gtkheaderbar.c
+++ b/gtk/gtkheaderbar.c
@@ -31,7 +31,6 @@
 #include "gtkintl.h"
 #include "gtklabel.h"
 #include "gtkprivate.h"
-#include "gtkseparator.h"
 #include "gtksizerequest.h"
 #include "gtktypebuiltins.h"
 #include "gtkwidgetprivate.h"
@@ -124,9 +123,6 @@ struct _GtkHeaderBarPrivate
   GtkWidget *titlebar_start_box;
   GtkWidget *titlebar_end_box;
 
-  GtkWidget *titlebar_start_separator;
-  GtkWidget *titlebar_end_separator;
-
   GdkSurfaceState state;
 };
 
@@ -243,38 +239,6 @@ update_window_icon (GtkHeaderBar *bar,
   return FALSE;
 }
 
-static void
-_gtk_header_bar_update_separator_visibility (GtkHeaderBar *bar)
-{
-  GtkHeaderBarPrivate *priv = gtk_header_bar_get_instance_private (bar);
-  gboolean have_visible_at_start = FALSE;
-  gboolean have_visible_at_end = FALSE;
-  GList *l;
-  GList *children;
-
-  children = gtk_container_get_children (GTK_CONTAINER (priv->start_box));
-  for (l = children; l; l = l->next)
-    {
-      if (l->data != priv->titlebar_start_box && gtk_widget_get_visible (l->data))
-        have_visible_at_start = TRUE;
-    }
-  g_list_free (children);
-
-  children = gtk_container_get_children (GTK_CONTAINER (priv->end_box));
-  for (l = children; l; l = l->next)
-    {
-      if (l->data != priv->titlebar_end_box && gtk_widget_get_visible (l->data))
-        have_visible_at_end = TRUE;
-    }
-  g_list_free (children);
-
-  if (priv->titlebar_start_separator != NULL)
-    gtk_widget_set_visible (priv->titlebar_start_separator, have_visible_at_start);
-
-  if (priv->titlebar_end_separator != NULL)
-    gtk_widget_set_visible (priv->titlebar_end_separator, have_visible_at_end);
-}
-
 static void
 update_window_buttons (GtkHeaderBar *bar)
 {
@@ -298,13 +262,11 @@ update_window_buttons (GtkHeaderBar *bar)
     {
       gtk_widget_unparent (priv->titlebar_start_box);
       priv->titlebar_start_box = NULL;
-      priv->titlebar_start_separator = NULL;
     }
   if (priv->titlebar_end_box)
     {
       gtk_widget_unparent (priv->titlebar_end_box);
       priv->titlebar_end_box = NULL;
-      priv->titlebar_end_separator = NULL;
     }
 
   if (!priv->show_title_buttons)
@@ -331,7 +293,6 @@ update_window_buttons (GtkHeaderBar *bar)
       for (i = 0; i < 2; i++)
         {
           GtkWidget *box;
-          GtkWidget *separator;
           int n_children = 0;
 
           if (tokens[i] == NULL)
@@ -339,9 +300,6 @@ update_window_buttons (GtkHeaderBar *bar)
 
           t = g_strsplit (tokens[i], ",", -1);
 
-          separator = gtk_separator_new (GTK_ORIENTATION_VERTICAL);
-          gtk_widget_add_css_class (separator, "titlebutton");
-
           box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0);
 
           for (j = 0; t[j]; j++)
@@ -437,15 +395,9 @@ update_window_buttons (GtkHeaderBar *bar)
             {
               g_object_ref_sink (box);
               g_object_unref (box);
-              g_object_ref_sink (separator);
-              g_object_unref (separator);
               continue;
             }
 
-          gtk_container_add (GTK_CONTAINER (box), separator);
-          if (i == 1)
-            gtk_box_reorder_child_after (GTK_BOX (box), separator, NULL);
-
           if (i == 0)
             gtk_widget_add_css_class (box, GTK_STYLE_CLASS_LEFT);
           else
@@ -454,21 +406,17 @@ update_window_buttons (GtkHeaderBar *bar)
           if (i == 0)
             {
               priv->titlebar_start_box = box;
-              priv->titlebar_start_separator = separator;
               gtk_container_add (GTK_CONTAINER (priv->start_box), box);
             }
           else
             {
               priv->titlebar_end_box = box;
-              priv->titlebar_end_separator = separator;
               gtk_container_add (GTK_CONTAINER (priv->end_box), box);
             }
         }
       g_strfreev (tokens);
     }
   g_free (layout_desc);
-
-  _gtk_header_bar_update_separator_visibility (bar);
 }
 
 static void
@@ -859,14 +807,6 @@ gtk_header_bar_set_property (GObject      *object,
     }
 }
 
-static void
-notify_child_cb (GObject      *child,
-                 GParamSpec   *pspec,
-                 GtkHeaderBar *bar)
-{
-  _gtk_header_bar_update_separator_visibility (bar);
-}
-
 static void
 gtk_header_bar_pack (GtkHeaderBar *bar,
                      GtkWidget    *widget,
@@ -886,9 +826,6 @@ gtk_header_bar_pack (GtkHeaderBar *bar,
       gtk_box_reorder_child_after (GTK_BOX (priv->end_box), widget, NULL);
     }
 
-  g_signal_connect (widget, "notify::visible", G_CALLBACK (notify_child_cb), bar);
-  _gtk_header_bar_update_separator_visibility (bar);
-
   if (priv->track_default_decoration)
     update_default_decoration (bar);
 }
@@ -914,13 +851,11 @@ gtk_header_bar_remove (GtkContainer *container,
 
   if (parent == priv->start_box)
     {
-      g_signal_handlers_disconnect_by_func (widget, notify_child_cb, bar);
       gtk_container_remove (GTK_CONTAINER (priv->start_box), widget);
       removed = TRUE;
     }
   else if (parent == priv->end_box)
     {
-      g_signal_handlers_disconnect_by_func (widget, notify_child_cb, bar);
       gtk_container_remove (GTK_CONTAINER (priv->end_box), widget);
       removed = TRUE;
     }
@@ -931,13 +866,8 @@ gtk_header_bar_remove (GtkContainer *container,
       removed = TRUE;
     }
 
-  if (removed)
-    {
-      _gtk_header_bar_update_separator_visibility (bar);
-
-      if (priv->track_default_decoration)
-        update_default_decoration (bar);
-    }
+  if (removed && priv->track_default_decoration)
+    update_default_decoration (bar);
 }
 
 static void
diff --git a/gtk/theme/Adwaita/_common.scss b/gtk/theme/Adwaita/_common.scss
index e26cadbad8..fdc84820b8 100644
--- a/gtk/theme/Adwaita/_common.scss
+++ b/gtk/theme/Adwaita/_common.scss
@@ -1505,8 +1505,6 @@ headerbar {
     }
   }
 
-  separator.titlebutton { opacity: 0; } /* hide the close button separator */
-
   .solid-csd & {
     &:backdrop, & {
       &:dir(rtl), &:dir(ltr) { // specificity bump


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