X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Ffolders.php;h=9a183392dcd0dd95cac52149c4677fbc62e70415;hb=c3ccfa1912b4ca47279d259bb587ceb293ce5d83;hp=d99e96bef891ea570f630b88e58550e8be1b0a83;hpb=12ff1cab14f01a1918c7d3d40e6358c13c3833a7;p=squirrelmail.git diff --git a/src/folders.php b/src/folders.php index d99e96be..9a183392 100644 --- a/src/folders.php +++ b/src/folders.php @@ -3,7 +3,7 @@ /** * folders.php * - * Copyright (c) 1999-2002 The SquirrelMail Project Team + * Copyright (c) 1999-2003 The SquirrelMail Project Team * Licensed under the GNU GPL. For full terms see the file COPYING. * * Handles all interaction between the user and the other folder @@ -18,9 +18,7 @@ define('SM_PATH','../'); /* SquirrelMail required files. */ require_once(SM_PATH . 'include/validate.php'); -require_once(SM_PATH . 'functions/imap_utf7_decode_local.php'); require_once(SM_PATH . 'functions/imap.php'); -require_once(SM_PATH . 'functions/array.php'); require_once(SM_PATH . 'functions/plugin.php'); require_once(SM_PATH . 'functions/html.php'); @@ -28,13 +26,12 @@ displayPageHeader($color, 'None'); /* get globals we may need */ -$username = $_SESSION['username']; -$key = $_COOKIE['key']; -$delimiter = $_SESSION['delimiter']; -$onetimepad = $_SESSION['onetimepad']; -if (isset($_GET['success'])) { - $success = $_GET['success']; -} +sqgetGlobalVar('username', $username, SQ_SESSION); +sqgetGlobalVar('key', $key, SQ_COOKIE); +sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION); +sqgetGlobalVar('onetimepad', $onetimepad, SQ_SESSION); + +sqgetGlobalVar('success', $success, SQ_GET); /* end of get globals */ @@ -46,35 +43,47 @@ echo '
' . html_tag( 'tr' ) . html_tag( 'td', '', 'center', $color[4] ); -if ((isset($success) && $success) || - (isset($sent_create) && $sent_create == 'true') || - (isset($trash_create) && $trash_create == 'true')) { - if ($success == "subscribe") { - $td_str = "" . _("Subscribed successfully!") . "
"; - } else if ($success == "unsubscribe") { - $td_str = "" . _("Unsubscribed successfully!") . "
"; - } else if ($success == "delete") { - $td_str = "" . _("Deleted folder successfully!") . "
"; - } else if ($success == "create") { - $td_str = "" . _("Created folder successfully!") . "
"; - } else if ($success == "rename") { - $td_str = "" . _("Renamed successfully!") . "
"; - } else if ($success == "subscribe-doesnotexist") { - $td_str = "" . - _("Subscription Unsuccessful - Folder does not exist.") . - "
"; +if ( isset($success) && $success ) { + + $td_str = ''; + + switch ($success) + { + case 'subscribe': + $td_str .= _("Subscribed successfully!"); + break; + case 'unsubscribe': + $td_str .= _("Unsubscribed successfully!"); + break; + case 'delete': + $td_str .= _("Deleted folder successfully!"); + break; + case 'create': + $td_str .= _("Created folder successfully!"); + break; + case 'rename': + $td_str .= _("Renamed successfully!"); + break; + case 'subscribe-doesnotexist': + $td_str .= _("Subscription Unsuccessful - Folder does not exist."); + break; } + $td_str .= '
'; + + echo html_tag( 'table', html_tag( 'tr', html_tag( 'td', $td_str . - "" . _("refresh folder list") . "" , + '' . + _("refresh folder list") . '' , 'center' ) ) , - 'center', '', 'width="100%" cellpadding="4" cellspacing="0" border="0"' ) . "
\n"; -} else { - echo "
"; + 'center', '', 'width="100%" cellpadding="4" cellspacing="0" border="0"' ); } + +echo "\n
"; + $imapConnection = sqimap_login ($username, $key, $imapServerAddress, $imapPort, 0); $boxes = sqimap_mailbox_list($imapConnection); @@ -89,38 +98,37 @@ echo html_tag( 'table', '', 'center', '', 'width="70%" cellpadding="4" cellspaci "
\n". "
\n". _("as a subfolder of"). - "
". + '
'. "\n"; if ($show_contain_subfolders_option) { - echo "
 "; - echo _("Let this folder contain subfolders"); - echo "
"; + echo '
 ' + . _("Let this folder contain subfolders") + . '
