X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=functions%2Fpage_header.php;h=bc63eced428808b71ddc765b81c0d652ed2e24f7;hp=c1131462ab0e6c7064e4d641cdc111a591431bad;hb=9f2f6126ab189f1ef4a3e34133b850fc3ff5622b;hpb=96b1b59739f8c572ae3d5206bf34b11ad045406e diff --git a/functions/page_header.php b/functions/page_header.php index c1131462..bc63eced 100644 --- a/functions/page_header.php +++ b/functions/page_header.php @@ -3,7 +3,7 @@ /** * page_header.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. * * Prints the page header (duh) @@ -11,50 +11,88 @@ * $Id$ */ -require_once('../functions/strings.php'); -require_once('../functions/imap_utf7_decode_local.php'); -require_once('../functions/html.php'); -//require_once('../functions/imap_mailbox.php'); +require_once(SM_PATH . 'functions/strings.php'); +require_once(SM_PATH . 'functions/html.php'); +require_once(SM_PATH . 'functions/imap_mailbox.php'); +require_once(SM_PATH . 'functions/global.php'); + /* Always set up the language before calling these functions */ function displayHtmlHeader( $title = 'SquirrelMail', $xtra = '', $do_hook = TRUE ) { + global $squirrelmail_language; - global $theme_css, $custom_css, $base_uri; + if ( !sqgetGlobalVar('base_uri', $base_uri, SQ_SESSION) ) { + global $base_uri; + } + global $theme_css, $custom_css, $pageheader_sent; - echo '' . - "\n\n\n\n"; + echo '' . + "\n\n" . html_tag( 'html' ,'' , '', '', 'lang="'.$squirrelmail_language.'"' ) . "\n\n"; if ( !isset( $custom_css ) || $custom_css == 'none' ) { if ($theme_css != '') { - echo ""; + echo ""; } } else { - echo ''; + echo ''; + } + + if ($squirrelmail_language == 'ja_JP') { + echo "\n"; + echo '' . "\n"; } if ($do_hook) { - do_hook("generic_header"); + do_hook('generic_header'); } - echo "\n$title$xtra\n\n"; -} + echo "\n$title$xtra\n"; + /* work around IE6's scrollbar bug */ + echo << + + -function displayInternalLink($path, $text, $target='') { - global $base_uri; +ECHO; + echo "\n\n\n"; + + /* this is used to check elsewhere whether we should call this function */ + $pageheader_sent = TRUE; +} + +function makeInternalLink($path, $text, $target='') { + sqgetGlobalVar('base_uri', $base_uri, SQ_SESSION); if ($target != '') { $target = " target=\"$target\""; } - echo ''.$text.''; + $hooktext = do_hook_function('internal_link',$text); + if ($hooktext != '') + $text = $hooktext; + return ''.$text.''; +} + +function displayInternalLink($path, $text, $target='') { + echo makeInternalLink($path, $text, $target); } function displayPageHeader($color, $mailbox, $xtra='', $session=false) { - global $delimiter, $hide_sm_attributions, $base_uri, $PHP_SELF, $frame_top, - $compose_new_win, $username, $datadir, $compose_width, $compose_height, - $attachemessages, $session; + global $hide_sm_attributions, $PHP_SELF, $frame_top, + $compose_new_win, $compose_width, $compose_height, + $attachemessages, $provider_name, $provider_uri, + $javascript_on, $default_use_mdn, $mdn_user_support; + sqgetGlobalVar('base_uri', $base_uri, SQ_SESSION ); + sqgetGlobalVar('delimiter', $delimiter, SQ_SESSION ); $module = substr( $PHP_SELF, ( strlen( $PHP_SELF ) - strlen( $base_uri ) ) * -1 ); if ($qmark = strpos($module, '?')) { $module = substr($module, 0, $qmark); @@ -63,127 +101,146 @@ function displayPageHeader($color, $mailbox, $xtra='', $session=false) { $frame_top = '_top'; } - if ($session != false) { - $compose_uri = $base_uri.'src/compose.php?mailbox='. urlencode($mailbox).'&attachedmessages=true&session='."$session"; + if ($session) { + $compose_uri = $base_uri.'src/compose.php?mailbox='.urlencode($mailbox).'&attachedmessages=true&session='."$session"; } else { $compose_uri = $base_uri.'src/compose.php?newmessage=1'; $session = 0; } - - switch ( $module ) { - case 'src/read_body.php': - $js =''; - if ($compose_new_win == '1') { - if (!preg_match("/^[0-9]{3,4}$/", $compose_width)) { - $compose_width = '640'; + + if($javascript_on) { + + switch ( $module ) { + case 'src/read_body.php': + $js =''; + + // compose in new window code + if ($compose_new_win == '1') { + if (!preg_match("/^[0-9]{3,4}$/", $compose_width)) { + $compose_width = '640'; + } + if (!preg_match("/^[0-9]{3,4}$/", $compose_height)) { + $compose_height = '550'; + } + $js .= "function comp_in_new(comp_uri) {\n". + " if (!comp_uri) {\n". + ' comp_uri = "'.$compose_uri."\";\n". + ' }'. "\n". + ' var newwin = window.open(comp_uri' . + ', "_blank",'. + '"width='.$compose_width. ',height='.$compose_height. + ',scrollbars=yes,resizable=yes");'."\n". + "}\n\n"; + } + + // javascript for sending read receipts + if($default_use_mdn && $mdn_user_support) { + $js .= 'function sendMDN() {'."\n". + " mdnuri=window.location+'&sendreceipt=1'; ". + "var newwin = window.open(mdnuri,'right');". + "\n}\n\n"; } - if (!preg_match("/^[0-9]{3,4}$/", $compose_height)) { - $compose_height = '550'; + + // if any of the above passes, add the JS tags too. + if($js) { + $js = "\n".'\n"; } - $js .= "\n".'\n"; - - } - displayHtmlHeader ('Squirrelmail', $js); - $onload = $xtra; - break; - case 'src/compose.php': - $js = '\n"; - $onload = "onLoad=\"checkForm();\""; - displayHtmlHeader ('Squirrelmail', $js); - break; - - default: - $js = '\n"; + $onload = 'onload="checkForm();"'; + displayHtmlHeader ('SquirrelMail', $js); + break; + + default: + $js = '\n"; + } + $js .= "// -->\n". "\n"; + $onload = 'onload="checkForm();"'; + displayHtmlHeader ('SquirrelMail', $js); + break; - $onload = "onLoad=\"checkForm();\""; - displayHtmlHeader ('Squirrelmail', $js); - break; - + } + } else { + /* do not use JavaScript */ + displayHtmlHeader ('SquirrelMail'); + $onload = ''; } echo "\n\n"; @@ -208,87 +265,101 @@ function displayPageHeader($color, $mailbox, $xtra='', $session=false) { echo "\n" . " \n" . html_tag( 'tr', '', '', $color[4] ) ."\n" - . html_tag( 'td', '', 'left' ) ."\n"; + . ($hide_sm_attributions ? html_tag( 'td', '', 'left', '', 'colspan="2"' ) + : html_tag( 'td', '', 'left' ) ) + . "\n"; $urlMailbox = urlencode($mailbox); - if ($compose_new_win == '1') { - echo "". _("Compose"). ''; - } - else { - displayInternalLink ("src/compose.php?mailbox=$urlMailbox", _("Compose"), 'right'); - } + echo makeComposeLink('src/compose.php?mailbox='.$urlMailbox); echo "  \n"; - displayInternalLink ("src/addressbook.php", _("Addresses"), 'right'); + displayInternalLink ('src/addressbook.php', _("Addresses"), 'right'); echo "  \n"; - displayInternalLink ("src/folders.php", _("Folders"), 'right'); + displayInternalLink ('src/folders.php', _("Folders"), 'right'); echo "  \n"; - displayInternalLink ("src/options.php", _("Options"), 'right'); + displayInternalLink ('src/options.php', _("Options"), 'right'); echo "  \n"; displayInternalLink ("src/search.php?mailbox=$urlMailbox", _("Search"), 'right'); echo "  \n"; - displayInternalLink ("src/help.php", _("Help"), 'right'); + displayInternalLink ('src/help.php', _("Help"), 'right'); echo "  \n"; - do_hook("menuline"); + do_hook('menuline'); + + echo " \n"; - echo " \n" - . html_tag( 'td', '', 'right' ) ."\n"; - echo ($hide_sm_attributions ? ' ' : - 'SquirrelMail'); - echo "\n". - " \n". - "\n\n"; + if (!$hide_sm_attributions) + { + echo html_tag( 'td', '', 'right' ) ."\n"; + if (!isset($provider_uri)) $provider_uri= 'http://www.squirrelmail.org/'; + if (!isset($provider_name)) $provider_name= 'SquirrelMail'; + echo ''.$provider_name.''; + echo "\n"; + } + echo " \n". + "
\n\n"; } /* blatently copied/truncated/modified from the above function */ function compose_Header($color, $mailbox) { - global $delimiter, $hide_sm_attributions, $base_uri, $PHP_SELF, $frame_top, $compose_new_win; + global $javascript_on; + /* + * Locate the first displayable form element (only when JavaScript on) + */ + if($javascript_on) { + global $delimiter, $base_uri, $PHP_SELF, $data_dir, $username; - $module = substr( $PHP_SELF, ( strlen( $PHP_SELF ) - strlen( $base_uri ) ) * -1 ); - if (!isset($frame_top)) { - $frame_top = '_top'; - } + $module = substr( $PHP_SELF, ( strlen( $PHP_SELF ) - strlen( $base_uri ) ) * -1 ); - /* - Locate the first displayable form element - */ - switch ( $module ) { - case 'src/search.php': - $pos = getPref($data_dir, $username, 'search_pos', 0 ) - 1; - $onload = "onLoad=\"document.forms[$pos].elements[2].focus();\""; - displayHtmlHeader (_("Compose")); - break; - default: - $js = '\n"; - $onload = "onLoad=\"checkForm();\""; - displayHtmlHeader (_("Compose"), $js); - break; - + "if( pos >= 0 ) {\n". + "document.forms[i-1].elements[pos].focus();\n". + "}\n". + "}\n"; + $js .= "// -->\n". + "\n"; + $onload = 'onload="checkForm();"'; + displayHtmlHeader (_("Compose"), $js); + break; + } + } else { + /* javascript off */ + displayHtmlHeader(_("Compose")); + $onload = ''; } echo "\n\n"; } + ?>