X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=functions%2Fpage_header.php;h=37d6c7dd1d6128333bb6a05fea058ddfc39168ab;hb=bfa045d3d871600c3d735bc34ad8bb75594f5cdd;hp=b28021692e08dd0761024abffaf6a43d0146e30c;hpb=0768773669776e69bc394f265dbb300584c33a29;p=squirrelmail.git
diff --git a/functions/page_header.php b/functions/page_header.php
index b2802169..37d6c7dd 100644
--- a/functions/page_header.php
+++ b/functions/page_header.php
@@ -3,83 +3,429 @@
/**
* page_header.php
*
- * Copyright (c) 1999-2002 The SquirrelMail Project Team
+ * Copyright (c) 1999-2005 The SquirrelMail Project Team
* Licensed under the GNU GPL. For full terms see the file COPYING.
*
* Prints the page header (duh)
*
- * $Id$
+ * @version $Id$
+ * @package squirrelmail
*/
-require_once('../functions/strings.php');
+/** Include required files from SM */
+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 ) {
+/**
+ * Output a SquirrelMail page header, from to
+ * Always set up the language before calling these functions.
+ *
+ * @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;
- 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";
+ if ($frames) {
+ echo '';
+ } else {
+ echo '';
+ }
+ echo "\n\n" . html_tag( 'html' ,'' , '', '', 'lang="'.$squirrelmail_language.'"' ) . "\n\n";
+ /*
+ * Add closing / to link and meta elements only after switching to xhtml 1.0 Transitional.
+ * It is not compatible with html 4.01 Transitional
+ */
if ( !isset( $custom_css ) || $custom_css == 'none' ) {
if ($theme_css != '') {
- echo "";
+ echo "";
}
} else {
- echo '';
}
-
- echo "\n$title$xtra\n\n";
-}
-function displayInternalLink($path, $text, $target='') {
- global $base_uri;
+ if ($squirrelmail_language == 'ja_JP') {
+ /*
+ * force correct detection of charset, when browser does not follow
+ * http content-type and tries to detect charset from page content.
+ * Shooting of browser's creator can't be implemented in php.
+ * We might get rid of it, if we follow http://www.w3.org/TR/japanese-xml/
+ * recommendations and switch to unicode.
+ */
+ echo "\n";
+ echo '' . "\n";
+ }
+
+ if ($do_hook) {
+ do_hook('generic_header');
+ }
+
+ echo "\n$title$xtra\n";
+
+ /* work around IE6's scrollbar bug */
+ echo <<
+
+
+
+ECHO;
+
+ echo "\n\n\n";
+ /* this is used to check elsewhere whether we should call this function */
+ $pageheader_sent = TRUE;
+}
+
+/**
+ * Given a path to a SquirrelMail file, return a HTML link to it
+ *
+ * @param string path the SquirrelMail file to link to
+ * @param string text the link text
+ * @param string target the target frame for this link
+ */
+function makeInternalLink($path, $text, $target='') {
+ sqgetGlobalVar('base_uri', $base_uri, SQ_SESSION);
if ($target != '') {
$target = " target=\"$target\"";
}
- echo ''.$text.'';
+ // This is an inefficient hook and is only used by
+ // one plugin that still needs to patch this code,
+ // plus if we are templat-izing SM, visual hooks
+ // are not needed. However, I am leaving the code
+ // here just in case we find a good (non-visual?)
+ // use for the internal_link hook.
+ //
+ //$hooktext = do_hook_function('internal_link',$text);
+ //if ($hooktext != '')
+ // $text = $hooktext;
+
+ return ''.$text.'';
}
-function displayPageHeader($color, $mailbox, $xtra='') {
+/**
+ * Same as makeInternalLink, but echoes it too
+ */
+function displayInternalLink($path, $text, $target='') {
+ echo makeInternalLink($path, $text, $target);
+}
- global $delimiter, $hide_sm_attributions, $base_uri, $PHP_SELF, $frame_top,
- $compose_new_win, $username, $datadir, $compose_width, $compose_height;
+/**
+ * Outputs a complete SquirrelMail page header, starting with and
+ * including the default menu bar. Uses displayHtmlHeader and takes
+ * JavaScript and locale settings into account.
+ *
+ * @param array color the array of theme colors
+ * @param string mailbox the current mailbox name to display
+ * @param string xtra extra html code to add
+ * @param bool session
+ * @return void
+ */
+function displayPageHeader($color, $mailbox, $xtra='', $session=false) {
+
+ global $hide_sm_attributions, $PHP_SELF, $frame_top,
+ $compose_new_win, $compose_width, $compose_height,
+ $provider_name, $provider_uri, $startMessage,
+ $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);
+ }
if (!isset($frame_top)) {
$frame_top = '_top';
}
- /*
- Locate the first displayable form element
- */
- switch ( $module ) {
- default:
- $js = '\n";
+ }
+
+ displayHtmlHeader ('SquirrelMail', $js);
+ $onload = $xtra;
+ break;
+ case 'src/compose.php':
+ $js = '\n";
+ $onload = 'onload="checkForm();"';
+ displayHtmlHeader ('SquirrelMail', $js);
+ break;
+
+ case 'src/right_main.php':
+ global $fancy_index_highlite;
+ if (!$fancy_index_highlite) {
+ $js = '';
+ } else //{ putting braces around this block creats strange PHP errors
+ // following code graciously borrowed from
+ // phpMyAdmin project at:
+ // http://www.phpmyadmin.net
+ $js = << exits
+ if ((thePointerColor == '' && theMarkColor == '')
+ || typeof(theRow.style) == 'undefined') {
+ return false;
+ }
+
+ // 2. Gets the current row and exits if the browser can't get it
+ if (typeof(document.getElementsByTagName) != 'undefined') {
+ theCells = theRow.getElementsByTagName('td');
+ }
+ else if (typeof(theRow.cells) != 'undefined') {
+ theCells = theRow.cells;
+ }
+ else {
+ return false;
+ }
+
+ // 3. Gets the current color...
+ var rowCellsCnt = theCells.length;
+ var domDetect = null;
+ var currentColor = null;
+ var newColor = null;
+ // 3.1 ... with DOM compatible browsers except Opera that does not return
+ // valid values with "getAttribute"
+ if (typeof(window.opera) == 'undefined'
+ && typeof(theCells[0].getAttribute) != 'undefined') {
+ currentColor = theCells[0].getAttribute('bgcolor');
+ domDetect = true;
+ }
+ // 3.2 ... with other browsers
+ else {
+ currentColor = theCells[0].style.backgroundColor;
+ domDetect = false;
+ } // end 3
+
+ // 3.3 ... Opera changes colors set via HTML to rgb(r,g,b) format so fix it
+ if (currentColor.indexOf("rgb") >= 0)
+ {
+ var rgbStr = currentColor.slice(currentColor.indexOf('(') + 1,
+ currentColor.indexOf(')'));
+ var rgbValues = rgbStr.split(",");
+ currentColor = "#";
+ var hexChars = "0123456789ABCDEF";
+ for (var i = 0; i < 3; i++)
+ {
+ var v = rgbValues[i].valueOf();
+ currentColor += hexChars.charAt(v/16) + hexChars.charAt(v%16);
+ }
+ }
+
+ // 4. Defines the new color
+ // 4.1 Current color is the default one
+ if (currentColor == ''
+ || currentColor.toLowerCase() == theDefaultColor.toLowerCase()) {
+ if (theAction == 'over' && thePointerColor != '') {
+ newColor = thePointerColor;
+ }
+ else if (theAction == 'click' && theMarkColor != '') {
+ newColor = theMarkColor;
+ marked_row[theRowNum] = true;
+ // deactivated onclick marking of the checkbox because it's also executed
+ // when an action (clicking on the checkbox itself) on a single item is
+ // performed. Then the checkbox would get deactived, even though we need
+ // it activated. Maybe there is a way to detect if the row was clicked,
+ // and not an item therein...
+ //document.getElementById('msg[' + theRowNum + ']').checked = true;
+ }
+ }
+ // 4.1.2 Current color is the pointer one
+ else if (currentColor.toLowerCase() == thePointerColor.toLowerCase()
+ && (typeof(marked_row[theRowNum]) == 'undefined' || !marked_row[theRowNum])) {
+ if (theAction == 'out') {
+ newColor = theDefaultColor;
+ }
+ else if (theAction == 'click' && theMarkColor != '') {
+ newColor = theMarkColor;
+ marked_row[theRowNum] = true;
+ //document.getElementById('msg[' + theRowNum + ']').checked = true;
+ }
+ }
+ // 4.1.3 Current color is the marker one
+ else if (currentColor.toLowerCase() == theMarkColor.toLowerCase()) {
+ if (theAction == 'click') {
+ newColor = (thePointerColor != '')
+ ? thePointerColor
+ : theDefaultColor;
+ marked_row[theRowNum] = (typeof(marked_row[theRowNum]) == 'undefined' || !marked_row[theRowNum])
+ ? true
+ : null;
+ //document.getElementById('msg[' + theRowNum + ']').checked = false;
+ }
+ } // end 4
+
+ // 5. Sets the new color...
+ if (newColor) {
+ var c = null;
+ // 5.1 ... with DOM compatible browsers except Opera
+ if (domDetect) {
+ for (c = 0; c < rowCellsCnt; c++) {
+ theCells[c].setAttribute('bgcolor', newColor, 0);
+ } // end for
+ }
+ // 5.2 ... with other browsers
+ else {
+ for (c = 0; c < rowCellsCnt; c++) {
+ theCells[c].style.backgroundColor = newColor;
+ }
+ }
+ } // end 5
+
+ return true;
+} // end of the 'setPointer()' function
+EOS;
+ //} putting braces around this block creats strange PHP errors
+ $js = "\n".'\n";
- $onload = "onLoad=\"checkForm();\"";
- displayHtmlHeader ('Squirrelmail', $js);
- break;
+ $js .= $xtra . "\n\n// -->\n\n";
+ $onload = '';
+ displayHtmlHeader ('SquirrelMail', $js);
+ break;
+
+ default:
+ $js = '\n";
+
+ $onload = 'onload="checkForm();"';
+ displayHtmlHeader ('SquirrelMail', $js);
+ break;
+ }
+ } else {
+ /* do not use JavaScript */
+ displayHtmlHeader ('SquirrelMail');
+ $onload = '';
}
- echo "\n\n";
+ echo "\n\n";
/** Here is the header and wrapping table **/
- $shortBoxName = readShortMailboxName($mailbox, $delimiter);
+ $shortBoxName = htmlspecialchars(imap_utf7_decode_local(
+ readShortMailboxName($mailbox, $delimiter)));
if ( $shortBoxName == 'INBOX' ) {
$shortBoxName = _("INBOX");
}
- echo "\n"
- . "\n"
- . " \n"
- . " \n";
+ echo "\n"
+ . html_tag( 'table', '', '', $color[4], 'border="0" width="100%" cellspacing="0" cellpadding="2"' ) ."\n"
+ . html_tag( 'tr', '', '', $color[9] ) ."\n"
+ . html_tag( 'td', '', 'left' ) ."\n";
if ( $shortBoxName <> '' && strtolower( $shortBoxName ) <> 'none' ) {
- echo ' ' . _("Current Folder") . ": $shortBoxName \n";
+ echo ' ' . _("Current Folder") . ": $shortBoxName \n";
} else {
echo ' ';
}
- echo " | \n"
- . ' ';
+ echo " | \n"
+ . html_tag( 'td', '', 'right' ) ."\n";
displayInternalLink ('src/signout.php', _("Sign Out"), $frame_top);
- echo "\n"
- . "
\n"
- . " \n"
- . " \n";
+ echo " | \n"
+ . "
\n"
+ . html_tag( 'tr', '', '', $color[4] ) ."\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.'&startMessage='.$startMessage);
echo " \n";
- displayInternalLink ("src/addressbook.php", _("Addresses"), 'right');
+ displayInternalLink ('src/addressbook.php', _("Addresses"));
echo " \n";
- displayInternalLink ("src/folders.php", _("Folders"), 'right');
+ displayInternalLink ('src/folders.php', _("Folders"));
echo " \n";
- displayInternalLink ("src/options.php", _("Options"), 'right');
+ displayInternalLink ('src/options.php', _("Options"));
echo " \n";
- displayInternalLink ("src/search.php?mailbox=$urlMailbox", _("Search"), 'right');
+ displayInternalLink ("src/search.php?mailbox=$urlMailbox", _("Search"));
echo " \n";
- displayInternalLink ("src/help.php", _("Help"), 'right');
+ displayInternalLink ('src/help.php', _("Help"));
echo " \n";
- do_hook("menuline");
+ do_hook('menuline');
- echo " \n ";
- echo ($hide_sm_attributions ? ' ' :
- 'SquirrelMail');
- echo " | \n".
- " \n".
- "
\n\n";
+ echo " \n";
+
+ if (!$hide_sm_attributions)
+ {
+ echo html_tag( 'td', '', 'right' ) ."\n";
+ if (empty($provider_uri)) {
+ echo 'SquirrelMail';
+ } else {
+ if (empty($provider_name)) $provider_name= 'SquirrelMail';
+ echo ''.$provider_name.'';
+ }
+ echo "\n";
+ }
+ echo " \n".
+ "
\n\n";
}
-/* blatently copied/truncated/modified from the above function */
+/**
+ * Blatantly copied/truncated/modified from displayPageHeader.
+ * Outputs a page header specifically for the compose_in_new popup window
+ *
+ * @param array color the array of theme colors
+ * @param string mailbox the current mailbox name to display
+ * @return void
+ */
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 $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";
+ echo "\n\n";
}
+
?>