X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Ffolders.php;h=182a1d3cb2e50bd32b4998c7fab75bd92815451f;hb=ce20ea9260adccbf62ca895c7e372947c3007f21;hp=f2589fb0e4203fdbbf2d3c24f726253c07c6a24d;hpb=7e235a1a75c0544d1b41270f54568990b3af112a;p=squirrelmail.git diff --git a/src/folders.php b/src/folders.php index f2589fb0..182a1d3c 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 @@ -13,137 +13,128 @@ * $Id$ */ -require_once('../src/validate.php'); -require_once('../functions/imap.php'); -require_once('../functions/array.php'); -require_once('../functions/plugin.php'); +/* Path for SquirrelMail required files. */ +define('SM_PATH','../'); + +/* SquirrelMail required files. */ +require_once(SM_PATH . 'include/validate.php'); +require_once(SM_PATH . 'functions/imap.php'); +require_once(SM_PATH . 'functions/plugin.php'); +require_once(SM_PATH . 'functions/html.php'); displayPageHeader($color, 'None'); -?> +/* get globals we may need */ -
- -
+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 */ -' . + html_tag( 'table', '', 'center', $color[0], 'width="95%" cellpadding="1" cellspacing="0" border="0"' ) . + html_tag( 'tr' ) . + html_tag( 'td', '', 'center' ) . '' . _("Folders") . '' . + html_tag( 'table', '', 'center', '', 'width="100%" cellpadding="5" cellspacing="0" border="0"' ) . + html_tag( 'tr' ) . + html_tag( 'td', '', 'center', $color[4] ); + +if ( isset($success) && $success ) { + + $td_str = ''; -if ((isset($success) && $success) || - (isset($sent_create) && $sent_create == 'true') || - (isset($trash_create) && $trash_create == 'true')) { - echo "\n" . - " \n"; - "
\n"; - if ($success == "subscribe") { - echo "" . _("Subscribed successfully!") . "
"; - } else if ($success == "unsubscribe") { - echo "" . _("Unsubscribed successfully!") . "
"; - } else if ($success == "delete") { - echo "" . _("Deleted folder successfully!") . "
"; - } else if ($success == "create") { - echo "" . _("Created folder successfully!") . "
"; - } else if ($success == "rename") { - echo "" . _("Renamed successfully!") . "
"; + 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; } - echo " " . _("refresh folder list") . "". - "

\n"; -} else { - echo "
"; + $td_str .= '

'; + + + echo html_tag( 'table', + html_tag( 'tr', + html_tag( 'td', $td_str . + '' . + _("refresh folder list") . '' , + 'center' ) + ) , + 'center', '', 'width="100%" cellpadding="4" cellspacing="0" border="0"' ); } + +echo "\n
"; + $imapConnection = sqimap_login ($username, $key, $imapServerAddress, $imapPort, 0); $boxes = sqimap_mailbox_list($imapConnection); /** CREATING FOLDERS **/ -echo "\n". - "". - "\n"; - -echo "\n"; - -/** RENAMING FOLDERS **/ -echo "". - "\n"; - if ((strtolower($boxes[$i]['unformatted']) != 'inbox') && - ($boxes[$i]['unformatted'] != $trash_folder) && - ($boxes[$i]['unformatted'] != $sent_folder) && - ($boxes[$i]['unformatted'] != $draft_folder)) { - $box = $boxes[$i]['unformatted-dm']; - - $box2 = str_replace(' ', ' ', $boxes[$i]['unformatted-disp']); - if (strtolower($imap_server_type) != 'courier' || strtolower($box) != 'inbox.trash') { - echo "\n"; - } - } - } - echo "\n". - "\n". - "\n"; -} else { - echo _("No folders found") . "

"; -} -$boxes_sub = $boxes; - -echo "\n"; - -/** DELETING FOLDERS **/ -echo ""; -echo "\n"; + echo "\n" + . "\n". + "\n". + "\n"; +} else { + echo _("No folders found") . '

'; +} +$boxes_sub = $boxes; + +echo html_tag( 'tr', + html_tag( 'td', ' ', 'left', $color[4] ) + ) ."\n"; + +/** DELETING FOLDERS **/ +echo html_tag( 'tr', + html_tag( 'td', '' . _("Delete Folder") . '', 'center', $color[9] ) + ) . + html_tag( 'tr' ) . + html_tag( 'td', '', 'center', $color[0] ); + +if ($count_special_folders < count($boxes)) { + echo "\n" + . "\n" + . '\n" + . "\n"; } else { - echo _("No folders found") . "

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

