diff options
author | thomascube <thomas@roundcube.net> | 2006-03-27 19:07:13 +0000 |
---|---|---|
committer | thomascube <thomas@roundcube.net> | 2006-03-27 19:07:13 +0000 |
commit | ac6b87c4a27c3ca7491af7f159778f333050519e (patch) | |
tree | 1c88e2be11f834a1771e239a8b946bbdedf1b103 /program/steps | |
parent | 0d361b9e4a878e63055aeab12a0dc9e21386501b (diff) |
Improved search function
Diffstat (limited to 'program/steps')
-rw-r--r-- | program/steps/mail/list.inc | 2 | ||||
-rw-r--r-- | program/steps/mail/search.inc | 15 |
2 files changed, 9 insertions, 8 deletions
diff --git a/program/steps/mail/list.inc b/program/steps/mail/list.inc index 40cd652df..ba4169f7b 100644 --- a/program/steps/mail/list.inc +++ b/program/steps/mail/list.inc @@ -61,7 +61,7 @@ $unseen = $IMAP->messagecount($mbox, 'UNSEEN', !empty($_GET['_refresh']) ? TRUE $pages = ceil($count/$IMAP->page_size); $commands = sprintf("this.set_env('messagecount', %d);\n", $count); $commands .= sprintf("this.set_env('pagecount', %d);\n", $pages); -$commands .= sprintf("this.set_rowcount('%s');\n", rcmail_get_messagecount_text()); +$commands .= sprintf("this.set_rowcount('%s');\n", rcmail_get_messagecount_text($count)); // update mailboxlist $mbox = $IMAP->get_mailbox_name(); diff --git a/program/steps/mail/search.inc b/program/steps/mail/search.inc index 7b49ed84f..142411443 100644 --- a/program/steps/mail/search.inc +++ b/program/steps/mail/search.inc @@ -21,6 +21,7 @@ $_SESSION['page'] = 1; // get search string $str = get_input_value('_search', RCUBE_INPUT_GET); $mbox = get_input_value('_mbox', RCUBE_INPUT_GET); +$search_request = md5($str); // Check the search string for type of search @@ -60,7 +61,7 @@ else { // Complete the search display results or report error function finish_search($mbox, $search) { - global $IMAP, $JS_OBJECT_NAME, $OUTPUT; + global $IMAP, $JS_OBJECT_NAME, $OUTPUT, $search_request; $commands = ''; $count = 0; @@ -70,28 +71,28 @@ function finish_search($mbox, $search) // Get the headers $result_h = $IMAP->list_header_set($mbox, $search, 1, $_SESSION['sort_col'], $_SESSION['sort_order']); $count = count($search); - + // save search results in session if (!is_array($_SESSION['search'])) $_SESSION['search'] = array(); - - $search_request = md5(uniqid(rand())); - $_SESSION['search'][$search_request] = join(',', $search); // Make sure we got the headers if ($result_h != NULL) { - $count = count($result_h); + $_SESSION['search'][$search_request] = join(',', $search); $commands = rcmail_js_message_list($result_h); $commands .= show_message('searchsuccessful', 'confirmation', array('nr' => $count)); - $commands .= sprintf("\nthis.set_env('search_request', '%s')\n", $search_request); } } else + { $commands = show_message('searchnomatch', 'warning'); + $search_request = -1; + } // update message count display $pages = ceil($count/$IMAP->page_size); + $commands .= sprintf("\nthis.set_env('search_request', '%s')\n", $search_request); $commands .= sprintf("this.set_env('messagecount', %d);\n", $count); $commands .= sprintf("this.set_env('pagecount', %d);\n", $pages); $commands .= sprintf("this.set_rowcount('%s');\n", rcmail_get_messagecount_text($count, 1)); |