From 2965a981b7ec22866fbdf2d567d87e2d068d3617 Mon Sep 17 00:00:00 2001
From: Thomas Bruederli <thomas@roundcube.net>
Date: Fri, 31 Jul 2015 16:04:08 -0400
Subject: [PATCH] Allow to search and import missing PGP pubkeys from keyservers using Publickey.js

---
 plugins/archive/archive.js |   45 ++++++++++++++++++++++++++++++---------------
 1 files changed, 30 insertions(+), 15 deletions(-)

diff --git a/plugins/archive/archive.js b/plugins/archive/archive.js
index cf44b74..f77bedf 100644
--- a/plugins/archive/archive.js
+++ b/plugins/archive/archive.js
@@ -1,6 +1,19 @@
-/*
+/**
  * Archive plugin script
- * @version 2.0
+ * @version 2.3
+ *
+ * @licstart  The following is the entire license notice for the
+ * JavaScript code in this file.
+ *
+ * Copyright (c) 2012-2014, The Roundcube Dev Team
+ *
+ * The JavaScript code in this page 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 3 of
+ * the License, or (at your option) any later version.
+ *
+ * @licend  The above is the entire license notice
+ * for the JavaScript code in this file.
  */
 
 function rcmail_archive(prop)
@@ -8,23 +21,25 @@
   if (!rcmail.env.uid && (!rcmail.message_list || !rcmail.message_list.get_selection().length))
     return;
 
-  if (rcmail.env.mailbox.indexOf(rcmail.env.archive_folder) != 0) {
+  if (!rcmail_is_archive()) {
     if (!rcmail.env.archive_type) {
       // simply move to archive folder (if no partition type is set)
       rcmail.command('move', rcmail.env.archive_folder);
     }
     else {
       // let the server sort the messages to the according subfolders
-      var post_data = { _uid: rcmail.env.uid ? rcmail.env.uid : rcmail.message_list.get_selection().join(','), _mbox: rcmail.env.mailbox };
-
-      if (rcmail.env.display_next && rcmail.env.next_uid)
-        post_data._next_uid = rcmail.env.next_uid;
-
-      if (rcmail.env.action)
-        post_data._from = rcmail.env.action;
-
-      rcmail.http_post('plugin.move2archive', post_data);
+      rcmail.http_post('plugin.move2archive', rcmail.selection_post_data());
     }
+  }
+}
+
+function rcmail_is_archive()
+{
+  // check if current folder is an archive folder or one of its children
+  if (rcmail.env.mailbox == rcmail.env.archive_folder
+    || rcmail.env.mailbox.startsWith(rcmail.env.archive_folder + rcmail.env.delimiter)
+  ) {
+    return true;
   }
 }
 
@@ -32,12 +47,12 @@
 if (window.rcmail) {
   rcmail.addEventListener('init', function(evt) {
     // register command (directly enable in message view mode)
-    rcmail.register_command('plugin.archive', rcmail_archive, (rcmail.env.uid && rcmail.env.mailbox != rcmail.env.archive_folder));
+    rcmail.register_command('plugin.archive', rcmail_archive, rcmail.env.uid && !rcmail_is_archive());
 
     // add event-listener to message list
     if (rcmail.message_list)
       rcmail.message_list.addEventListener('select', function(list) {
-        rcmail.enable_command('plugin.archive', (list.get_selection().length > 0 && rcmail.env.mailbox != rcmail.env.archive_folder));
+        rcmail.enable_command('plugin.archive', list.get_selection().length > 0 && !rcmail_is_archive());
       });
 
     // set css style for archive folder
@@ -48,7 +63,7 @@
     // callback for server response
     rcmail.addEventListener('plugin.move2archive_response', function(result) {
       if (result.update)
-        rcmail.command('checkmail');  // refresh list
+        rcmail.command('list');  // refresh list
     });
   })
 }

--
Gitblit v1.9.1