X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Ffolders.php;h=dc708a34a777522ac46566966b08e7418216b712;hb=623662614b34b6f05a5ba6330bc5a624c8e9b731;hp=861ddf0997975ee943f3abdcf2a5b1dfc2b20ece;hpb=e146912692c921160f93dcb6da97dc6246bf95d2;p=squirrelmail.git diff --git a/src/folders.php b/src/folders.php index 861ddf09..dc708a34 100644 --- a/src/folders.php +++ b/src/folders.php @@ -1,155 +1,341 @@ -\n"; - - displayPageHeader($color, "None"); - - echo "\n"; - echo " \n"; - echo "
\n"; - echo _("Folders"); - echo "
\n"; - - $imapConnection = sqimap_login ($username, $key, $imapServerAddress, $imapPort, 0); - $boxes = sqimap_mailbox_list($imapConnection); - - /** DELETING FOLDERS **/ - echo "\n"; - echo ""; - echo "\n"; - } else { - echo _("No mailboxes found") . "

"; - } - - - /** CREATING FOLDERS **/ - echo ""; - echo "
\n"; - - /** RENAMING FOLDERS **/ - echo ""; - echo "\n"; + +echo html_tag( 'tr', + html_tag( 'td', ' ', 'left', $color[4] ) + ) ."\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++; +} +if ($move_to_sent) { + $num_max++; +} +if ($save_as_draft) { + $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++) { + 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; + } +} + + +/** 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 addForm('folders_rename_getname.php') + . "\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 addForm('folders_delete.php') + . "\n" + . '\n" + . "\n"; +} else { + echo _("No folders found") . "

"; +} + +echo html_tag( 'tr', + html_tag( 'td', ' ', 'left', $color[4] ) + ) ."
"; - echo _("Delete Folder"); - echo "
"; - $count_special_folders = 0; - for ($i = 0; $i < count($special_folders); $i++) { - for ($p = 0; $p < count($special_folders); $p++) { - if ($boxes[$i]["unformatted"] == $special_folders[$p]) { - $count_special_folders++; - } - } - } - - if ($count_special_folders < count($boxes)) { - echo "
\n"; - echo "\n"; - echo "\n"; - echo "

"; - echo _("Create Folder"); - echo "
"; - echo "
\n"; - echo "
\n"; - echo _("as a subfolder of"); - echo "
"; - echo "
\n"; - if ($show_contain_subfolders_option) { - echo "  "; - echo _("Let this folder contain subfolders"); - echo "
"; - } - echo "\n"; - echo "

"; - echo _("Rename a Folder"); - echo "
"; - if ($count_special_folders < count($boxes)) { - echo "
\n"; - echo "\n"; + +$show_selected = array(); +$skip_folders = array(); +$server_type = strtolower($imap_server_type); +if ( $server_type == 'courier' ) { + array_push($skip_folders, 'inbox.trash'); + if ( $default_folder_prefix == 'INBOX.' ) { + array_push($skip_folders, 'inbox'); + } +} + +if ( $default_sub_of_inbox == false ) { + echo '\n"; +if ($show_contain_subfolders_option) { + echo '
'. + addCheckBox('contain_subs', FALSE, '1') .'  ' + . _("Let this folder contain subfolders") + . '
'; +} +echo "\n"; +echo "
\n"; + + +/** UNSUBSCRIBE FOLDERS **/ +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 addForm('folders_subscribe.php?method=unsub') + . "\n"; - echo "\n"; - echo "
\n"; - } else { - echo _("No mailboxes found") . "

"; - } + } + } + echo "

\n" + . '\n" + . "\n"; +} else { + echo _("No folders were found to unsubscribe from!") . ''; +} +$boxes_sub = $boxes; + +/** SUBSCRIBE TO FOLDERS **/ +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++) { + $use_folder = true; + for ($p = 0; $p < count ($boxes); $p++) { + if ($boxes_all[$i]['unformatted'] == $boxes[$p]['unformatted']) { + $use_folder = false; + continue; + } else if ($boxes_all[$i]['unformatted-dm'] == $folder_prefix) { + $use_folder = false; + } + } + if ($use_folder == true) { + $box[$q] = htmlspecialchars($boxes_all[$i]['unformatted-dm']); + $box2[$q] = htmlspecialchars(imap_utf7_decode_local($boxes_all[$i]['unformatted-disp'])); + $q++; + } + } + if ($box && $box2) { + echo addForm('folders_subscribe.php?method=sub') + . '

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