X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=functions%2Fpage_header.php;h=c7e0fb650a8f28997888da32838c36ad161bae2e;hb=a28de4194b8f41675c0034aeabee86ab35a8c00f;hp=c3a95f49e475fc746b2e1367c511b0ffeb011cb1;hpb=5bbe20e463dc798b73953224f54fd9bbeb5dad29;p=squirrelmail.git diff --git a/functions/page_header.php b/functions/page_header.php index c3a95f49..c7e0fb65 100644 --- a/functions/page_header.php +++ b/functions/page_header.php @@ -1,111 +1,373 @@ '; - echo "\n\n"; - echo "\n"; - echo "\n"; - if ($theme_css != "") { - printf ('', - $theme_css); - echo "\n"; - } - - do_hook ("generic_header"); - - echo "$title"; - echo "\n\n"; - } - - function displayInternalLink ($path, $text, $target="") { - global $base_uri; - - if ($target != "") - $target = " target=\"$target\""; - - echo ''.$text.''; - } - - function displayPageHeader($color, $mailbox) { - displayHtmlHeader ($color); - - printf('', - $color[8], $color[4], $color[7], $color[7], $color[7]); - echo "\n\n"; - - /** Here is the header and wrapping table **/ - $shortBoxName = readShortMailboxName($mailbox, "."); - $shortBoxName = stripslashes($shortBoxName); - echo "\n"; - echo " \n"; - echo " \n"; - echo " \n"; - echo "
\n"; - displayInternalLink ("src/signout.php", _("Sign Out"), "_top"); - echo " \n"; - echo "
" . _("Current Folder: ") . "$shortBoxName 
\n"; - echo "
\n\n"; - echo "\n"; - echo " \n"; - echo " \n"; - echo " \n"; - echo "
\n"; - $urlMailbox = $mailbox; - displayInternalLink ("src/compose.php?mailbox=$urlMailbox", _("Compose"), "right"); - echo "  \n"; - displayInternalLink ("src/addressbook.php", _("Addresses"), "right"); - echo "  \n"; - displayInternalLink ("src/folders.php", _("Folders"), "right"); - echo "  \n"; - displayInternalLink ("src/options.php", _("Options"), "right"); - echo "  \n"; - displayInternalLink ("src/webmail.php?right_frame=help.php", _("Help"), "Help Me!"); - echo "  \n"; - - do_hook("menuline"); - - echo " \n"; - echo " SquirrelMail\n"; - echo "
\n\n"; - } -?> + +/** + * page_header.php + * + * Prints the page header (duh) + * + * @copyright © 1999-2009 The SquirrelMail Project Team + * @license http://opensource.org/licenses/gpl-license.php GNU Public License + * @version $Id$ + * @package squirrelmail + */ + +/** Include required files from SM */ +include_once(SM_PATH . 'functions/imap_mailbox.php'); + +/** + * Output a SquirrelMail page header, from to + * Always set up the language before calling these functions. + * + * Since 1.5.1 function sends http headers. Function should be called + * before any output is started. + * @param string title the page title, default SquirrelMail. + * @param string xtra extra HTML to insert into the header + * @param bool do_hook whether to execute hooks, default true + * @param bool frames generate html frameset doctype (since 1.5.1) + * @return void + */ +function displayHtmlHeader( $title = 'SquirrelMail', $xtra = '', $do_hook = TRUE, $frames = FALSE ) { + global $squirrelmail_language, $sTemplateID, $oErrorHandler, $oTemplate; + + if ( !sqgetGlobalVar('base_uri', $base_uri, SQ_SESSION) ) { + global $base_uri; + } + global $custom_css, $pageheader_sent, $theme, $theme_default, $text_direction, + $default_fontset, $chosen_fontset, $default_fontsize, $chosen_fontsize, + $chosen_theme, $chosen_theme_path, $user_themes, $user_theme_default; + + /* add no cache headers here */ +//FIXME: should change all header() calls in SM core to use $oTemplate->header()!! + $oTemplate->header('Pragma: no-cache'); // http 1.0 (rfc1945) + $oTemplate->header('Cache-Control: private, no-cache, no-store'); // http 1.1 (rfc2616) + + // don't show version as a security measure + //$oTemplate->header('X-Powered-By: SquirrelMail/' . SM_VERSION, FALSE); + $oTemplate->header('X-Powered-By: SquirrelMail', FALSE); + + $oTemplate->assign('frames', $frames); + $oTemplate->assign('lang', $squirrelmail_language); + + $header_tags = ''; + + $header_tags .= "\n"; + + $used_fontset = (!empty($chosen_fontset) ? $chosen_fontset : $default_fontset); + $used_fontsize = (!empty($chosen_fontsize) ? $chosen_fontsize : $default_fontsize); + $used_theme = !isset($chosen_theme) && $user_theme_default != 'none' && is_dir($chosen_theme) && is_readable($chosen_theme)? $user_themes[$user_theme_default]['PATH'].'/default.css' : $chosen_theme_path; + + /** + * Stylesheets are loaded in the following order: + * 1) All stylesheets provided by the template. Normally, these are + * stylsheets in templates/