evolution/evolution-3.28.5-dont-expand-archive-folder.patch

163 lines
5.3 KiB
Diff

From dd4cd78c96c7e91d17f7cd9c1d7d220ac8504f3e Mon Sep 17 00:00:00 2001
From: Milan Crha <mcrha@redhat.com>
Date: Thu, 26 Apr 2018 11:48:47 +0200
Subject: [PATCH] Bug 795567 - Do not expand archive folder in Copy/Move
message to folder dialog
---
data/org.gnome.evolution.mail.gschema.xml.in | 4 +
src/mail/e-mail-reader.c | 1 +
src/mail/em-folder-selector.c | 98 ++++++++++++++++++++
src/mail/em-folder-selector.h | 2 +
src/modules/mail/e-mail-shell-view-actions.c | 1 +
5 files changed, 106 insertions(+)
--- a/data/org.gnome.evolution.mail.gschema.xml.in
+++ b/data/org.gnome.evolution.mail.gschema.xml.in
@@ -728,6 +728,10 @@
<_summary>Visually wrap long lines in composer</_summary>
<_description>Whether to visually wrap long lines of text to avoid horizontal scrolling</_description>
</key>
+ <key name="collapse-archive-folders-in-selectors" type="b">
+ <default>false</default>
+ <_summary>collapse archive folders in move/copy message to folder and go to folder selectors.</_summary>
+ </key>
<!-- The following keys are deprecated. -->
--- a/src/mail/e-mail-reader.c
+++ b/src/mail/e-mail-reader.c
@@ -363,6 +363,7 @@ mail_reader_copy_or_move_selected_messag
EMFT_EXCLUDE_VIRTUAL |
EMFT_EXCLUDE_VTRASH);
gtk_tree_view_expand_all (GTK_TREE_VIEW (folder_tree));
+ em_folder_selector_maybe_collapse_archive_folders (selector);
if (default_xfer_messages_uri != NULL) {
em_folder_tree_set_selected (
--- a/src/mail/em-folder-selector.c
+++ b/src/mail/em-folder-selector.c
@@ -825,3 +825,101 @@ em_folder_selector_new_activity (EMFolde
return activity;
}
+void
+em_folder_selector_maybe_collapse_archive_folders (EMFolderSelector *selector)
+{
+ EMFolderTreeModel *model;
+ EMailSession *mail_session;
+ ESourceRegistry *registry;
+ CamelSession *session;
+ GSettings *settings;
+ GList *services, *link;
+ GHashTable *archives;
+ gchar *local_archive_folder;
+
+ g_return_if_fail (EM_IS_FOLDER_SELECTOR (selector));
+
+ settings = e_util_ref_settings ("org.gnome.evolution.mail");
+ if (!g_settings_get_boolean (settings, "collapse-archive-folders-in-selectors")) {
+ g_object_unref (settings);
+ return;
+ }
+ local_archive_folder = g_settings_get_string (settings, "local-archive-folder");
+ g_object_unref (settings);
+
+ model = em_folder_selector_get_model (selector);
+ mail_session = em_folder_tree_model_get_session (model);
+ registry = e_mail_session_get_registry (mail_session);
+ session = CAMEL_SESSION (mail_session);
+
+ archives = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, NULL);
+
+ if (local_archive_folder && *local_archive_folder) {
+ g_hash_table_insert (archives, local_archive_folder, NULL);
+ } else {
+ g_free (local_archive_folder);
+ }
+
+ services = camel_session_list_services (session);
+ for (link = services; link; link = g_list_next (link)) {
+ CamelService *service = link->data;
+
+ if (CAMEL_IS_STORE (service)) {
+ ESource *source;
+
+ source = e_source_registry_ref_source (registry, camel_service_get_uid (service));
+ if (source && e_source_has_extension (source, E_SOURCE_EXTENSION_MAIL_ACCOUNT)) {
+ ESourceMailAccount *account_ext;
+ gchar *archive_folder;
+
+ account_ext = e_source_get_extension (source, E_SOURCE_EXTENSION_MAIL_ACCOUNT);
+
+ archive_folder = e_source_mail_account_dup_archive_folder (account_ext);
+ if (archive_folder && *archive_folder) {
+ g_hash_table_insert (archives, archive_folder, NULL);
+ } else {
+ g_free (archive_folder);
+ }
+ }
+
+ g_clear_object (&source);
+ }
+ }
+
+ g_list_free_full (services, g_object_unref);
+
+ if (g_hash_table_size (archives)) {
+ GtkTreeView *tree_view;
+ GHashTableIter iter;
+ gpointer key;
+
+ tree_view = GTK_TREE_VIEW (em_folder_selector_get_folder_tree (selector));
+
+ g_hash_table_iter_init (&iter, archives);
+
+ while (g_hash_table_iter_next (&iter, &key, NULL)) {
+ const gchar *folder_uri = key;
+ CamelStore *store = NULL;
+ gchar *folder_name = NULL;
+
+ if (folder_uri && *folder_uri &&
+ e_mail_folder_uri_parse (session, folder_uri, &store, &folder_name, NULL)) {
+ GtkTreeRowReference *row;
+
+ row = em_folder_tree_model_get_row_reference (model, store, folder_name);
+ if (row) {
+ GtkTreePath *path;
+
+ path = gtk_tree_row_reference_get_path (row);
+ gtk_tree_view_collapse_row (tree_view, path);
+ gtk_tree_path_free (path);
+ }
+
+ g_clear_object (&store);
+ g_free (folder_name);
+ }
+ }
+ }
+
+ g_hash_table_destroy (archives);
+}
--- a/src/mail/em-folder-selector.h
+++ b/src/mail/em-folder-selector.h
@@ -96,6 +96,8 @@ void em_folder_selector_set_selected (E
const gchar * em_folder_selector_get_selected_uri
(EMFolderSelector *selector);
EActivity * em_folder_selector_new_activity (EMFolderSelector *selector);
+void em_folder_selector_maybe_collapse_archive_folders
+ (EMFolderSelector *selector);
G_END_DECLS
--- a/src/modules/mail/e-mail-shell-view-actions.c
+++ b/src/modules/mail/e-mail-shell-view-actions.c
@@ -1145,6 +1145,7 @@ action_mail_goto_folder_cb (GtkAction *a
folder_tree = em_folder_selector_get_folder_tree (selector);
gtk_tree_view_expand_all (GTK_TREE_VIEW (folder_tree));
+ em_folder_selector_maybe_collapse_archive_folders (selector);
if (folder) {
gchar *uri = e_mail_folder_uri_from_folder (folder);