"; } -echo "
". - _("Create Folder"). - "
". +echo html_tag( 'table', '', 'center', '', 'width="70%" cellpadding="4" cellspacing="0" border="0"' ) . + html_tag( 'tr', + html_tag( 'td', '' . _("Create Folder") . '', 'center', $color[9] ) + ) . + html_tag( 'tr' ) . + html_tag( 'td', '', 'center', $color[0] ) . + "
\n". - "
\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 "
 
". - _("Rename a Folder"). - "
"; -if (count($boxes)) { - echo "
\n". - "\n"; +echo "
 
"; -echo _("Delete Folder"); -echo "
"; +echo html_tag( 'tr', + html_tag( 'td', ' ', 'left', $color[4] ) + ) ."\n"; +/** count special folders **/ $count_special_folders = 0; $num_max = 1; if (strtolower($imap_server_type) == "courier" || $move_to_trash) { @@ -155,7 +146,7 @@ if ($move_to_sent) { if ($save_as_draft) { $num_max++; } -for ($p = 0; $p < count($boxes) && $count_special_folders < $num_max; $p++) { +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' && @@ -169,41 +160,74 @@ for ($p = 0; $p < count($boxes) && $count_special_folders < $num_max; $p++) { $count_special_folders++; } + +/** RENAMING FOLDERS **/ +echo html_tag( 'tr', + html_tag( 'td', '' . _("Rename a Folder") . '', 'center', $color[9] ) + ) . + html_tag( 'tr' ) . + html_tag( 'td', '', 'center', $color[0] ); + if ($count_special_folders < count($boxes)) { - echo "
\n"; - echo "\n"; - echo "\n"; - echo "
 
\n"; + +echo html_tag( 'tr', + html_tag( 'td', ' ', 'left', $color[4] ) + ) ."
\n"; + /** UNSUBSCRIBE FOLDERS **/ -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; /** SUBSCRIBE TO FOLDERS **/ -echo "
"; -echo _("Unsubscribe") . "/" . _("Subscribe"); -echo "
\n"; +echo html_tag( 'table', '', 'center', '', 'width="70%" cellpadding="4" cellspacing="0" border="0"' ) . + html_tag( 'tr', + html_tag( 'td', '' . _("Unsubscribe") . '/' . _("Subscribe") . '', 'center', $color[9], 'colspan="2"' ) + ) . + html_tag( 'tr' ) . + 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") && @@ -211,63 +235,69 @@ if ($count_special_folders < count($boxes)) { ($boxes[$i]["unformatted"] != $sent_folder) && ($boxes[$i]["unformatted"] != $draft_folder)) { $box = $boxes[$i]["unformatted-dm"]; - $box2 = str_replace(' ', ' ', $boxes[$i]["unformatted-disp"]); + $box2 = str_replace(' ', ' ', + imap_utf7_decode_local($boxes[$i]["unformatted-disp"])); echo "

\n"; - echo "\n"; - echo "
"; -$imap_stream = sqimap_login ($username, $key, $imapServerAddress, $imapPort, 1); -$boxes_all = sqimap_mailbox_list_all ($imap_stream); +echo html_tag( 'td', '', 'center', $color[0], 'width="50%"' ); +if(!$no_list_for_subscribe) { + $boxes_all = sqimap_mailbox_list_all ($imapConnection); -$box = ""; -$box2 = ""; -for ($i = 0, $q = 0; $i < count($boxes_all); $i++) { + $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] = $boxes_all[$i]["unformatted-disp"]; + $box[$q] = $boxes_all[$i]['unformatted-dm']; + $box2[$q] = imap_utf7_decode_local($boxes_all[$i]['unformatted-disp']); $q++; } -} -sqimap_logout($imap_stream); - -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!") . ''; + } } else { - echo _("No folders were found to subscribe to!") . ""; + /* don't perform the list action -- this is much faster */ + echo "
\n" + . _("Subscribe to:") . '
' + . '' + . '\n" + . "
\n"; } -do_hook("folders_bottom"); +do_hook('folders_bottom'); ?> - @@ -278,4 +308,4 @@ do_hook("folders_bottom"); sqimap_logout($imapConnection); ?> - \ No newline at end of file +