X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Fleft_main.php;h=3d38e173f87a7952661bdc5e8b25c0af08035b76;hb=541506f3bbe3cfc966221c55c35e50e9bda6f181;hp=dea9fd580f7a38c01fddf191a196404784b8be5d;hpb=d3cdb279bd61b172926b51d41d09c8a691d6c347;p=squirrelmail.git
diff --git a/src/left_main.php b/src/left_main.php
index dea9fd58..3d38e173 100644
--- a/src/left_main.php
+++ b/src/left_main.php
@@ -1,119 +1,198 @@
-
+
-
-
- include("../config/config.php");
+ include('../src/validate.php');
include("../functions/array.php");
- include("../functions/strings.php");
include("../functions/imap.php");
- include("../functions/mailbox.php");
-
- include("../src/load_prefs.php");
-
- function formatMailboxName($imapConnection, $mailbox, $delimeter, $color) {
- require ("../config/config.php");
+ include("../functions/plugin.php");
- $mailboxURL = urlencode($mailbox);
- selectMailbox($imapConnection, $mailbox, $numNessages);
- $unseen = unseenMessages($imapConnection, $numUnseen);
-
- echo "";
- if ($unseen)
- $line .= "";
+ // open a connection on the imap port (143)
+ $imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 10); // the 10 is to hide the output
+
+ displayHtmlHeader();
+
+ if ($auto_create_special && ! isset($auto_create_done)) {
+ if (isset ($sent_folder) && $sent_folder != "none") {
+ if (!sqimap_mailbox_exists ($imapConnection, $sent_folder)) {
+ sqimap_mailbox_create ($imapConnection, $sent_folder, "");
+ }
+ }
+ if (isset ($trash_folder) && $trash_folder != "none") {
+ if (!sqimap_mailbox_exists ($imapConnection, $trash_folder)) {
+ sqimap_mailbox_create ($imapConnection, $trash_folder, "");
+ }
+ }
+ $auto_create_done = true;
+ session_register('auto_create_done');
+ }
+ function formatMailboxName($imapConnection, $box_array, $delimeter) {
+ global $folder_prefix, $trash_folder, $sent_folder;
+ global $color, $move_to_sent, $move_to_trash;
+ global $unseen_notify, $unseen_type, $collapse_folders;
+
+ $real_box = $box_array['unformatted'];
+ $mailbox = $box_array['formatted'];
+ $mailboxURL = urlencode($real_box);
+
+ $unseen = 0;
+
+ if (($unseen_notify == 2 && $real_box == "INBOX") ||
+ $unseen_notify == 3) {
+ $unseen = sqimap_unseen_messages($imapConnection, $real_box);
+ if ($unseen_type == 1 && $unseen > 0) {
+ $unseen_string = "($unseen)";
+ $unseen_found = true;
+ } else if ($unseen_type == 2) {
+ $numMessages = sqimap_get_num_messages($imapConnection, $real_box);
+ $unseen_string = "($unseen/$numMessages)";
+ $unseen_found = true;
+ }
+ }
+
$special_color = false;
- for ($i = 0; $i < count($special_folders); $i++) {
- if (($special_folders[$i] == $mailbox) && ($use_special_folder_color == true))
- $special_color = true;
+ if ((strtolower($real_box) == "inbox") ||
+ (($real_box == $trash_folder) && ($move_to_trash)) ||
+ (($real_box == $sent_folder) && ($move_to_sent)))
+ $special_color = true;
+
+ $spaces = '';
+ $line = "";
+ if (ereg("^( *)([^ ]*)$", $mailbox, $regs)) {
+ $spaces = $regs[1];
+ $mailbox = $regs[2];
}
-
- if ($special_color == true) {
- $line .= "";
- $line .= readShortMailboxName($mailbox, $delimeter);
- $line .= "";
- } else {
- $line .= "";
- $line .= readShortMailboxName($mailbox, $delimeter);
- $line .= "";
+
+ if ($unseen > 0)
+ $line .= "";
+ $line .= str_replace(' ', ' ', $spaces);
+
+ if ($collapse_folders) {
+ if (isset($box_array['parent']))
+ $line .= FoldLink($box_array['unformatted'], $box_array['parent']);
+ else
+ $line .= ' ';
}
-
- if ($unseen)
+
+ $line .= "";
+ if ($special_color == true)
+ $line .= "";
+ $line .= str_replace(' ', ' ', $mailbox);
+ if ($special_color == true)
+ $line .= "";
+ $line .= "";
+
+ if ($unseen > 0)
$line .= "";
- if ($numUnseen > 0) {
- $line .= " ($numUnseen)";
+ if (isset($unseen_found) && $unseen_found) {
+ $line .= " $unseen_string";
}
- if (($move_to_trash == true) && (trim($mailbox) == $trash_folder)) {
- $urlMailbox = urlencode($mailbox);
- $line .= "";
- $line .= " (empty)";
- $line .= "\n";
- }
+ if (($move_to_trash == true) && ($real_box == $trash_folder)) {
+ if (! isset($numMessages))
+ $numMessages = sqimap_get_num_messages($imapConnection, $real_box);
- echo "";
+ if ($numMessages > 0)
+ {
+ $urlMailbox = urlencode($real_box);
+ $line .= "\n\n";
+ $line .= " ("._("purge").")";
+ $line .= "\n\n";
+ }
+ }
+ $line .= "";
return $line;
}
- echo "
";
- echo "";
- // open a connection on the imap port (143)
- $imapConnection = loginToImapServer($username, $key, $imapServerAddress, 10); // the 10 is to hide the output
-
- getFolderList($imapConnection, $boxes);
-
- echo "";
- echo "Folders
";
+ if (isset($left_refresh) && ($left_refresh != "None") && ($left_refresh != "")) {
+ echo "\n";
+ echo "\n";
+ echo "\n";
+ }
+
+ echo "\n\n";
+
+ do_hook("left_main_before");
+
+ $boxes = sqimap_mailbox_list($imapConnection);
+
+ echo "";
+ echo _("Folders") . "
\n\n";
+
+ echo "(";
+ echo _("refresh folder list");
+ echo ")
";
+ $delimeter = sqimap_get_delimiter($imapConnection);
+
+ if (isset($collapse_folders) && $collapse_folders) {
+ if (isset($fold))
+ setPref($data_dir, $username, 'collapse_folder_' . $fold, 1);
+ if (isset($unfold))
+ setPref($data_dir, $username, 'collapse_folder_' . $unfold, 0);
+ $IAmAParent = array();
+ for ($i = 0; $i < count($boxes); $i ++) {
+ $parts = explode($delimeter, $boxes[$i]['unformatted']);
+ $box_name = array_pop($parts);
+ $box_parent = implode($delimeter, $parts);
+ $hidden = 0;
+ if (isset($box_parent)) {
+ $hidden = getPref($data_dir, $username,
+ 'collapse_folder_' . $box_parent);
+ $IAmAParent[$box_parent] = $hidden;
+ }
+ $boxes[$i]['folded'] = $hidden;
+ }
+ }
- echo "(refresh folder list)
";
- echo "\n";
- $delimeter = findMailboxDelimeter($imapConnection);
for ($i = 0;$i < count($boxes); $i++) {
- $mailbox = $boxes[$i]["UNFORMATTED"];
- $boxFlags = getMailboxFlags($boxes[$i]["RAW"]);
-
- $boxCount = countCharInString($mailbox, $delimeter);
-
- $line = "";
- // indent the correct number of spaces.
- for ($j = 0;$j < $boxCount;$j++)
- $line .= " ";
+ if (! isset($boxes[$i]['folded']) || ! $boxes[$i]['folded'])
+ {
+ $line = "";
+ $mailbox = $boxes[$i]["formatted"];
- if (trim($boxFlags[0]) != "") {
- $noselect = false;
- for ($h = 0; $h < count($boxFlags); $h++) {
- if (strtolower($boxFlags[$h]) == "noselect")
- $noselect = true;
+ if (isset($collapse_folders) && $collapse_folders && isset($IAmAParent[$boxes[$i]['unformatted']])) {
+ $boxes[$i]['parent'] = $IAmAParent[$boxes[$i]['unformatted']];
}
- if ($noselect == true) {
- $line .= "";
- $line .= readShortMailboxName($mailbox, $delimeter);
- $line .= "";
+ if (in_array('noselect', $boxes[$i]['flags'])) {
+ $line .= "";
+ if (ereg("^( *)([^ ]*)", $mailbox, $regs)) {
+ $line .= str_replace(' ', ' ', $mailbox);
+ if (isset($boxes[$i]['parent']))
+ $line .= FoldLink($boxes[$i]['unformatted'], $boxes[$i]['parent']);
+ elseif ($collapse_folders)
+ $line .= ' ';
+ }
+ $line .= '';
} else {
- $line .= formatMailboxName($imapConnection, $mailbox, $delimeter, $color);
+ $line .= formatMailboxName($imapConnection, $boxes[$i], $delimeter);
}
- } else {
- $line .= formatMailboxName($imapConnection, $mailbox, $delimeter, $color);
+ echo "$line
\n";
}
- echo "$line
";
}
-
- echo "";
-
- fclose($imapConnection);
-
+ sqimap_logout($imapConnection);
+ do_hook("left_main_after");
+
+ function FoldLink($mailbox, $folded) {
+ $mailbox = urlencode($mailbox);
+ echo '+";
+ else
+ echo "fold=$mailbox\">-";
+ echo ' ';
+ }
+
?>
-
+