From 022bcd11320398b6652eacc5c264a87adc16af84 Mon Sep 17 00:00:00 2001 From: alecpl <alec@alec.pl> Date: Wed, 27 Oct 2010 08:45:51 -0400 Subject: [PATCH] - When contacts search returns no rows display message of type 'notice' instead of 'warning' --- installer/config.php | 233 ++++++++++++++++++++++++++++++++++++++++++++-------------- 1 files changed, 177 insertions(+), 56 deletions(-) diff --git a/installer/config.php b/installer/config.php index f691640..5250782 100644 --- a/installer/config.php +++ b/installer/config.php @@ -6,7 +6,7 @@ $RCI->load_defaults(); // register these boolean fields -$RCI->config_props = array( +$RCI->bool_config_props = array( 'ip_check' => 1, 'enable_caching' => 1, 'enable_spellcheck' => 1, @@ -14,7 +14,7 @@ 'smtp_log' => 1, 'prefer_html' => 1, 'preview_pane' => 1, - 'htmleditor' => 1, + 'debug_level' => 1, ); // allow the current user to get to the next step @@ -23,16 +23,16 @@ if (!empty($_POST['submit'])) { echo '<p class="notice">Copy or download the following configurations and save them in two files'; - echo ' (names above the text box) within the <tt>config/</tt> directory of your RoundCube installation.<br/>'; + echo ' (names above the text box) within the <tt>'.RCMAIL_CONFIG_DIR.'</tt> directory of your Roundcube installation.<br/>'; echo ' Make sure that there are no characters outside the <tt><?php ?></tt> brackets when saving the files.</p>'; $textbox = new html_textarea(array('rows' => 16, 'cols' => 60, 'class' => "configfile")); echo '<div><em>main.inc.php (<a href="index.php?_getfile=main">download</a>)</em></div>'; - echo $textbox->show($RCI->create_config('main')); + echo $textbox->show(($_SESSION['main.inc.php'] = $RCI->create_config('main'))); echo '<div style="margin-top:1em"><em>db.inc.php (<a href="index.php?_getfile=db">download</a>)</em></div>'; - echo $textbox->show($RCI->create_config('db')); + echo $textbox->show($_SESSION['db.inc.php'] = $RCI->create_config('db')); echo '<p class="hint">Of course there are more options to configure. Have a look at the config files or visit <a href="http://trac.roundcube.net/wiki/Howto_Config">Howto_Config</a> to find out.</p>'; @@ -47,25 +47,6 @@ <fieldset> <legend>General configuration</legend> <dl class="configblock"> -<!-- -<dt id="cgfblockgeneral" class="propname">debug_level</dt> -<dd> -<?php -/* -$value = $RCI->getprop('debug_level'); -$check_debug = new html_checkbox(array('name' => '_debug_level[]')); -echo $check_debug->show(($value & 1) ? 1 : 0 , array('value' => 1, 'id' => 'cfgdebug1')); -echo '<label for="cfgdebug1">Log errors</label><br />'; - -echo $check_debug->show(($value & 4) ? 4 : 0, array('value' => 4, 'id' => 'cfgdebug4')); -echo '<label for="cfgdebug4">Display errors</label><br />'; - -echo $check_debug->show(($value & 8) ? 8 : 0, array('value' => 8, 'id' => 'cfgdebug8')); -echo '<label for="cfgdebug8">Verbose display</label><br />'; -*/ -?> -</dd> ---> <dt class="propname">product_name</dt> <dd> @@ -86,19 +67,9 @@ echo $input_tempdir->show($RCI->getprop('temp_dir')); ?> -<div>Use this folder to store temp files (must be writebale for webserver)</div> +<div>Use this folder to store temp files (must be writeable for webserver)</div> </dd> -<dt class="propname">log_dir</dt> -<dd> -<?php - -$input_logdir = new html_inputfield(array('name' => '_log_dir', 'size' => 30, 'id' => "cfglogdir")); -echo $input_logdir->show($RCI->getprop('log_dir')); - -?> -<div>Use this folder to store log files (must be writebale for webserver)</div> -</dd> <dt class="propname">ip_check</dt> <dd> @@ -140,18 +111,130 @@ <dt class="propname">enable_spellcheck</dt> <dd> <?php +$check_spell = new html_checkbox(array('name' => '_enable_spellcheck', 'id' => "cfgspellcheck")); +echo $check_spell->show(intval($RCI->getprop('enable_spellcheck')), array('value' => 1)); +?> +<label for="cfgspellcheck">Make use of the spell checker</label><br /> +</dd> -$check_caching = new html_checkbox(array('name' => '_enable_spellcheck', 'id' => "cfgspellcheck")); -echo $check_caching->show(intval($RCI->getprop('enable_spellcheck')), array('value' => 1)); +<dt class="propname">spellcheck_engine</dt> +<dd> +<?php +$select_spell = new html_select(array('name' => '_spellcheck_engine', 'id' => "cfgspellcheckengine")); +if (extension_loaded('pspell')) + $select_spell->add('pspell', 'pspell'); +$select_spell->add('Googie', 'googie'); + +echo $select_spell->show($RCI->is_post ? $_POST['_spellcheck_engine'] : 'pspell'); ?> -<label for="cfgspellcheck">Make use of the built-in spell checker</label><br /> +<label for="cfgspellcheckengine">Which spell checker to use</label><br /> -<p class="hint">It is based on GoogieSpell what implies that the message content will be sent to Google in order to check the spelling.</p> +<p class="hint">GoogieSpell implies that the message content will be sent to Google in order to check the spelling.</p> +</dd> + +<dt class="propname">identities_level</dt> +<dd> +<?php + +$input_ilevel = new html_select(array('name' => '_identities_level', 'id' => "cfgidentitieslevel")); +$input_ilevel->add('many identities with possibility to edit all params', 0); +$input_ilevel->add('many identities with possibility to edit all params but not email address', 1); +$input_ilevel->add('one identity with possibility to edit all params', 2); +$input_ilevel->add('one identity with possibility to edit all params but not email address', 3); +echo $input_ilevel->show($RCI->getprop('identities_level'), 0); + +?> +<div>Level of identities access</div> +<p class="hint">Defines what users can do with their identities.</p> </dd> </dl> </fieldset> + +<fieldset> +<legend>Logging & Debugging</legend> +<dl class="loggingblock"> + +<dt class="propname">debug_level</dt> +<dd> +<?php + +$value = $RCI->getprop('debug_level'); +$check_debug = new html_checkbox(array('name' => '_debug_level[]')); +echo $check_debug->show(($value & 1) ? 1 : 0 , array('value' => 1, 'id' => 'cfgdebug1')); +echo '<label for="cfgdebug1">Log errors</label><br />'; + +echo $check_debug->show(($value & 4) ? 4 : 0, array('value' => 4, 'id' => 'cfgdebug4')); +echo '<label for="cfgdebug4">Print errors (to the browser)</label><br />'; + +echo $check_debug->show(($value & 8) ? 8 : 0, array('value' => 8, 'id' => 'cfgdebug8')); +echo '<label for="cfgdebug8">Verbose display (enables debug console)</label><br />'; + +?> +</dd> + +<dt class="propname">log_driver</dt> +<dd> +<?php + +$select_log_driver = new html_select(array('name' => '_log_driver', 'id' => "cfglogdriver")); +$select_log_driver->add(array('file', 'syslog'), array('file', 'syslog')); +echo $select_log_driver->show($RCI->getprop('log_driver', 'file')); + +?> +<div>How to do logging? 'file' - write to files in the log directory, 'syslog' - use the syslog facility.</div> +</dd> + +<dt class="propname">log_dir</dt> +<dd> +<?php + +$input_logdir = new html_inputfield(array('name' => '_log_dir', 'size' => 30, 'id' => "cfglogdir")); +echo $input_logdir->show($RCI->getprop('log_dir')); + +?> +<div>Use this folder to store log files (must be writeable for webserver). Note that this only applies if you are using the 'file' log_driver.</div> +</dd> + +<dt class="propname">syslog_id</dt> +<dd> +<?php + +$input_syslogid = new html_inputfield(array('name' => '_syslog_id', 'size' => 30, 'id' => "cfgsyslogid")); +echo $input_syslogid->show($RCI->getprop('syslog_id', 'roundcube')); + +?> +<div>What ID to use when logging with syslog. Note that this only applies if you are using the 'syslog' log_driver.</div> +</dd> + +<dt class="propname">syslog_facility</dt> +<dd> +<?php + +$input_syslogfacility = new html_select(array('name' => '_syslog_facility', 'id' => "cfgsyslogfacility")); +$input_syslogfacility->add('user-level messages', LOG_USER); +$input_syslogfacility->add('mail subsystem', LOG_MAIL); +$input_syslogfacility->add('local level 0', LOG_LOCAL0); +$input_syslogfacility->add('local level 1', LOG_LOCAL1); +$input_syslogfacility->add('local level 2', LOG_LOCAL2); +$input_syslogfacility->add('local level 3', LOG_LOCAL3); +$input_syslogfacility->add('local level 4', LOG_LOCAL4); +$input_syslogfacility->add('local level 5', LOG_LOCAL5); +$input_syslogfacility->add('local level 6', LOG_LOCAL6); +$input_syslogfacility->add('local level 7', LOG_LOCAL7); +echo $input_syslogfacility->show($RCI->getprop('syslog_facility'), LOG_USER); + +?> +<div>What ID to use when logging with syslog. Note that this only applies if you are using the 'syslog' log_driver.</div> +</dd> + + + + +</dl> +</fieldset> + <fieldset> <legend>Database setup</legend> @@ -183,13 +266,13 @@ echo $select_dbtype->show($RCI->is_post ? $_POST['_dbtype'] : $dsnw['phptype']); echo '<label for="cfgdbtype">Database type</label><br />'; echo $input_dbhost->show($RCI->is_post ? $_POST['_dbhost'] : $dsnw['hostspec']); -echo '<label for="cfgdbhost">Database server</label><br />'; +echo '<label for="cfgdbhost">Database server (omit for sqlite)</label><br />'; echo $input_dbname->show($RCI->is_post ? $_POST['_dbname'] : $dsnw['database']); -echo '<label for="cfgdbname">Database name</label><br />'; +echo '<label for="cfgdbname">Database name (use absolute path and filename for sqlite)</label><br />'; echo $input_dbuser->show($RCI->is_post ? $_POST['_dbuser'] : $dsnw['username']); -echo '<label for="cfgdbuser">Database user name (needs write permissions)</label><br />'; +echo '<label for="cfgdbuser">Database user name (needs write permissions)(omit for sqlite)</label><br />'; echo $input_dbpass->show($RCI->is_post ? $_POST['_dbpass'] : $dsnw['password']); -echo '<label for="cfgdbpass">Database password</label><br />'; +echo '<label for="cfgdbpass">Database password (omit for sqlite)</label><br />'; ?> </dd> @@ -259,12 +342,12 @@ echo $check_autocreate->show(intval($RCI->getprop('auto_create_user')), array('value' => 1)); ?> -<label for="cfgautocreate">Automatically create a new RoundCube user when log-in the first time</label><br /> +<label for="cfgautocreate">Automatically create a new Roundcube user when log-in the first time</label><br /> <p class="hint">A user is authenticated by the IMAP server but it requires a local record to store settings and contacts. With this option enabled a new user record will automatically be created once the IMAP login succeeds.</p> -<p class="hint">If this option is disabled, the login only succeeds if there's a matching user-record in the local RoundCube database +<p class="hint">If this option is disabled, the login only succeeds if there's a matching user-record in the local Roundcube database what means that you have to create those records manually or disable this option after the first login.</p> </dd> @@ -276,7 +359,7 @@ echo $text_sentmbox->show($RCI->getprop('sent_mbox')); ?> -<div>Store sent messages is this folder</div> +<div>Store sent messages in this folder</div> <p class="hint">Leave blank if sent messages should not be stored</p> </dd> @@ -302,9 +385,21 @@ echo $text_draftsmbox->show($RCI->getprop('drafts_mbox')); ?> -<div>Store draft messages is this folder</div> +<div>Store draft messages in this folder</div> + +<p class="hint">Leave blank if they should not be stored</p> </dd> +<dt class="propname">junk_mbox</dt> +<dd> +<?php + +$text_junkmbox = new html_inputfield(array('name' => '_junk_mbox', 'size' => 20, 'id' => "cfgjunkmbox")); +echo $text_junkmbox->show($RCI->getprop('junk_mbox')); + +?> +<div>Store spam messages in this folder</div> +</dd> </dl> </fieldset> @@ -333,7 +428,7 @@ echo $text_smtpport->show($RCI->getprop('smtp_port')); ?> -<div>SMTP port (default is 25; 465 for SSL)</div> +<div>SMTP port (default is 25; 465 for SSL; 587 for submission)</div> </dd> <dt class="propname">smtp_user/smtp_pass</dt> @@ -378,7 +473,7 @@ echo $check_smtplog->show(intval($RCI->getprop('smtp_log')), array('value' => 1)); ?> -<label for="cfgsmtplog">Log sent messages in <tt>logs/sendmail</tt></label><br /> +<label for="cfgsmtplog">Log sent messages in <tt>{log_dir}/sendmail</tt> or to syslog.</label><br /> </dd> </dl> @@ -389,7 +484,7 @@ <legend>Display settings & user prefs</legend> <dl class="configblock" id="cgfblockdisplay"> -<dt class="propname">language</dt> +<dt class="propname">language <span class="userconf">*</span></dt> <dd> <?php @@ -397,7 +492,7 @@ echo $input_locale->show($RCI->getprop('language')); ?> -<div>The default locale setting. This also defines the language of the login screen.</div> +<div>The default locale setting. This also defines the language of the login screen.<br/>Leave it empty to auto-detect the user agent language.</div> <p class="hint">Enter a <a href="http://www.faqs.org/rfcs/rfc1766">RFC1766</a> formatted language name. Examples: en_US, de_DE, de_CH, fr_FR, pt_BR</p> </dd> @@ -447,13 +542,16 @@ <dt class="propname">htmleditor <span class="userconf">*</span></dt> <dd> +<label for="cfghtmlcompose">Compose HTML formatted messages</label> <?php -$check_htmlcomp = new html_checkbox(array('name' => '_htmleditor', 'id' => "cfghtmlcompose", 'value' => 1)); -echo $check_htmlcomp->show(intval($RCI->getprop('htmleditor'))); +$select_htmlcomp = new html_select(array('name' => '_htmleditor', 'id' => "cfghtmlcompose")); +$select_htmlcomp->add('never', 0); +$select_htmlcomp->add('always', 1); +$select_htmlcomp->add('on reply to HTML message only', 2); +echo $select_htmlcomp->show(intval($RCI->getprop('htmleditor'))); ?> -<label for="cfghtmlcompose">Compose HTML formatted messages</label><br /> </dd> <dt class="propname">draft_autosave <span class="userconf">*</span></dt> @@ -463,7 +561,7 @@ $select_autosave = new html_select(array('name' => '_draft_autosave', 'id' => 'cfgautosave')); $select_autosave->add('never', 0); -foreach (array(3, 5, 10) as $i => $min) +foreach (array(1, 3, 5, 10) as $i => $min) $select_autosave->add("$min min", $min*60); echo $select_autosave->show(intval($RCI->getprop('draft_autosave'))); @@ -475,14 +573,37 @@ <dd> <?php +$mdn_opts = array( + 0 => 'ask the user', + 1 => 'send automatically', + 3 => 'send receipt to user contacts, otherwise ask the user', + 4 => 'send receipt to user contacts, otherwise ignore', + 2 => 'ignore', +); + $select_mdnreq = new html_select(array('name' => '_mdn_requests', 'id' => "cfgmdnreq")); -$select_mdnreq->add(array('ask the user', 'send automatically', 'ignore'), array(0, 1, 2)); +$select_mdnreq->add(array_values($mdn_opts), array_keys($mdn_opts)); echo $select_mdnreq->show(intval($RCI->getprop('mdn_requests'))); ?> <div>Behavior if a received message requests a message delivery notification (read receipt)</div> </dd> +<dt class="propname">mime_param_folding <span class="userconf">*</span></dt> +<dd> +<?php + +$select_param_folding = new html_select(array('name' => '_mime_param_folding', 'id' => "cfgmimeparamfolding")); +$select_param_folding->add('Full RFC 2231 (Roundcube, Thunderbird)', '0'); +$select_param_folding->add('RFC 2047/2231 (MS Outlook, OE)', '1'); +$select_param_folding->add('Full RFC 2047 (deprecated)', '2'); + +echo $select_param_folding->show(intval($RCI->getprop('mime_param_folding'))); + +?> +<div>How to encode attachment long/non-ascii names</div> +</dd> + </dl> <p class="hint"><span class="userconf">*</span> These settings are defaults for the user preferences</p> -- Gitblit v1.9.1