X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=src%2Fwebmail.php;h=cdd66223fd5247f0a91258a673b4bea1ecfdb6b4;hb=2878b00ba5a908f5ca4b3d6e7d00c5bfb6618cc8;hp=37ac05da50d859df448deccd3adb06a3d5a25262;hpb=7b7ce8c591a0c5db98cfdea789f2d72a3bbaff3c;p=squirrelmail.git diff --git a/src/webmail.php b/src/webmail.php index 37ac05da..cdd66223 100644 --- a/src/webmail.php +++ b/src/webmail.php @@ -1,110 +1,121 @@ ', - $color[8], $color[4], $color[7], $color[7], $color[7]); - plain_error_message(_("You need a valid user and password to access this page!") - . "
" - . _("Click here to log back in.") . ".", $color); - echo ''; - exit; - } +sqgetGlobalVar('right_frame', $right_frame, SQ_GET); - if (!isset($strings_php)) - include ('../functions/strings.php'); - include ('../config/config.php'); - include ('../functions/prefs.php'); - include ('../functions/imap.php'); - if (!isset($plugin_php)) - include ('../functions/plugin.php'); - if (!isset($auth_php)) - include ('../functions/auth.php'); +if(!sqgetGlobalVar('mailtodata', $mailtodata)) { + $mailtourl = 'mailtodata='.urlencode($mailtodata); +} else { + $mailtourl = ''; +} - include ('../src/load_prefs.php'); +// Determine the size of the left frame +$left_size = getPref($data_dir, $username, 'left_size'); +if ($left_size == "") { + if (isset($default_left_size)) { + $left_size = $default_left_size; + } + else { + $left_size = 200; + } +} - // We'll need this to later have a noframes version - // - // Check if the user has a language preference, but no cookie. - // Send him a cookie with his language preference, if there is - // such discrepancy. - $my_language=getPref($data_dir, $username, "language"); - if ($my_language != $squirrelmail_language) - setcookie('squirrelmail_language', $my_language, time()+2592000); +// Determine where the navigation frame should be +$location_of_bar = getPref($data_dir, $username, 'location_of_bar'); +if (isset($languages[$squirrelmail_language]['DIR']) && + strtolower($languages[$squirrelmail_language]['DIR']) == 'rtl') { + $temp_location_of_bar = 'right'; +} else { + $temp_location_of_bar = 'left'; +} +if ($location_of_bar == '') { + $location_of_bar = $temp_location_of_bar; +} - set_up_language(getPref($data_dir, $username, 'language')); +// Determine the main frame URL +/* + * There are three ways to call webmail.php + * 1. webmail.php + * - This just loads the default entry screen. + * 2. webmail.php?right_frame=right_main.php&sort=X&startMessage=X&mailbox=XXXX + * - This loads the frames starting at the given values. + * 3. webmail.php?right_frame=folders.php + * - Loads the frames with the Folder options in the right frame. + * + * This was done to create a pure HTML way of refreshing the folder list since + * we would like to use as little Javascript as possible. + * + * The test for // should catch any attempt to include off-site webpages into + * our frameset. + */ +if (empty($right_frame) || (strpos(urldecode($right_frame), '//') !== false)) { + $right_frame = ''; +} +if ( strpos($right_frame,'?') ) { + $right_frame_file = substr($right_frame,0,strpos($right_frame,'?')); +} else { + $right_frame_file = $right_frame; +} +switch($right_frame) { + case 'right_main.php': + $right_frame_url = "right_main.php?mailbox=".urlencode($mailbox) + . (!empty($sort)?"&sort=$sort":'') + . (!empty($startMessage)?"&startMessage=$startMessage":''); + break; + case 'options.php': + $right_frame_url = 'options.php'; + break; + case 'folders.php': + $right_frame_url = 'folders.php'; + break; + case 'compose.php': + $right_frame_url = 'compose.php?' . $mailtourl; + break; + case '': + $right_frame_url = 'right_main.php'; + break; + default: + $right_frame_url = urlencode($right_frame); + break; +} - echo "\n"; - echo ''; - echo $org_title; - echo ''; - - $bar_size = $left_size; - - if ($location_of_bar == 'right') - { - echo ""; - } else { - echo ""; - } +$oErrorHandler->setDelayedErrors(true); -/** - There are three ways to call webmail.php - 1. webmail.php - - This just loads the default entry screen. - 2. webmail.php?right_frame=right_main.php&sort=X&startMessage=X&mailbox=XXXX - - This loads the frames starting at the given values. - 3. webmail.php?right_frame=folders.php - - Loads the frames with the Folder options in the right frame. +$oTemplate->assign('nav_size', $left_size); +$oTemplate->assign('nav_on_left', $location_of_bar=='left'); +$oTemplate->assign('right_frame_url', $right_frame_url); - This was done to create a pure HTML way of refreshing the folder list since - we would like to use as little Javascript as possible. -**/ - if (!isset($right_frame)) $right_frame = ""; +do_hook('webmail_top', $null); - if ($right_frame == 'right_main.php') { - $urlMailbox = urlencode($mailbox); - $right_frame_url = "right_main.php?mailbox=$urlMailbox&sort=$sort&startMessage=$startMessage"; - } else if ($right_frame == 'options.php') { - $right_frame_url = 'options.php'; - } else if ($right_frame == 'folders.php') { - $right_frame_url = 'folders.php'; - } else { - if (!isset($just_logged_in)) $just_logged_in = 1; - $right_frame_url = "right_main.php?just_logged_in=$just_logged_in"; - } +displayHtmlHeader($org_title, '', false, true); - if ($location_of_bar == 'right') - { - echo ""; - echo ''; - } - else - { - echo ''; - echo ""; - } +$oTemplate->display('webmail.tpl'); -?> - -