X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=include%2Foptions%2Fdisplay.php;h=1effe44a4a2de21c03f2d8481cc2f81c24e96c69;hp=4511c9aa9e7f0426e89c5d921aa51a2b8a679157;hb=c4faef335b2362c81b8ebf026d4066c12d70536c;hpb=82351c82c9251726ce0f999708d06b3460db3714 diff --git a/include/options/display.php b/include/options/display.php index 4511c9aa..1effe44a 100644 --- a/include/options/display.php +++ b/include/options/display.php @@ -5,7 +5,7 @@ * * Displays all optinos about display preferences * - * @copyright © 1999-2006 The SquirrelMail Project Team + * @copyright 1999-2020 The SquirrelMail Project Team * @license http://opensource.org/licenses/gpl-license.php GNU Public License * @version $Id$ * @package squirrelmail @@ -15,27 +15,7 @@ define('SMOPT_GRP_GENERAL', 0); define('SMOPT_GRP_MAILBOX', 1); define('SMOPT_GRP_MESSAGE', 2); - -/** - * Icon themes and user CSS themes should probably both be moved to conf.pl - * - * TODO: move to conf.pl - **/ -// 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"); - } - } - } -} +define('SMOPT_GRP_ABOOK', 3); global $use_iframe; if (! isset($use_iframe)) $use_iframe=false; @@ -56,8 +36,9 @@ if (! isset($use_iframe)) $use_iframe=false; function load_optpage_data_display() { global $theme, $fontsets, $language, $languages,$aTemplateSet, $default_use_mdn, $squirrelmail_language, $allow_thread_sort, - $show_alternative_names, $use_icons, $use_iframe, $sTemplateID, - $oTemplate, $user_themes; + $show_alternative_names, $use_iframe, $use_icons, + $sTemplateID, $oTemplate, + $user_themes, $chosen_theme; /* Build a simple array into which we will build options. */ $optgrps = array(); @@ -92,43 +73,23 @@ function load_optpage_data_display() { } /* Load the theme option. */ - - /** - * User themes start with a 'u_', template themes start with a 't_' to - * differentiate which is which. This seems kind of hackish, but we can - * come up with a better solution later. -PL: No need for the prefixes. Just use full paths, no? - -SB: Don't think so. If the user chooses a template theme than changes the - path to the template, it would error out, right? Or should we worry about - that? - * - * TODO: Clean me. - **/ $theme_values = array(); // Always provide the template default first. $theme_values['none'] = 'Template Default Theme'; // List alternate themes provided by templates first - $template_themes = array(); -/* - * Since this requires mods to the template class, I'm holding off on alternate - * template styles until Paul finishes template inheritence. - * -- SB, 2006-09-30 - * - $template_themes = $oTemplate->get_alternative_stylesheets(); - asort($template_provided); - foreach ($template_provided as $sheet=>$name) { - $theme_values['t_'.$sheet] = 'Template Theme - '.htmlspecialchars($name); + $template_themes = $oTemplate->get_alternative_stylesheets(true); + asort($template_themes); + foreach ($template_themes as $sheet=>$name) { + $theme_values[$sheet] = 'Template Theme - '.sm_encode_html_special_chars($name); } -*/ - // Next, list styles provided in SM_PATH/css/ + // Next, list user-provided styles asort($user_themes); foreach ($user_themes as $style) { if ($style['PATH'] == 'none') continue; - $theme_values['u_'.$style['PATH']] = 'User Theme - '.htmlspecialchars($style['NAME']); + $theme_values[$style['PATH']] = 'User Theme - '.sm_encode_html_special_chars($style['NAME']); } if (count($user_themes) + count($template_themes) > 1) { @@ -237,7 +198,7 @@ SB: Don't think so. If the user chooses a template theme than changes the SMPREF_JS_ON => _("Always"), SMPREF_JS_OFF => _("Never")), 'save' => 'save_option_javascript_autodetect', - 'script' => 'onclick="document.forms[0].new_js_autodetect_results.value = \'' . SMPREF_JS_ON . '\';"' + 'extra_attributes' => array('onclick' => 'document.option_form.new_js_autodetect_results.value = \'' . SMPREF_JS_ON . '\';'), ); $optvals[SMOPT_GRP_GENERAL][] = array( @@ -319,6 +280,13 @@ SB: Don't think so. If the user chooses a template theme than changes the 'size' => SMOPT_SIZE_TINY ); + $optvals[SMOPT_GRP_MAILBOX][] = array( + 'name' => 'show_personal_names', + 'caption' => _("Show Names Instead of Email Addresses"), + 'type' => SMOPT_TYPE_BOOLEAN, + 'refresh' => SMOPT_REFRESH_NONE, + ); + $optvals[SMOPT_GRP_MAILBOX][] = array( 'name' => 'show_full_date', 'caption' => _("Always Show Full Date"), @@ -326,6 +294,16 @@ SB: Don't think so. If the user chooses a template theme than changes the 'refresh' => SMOPT_REFRESH_NONE ); + $optvals[SMOPT_GRP_MAILBOX][] = array( + 'name' => 'custom_date_format', + 'caption' => _("Custom Date Format"), +//FIXME: need better wording here. users should be made aware that this is for advanced use. It might be nice to provide a list of the more common date format characters. It may be helpful to know that it overrides settings such as the one above show_full_date, and only if kept empty will the other date formats apply. For non-English users, it also may be helpful to know that the format is still passed through our own date_intl() function which translates things like the day of the week, month names and abbreviations, etc. + 'trailing_text' => ' ' . _("(Uses format of PHP date() function)"), + 'type' => SMOPT_TYPE_STRING, + 'refresh' => SMOPT_REFRESH_NONE, + 'size' => SMOPT_SIZE_TINY, + ); + $optvals[SMOPT_GRP_MAILBOX][] = array( 'name' => 'truncate_sender', 'caption' => _("Length of From/To Field (0 for full)"), @@ -430,6 +408,44 @@ FIXME! 'refresh' => SMOPT_REFRESH_ALL ); + + + /*** Load the Address Book Options into the array ***/ + $optgrps[SMOPT_GRP_ABOOK] = _("Address Book Display Options"); + $optvals[SMOPT_GRP_ABOOK] = array(); + + $optvals[SMOPT_GRP_ABOOK][] = array( + 'name' => 'abook_show_num', + 'caption' => _("Number of Addresses per Page"), + 'type' => SMOPT_TYPE_INTEGER, + 'refresh' => SMOPT_REFRESH_NONE, + 'size' => SMOPT_SIZE_TINY + ); + + $optvals[SMOPT_GRP_ABOOK][] = array( + 'name' => 'abook_page_selector', + 'caption' => _("Enable Page Selector"), + 'type' => SMOPT_TYPE_BOOLEAN, + 'refresh' => SMOPT_REFRESH_NONE + ); + + $optvals[SMOPT_GRP_ABOOK][] = array( + 'name' => 'abook_compact_paginator', + 'caption' => _("Use Compact Page Selector"), + 'type' => SMOPT_TYPE_BOOLEAN, + 'refresh' => SMOPT_REFRESH_NONE + ); + + $optvals[SMOPT_GRP_ABOOK][] = array( + 'name' => 'abook_page_selector_max', + 'caption' => _("Maximum Number of Pages to Show"), + 'type' => SMOPT_TYPE_INTEGER, + 'refresh' => SMOPT_REFRESH_NONE, + 'size' => SMOPT_SIZE_TINY + ); + + + /* Assemble all this together and return it as our result. */ $result = array( 'grps' => $optgrps, @@ -470,34 +486,14 @@ function save_option_template($option) { // global $sTemplateID; $sTemplateID = $option->new_value; - Template::cache_template_file_hierarchy(TRUE); - - } - - /* Save the option like normal. */ - save_option($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) { - if ($theme[$i]['PATH'] == $option->new_value) { - $theme_in_array = true; - break; - } - } + Template::cache_template_file_hierarchy($sTemplateID, TRUE); - if (!$theme_in_array) { - $option->new_value = ''; } + /** + * TODO: If the template changes and we are using a template provided theme + * ($user_theme), do we want to reset $user_theme? + */ /* Save the option like normal. */ save_option($option); } @@ -514,40 +510,47 @@ function save_option_javascript_autodetect($option) { * This function saves the user's icon theme setting */ function icon_theme_save($option) { - global $icon_themes, $data_dir, $username; + global $icon_themes; // Don't assume the new value is there, double check // and only save if found - // $found = false; while (!$found && (list($index, $data) = each($icon_themes))) { if ($data['PATH'] == $option->new_value) $found = true; } - if ($found) - setPref($data_dir, $username, 'icon_theme', $option->new_value); - else - setPref($data_dir, $username, 'icon_theme', 'none'); - + + if (!$found) + $option->new_value = 'none'; + + save_option($option); } function css_theme_save ($option) { - global $user_themes, $data_dir, $username; + global $user_themes, $oTemplate; // Don't assume the new value is there, double check // and only save if found - // $found = false; reset($user_themes); while (!$found && (list($index, $data) = each($user_themes))) { - if ('u_'.$data['PATH'] == $option->new_value) + if ($data['PATH'] == $option->new_value) $found = true; } - if ($found) - setPref($data_dir, $username, 'chosen_theme', $option->new_value); - else - setPref($data_dir, $username, 'chosen_theme', 'none'); + + if (!$found) { + $template_themes = $oTemplate->get_alternative_stylesheets(true); + while (!$found && (list($path, $name) = each($template_themes))) { + if ($path == $option->new_value) + $found = true; + } + } + + if (!$found) + $option->new_value = 'none'; + + save_option($option); }