/* * Copyright © 2002 Jorn Baayen * Copyright © 2003, 2004 Marco Pesenti Gritti * Copyright © 2004, 2007 Christian Persch * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2, or (at your option) * any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * */ #include "config.h" #include "ephy-statusbar.h" #include "ephy-stock-icons.h" #include #include #include /** * SECTION:ephy-statusbar * @short_description: A statusbar widget for Epiphany * * #EphyStatusbar is Epiphany's default statusbar for all windows. */ static void ephy_statusbar_class_init (EphyStatusbarClass *klass); static void ephy_statusbar_init (EphyStatusbar *t); #define EPHY_STATUSBAR_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_STATUSBAR, EphyStatusbarPrivate)) struct _EphyStatusbarPrivate { GtkWidget *hbox; GtkWidget *icon_container; }; G_DEFINE_TYPE (EphyStatusbar, ephy_statusbar, GTK_TYPE_STATUSBAR) static void ephy_statusbar_class_init (EphyStatusbarClass *klass) { GObjectClass *object_class = G_OBJECT_CLASS (klass); g_type_class_add_private (object_class, sizeof (EphyStatusbarPrivate)); } static void ephy_statusbar_init (EphyStatusbar *t) { GtkStatusbar *gstatusbar = GTK_STATUSBAR (t); EphyStatusbarPrivate *priv; priv = t->priv = EPHY_STATUSBAR_GET_PRIVATE (t); gtk_statusbar_set_has_resize_grip (gstatusbar, TRUE); #if GTK_CHECK_VERSION (2, 19, 1) priv->hbox = gtk_statusbar_get_message_area (gstatusbar); #else priv->hbox = gtk_hbox_new (FALSE, 4); #endif priv->icon_container = gtk_hbox_new (FALSE, 4); gtk_box_pack_start (GTK_BOX (priv->hbox), priv->icon_container, FALSE, FALSE, 0); gtk_widget_show (priv->icon_container); #if GTK_CHECK_VERSION (2, 19, 1) gtk_box_reorder_child (GTK_BOX (priv->hbox), priv->icon_container, 0); #else /* Put the label in the hbox, and substitute the hbox into the frame */ g_object_ref (gstatusbar->label); gtk_container_remove (GTK_CONTAINER (gstatusbar->frame), gstatusbar->label); gtk_box_pack_start (GTK_BOX (priv->hbox), gstatusbar->label, TRUE, TRUE, 0); g_object_unref (gstatusbar->label); gtk_container_add (GTK_CONTAINER (gstatusbar->frame), priv->hbox); gtk_widget_show (priv->hbox); #endif } /** * ephy_statusbar_new: * * Creates a new #EphyStatusbar. * * Return value: the new #EphyStatusbar object **/ GtkWidget * ephy_statusbar_new (void) { return GTK_WIDGET (g_object_new (EPHY_TYPE_STATUSBAR, NULL)); } static void sync_visibility (GtkWidget *widget, GParamSpec *pspec, GtkWidget *separator) { if (gtk_widget_get_visible (widget)) { gtk_widget_show (separator); } else { gtk_widget_hide (separator); } } /** * ephy_statusbar_add_widget: * @statusbar: an #EphyStatusbar * @widget: a #GtkWidget * * Adds the @widget to the statusbar. Use this function whenever you want to * add a widget to the statusbar. You can remove the widget again with * ephy_statusbar_remove_widget(). **/ void ephy_statusbar_add_widget (EphyStatusbar *statusbar, GtkWidget *widget) { EphyStatusbarPrivate *priv; GtkWidget *vsep; g_return_if_fail (EPHY_IS_STATUSBAR (statusbar)); g_return_if_fail (GTK_IS_WIDGET (widget)); priv = statusbar->priv; gtk_box_pack_start (GTK_BOX (priv->icon_container), widget, FALSE, FALSE, 0); vsep = gtk_vseparator_new (); gtk_box_pack_start (GTK_BOX (priv->icon_container), vsep, FALSE, FALSE, 0); sync_visibility (widget, NULL, vsep); g_object_set_data (G_OBJECT (widget), "EphyStatusbar::separator", vsep); g_signal_connect (widget, "notify::visible", G_CALLBACK (sync_visibility), vsep); } /** * ephy_statusbar_remove_widget: * @statusbar: an #EphyStatusbar * @widget: a #GtkWidget * * Removes @widget, which must have been added to @statusbar using * ephy_statusbar_add_widget (). */ void ephy_statusbar_remove_widget (EphyStatusbar *statusbar, GtkWidget *widget) { EphyStatusbarPrivate *priv; GtkWidget *vsep; g_return_if_fail (EPHY_IS_STATUSBAR (statusbar)); g_return_if_fail (GTK_IS_WIDGET (widget)); priv = statusbar->priv; vsep = g_object_steal_data (G_OBJECT (widget), "EphyStatusbar::separator"); g_return_if_fail (vsep != NULL); g_signal_handlers_disconnect_by_func (widget, G_CALLBACK (sync_visibility), vsep); gtk_container_remove (GTK_CONTAINER (priv->icon_container), vsep); gtk_container_remove (GTK_CONTAINER (priv->icon_container), widget); }