X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=include%2Foptions%2Fdisplay.php;h=0ae31bd6b4bdc494c01a301fe62a61514319eb0d;hp=7ccb61101aa553d618aa3568cac12c6bc0167012;hb=192cdcf506576a2d0743c4e6b79d3556cbf3fd6d;hpb=ac50138c1be7836d931e8c45a959f815a500203f diff --git a/include/options/display.php b/include/options/display.php index 7ccb6110..0ae31bd6 100644 --- a/include/options/display.php +++ b/include/options/display.php @@ -3,23 +3,53 @@ /** * options_display.php * - * Copyright (c) 1999-2002 The SquirrelMail Project Team + * Copyright (c) 1999-2004 The SquirrelMail Project Team * Licensed under the GNU GPL. For full terms see the file COPYING. * * Displays all optinos about display preferences * - * $Id$ + * @version $Id$ + * @package squirrelmail */ -/* Define the group constants for the display options page. */ +/** Define the group constants for the display options page. */ define('SMOPT_GRP_GENERAL', 0); define('SMOPT_GRP_MAILBOX', 1); define('SMOPT_GRP_MESSAGE', 2); -/* Define the optpage load function for the display options page. */ +// load icon themes if in use +global $use_icons; +if ($use_icons) { + global $icon_themes; + $dirName = SM_PATH . 'images/themes'; + if (is_readable($dirName) && is_dir($dirName)) { + $d = dir($dirName); + while($dir = $d->read()) { + if ($dir != "." && $dir != "..") { + if (is_dir($dirName."/".$dir) && file_exists("$dirName/$dir/theme.php")) + include("$dirName/$dir/theme.php"); + } + } + } +} + +/** + * This function builds an array with all the information about + * the options available to the user, and returns it. The options + * are grouped by the groups in which they are displayed. + * For each option, the following information is stored: + * - name: the internal (variable) name + * - caption: the description of the option in the UI + * - type: one of SMOPT_TYPE_* + * - refresh: one of SMOPT_REFRESH_* + * - size: one of SMOPT_SIZE_* + * - save: the name of a function to call when saving this option + * @return array all option information + */ function load_optpage_data_display() { - global $theme, $language, $languages, $js_autodetect_results, - $compose_new_win, $default_use_mdn, $squirrelmail_language, $allow_thread_sort; + global $theme, $language, $languages, $js_autodetect_results, $javascript_setting, + $compose_new_win, $default_use_mdn, $squirrelmail_language, $allow_thread_sort, + $optmode, $show_alternative_names, $available_languages, $use_icons; /* Build a simple array into which we will build options. */ $optgrps = array(); @@ -48,18 +78,21 @@ function load_optpage_data_display() { 'posvals' => $theme_values, 'save' => 'save_option_theme' ); - + $css_values = array( 'none' => _("Default" ) ); - $handle=opendir('../themes/css/'); - while ($file = readdir($handle) ) { - if ( substr( $file, -4 ) == '.css' ) { - $css_values[$file] = substr( $file, 0, strlen( $file ) - 4 ); + + if (is_readable(SM_PATH . 'themes/css') && is_dir(SM_PATH . 'themes/css')) { + $handle=opendir(SM_PATH . 'themes/css'); + while ($file = readdir($handle) ) { + if ( substr( $file, -4 ) == '.css' ) { + $css_values[$file] = substr( $file, 0, strlen( $file ) - 4 ); + } } + closedir($handle); } - closedir($handle); - - if ( count( $css_values > 1 ) ) { - + + if ( count( $css_values ) > 1 ) { + $optvals[SMOPT_GRP_GENERAL][] = array( 'name' => 'custom_css', 'caption' => _("Custom Stylesheet"), @@ -67,26 +100,53 @@ function load_optpage_data_display() { 'refresh' => SMOPT_REFRESH_ALL, 'posvals' => $css_values ); - + } - + + // config.php can be unupdated. + if (! isset($available_languages) || $available_languages=="" ) { + $available_languages="ALL"; } + $language_values = array(); - foreach ($languages as $lang_key => $lang_attributes) { - if (isset($lang_attributes['NAME'])) { - $language_values[$lang_key] = $lang_attributes['NAME']; - } + if ( strtoupper($available_languages)=='ALL') { + foreach ($languages as $lang_key => $lang_attributes) { + if (isset($lang_attributes['NAME'])) { + $language_values[$lang_key] = $lang_attributes['NAME']; + if ( isset($show_alternative_names) && + $show_alternative_names && + isset($lang_attributes['ALTNAME']) ) { + $language_values[$lang_key] .= " / " . $lang_attributes['ALTNAME']; + } + } + } + } else if (strtoupper($available_languages)!='NONE') { + // admin can set list of available languages in config + $available_languages_array=explode (" ",$available_languages); + foreach ($available_languages_array as $lang_key ) { + if (isset($languages[$lang_key]['NAME'])) { + $language_values[$lang_key] = $languages[$lang_key]['NAME']; + if ( isset($show_alternative_names) && + $show_alternative_names && + isset($languages[$lang_key]['ALTNAME']) ) { + $language_values[$lang_key] .= " / " . $languages[$lang_key]['ALTNAME']; + } + } + } } asort($language_values); $language_values = array_merge(array('' => _("Default")), $language_values); $language = $squirrelmail_language; - $optvals[SMOPT_GRP_GENERAL][] = array( - 'name' => 'language', - 'caption' => _("Language"), - 'type' => SMOPT_TYPE_STRLIST, - 'refresh' => SMOPT_REFRESH_ALL, - 'posvals' => $language_values - ); + if (strtoupper($available_languages)!='NONE') { + // if set to 'none', interface will use only default language + $optvals[SMOPT_GRP_GENERAL][] = array( + 'name' => 'language', + 'caption' => _("Language"), + 'type' => SMOPT_TYPE_STRLIST, + 'refresh' => SMOPT_REFRESH_ALL, + 'posvals' => $language_values + ); + } /* Set values for the "use javascript" option. */ $optvals[SMOPT_GRP_GENERAL][] = array( @@ -96,21 +156,17 @@ function load_optpage_data_display() { 'refresh' => SMOPT_REFRESH_ALL, 'posvals' => array(SMPREF_JS_AUTODETECT => _("Autodetect"), SMPREF_JS_ON => _("Always"), - SMPREF_JS_OFF => _("Never")) + SMPREF_JS_OFF => _("Never")), + 'save' => 'save_option_javascript_autodetect', + 'script' => 'onclick="document.forms[0].new_js_autodetect_results.value = \'' . SMPREF_JS_ON . '\';"' ); - $js_autodetect_script = - "\n"; - $js_autodetect_results = SMPREF_JS_OFF; $optvals[SMOPT_GRP_GENERAL][] = array( 'name' => 'js_autodetect_results', 'caption' => '', 'type' => SMOPT_TYPE_HIDDEN, - 'refresh' => SMOPT_REFRESH_NONE, - 'script' => $js_autodetect_script, - 'save' => 'save_option_javascript_autodetect' + 'refresh' => SMOPT_REFRESH_NONE + //'post_script' => $js_autodetect_script, ); /*** Load the General Options into the array ***/ @@ -132,6 +188,34 @@ function load_optpage_data_display() { 'refresh' => SMOPT_REFRESH_NONE ); + if ($use_icons) { + global $icon_themes, $icon_theme; + $temp = array(); + for ($count = 0; $count < sizeof($icon_themes); $count++) { + $temp[$count] = $icon_themes[$count]['NAME']; + if ($icon_theme == $icon_themes[$count]['PATH']) + $value = $count; + } + if (sizeof($icon_themes) > 0) { + $optvals[SMOPT_GRP_MAILBOX][] = array( + 'name' => 'icon_theme', + 'caption' => _("Message Flags Icon Theme"), + 'type' => SMOPT_TYPE_STRLIST, + 'refresh' => SMOPT_REFRESH_NONE, + 'posvals' => $temp, + 'initial_value' => $value, + 'save' => 'icon_theme_save' + ); + } + } + + $optvals[SMOPT_GRP_MAILBOX][] = array( + 'name' => 'show_flag_buttons', + 'caption' => _("Show Flag / Unflag Buttons"), + 'type' => SMOPT_TYPE_BOOLEAN, + 'refresh' => SMOPT_REFRESH_NONE + ); + $optvals[SMOPT_GRP_MAILBOX][] = array( 'name' => 'page_selector', 'caption' => _("Enable Page Selector"), @@ -147,6 +231,38 @@ function load_optpage_data_display() { 'size' => SMOPT_SIZE_TINY ); + $optvals[SMOPT_GRP_MAILBOX][] = array( + 'name' => 'show_full_date', + 'caption' => _("Always Show Full Date"), + 'type' => SMOPT_TYPE_BOOLEAN, + 'refresh' => SMOPT_REFRESH_NONE + ); + + $optvals[SMOPT_GRP_MAILBOX][] = array( + 'name' => 'truncate_sender', + 'caption' => _("Length of From/To Field (0 for full)"), + 'type' => SMOPT_TYPE_INTEGER, + 'refresh' => SMOPT_REFRESH_NONE, + 'size' => SMOPT_SIZE_TINY + ); + + $optvals[SMOPT_GRP_MAILBOX][] = array( + 'name' => 'truncate_subject', + 'caption' => _("Length of Subject Field (0 for full)"), + 'type' => SMOPT_TYPE_INTEGER, + 'refresh' => SMOPT_REFRESH_NONE, + 'size' => SMOPT_SIZE_TINY + ); + + $optvals[SMOPT_GRP_MAILBOX][] = array( + 'name' => 'show_recipient_instead', + 'caption' => _("Show recipient name if the message is from your default identity"), + 'type' => SMOPT_TYPE_BOOLEAN, + 'refresh' => SMOPT_REFRESH_NONE, + 'size' => SMOPT_SIZE_TINY + ); + + /*** Load the General Options into the array ***/ $optgrps[SMOPT_GRP_MESSAGE] = _("Message Display and Composition"); $optvals[SMOPT_GRP_MESSAGE] = array(); @@ -161,7 +277,15 @@ function load_optpage_data_display() { $optvals[SMOPT_GRP_MESSAGE][] = array( 'name' => 'editor_size', - 'caption' => _("Size of Editor Window"), + 'caption' => _("Width of Editor Window"), + 'type' => SMOPT_TYPE_INTEGER, + 'refresh' => SMOPT_REFRESH_NONE, + 'size' => SMOPT_SIZE_TINY + ); + + $optvals[SMOPT_GRP_MESSAGE][] = array( + 'name' => 'editor_height', + 'caption' => _("Height of Editor Window"), 'type' => SMOPT_TYPE_INTEGER, 'refresh' => SMOPT_REFRESH_NONE, 'size' => SMOPT_SIZE_TINY @@ -229,13 +353,6 @@ function load_optpage_data_display() { 'refresh' => SMOPT_REFRESH_NONE ); - $optvals[SMOPT_GRP_MESSAGE][] = array( - 'name' => 'pf_subtle_link', - 'caption' => _("Enable Subtle Printer Friendly Link"), - 'type' => SMOPT_TYPE_BOOLEAN, - 'refresh' => SMOPT_REFRESH_NONE - ); - $optvals[SMOPT_GRP_MESSAGE][] = array( 'name' => 'pf_cleandisplay', 'caption' => _("Enable Printer Friendly Clean Display"), @@ -282,6 +399,33 @@ function load_optpage_data_display() { 'refresh' => SMOPT_REFRESH_NONE ); + $optvals[SMOPT_GRP_MESSAGE][] = array( + 'name' => 'body_quote', + 'caption' => _("Prefix for Original Message when Replying"), + 'type' => SMOPT_TYPE_STRING, + 'refresh' => SMOPT_REFRESH_NONE, + 'size' => SMOPT_SIZE_TINY, + 'save' => 'save_option_reply_prefix' + ); + + $optvals[SMOPT_GRP_MESSAGE][] = array( + 'name' => 'reply_focus', + 'caption' => _("Cursor Position when Replying"), + 'type' => SMOPT_TYPE_STRLIST, + 'refresh' => SMOPT_REFRESH_NONE, + 'posvals' => array('' => _("To: field"), + 'focus' => _("Focus in body"), + 'select' => _("Select body"), + 'none' => _("No focus")) + ); + + $optvals[SMOPT_GRP_MESSAGE][] = array( + 'name' => 'strip_sigs', + 'caption' => _("Strip signature when replying"), + 'type' => SMOPT_TYPE_BOOLEAN, + 'refresh' => SMOPT_REFRESH_NONE + ); + $optvals[SMOPT_GRP_MESSAGE][] = array( 'name' => 'internal_date_sort', 'caption' => _("Enable Sort by of Receive Date"), @@ -295,6 +439,13 @@ function load_optpage_data_display() { 'type' => SMOPT_TYPE_BOOLEAN, 'refresh' => SMOPT_REFRESH_ALL ); + $optvals[SMOPT_GRP_MESSAGE][] = array( + 'name' => 'delete_prev_next_display', + 'caption' => _("Show 'Delete & Prev/Next' Links"), + 'type' => SMOPT_TYPE_BOOLEAN, + 'refresh' => SMOPT_REFRESH_ALL + ); + } /* Assemble all this together and return it as our result. */ $result = array( @@ -308,9 +459,15 @@ function load_optpage_data_display() { /** Define any specialized save functions for this option page. ***/ /******************************************************************/ +function save_option_header($option) { +} + +/** + * This function saves a new theme setting. + * It updates the theme array. + */ function save_option_theme($option) { global $theme; - /* Do checking to make sure $new_theme is in the array. */ $theme_in_array = false; for ($i = 0; $i < count($theme); ++$i) { @@ -328,19 +485,49 @@ function save_option_theme($option) { save_option($option); } +/** + * This function saves the javascript detection option. + */ function save_option_javascript_autodetect($option) { + global $data_dir, $username; + + save_option($option); + checkForJavascript(TRUE); +} + +/** + * This function saves the user's icon theme setting + */ +function icon_theme_save($option) { + + global $icon_themes, $data_dir, $username; + + + // Don't assume the new value is there, double check + // and only save if found + // + if (isset($icon_themes[$option->new_value]['PATH'])) + setPref($data_dir, $username, 'icon_theme', $icon_themes[$option->new_value]['PATH']); + else + setPref($data_dir, $username, 'icon_theme', 'none'); + +} + +/** + * This function saves the reply prefix (body_quote) character(s) + */ +function save_option_reply_prefix($option) { global $data_dir, $username, $new_javascript_setting; - /* Set javascript either on or off. */ - if ($new_javascript_setting == SMPREF_JS_AUTODETECT) { - if ($option->new_value == SMPREF_JS_ON) { - setPref($data_dir, $username, 'javascript_on', SMPREF_JS_ON); - } else { - setPref($data_dir, $username, 'javascript_on', SMPREF_JS_OFF); - } - } else { - setPref($data_dir, $username, 'javascript_on', $new_javascript_setting); - } + // save as "NONE" if it was blanked out + // + if (empty($option->new_value)) $option->new_value = 'NONE'; + + + // Save the option like normal. + // + save_option($option); + } ?>