X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=functions%2Fmailbox_display.php;h=8d1e5be39a32add371145f1ce669b646df1b9bb1;hp=c51dd746accf0d9d900c290cdad6db37abb257e1;hb=c57b0888fe1f3bf8dbd55b8a4657a4de23a29f6a;hpb=cd9281577d4b1042f586808bbd12369ced6b183f;ds=sidebyside
diff --git a/functions/mailbox_display.php b/functions/mailbox_display.php
index c51dd746..8d1e5be3 100644
--- a/functions/mailbox_display.php
+++ b/functions/mailbox_display.php
@@ -1,70 +1,79 @@
\n";
- if (isset($msg['FLAG_FLAGGED']) && $msg['FLAG_FLAGGED'] == true)
- {
- $flag = "";
- $flag_end = ' ';
- }
- else
- {
+ if (isset($msg['FLAG_FLAGGED']) && ($msg['FLAG_FLAGGED'] == true)) {
+ $flag = "";
+ $flag_end = ' ';
+ } else {
$flag = '';
$flag_end = '';
}
- if (!isset($msg['FLAG_SEEN']) || $msg['FLAG_SEEN'] == false)
- {
- $bold = '';
- $bold_end = ' ';
- }
- else
- {
+ if (!isset($msg['FLAG_SEEN']) || ($msg['FLAG_SEEN'] == false)) {
+ $bold = '';
+ $bold_end = ' ';
+ } else {
$bold = '';
$bold_end = '';
}
- if ($mailbox == $sent_folder)
- {
- $italic = '';
- $italic_end = ' ';
- }
- else
- {
+
+ if (($mailbox == $sent_folder) || ($mailbox == $draft_folder)) {
+ $italic = '';
+ $italic_end = ' ';
+ } else {
$italic = '';
$italic_end = '';
}
- if (isset($msg['FLAG_DELETED']) && $msg['FLAG_DELETED'])
- {
- $fontstr = "";
- $fontstr_end = ' ';
- }
- else
- {
+
+ if (isset($msg['FLAG_DELETED']) && $msg['FLAG_DELETED']) {
+ $fontstr = "";
+ $fontstr_end = ' ';
+ } else {
$fontstr = '';
$fontstr_end = '';
}
@@ -83,45 +92,46 @@
}
}
- if (!isset($hlt_color))
- $hlt_color = $color[4];
+ if (!isset($hlt_color)) {
+ $hlt_color = $color_string;
+ }
if ($where && $what) {
$search_stuff = '&where='.urlencode($where).'&what='.urlencode($what);
}
- if ($checkall == 1)
- $checked = ' checked';
- else
- $checked = '';
-
+ $checked = ($checkall == 1 ?' checked' : '');
+
for ($i=1; $i <= count($index_order); $i++) {
switch ($index_order[$i]) {
- case 1: # checkbox
- echo "
\n";
+ case 1: /* checkbox */
+ echo " \n";
break;
- case 2: # from
- echo " $italic$bold$flag$fontstr$senderName$fontstr_end$flag_end$bold_end$italic_end \n";
+ case 2: /* from */
+ echo " $italic$bold$flag$fontstr$senderName$fontstr_end$flag_end$bold_end$italic_end \n";
break;
- case 3: # date
- echo " $bold$flag$fontstr".$msg["DATE_STRING"]."$fontstr_end$flag_end$bold_end \n";
+ case 3: /* date */
+ echo " $bold$flag$fontstr".$msg["DATE_STRING"]."$fontstr_end$flag_end$bold_end \n";
break;
- case 4: # subject
+ case 4: /* subject */
echo " $bold";
if (! isset($search_stuff)) { $search_stuff = ''; }
- echo "$flag";
- if (strlen($subject) > 55)
- echo substr($subject, 0, 50) . '...';
- else
- echo $subject;
- echo "$flag_end $bold_end \n";
+
+ if ($subject != $msg['SUBJECT']) {
+ $title = get_html_translation_table(HTML_SPECIALCHARS);
+ $title = array_flip($title);
+ $title = strtr($msg['SUBJECT'], $title);
+ $title = str_replace('"', "''", $title);
+ echo " title=\"$title\"";
+ }
+ echo ">$flag$subject$flag_end$bold_end\n";
break;
- case 5: # flags
+ case 5: /* flags */
$stuff = false;
- echo " \n";
- if (isset($msg['FLAG_ANSWERED']) &&
+ echo " \n";
+ if (isset($msg['FLAG_ANSWERED']) &&
$msg['FLAG_ANSWERED'] == true) {
echo "A\n";
$stuff = true;
@@ -130,9 +140,15 @@
echo "+\n";
$stuff = true;
}
- if (ereg('(1|2)',substr($msg['PRIORITY'],0,1))) {
- echo "! \n";
- $stuff = true;
+ if ($default_use_priority) {
+ if (ereg('(1|2)',substr($msg['PRIORITY'],0,1))) {
+ echo "! \n";
+ $stuff = true;
+ }
+ if (ereg('(5)',substr($msg['PRIORITY'],0,1))) {
+ echo "? \n";
+ $stuff = true;
+ }
}
if (isset($msg['FLAG_DELETED']) && $msg['FLAG_DELETED']) {
echo "D \n";
@@ -142,103 +158,90 @@
if (!$stuff) echo " \n";
echo " \n";
break;
- case 6: # size
- echo " $bold$fontstr".show_readable_size($msg['SIZE'])."$fontstr_end$bold_end \n";
+ case 6: /* size */
+ echo " $bold$fontstr".show_readable_size($msg['SIZE'])."$fontstr_end$bold_end \n";
break;
}
}
-
-
echo "\n";
}
/**
- ** This function loops through a group of messages in the mailbox and shows them
- **/
- function showMessagesForMailbox($imapConnection, $mailbox, $numMessages, $startMessage, $sort, $color,$show_num, $use_cache) {
+ * This function loops through a group of messages in the mailbox
+ * and shows them to the user.
+ */
+ function showMessagesForMailbox
+ ($imapConnection, $mailbox, $num_msgs, $start_msg,
+ $sort, $color,$show_num, $use_cache) {
global $msgs, $msort;
- global $sent_folder;
+ global $sent_folder, $draft_folder;
global $message_highlight_list;
global $auto_expunge;
- if ($auto_expunge == true) sqimap_mailbox_expunge($imapConnection, $mailbox, false);
+ /* If autoexpunge is turned on, then do it now. */
+ if ($auto_expunge == true) {
+ sqimap_mailbox_expunge($imapConnection, $mailbox, false);
+ }
sqimap_mailbox_select($imapConnection, $mailbox);
+ $issent = (($mailbox == $sent_folder) || ($mailbox == $draft_folder));
if (!$use_cache) {
- // if it's sorted
- if ($numMessages >= 1) {
+ /* If it is sorted... */
+ if ($num_msgs >= 1) {
if ($sort < 6) {
- for ($q = 0; $q < $numMessages; $q++) {
- if($mailbox == $sent_folder)
- $hdr = sqimap_get_small_header ($imapConnection, $q+1, true);
- else
- $hdr = sqimap_get_small_header ($imapConnection, $q+1, false);
-
- $from[$q] = $hdr->from;
- $date[$q] = $hdr->date;
- $subject[$q] = $hdr->subject;
- $to[$q] = $hdr->to;
- $priority[$q] = $hdr->priority;
- $cc[$q] = $hdr->cc;
- $size[$q] = $hdr->size;
- $type[$q] = $hdr->type0;
- $flags[$q] = sqimap_get_flags ($imapConnection, $q+1);
- $id[$q] = $q + 1;
- }
+ $id = range(1, $num_msgs);
} else {
// if it's not sorted
- if ($startMessage + ($show_num - 1) < $numMessages) {
- $endMessage = $startMessage + ($show_num-1);
+ if ($start_msg + ($show_num - 1) < $num_msgs) {
+ $end_msg = $start_msg + ($show_num-1);
} else {
- $endMessage = $numMessages;
+ $end_msg = $num_msgs;
}
- if ($endMessage < $startMessage) {
- $startMessage = $startMessage - $show_num;
- if ($startMessage < 1)
- $startMessage = 1;
+ if ($end_msg < $start_msg) {
+ $start_msg = $start_msg - $show_num;
+ if ($start_msg < 1) {
+ $start_msg = 1;
+ }
}
-
- $real_startMessage = $numMessages - $startMessage + 1;
- $real_endMessage = $numMessages - $startMessage - $show_num;
- if ($real_endMessage <= 0)
- $real_endMessage = 1;
-
- $j = 0;
- for ($q = $real_startMessage; $q >= $real_endMessage; $q--) {
- if($mailbox == $sent_folder)
- $hdr = sqimap_get_small_header ($imapConnection, $q, true);
- else
- $hdr = sqimap_get_small_header ($imapConnection, $q, false);
-
- $from[$j] = $hdr->from;
- $date[$j] = $hdr->date;
- $subject[$j] = $hdr->subject;
- $to[$j] = $hdr->to;
- $priority[$j] = $hdr->priority;
- $cc[$j] = $hdr->cc;
- $size[$j] = $hdr->size;
- $type[$j] = $hdr->type0;
- $flags[$j] = sqimap_get_flags ($imapConnection, $q);
- $id[$j] = $q;
- $j++;
+ $real_startMessage = $num_msgs - $start_msg + 1;
+ $real_endMessage = $num_msgs - $start_msg - $show_num + 2;
+ if ($real_endMessage <= 0) {
+ $real_endMessage = 1;
}
+ $id = array_reverse(range($real_endMessage, $real_startMessage));
+ }
+
+ $msgs_list = sqimap_get_small_header_list($imapConnection, $id, $issent);
+ $flags = sqimap_get_flags_list($imapConnection, $id, $issent);
+ foreach ($msgs_list as $hdr) {
+ $from[] = $hdr->from;
+ $date[] = $hdr->date;
+ $subject[] = $hdr->subject;
+ $to[] = $hdr->to;
+ $priority[] = $hdr->priority;
+ $cc[] = $hdr->cc;
+ $size[] = $hdr->size;
+ $type[] = $hdr->type0;
}
}
$j = 0;
if ($sort == 6) {
- $end = $startMessage + $show_num - 1;
- if ($numMessages < $show_num)
- $end_loop = $numMessages;
- else
- $end_loop = $show_num;
+ $end = $start_msg + $show_num - 1;
+ if ($num_msgs < $show_num) {
+ $end_loop = $num_msgs;
+ } else if ($end > $num_msgs) {
+ $end_loop = $num_msgs - $start_msg + 1;
+ } else {
+ $end_loop = $show_num;
+ }
} else {
- $end = $numMessages;
+ $end = $num_msgs;
$end_loop = $end;
}
- if ($end > $numMessages) $end = $numMessages;
+
while ($j < $end_loop) {
if (isset($date[$j])) {
$date[$j] = ereg_replace(' ', ' ', $date[$j]);
@@ -264,22 +267,20 @@
$re_abbr = # Add more here!
'vedr|sv|' . # Danish
're|aw'; # English
- if (eregi("^($re_abbr):[ ]*(.*)$", $messages[$j]['SUBJECT-SORT'], $regs))
+
+ if (eregi( "^($re_abbr):[ ]*(.*)$", $messages[$j]['SUBJECT-SORT'], $regs))
$messages[$j]['SUBJECT-SORT'] = $regs[2];
$num = 0;
while ($num < count($flags[$j])) {
if ($flags[$j][$num] == 'Deleted') {
- $messages[$j]['FLAG_DELETED'] = true;
- }
- elseif ($flags[$j][$num] == 'Answered') {
- $messages[$j]['FLAG_ANSWERED'] = true;
- }
- elseif ($flags[$j][$num] == 'Seen') {
- $messages[$j]['FLAG_SEEN'] = true;
- }
- elseif ($flags[$j][$num] == 'Flagged') {
- $messages[$j]['FLAG_FLAGGED'] = true;
+ $messages[$j]['FLAG_DELETED'] = true;
+ } else if ($flags[$j][$num] == 'Answered') {
+ $messages[$j]['FLAG_ANSWERED'] = true;
+ } else if ($flags[$j][$num] == 'Seen') {
+ $messages[$j]['FLAG_SEEN'] = true;
+ } else if ($flags[$j][$num] == 'Flagged') {
+ $messages[$j]['FLAG_FLAGGED'] = true;
}
$num++;
}
@@ -288,13 +289,14 @@
/* Only ignore messages flagged as deleted if we are using a
* trash folder or auto_expunge */
- if (((isset($move_to_trash) && $move_to_trash)
- || (isset($auto_expunge) && $auto_expunge)) && $sort != 6)
- {
+ if (((isset($move_to_trash) && $move_to_trash)
+ || (isset($auto_expunge) && $auto_expunge)) && $sort != 6) {
+
/** Find and remove the ones that are deleted */
$i = 0;
$j = 0;
- while ($j < $numMessages) {
+
+ while ($j < $num_msgs) {
if (isset($messages[$j]['FLAG_DELETED']) && $messages[$j]['FLAG_DELETED'] == true) {
$j++;
continue;
@@ -304,16 +306,17 @@
$i++;
$j++;
}
- $numMessages = $i;
+ $num_msgs = $i;
} else {
- if (! isset($messages))
- $messages = array();
- $msgs = $messages;
+ if (!isset($messages)) {
+ $messages = array();
+ }
+ $msgs = $messages;
}
- }
+ }
// There's gotta be messages in the array for it to sort them.
- if ($numMessages > 0 && ! $use_cache) {
+ if ($num_msgs > 0 && ! $use_cache) {
/** 0 = Date (up) 4 = Subject (up)
** 1 = Date (dn) 5 = Subject (dn)
** 2 = Name (up)
@@ -322,15 +325,15 @@
session_unregister("msgs");
if (($sort == 0) || ($sort == 1))
$msort = array_cleave ($msgs, 'TIME_STAMP');
- if (($sort == 2) || ($sort == 3))
+ elseif (($sort == 2) || ($sort == 3))
$msort = array_cleave ($msgs, 'FROM-SORT');
- if (($sort == 4) || ($sort == 5))
+ elseif (($sort == 4) || ($sort == 5))
$msort = array_cleave ($msgs, 'SUBJECT-SORT');
- if ($sort == 6)
+ else // ($sort == 6)
$msort = $msgs;
if ($sort < 6) {
- if($sort % 2) {
+ if ($sort % 2) {
asort($msort);
} else {
arsort($msort);
@@ -338,270 +341,417 @@
}
session_register('msort');
}
- displayMessageArray($imapConnection, $numMessages, $startMessage, $msgs, $msort, $mailbox, $sort, $color,$show_num);
- session_register('msgs');
+ displayMessageArray($imapConnection, $num_msgs, $start_msg, $msgs, $msort, $mailbox, $sort, $color,$show_num);
+ session_register('msgs');
}
- // generic function to convert the msgs array into an HTML table
- function displayMessageArray($imapConnection, $numMessages, $startMessage, &$msgs, $msort, $mailbox, $sort, $color,$show_num) {
+ /******************************************************************/
+ /* Generic function to convert the msgs array into an HTML table. */
+ /******************************************************************/
+ function displayMessageArray($imapConnection, $num_msgs, $start_msg, &$msgs, $msort, $mailbox, $sort, $color, $show_num) {
global $folder_prefix, $sent_folder;
- global $imapServerAddress;
+ global $imapServerAddress, $data_dir, $username, $use_mailbox_cache;
global $index_order, $real_endMessage, $real_startMessage, $checkall;
-
- // if cache isn't already set, do it now
- if (!session_is_registered('msgs'))
- session_register('msgs');
- if (!session_is_registered('msort'))
- session_register('msort');
- if ($startMessage + ($show_num - 1) < $numMessages) {
- $endMessage = $startMessage + ($show_num-1);
+ /* If cache isn't already set, do it now. */
+ if (!session_is_registered('msgs')) { session_register('msgs'); }
+ if (!session_is_registered('msort')) { session_register('msort'); }
+
+ if ($start_msg + ($show_num - 1) < $num_msgs) {
+ $end_msg = $start_msg + ($show_num-1);
} else {
- $endMessage = $numMessages;
+ $end_msg = $num_msgs;
}
- if ($endMessage < $startMessage) {
- $startMessage = $startMessage - $show_num;
- if ($startMessage < 1)
- $startMessage = 1;
+ if ($end_msg < $start_msg) {
+ $start_msg = $start_msg - $show_num;
+ if ($start_msg < 1) { $start_msg = 1; }
}
- $nextGroup = $startMessage + $show_num;
- $prevGroup = $startMessage - $show_num;
$urlMailbox = urlencode($mailbox);
do_hook('mailbox_index_before');
- $Message = '';
- if ($startMessage < $endMessage) {
- $Message = _("Viewing messages") ." $startMessage ". _("to") ." $endMessage ($numMessages " . _("total") . ")\n";
- } elseif ($startMessage == $endMessage) {
- $Message = _("Viewing message") ." $startMessage ($numMessages " . _("total") . ")\n";
- }
+ $msg_cnt_str = get_msgcnt_str($start_msg, $end_msg, $num_msgs);
+ $paginator_str = get_paginator_str($urlMailbox, $start_msg, $end_msg, $num_msgs, $show_num, $sort);
- $More = '';
- if ($sort == 6) {
- $use = 0;
- } else {
- $use = 1;
- }
- if (($nextGroup <= $numMessages) && ($prevGroup >= 0)) {
- $More = "". _("Previous") ." | \n";
- $More .= "". _("Next") ." \n";
- }
- elseif (($nextGroup > $numMessages) && ($prevGroup >= 0)) {
- $More = "". _("Previous") ." | \n";
- $More .= ""._("Next")." \n";
- }
- elseif (($nextGroup <= $numMessages) && ($prevGroup < 0)) {
- $More = ""._("Previous")." | \n";
- $More .= "". _("Next") ." \n";
+ if (! isset($msg)) {
+ $msg = '';
}
- if (! isset($msg))
- $msg = "";
- mail_message_listing_beginning($imapConnection,
- "move_messages.php?msg=$msg&mailbox=$urlMailbox&startMessage=$startMessage",
- $mailbox, $sort, $Message, $More, $startMessage);
+ mail_message_listing_beginning
+ ($imapConnection,
+ "move_messages.php?msg=$msg&mailbox=$urlMailbox&startMessage=$start_msg",
+ $mailbox, $sort, $msg_cnt_str, $paginator_str, $start_msg);
- $groupNum = $startMessage % ($show_num - 1);
- $real_startMessage = $startMessage;
+ $groupNum = $start_msg % ($show_num - 1);
+ $real_startMessage = $start_msg;
if ($sort == 6) {
- if ($endMessage - $startMessage < $show_num - 1) {
- $endMessage = $endMessage - $startMessage + 1;
- $startMessage = 1;
- } else if ($startMessage > $show_num) {
- $endMessage = $show_num;
- $startMessage = 1;
+ if ($end_msg - $start_msg < $show_num - 1) {
+ $end_msg = $end_msg - $start_msg + 1;
+ $start_msg = 1;
+ } else if ($start_msg > $show_num) {
+ $end_msg = $show_num;
+ $start_msg = 1;
}
}
+ $endVar = $end_msg + 1;
- $endVar = $endMessage + 1;
-
- // loop through and display the info for each message.
+ /* Loop through and display the info for each message. */
$t = 0; // $t is used for the checkbox number
- if ($numMessages == 0) { // if there's no messages in this folder
- echo "". _("THIS FOLDER IS EMPTY") ." ";
- } else if ($startMessage == $endMessage) { // if there's only one message in the box, handle it different.
- if ($sort != 6)
- $i = $startMessage;
- else
- $i = 1;
- reset($msort);
- $k = 0;
- do {
- $key = key($msort);
- next($msort);
- $k++;
- } while (isset ($key) && ($k < $i));
- printMessageInfo($imapConnection, $t, $i, $key, $mailbox, $sort, $real_startMessage, 0, 0);
+ if ($num_msgs == 0) { // if there's no messages in this folder
+ echo "\n".
+ " ". _("THIS FOLDER IS EMPTY") ." \n".
+ " ";
+ } else if ($start_msg == $end_msg) {
+ /* If there's only one message in the box, handle it differently. */
+ if ($sort != 6) {
+ $i = $start_msg;
+ } else {
+ $i = 1;
+ }
+
+ reset($msort);
+ $k = 0;
+ do {
+ $key = key($msort);
+ next($msort);
+ $k++;
+ } while (isset ($key) && ($k < $i));
+ printMessageInfo($imapConnection, $t, $i, $key, $mailbox, $sort, $real_startMessage, 0, 0);
} else {
- $i = $startMessage;
-
- reset($msort);
- $k = 0;
- do {
- $key = key($msort);
- next($msort);
- $k++;
- } while (isset ($key) && ($k < $i));
-
- do {
- printMessageInfo($imapConnection, $t, $i, $key, $mailbox, $sort, $real_startMessage, 0, 0);
- $key = key($msort);
- $t++;
- $i++;
- next($msort);
- } while ($i && $i < $endVar);
+ $i = $start_msg;
+
+ reset($msort);
+ $k = 0;
+ do {
+ $key = key($msort);
+ next($msort);
+ $k++;
+ } while (isset ($key) && ($k < $i));
+
+ do {
+ printMessageInfo($imapConnection, $t, $i, $key, $mailbox, $sort, $real_startMessage, 0, 0);
+ $key = key($msort);
+ $t++;
+ $i++;
+ next($msort);
+ } while ($i && $i < $endVar);
}
- echo '';
-
- echo " \n";
-
- echo "";
- echo '';
- echo ' ';
- echo ''; /** End of message-list table */
+ echo ''.
+ "" .
+ "" .
+ "$paginator_str ".
+ "$msg_cnt_str
".
+ " ".
+ "
";
+ /** End of message-list table */
do_hook('mailbox_index_after');
+ echo "\n";
}
- /* Displays the standard message list header.
- * To finish the table, you need to do a "";
+ /**
+ * Displays the standard message list header. To finish the table,
+ * you need to do a "";
+ *
* $moveURL is the URL to submit the delete/move form to
* $mailbox is the current mailbox
* $sort is the current sorting method (-1 for no sorting available [searches])
* $Message is a message that is centered on top of the list
* $More is a second line that is left aligned
*/
- function mail_message_listing_beginning($imapConnection, $moveURL,
- $mailbox = '', $sort = -1, $Message = '', $More = '', $startMessage = 1)
- {
+ function mail_message_listing_beginning
+ ($imapConnection, $moveURL, $mailbox = '', $sort = -1,
+ $msg_cnt_str = '', $paginator = ' ', $start_msg = 1) {
global $color, $index_order, $auto_expunge, $move_to_trash;
- global $checkall, $sent_folder;
+ global $checkall, $sent_folder, $draft_folder;
$urlMailbox = urlencode($mailbox);
- /** This is the beginning of the message list table. It wraps around all messages */
- echo '';
-
- if ($Message)
- {
- echo "$Message \n";
- }
-
- echo "";
- echo '';
- echo ' ';
-
- /** The delete and move options */
- echo "";
-
- echo "\n\n\n