X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=functions%2Fdisplay_messages.php;h=470a5d359ab0733a8ef1d0c7707a247b538e4508;hb=10bf80c009d938fc0cf85a70d0a6b3834365b146;hp=090fc062ad04902be7fa8de8d43fcc5fecc989f6;hpb=36ec6865435cae4ac4fc916b89ff0dfd7569cfb9;p=squirrelmail.git diff --git a/functions/display_messages.php b/functions/display_messages.php index 090fc062..470a5d35 100644 --- a/functions/display_messages.php +++ b/functions/display_messages.php @@ -3,22 +3,31 @@ /** * display_messages.php * - * Copyright (c) 1999-2003 The SquirrelMail Project Team - * Licensed under the GNU GPL. For full terms see the file COPYING. - * * This contains all messages, including information, error, and just * about any other message you can think of. * - * $Id$ + * @copyright © 1999-2005 The SquirrelMail Project Team + * @license http://opensource.org/licenses/gpl-license.php GNU Public License + * @version $Id$ + * @package squirrelmail + */ + +/** @ignore */ +if (! defined('SM_PATH')) define('SM_PATH','../'); + +/** + * including plugin functions */ +include_once(SM_PATH . 'functions/plugin.php'); /** - * Find out where squirrelmail lives and try to be smart about it. - * The only problem would be when squirrelmail lives in directories + * Find out where SquirrelMail lives and try to be smart about it. + * The only problem would be when SquirrelMail lives in directories * called "src", "functions", or "plugins", but people who do that need * to be beaten with a steel pipe anyway. * - * @return the base uri of squirrelmail installation. + * @return string the base uri of SquirrelMail installation. + * @since 1.2.6 */ function sqm_baseuri(){ global $base_uri, $PHP_SELF; @@ -34,45 +43,48 @@ function sqm_baseuri(){ return $base_uri; } -function error_username_password_incorrect() { - global $frame_top, $color; - /* XXX: Should really not start the HTML before this, or close off more - cleanly. */ - - if (!isset($frame_top)) { - $frame_top = '_top'; - } - $string = ''. - _("Unknown user or password incorrect.") . - ''. - '' . _("Click here to try again") . - '.'. - ''; - error_box($string,$color); -echo ''; -} - +/** + * Displays error message and URL to message listing + * @param string $message error message + * @param string $mailbox mailbox name + * @param integer $sort sort order + * @param integer $startMessage first message + * @param array $color color theme + * @since 1.0 + */ function error_message($message, $mailbox, $sort, $startMessage, $color) { $urlMailbox = urlencode($mailbox); - - $string = '' . $message . ''."\n". - ''. - '" . - sprintf (_("Click here to return to %s"), $mailbox) . - ''; + $string = '' . $message . ''. + ''. + '". + sprintf (_("Click here to return to %s"), + strtoupper($mailbox) == 'INBOX' ? _("INBOX") : imap_utf7_decode_local($mailbox)). + ''; error_box($string, $color); } +/** + * Displays error message + * @param string $message error message + * @param array $color color theme + * @since 1.0 + */ function plain_error_message($message, $color) { error_box($message, $color); } +/** + * Displays error when user is logged out + * + * Error strings can be overriden by logout_error hook + * @param string $errString error message + * @param string $errTitle title of page with error message + * @since 1.2.6 + */ function logout_error( $errString, $errTitle = '' ) { global $frame_top, $org_logo, $org_name, $org_logo_width, $org_logo_height, - $hide_sm_attributions, $version, $squirrelmail_language; + $hide_sm_attributions, $version, $squirrelmail_language, + $color, $theme, $theme_default; $base_uri = sqm_baseuri(); @@ -84,63 +96,95 @@ function logout_error( $errString, $errTitle = '' ) { /* Display width and height like good little people */ $width_and_height = ''; if (isset($org_logo_width) && is_numeric($org_logo_width) && $org_logo_width>0) { - $width_and_height = " WIDTH=\"$org_logo_width\""; + $width_and_height = " width=\"$org_logo_width\""; } if (isset($org_logo_height) && is_numeric($org_logo_height) && $org_logo_height>0) { - $width_and_height .= " HEIGHT=\"$org_logo_height\""; + $width_and_height .= " height=\"$org_logo_height\""; } if (!isset($frame_top) || $frame_top == '' ) { $frame_top = '_top'; } + // load default theme if possible + if (!isset($color) && @file_exists($theme[$theme_default]['PATH'])) + @include ($theme[$theme_default]['PATH']); + if ( !isset( $color ) ) { $color = array(); - $color[0] = '#DCDCDC'; /* light gray TitleBar */ + $color[0] = '#dcdcdc'; /* light gray TitleBar */ $color[1] = '#800000'; /* red */ - $color[2] = '#CC0000'; /* light red Warning/Error Messages */ - $color[4] = '#FFFFFF'; /* white Normal Background */ - $color[7] = '#0000CC'; /* blue Links */ + $color[2] = '#cc0000'; /* light red Warning/Error Messages */ + $color[4] = '#ffffff'; /* white Normal Background */ + $color[7] = '#0000cc'; /* blue Links */ $color[8] = '#000000'; /* black Normal text */ } + list($junk, $errString, $errTitle) = do_hook('logout_error', $errString, $errTitle); + if ( $errTitle == '' ) { $errTitle = $errString; } set_up_language($squirrelmail_language, true); - displayHtmlHeader( $errTitle, '', false ); + displayHtmlHeader( $org_name.' - '.$errTitle, '', false ); - echo "\n\n" . - '
'; + echo '\n\n". + '
'; if (isset($org_logo) && ($org_logo != '')) { - echo "\""
\n"; + echo ''.sprintf(_(
\n"; } echo ( $hide_sm_attributions ? '' : - '' . sprintf (_("SquirrelMail version %s"), $version) . "
\n". - ' ' . _("By the SquirrelMail Development Team") . "
\n" ) . - "
". - "". - "'. - ''. - "'. - '
". - "" . _("ERROR") . - '
' . $errString . '
". - "". - '' . - _("Go to the login page") . "". - '
'; + '' . _("SquirrelMail Webmail Application") . '
'. + _("By the SquirrelMail Project Team") . "
\n" ). + ''. + '
'. + ''. + ''. + ''. + ''. + '
'. + '' . _("ERROR") . ''. + '
' . $errString . '
'. + ''. + ''. + _("Go to the login page") . '
'; } +/** + * Displays error message + * + * Since 1.4.1 function checks if page header is already displayed. + * Since 1.4.3 and 1.5.1 function contains error_box hook. + * Use plain_error_message() and make sure that page header is created, + * if you want compatibility with 1.4.0 and older. + * @param string $string + * @param array $color + * @since 1.3.2 + */ function error_box($string, $color) { global $pageheader_sent; + if ( !isset( $color ) ) { + $color = array(); + $color[0] = '#dcdcdc'; /* light gray TitleBar */ + $color[1] = '#800000'; /* red */ + $color[2] = '#cc0000'; /* light red Warning/Error Messages */ + $color[4] = '#ffffff'; /* white Normal Background */ + $color[7] = '#0000cc'; /* blue Links */ + $color[8] = '#000000'; /* black Normal text */ + $color[9] = '#ababab'; /* mid-gray Darker version of #0 */ + } + $err = _("ERROR"); + $ret = concat_hook_function('error_box', $string); + if($ret != '') { + $string = $ret; + } + /* check if the page header has been sent; if not, send it! */ if(!isset($pageheader_sent) && !$pageheader_sent) { /* include this just to be sure */ @@ -150,19 +194,29 @@ function error_box($string, $color) { echo "\n\n"; } - echo ' '; - echo ' '; - echo '
'; - echo ' '; - echo ' '; - echo '
'; - echo ' ' . _("ERROR") . ':'; - echo '
'; - echo ' '; - echo ' ' . html_tag( 'td', $string."\n", 'left') - . ''; - echo '
'; - echo '
'; - echo ' '; + echo ''. + '
'. + ''. + '
'. + '' . $err . ':'. + '
'. + ''. + '' . html_tag( 'td', $string."\n", 'left') . '
'. + '
'; +} + +/** + * Adds message that informs about non fatal error that can happen while saving preferences + * @param string $message error message + * @since 1.5.1 and 1.4.5 + */ +function error_option_save($message) { + global $optpage_save_error; + + if (! is_array($optpage_save_error) ) + $optpage_save_error=array(); + + $optpage_save_error=array_merge($optpage_save_error,array($message)); } -?> +// vim: et ts=4 +?> \ No newline at end of file