From df0da2e059ac7d12f5fbd4735a66736b2efdf61d Mon Sep 17 00:00:00 2001
From: thomascube <thomas@roundcube.net>
Date: Sat, 02 Feb 2008 14:41:32 -0500
Subject: [PATCH] Simplified fix for remembering searches when viewing message + Don't ask for MDN confirmations on drafted messages (#1484691)

---
 program/steps/mail/show.inc |   28 ++--------------------------
 1 files changed, 2 insertions(+), 26 deletions(-)

diff --git a/program/steps/mail/show.inc b/program/steps/mail/show.inc
index 9a94a94..e6aa192 100644
--- a/program/steps/mail/show.inc
+++ b/program/steps/mail/show.inc
@@ -74,24 +74,17 @@
   $OUTPUT->set_env('safemode', intval($_GET['_safe']));
   
   // check for unset disposition notification
-  if ($MESSAGE['headers']->mdn_to && !$MESSAGE['headers']->mdn_sent)
+  if ($MESSAGE['headers']->mdn_to && !$MESSAGE['headers']->mdn_sent && $IMAP->get_mailbox_name() != $CONFIG['drafts_mbox'])
   {
     rcube_add_label('mdnrequest');
     $OUTPUT->set_env('mdn_request', true);
   }
 
-  // set message set for search result
-  if (!empty($_REQUEST['_search']) && isset($_SESSION['search'][$_REQUEST['_search']]))
-    {
-    $IMAP->set_search_set($_SESSION['search'][$_REQUEST['_search']]);
-    $OUTPUT->set_env('search_request', $_REQUEST['_search']);
-    }
 
   $next = $prev = $first = $last = -1;
   // get previous, first, next and last message UID
   if ((!($_SESSION['sort_col'] == 'date' && $_SESSION['sort_order'] == 'DESC') &&
-      $IMAP->get_capability('sort') ) && !(!empty($_REQUEST['_search']) &&
-      isset($_SESSION['search'][$_REQUEST['_search']])) )
+      $IMAP->get_capability('sort')) || !empty($_REQUEST['_search']))
     {
     // Only if we use custom sorting
     $a_msg_index = $IMAP->message_index(NULL, $_SESSION['sort_col'], $_SESSION['sort_order']);
@@ -101,23 +94,6 @@
     $first = count($a_msg_index)>0 ? $a_msg_index[0] : -1;
     $next = isset($a_msg_index[$MESSAGE['index']+1]) ? $a_msg_index[$MESSAGE['index']+1] : -1 ;
     $last = count($a_msg_index)>0 ? $a_msg_index[count($a_msg_index)-1] : -1;
-    }
-  elseif (!empty($_REQUEST['_search']) && isset($_SESSION['search'][$_REQUEST['_search']]))
-    {
-      $search_data = $_SESSION['search'][$_REQUEST['_search']];
-      $result = $IMAP->search(NULL, $search_data[0], $search_data[1],$search_data[3]);
-      $result = array_reverse($result);
-      foreach ($result as $key=>$rid)
-        {
-        $result[$key] = $IMAP->get_uid($rid);
-        if ($MESSAGE['UID'] == $result[$key])
-          $seq = $key;
-        }
-      $prev = isset($result[$seq-1]) ? $result[$seq-1] : -1 ;
-      $first = count($result)>0 ? $result[0] : -1;
-      $next = isset($result[$seq+1]) ? $result[$seq+1] : -1 ;
-      $last = count($result)>0 ? $result[count($result)-1] : -1;
-      $MESSAGE['index'] = $seq;
     }
   else
     {

--
Gitblit v1.9.1