diff options
Diffstat (limited to 'embed')
-rw-r--r-- | embed/downloader-view.c | 110 |
1 files changed, 97 insertions, 13 deletions
diff --git a/embed/downloader-view.c b/embed/downloader-view.c index ec2575853..4b891b393 100644 --- a/embed/downloader-view.c +++ b/embed/downloader-view.c @@ -28,6 +28,8 @@ #include "ephy-stock-icons.h" #include "ephy-gui.h" #include "ephy-debug.h" +#include "ephy-prefs.h" +#include "eel-gconf-extensions.h" #include <glib/gi18n.h> #include <gtk/gtkversion.h> @@ -48,8 +50,7 @@ #include <gtk/gtkstatusicon.h> #include <libgnomevfs/gnome-vfs-utils.h> #include <libgnomeui/gnome-icon-lookup.h> - -#define CONF_DOWNLOADING_SHOW_DETAILS "/apps/epiphany/dialogs/downloader_show_details" +#include <libnotify/notify.h> enum { @@ -82,9 +83,11 @@ struct _DownloaderViewPrivate GtkWidget *abort_button; GtkStatusIcon *status_icon; + NotifyNotification *notification; guint idle_unref : 1; guint source_id; + guint notification_timeout; }; enum @@ -129,6 +132,9 @@ download_dialog_delete_event_cb (GtkWidget *window, GdkEventAny *event, DownloaderView *dv); +static void +show_notification_window (DownloaderView *dv); + static GObjectClass *parent_class = NULL; GType @@ -169,6 +175,8 @@ downloader_view_class_init (DownloaderViewClass *klass) object_class->finalize = downloader_view_finalize; g_type_class_add_private (object_class, sizeof(DownloaderViewPrivate)); + + notify_init (PACKAGE); } static void @@ -176,11 +184,13 @@ show_downloader_cb (DownloaderView *dv) { if (!gtk_window_has_toplevel_focus (GTK_WINDOW (dv->priv->window))) { - gtk_window_present (GTK_WINDOW (dv->priv->window)); + ephy_dialog_show (EPHY_DIALOG (dv)); + eel_gconf_set_boolean (CONF_DOWNLOADS_HIDDEN, FALSE); } else { - gtk_widget_hide (dv->priv->window); + ephy_dialog_hide (EPHY_DIALOG (dv)); + eel_gconf_set_boolean (CONF_DOWNLOADS_HIDDEN, TRUE); } } @@ -214,7 +224,8 @@ show_status_icon (DownloaderView *dv) DownloaderViewPrivate *priv = dv->priv; priv->status_icon = gtk_status_icon_new_from_stock (STOCK_DOWNLOAD); - + notify_notification_attach_to_status_icon (priv->notification, priv->status_icon); + g_signal_connect_swapped (priv->status_icon, "activate", G_CALLBACK (show_downloader_cb), dv); g_signal_connect (dv->priv->status_icon, "popup-menu", @@ -296,10 +307,20 @@ downloader_view_finalize (GObject *object) g_source_remove (priv->source_id); priv->source_id = 0; } + + if (priv->notification_timeout != 0) + { + g_source_remove (priv->notification_timeout); + } g_hash_table_destroy (dv->priv->downloads_hash); G_OBJECT_CLASS (parent_class)->finalize (object); + + if (notify_is_initted ()) + { + notify_uninit (); + } if (idle_unref) { @@ -404,16 +425,36 @@ update_download_row (DownloaderView *dv, EphyDownload *download) char *remaining, *file, *cur_progress, *name; struct tm; int percent = 0; + char *downloaded; row_ref = get_row_from_download (dv, download); g_return_if_fail (row_ref != NULL); /* State special casing */ state = ephy_download_get_state (download); + + total = ephy_download_get_total_progress (download); + current = ephy_download_get_current_progress (download); + + cur_progress = gnome_vfs_format_file_size_for_display (current); + + name = ephy_download_get_name (download); + switch (state) { case EPHY_DOWNLOAD_COMPLETED: downloader_view_remove_download (dv, download); + + downloaded = g_strdup_printf (_("The file ā%sā has been downloaded."), + name); + notify_notification_update (dv->priv->notification, + _("Download finished"), + downloaded, + GTK_STOCK_INFO); + + show_notification_window (dv); + + g_free (downloaded); return; case EPHY_DOWNLOAD_PAUSED: case EPHY_DOWNLOAD_DOWNLOADING: @@ -424,13 +465,6 @@ update_download_row (DownloaderView *dv, EphyDownload *download) break; } - total = ephy_download_get_total_progress (download); - current = ephy_download_get_current_progress (download); - - cur_progress = gnome_vfs_format_file_size_for_display (current); - - name = ephy_download_get_name (download); - if (total != -1 && current != -1) { char *total_progress; @@ -508,6 +542,27 @@ update_buttons_timeout_cb (DownloaderView *dv) return FALSE; } +static gboolean +queue_show_notification (DownloaderView *dv) +{ + if (gtk_status_icon_is_embedded (dv->priv->status_icon)) + { + notify_notification_show (dv->priv->notification, NULL); + return FALSE; + } + + return TRUE; +} + +static void +show_notification_window (DownloaderView *dv) +{ + if (gtk_status_icon_is_embedded (dv->priv->status_icon)) + notify_notification_show (dv->priv->notification, NULL); + else + dv->priv->notification_timeout = g_timeout_add_seconds (1, (GSourceFunc) queue_show_notification, dv); +} + void downloader_view_add_download (DownloaderView *dv, EphyDownload *download) @@ -521,6 +576,8 @@ downloader_view_add_download (DownloaderView *dv, GdkPixbuf *pixbuf; char *mime, *icon_name; int width = 16, height = 16; + GValue visible = {0, }; + char *downloading; g_object_ref (download); @@ -549,7 +606,30 @@ downloader_view_add_download (DownloaderView *dv, G_CALLBACK (download_changed_cb), dv, 0); /* Show it already */ - ephy_dialog_show (EPHY_DIALOG (dv)); + g_value_init (&visible, G_TYPE_BOOLEAN); + g_object_get_property (G_OBJECT(dv->priv->window), "visible", &visible); + + if (eel_gconf_get_boolean (CONF_DOWNLOADS_HIDDEN) && !g_value_get_boolean (&visible)) + { + downloading = g_strdup_printf(_("The file ā%sā has been added to the downloads queue."), + ephy_download_get_name (download)); + notify_notification_update (dv->priv->notification, + _("Download started"), + downloading, + GTK_STOCK_INFO); + + show_notification_window (dv); + + g_free (downloading); + + ephy_dialog_hide (EPHY_DIALOG (dv)); + } + else + { + ephy_dialog_show (EPHY_DIALOG (dv)); + } + + g_value_unset (&visible); mime = ephy_download_get_mime (download); @@ -730,6 +810,10 @@ downloader_view_build_ui (DownloaderView *dv) selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (priv->treeview)); g_signal_connect (selection, "changed", G_CALLBACK (selection_changed), dv); + + priv->notification = notify_notification_new (" ", " ", GTK_STOCK_INFO, NULL); + notify_notification_set_timeout (priv->notification, NOTIFY_EXPIRES_DEFAULT); + notify_notification_set_urgency (priv->notification, NOTIFY_URGENCY_LOW); } static void |