'; } echo "\n"; echo "
\n"; @@ -130,29 +138,49 @@ echo html_tag( 'tr', ) ."\n"; /** count special folders **/ + +// FIX ME, why not check if the folders are defined IMHO move_to_sent, move_to_trash has nothing todo with it $count_special_folders = 0; $num_max = 1; if (strtolower($imap_server_type) == "courier" || $move_to_trash) { - $num_max++; + $num_max++; } if ($move_to_sent) { - $num_max++; + $num_max++; } if ($save_as_draft) { - $num_max++; + $num_max++; } + +// What if move_to_sent = false and $sent_folder is set? Should it still be skipped? + for ($p = 0, $cnt = count($boxes); $p < $cnt && $count_special_folders < $num_max; $p++) { - if (strtolower($boxes[$p]['unformatted']) == 'inbox') - $count_special_folders++; - else if (strtolower($imap_server_type) == 'courier' && - strtolower($boxes[$p]['unformatted']) == 'inbox.trash') - $count_special_folders++; - else if ($boxes[$p]['unformatted'] == $trash_folder && $trash_folder) - $count_special_folders++; - else if ($boxes[$p]['unformatted'] == $sent_folder && $sent_folder) - $count_special_folders++; - else if ($boxes[$p]['unformatted'] == $draft_folder && $draft_folder) - $count_special_folders++; + switch ($boxes[$p]['unformatted']) + { + case (strtoupper($boxes[$p]['unformatted']) == 'INBOX'): + ++$count_special_folders; + $skip_folders[] = $boxes[$p]['unformatted']; + break; + // FIX ME inbox.trash should be set in conf.pl + case 'inbox.trash': + if (strtolower($imap_server_type) == 'courier') { + ++$count_special_folders; + } + break; + case $trash_folder: + ++$count_special_folders; + $skip_folders[] = $trash_folder; + break; + case $sent_folder: + ++$count_special_folders; + $skip_folders[] = $sent_folder; + break; + case $draft_folder: + ++$count_special_folders; + $skip_folders[] = $draft_folder; + break; + default: break; + } } @@ -167,29 +195,20 @@ if ($count_special_folders < count($boxes)) { echo "
\n" . "\n". "\n". "
\n"; } else { - echo _("No folders found") . "

"; + echo _("No folders found") . '

'; } $boxes_sub = $boxes; @@ -208,26 +227,16 @@ if ($count_special_folders < count($boxes)) { echo "
\n" . "\n"; - echo "\n"; - echo "
\n"; + + // send NULL for the flag - ALL folders are eligible for delete (except what we've got in skiplist) + // use long format to make sure folder names make sense when parents may be missing. + echo sqimap_mailbox_option_list($imapConnection, 0, $skip_folders, $boxes, NULL, true); + + echo "\n" + . '\n" + . "\n"; } else { echo _("No folders found") . "

"; } @@ -246,8 +255,8 @@ echo html_tag( 'table', '', 'center', '', 'width="70%" cellpadding="4" cellspaci html_tag( 'td', '', 'center', $color[0], 'width="50%"' ); if ($count_special_folders < count($boxes)) { - echo "
\n"; - echo "\n"; for ($i = 0; $i < count($boxes); $i++) { $use_folder = true; if ((strtolower($boxes[$i]["unformatted"]) != "inbox") && @@ -260,13 +269,13 @@ if ($count_special_folders < count($boxes)) { echo "

\n"; - echo "\n"; - echo "
\n"; + echo "

\n" + . '\n" + . "\n"; } else { - echo _("No folders were found to unsubscribe from!") . ""; + echo _("No folders were found to unsubscribe from!") . ''; } $boxes_sub = $boxes; @@ -275,50 +284,49 @@ echo html_tag( 'td', '', 'center', $color[0], 'width="50%"' ); if(!$no_list_for_subscribe) { $boxes_all = sqimap_mailbox_list_all ($imapConnection); - $box = ""; - $box2 = ""; + $box = ''; + $box2 = ''; for ($i = 0, $q = 0; $i < count($boxes_all); $i++) { $use_folder = true; for ($p = 0; $p < count ($boxes); $p++) { - if ($boxes_all[$i]["unformatted"] == $boxes[$p]["unformatted"]) { + if ($boxes_all[$i]['unformatted'] == $boxes[$p]['unformatted']) { $use_folder = false; continue; - } else if ($boxes_all[$i]["unformatted-dm"] == $folder_prefix) { + } else if ($boxes_all[$i]['unformatted-dm'] == $folder_prefix) { $use_folder = false; } } if ($use_folder == true) { - $box[$q] = $boxes_all[$i]["unformatted-dm"]; - $box2[$q] = imap_utf7_decode_local($boxes_all[$i]["unformatted-disp"]); + $box[$q] = $boxes_all[$i]['unformatted-dm']; + $box2[$q] = imap_utf7_decode_local($boxes_all[$i]['unformatted-disp']); $q++; } } if ($box && $box2) { - echo "
\n"; - echo "'; for ($q = 0; $q < count($box); $q++) { echo "

"; - echo "\n"; - echo "

\n"; + echo '

' + . '\n" + . "
\n"; } else { - echo _("No folders were found to subscribe to!") . ""; + echo _("No folders were found to subscribe to!") . ''; } } else { /* don't perform the list action -- this is much faster */ - echo "
\n"; - echo _("Subscribe to:") . "
"; - echo ""; - echo "\n"; - echo "
\n"; + echo "
\n" + . _("Subscribe to:") . '
' + . '' + . '\n" + . "
\n"; } -do_hook("folders_bottom"); +do_hook('folders_bottom'); ?> -