Remember last folder of the Save As dialog when downloading files
This is done by creating the dialog only once and holding a reference to it in memory. When the dialog is closed, it is only hidden instead of destroyed. So, the next time we just re-show the dialog with the previously used directory. It is destroyed when the parent MidoriBrowser instance is destroyed.
This commit is contained in:
parent
144eb69e5c
commit
ad0b2ac077
1 changed files with 24 additions and 16 deletions
|
@ -1238,12 +1238,12 @@ midori_browser_add_download_item (MidoriBrowser* browser,
|
||||||
static void
|
static void
|
||||||
midori_view_download_save_as_response_cb (GtkWidget* dialog,
|
midori_view_download_save_as_response_cb (GtkWidget* dialog,
|
||||||
gint response,
|
gint response,
|
||||||
WebKitDownload* download)
|
MidoriBrowser* browser)
|
||||||
{
|
{
|
||||||
|
WebKitDownload* download = g_object_get_data (G_OBJECT (dialog), "download");
|
||||||
if (response == GTK_RESPONSE_ACCEPT)
|
if (response == GTK_RESPONSE_ACCEPT)
|
||||||
{
|
{
|
||||||
gchar* uri = gtk_file_chooser_get_uri (GTK_FILE_CHOOSER (dialog));
|
gchar* uri = gtk_file_chooser_get_uri (GTK_FILE_CHOOSER (dialog));
|
||||||
MidoriBrowser* browser = midori_browser_get_for_widget (dialog);
|
|
||||||
webkit_download_set_destination_uri (download, uri);
|
webkit_download_set_destination_uri (download, uri);
|
||||||
midori_browser_add_download_item (browser, download);
|
midori_browser_add_download_item (browser, download);
|
||||||
g_free (uri);
|
g_free (uri);
|
||||||
|
@ -1251,7 +1251,7 @@ midori_view_download_save_as_response_cb (GtkWidget* dialog,
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
g_object_unref (download);
|
g_object_unref (download);
|
||||||
gtk_widget_destroy (dialog);
|
gtk_widget_hide (dialog);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
|
@ -1262,9 +1262,14 @@ midori_view_download_requested_cb (GtkWidget* view,
|
||||||
g_signal_emit (browser, signals[ADD_DOWNLOAD], 0, download);
|
g_signal_emit (browser, signals[ADD_DOWNLOAD], 0, download);
|
||||||
if (!webkit_download_get_destination_uri (download))
|
if (!webkit_download_get_destination_uri (download))
|
||||||
{
|
{
|
||||||
|
gchar* folder;
|
||||||
if (g_object_get_data (G_OBJECT (download), "save-as-download"))
|
if (g_object_get_data (G_OBJECT (download), "save-as-download"))
|
||||||
{
|
{
|
||||||
GtkWidget* dialog = gtk_file_chooser_dialog_new (
|
static GtkWidget* dialog = NULL;
|
||||||
|
|
||||||
|
if (!dialog)
|
||||||
|
{
|
||||||
|
dialog = gtk_file_chooser_dialog_new (
|
||||||
_("Save file"), GTK_WINDOW (browser),
|
_("Save file"), GTK_WINDOW (browser),
|
||||||
GTK_FILE_CHOOSER_ACTION_SAVE,
|
GTK_FILE_CHOOSER_ACTION_SAVE,
|
||||||
GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
|
GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
|
||||||
|
@ -1272,17 +1277,20 @@ midori_view_download_requested_cb (GtkWidget* view,
|
||||||
NULL);
|
NULL);
|
||||||
gtk_window_set_icon_name (GTK_WINDOW (dialog), GTK_STOCK_SAVE);
|
gtk_window_set_icon_name (GTK_WINDOW (dialog), GTK_STOCK_SAVE);
|
||||||
gtk_window_set_transient_for (GTK_WINDOW (dialog), GTK_WINDOW (browser));
|
gtk_window_set_transient_for (GTK_WINDOW (dialog), GTK_WINDOW (browser));
|
||||||
/* FIXME: Remember the last folder
|
gtk_window_set_destroy_with_parent (GTK_WINDOW (dialog), TRUE);
|
||||||
gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (dialog), last_dir); */
|
folder = katze_object_get_string (browser->settings, "download-folder");
|
||||||
|
gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (dialog), folder);
|
||||||
|
g_free (folder);
|
||||||
|
g_signal_connect (dialog, "response",
|
||||||
|
G_CALLBACK (midori_view_download_save_as_response_cb), browser);
|
||||||
|
}
|
||||||
|
g_object_set_data (G_OBJECT (dialog), "download", download);
|
||||||
gtk_file_chooser_set_current_name (GTK_FILE_CHOOSER (dialog),
|
gtk_file_chooser_set_current_name (GTK_FILE_CHOOSER (dialog),
|
||||||
webkit_download_get_suggested_filename (download));
|
webkit_download_get_suggested_filename (download));
|
||||||
gtk_widget_show (dialog);
|
gtk_widget_show (dialog);
|
||||||
g_signal_connect (dialog, "response",
|
|
||||||
G_CALLBACK (midori_view_download_save_as_response_cb), download);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
gchar* folder;
|
|
||||||
gchar* filename;
|
gchar* filename;
|
||||||
gchar* uri;
|
gchar* uri;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue