diff options
author | Cosimo Cecchi <cosimoc@gnome.org> | 2011-03-09 08:08:50 +0800 |
---|---|---|
committer | Cosimo Cecchi <cosimoc@gnome.org> | 2011-03-09 08:41:30 +0800 |
commit | 4408cb9c396ee85e031a18763e1f80c9c5550880 (patch) | |
tree | 5458b4452862cd1f5d475a6d52393ea066efcd92 | |
parent | 7090a15a48f4371aba7b4ccf823bc0236afb1f03 (diff) | |
download | gsoc2013-epiphany-4408cb9c396ee85e031a18763e1f80c9c5550880.tar gsoc2013-epiphany-4408cb9c396ee85e031a18763e1f80c9c5550880.tar.gz gsoc2013-epiphany-4408cb9c396ee85e031a18763e1f80c9c5550880.tar.bz2 gsoc2013-epiphany-4408cb9c396ee85e031a18763e1f80c9c5550880.tar.lz gsoc2013-epiphany-4408cb9c396ee85e031a18763e1f80c9c5550880.tar.xz gsoc2013-epiphany-4408cb9c396ee85e031a18763e1f80c9c5550880.tar.zst gsoc2013-epiphany-4408cb9c396ee85e031a18763e1f80c9c5550880.zip |
toolbar: make sure the first toolbar gets the 'primary-toolbar' class
https://bugzilla.gnome.org/show_bug.cgi?id=644261
-rw-r--r-- | lib/egg/egg-editable-toolbar.c | 53 | ||||
-rw-r--r-- | lib/egg/egg-editable-toolbar.h | 4 | ||||
-rw-r--r-- | src/ephy-toolbar.c | 2 |
3 files changed, 55 insertions, 4 deletions
diff --git a/lib/egg/egg-editable-toolbar.c b/lib/egg/egg-editable-toolbar.c index 24649e367..c47dc9040 100644 --- a/lib/egg/egg-editable-toolbar.c +++ b/lib/egg/egg-editable-toolbar.c @@ -79,6 +79,9 @@ struct _EggEditableToolbarPrivate guint dnd_pending; GtkToolbar *dnd_toolbar; GtkToolItem *dnd_toolitem; + + gboolean set_primary_class; + gchar *primary_name; }; G_DEFINE_TYPE (EggEditableToolbar, egg_editable_toolbar, GTK_TYPE_VBOX); @@ -862,6 +865,10 @@ toolbar_visibility_refresh (EggEditableToolbar *etoolbar) char action_name[40]; char *action_label; char *tmp; + gboolean primary_class_set; + GtkStyleContext *context; + const gchar *toolbar_name; + gboolean visible; if (priv == NULL || priv->model == NULL || priv->manager == NULL || priv->visibility_paths == NULL || priv->actions == NULL) @@ -887,9 +894,12 @@ toolbar_visibility_refresh (EggEditableToolbar *etoolbar) showing = GTK_WIDGET_VISIBLE (etoolbar); #endif + primary_class_set = !priv->set_primary_class; + n_toolbars = egg_toolbars_model_n_toolbars (priv->model); for (i = 0; i < n_toolbars; i++) { + toolbar_name = egg_toolbars_model_toolbar_nth (priv->model, i); string = g_string_sized_new (0); n_items = egg_toolbars_model_n_items (priv->model, i); for (k = 0, j = 0; j < n_items; j++) @@ -967,14 +977,33 @@ toolbar_visibility_refresh (EggEditableToolbar *etoolbar) gtk_action_set_visible (GTK_ACTION (action), (egg_toolbars_model_get_flags (priv->model, i) & EGG_TB_MODEL_NOT_REMOVABLE) == 0); gtk_action_set_sensitive (GTK_ACTION (action), showing); + #if GTK_CHECK_VERSION(2,20,0) - gtk_toggle_action_set_active (action, gtk_widget_get_visible - (get_dock_nth (etoolbar, i))); + visible = gtk_widget_get_visible (get_dock_nth (etoolbar, i)); #else - gtk_toggle_action_set_active (action, GTK_WIDGET_VISIBLE - (get_dock_nth (etoolbar, i))); + visible = GTK_WIDGET_VISIBLE (get_dock_nth (etoolbar, i)); #endif + gtk_toggle_action_set_active (action, visible); + context = gtk_widget_get_style_context (get_toolbar_nth (etoolbar, i)); + + /* apply the primary toolbar class to the first toolbar we see, + * or to that specified by the primary name, if any. + */ + if (!primary_class_set && visible && + (g_strcmp0 (priv->primary_name, toolbar_name) == 0) || + (priv->primary_name == NULL)) + { + primary_class_set = TRUE; + gtk_style_context_add_class (context, GTK_STYLE_CLASS_PRIMARY_TOOLBAR); + } + else + { + gtk_style_context_remove_class (context, GTK_STYLE_CLASS_PRIMARY_TOOLBAR); + } + + gtk_widget_reset_style (get_toolbar_nth (etoolbar, i)); + for (list = priv->visibility_paths; list != NULL; list = g_list_next (list)) { gtk_ui_manager_add_ui (priv->manager, priv->visibility_id, @@ -1385,6 +1414,9 @@ egg_editable_toolbar_dispose (GObject *object) g_free (priv->popup_path); priv->popup_path = NULL; + g_free (priv->primary_name); + priv->primary_name = NULL; + if (priv->manager != NULL) { if (priv->visibility_id) @@ -1850,3 +1882,16 @@ egg_editable_toolbar_get_manager (EggEditableToolbar *etoolbar) { return etoolbar->priv->manager; } + +void +egg_editable_toolbar_set_primary_class (EggEditableToolbar *etoolbar, + gboolean set, + const gchar *name) +{ + etoolbar->priv->set_primary_class = set; + + g_free (etoolbar->priv->primary_name); + etoolbar->priv->primary_name = g_strdup (name); + + toolbar_visibility_refresh (etoolbar); +} diff --git a/lib/egg/egg-editable-toolbar.h b/lib/egg/egg-editable-toolbar.h index 8537ba808..b08f68a79 100644 --- a/lib/egg/egg-editable-toolbar.h +++ b/lib/egg/egg-editable-toolbar.h @@ -82,6 +82,10 @@ void egg_editable_toolbar_set_selected (EggEditableToolbar * void egg_editable_toolbar_add_visibility (EggEditableToolbar *etoolbar, const char *path); +void egg_editable_toolbar_set_primary_class (EggEditableToolbar *etoolbar, + gboolean set, + const gchar *path); + /* Private Functions */ GtkWidget *_egg_editable_toolbar_new_separator_image (void); diff --git a/src/ephy-toolbar.c b/src/ephy-toolbar.c index 65b515872..84191cee4 100644 --- a/src/ephy-toolbar.c +++ b/src/ephy-toolbar.c @@ -588,6 +588,8 @@ ephy_toolbar_init (EphyToolbar *toolbar) EphyToolbarPrivate *priv; priv = toolbar->priv = EPHY_TOOLBAR_GET_PRIVATE (toolbar); + + egg_editable_toolbar_set_primary_class (EGG_EDITABLE_TOOLBAR (toolbar), TRUE, NULL); } static GObject * |