[epiphany] EphyEmbed: Hide the statusbar in a timeout handler
- From: Claudio Saavedra <csaavedra src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [epiphany] EphyEmbed: Hide the statusbar in a timeout handler
- Date: Fri, 16 Dec 2011 12:41:33 +0000 (UTC)
commit 8fad1a68ef1649601b1cde4fb5830d0e34023aba
Author: Claudio Saavedra <csaavedra igalia com>
Date: Fri Dec 16 14:38:05 2011 +0200
EphyEmbed: Hide the statusbar in a timeout handler
To allow it being displayed for a short while once it's complete.
embed/ephy-embed.c | 23 ++++++++++++++++++++++-
1 files changed, 22 insertions(+), 1 deletions(-)
---
diff --git a/embed/ephy-embed.c b/embed/ephy-embed.c
index d7366cc..05fc639 100644
--- a/embed/ephy-embed.c
+++ b/embed/ephy-embed.c
@@ -85,6 +85,8 @@ struct _EphyEmbedPrivate
guint tab_message_id;
guint pop_statusbar_later_source_id;
+
+ guint clear_progress_source_id;
};
G_DEFINE_TYPE (EphyEmbed, ephy_embed, GTK_TYPE_BOX)
@@ -309,6 +311,9 @@ ephy_embed_finalize (GObject *object)
g_slist_free (embed->priv->keys);
embed->priv->keys = NULL;
+ if (embed->priv->clear_progress_source_id)
+ g_source_remove (embed->priv->clear_progress_source_id);
+
G_OBJECT_CLASS (ephy_embed_parent_class)->finalize (object);
}
@@ -523,6 +528,15 @@ frame_enter_notify_cb (GtkWidget *widget,
return FALSE;
}
+static gboolean
+clear_progress_cb (EphyEmbed *embed)
+{
+ gtk_widget_hide (embed->priv->progress);
+ embed->priv->clear_progress_source_id = 0;
+
+ return FALSE;
+}
+
static void
progress_update (EphyWebView *view, GParamSpec *pspec, EphyEmbed *embed)
{
@@ -531,11 +545,18 @@ progress_update (EphyWebView *view, GParamSpec *pspec, EphyEmbed *embed)
EphyEmbedPrivate *priv = embed->priv;
+ if (priv->clear_progress_source_id) {
+ g_source_remove (priv->clear_progress_source_id);
+ priv->clear_progress_source_id = 0;
+ }
+
progress = webkit_web_view_get_progress (priv->web_view);
loading = ephy_web_view_is_loading (EPHY_WEB_VIEW (priv->web_view));
if (progress == 1.0 || !loading)
- gtk_widget_hide (priv->progress);
+ priv->clear_progress_source_id = g_timeout_add (500,
+ (GSourceFunc) clear_progress_cb,
+ embed);
else
gtk_widget_show (priv->progress);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]