From 538e64c572220bba43960a3073468c0ce3dc5f4c Mon Sep 17 00:00:00 2001
From: Aleksander Machniak <alec@alec.pl>
Date: Wed, 18 Dec 2013 14:57:35 -0500
Subject: [PATCH] Fix Closure-compiler warnings, small code improvements

---
 plugins/archive/archive.js |   52 ++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 36 insertions(+), 16 deletions(-)

diff --git a/plugins/archive/archive.js b/plugins/archive/archive.js
index d771fb6..8130334 100644
--- a/plugins/archive/archive.js
+++ b/plugins/archive/archive.js
@@ -1,36 +1,56 @@
-/*
+/**
  * Archive plugin script
- * @version 1.2
+ * @version 2.1
  */
 
 function rcmail_archive(prop)
 {
   if (!rcmail.env.uid && (!rcmail.message_list || !rcmail.message_list.get_selection().length))
     return;
-  
-  var uids = rcmail.env.uid ? rcmail.env.uid : rcmail.message_list.get_selection().join(',');
-    
-  rcmail.set_busy(true, 'loading');
-  rcmail.http_post('plugin.archive', '_uid='+uids+'&_mbox='+urlencode(rcmail.env.mailbox), true);
+
+  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
+      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;
+  }
 }
 
 // callback for app-onload event
 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.message_list.addEventListener('select', function(list) {
+        rcmail.enable_command('plugin.archive', list.get_selection().length > 0 && !rcmail_is_archive());
       });
-    
+
     // set css style for archive folder
     var li;
-    if (rcmail.env.archive_folder && (li = rcmail.get_folder_li(rcmail.env.archive_folder)))
-      $(li).css('background-image', 'url(plugins/archive/foldericon.png)');
+    if (rcmail.env.archive_folder && (li = rcmail.get_folder_li(rcmail.env.archive_folder, '', true)))
+      $(li).addClass('archive');
+
+    // callback for server response
+    rcmail.addEventListener('plugin.move2archive_response', function(result) {
+      if (result.update)
+        rcmail.command('list');  // refresh list
+    });
   })
 }
-

--
Gitblit v1.9.1