diff --git a/lib/plugins/config/admin.php b/lib/plugins/config/admin.php index 4248ee40cc1d8a68776149633660668c5e65e902..93c8756236b66233ef9b8b19f77cbc1f18556753 100644 --- a/lib/plugins/config/admin.php +++ b/lib/plugins/config/admin.php @@ -131,7 +131,7 @@ class admin_plugin_config extends DokuWiki_Admin_Plugin { if (!$this->_config->locked) { ptln(' <input type="hidden" name="save" value="1" />'); - ptln(' <input type="submit" name="submit" class="button" value="'.$lang['btn_save'].'" />'); + ptln(' <input type="submit" name="submit" class="button" value="'.$lang['btn_save'].'" accesskey="s" />'); ptln(' <input type="reset" class="button" value="'.$lang['btn_reset'].'" />'); } diff --git a/lib/plugins/config/settings/config.class.php b/lib/plugins/config/settings/config.class.php index ba071b4d1f3a9d2e2a654e0a4685a3f34229fb72..d5e77a261283756df284047fdcd142e152e08732 100644 --- a/lib/plugins/config/settings/config.class.php +++ b/lib/plugins/config/settings/config.class.php @@ -305,7 +305,6 @@ if (!class_exists('setting')) { * @return array(string $label_html, string $input_html) */ function html(&$plugin, $echo=false) { - $value = ''; $disable = ''; @@ -324,7 +323,7 @@ if (!class_exists('setting')) { $value = htmlspecialchars($value); $label = '<label for="config__'.$key.'">'.$this->prompt($plugin).'</label>'; - $input = '<input id="config__'.$key.'" name="config['.$key.']" type="text" class="edit" value="'.$value.'" '.$disable.'/>'; + $input = '<textarea rows="3" cols="40" id="config__'.$key.'" name="config['.$key.']" class="edit" '.$disable.'>'.$value.'</textarea>'; return array($label,$input); } @@ -341,6 +340,7 @@ if (!class_exists('setting')) { if ($fmt=='php') { // translation string needs to be improved FIXME $tr = array("\n"=>'\n', "\r"=>'\r', "\t"=>'\t', "\\" => '\\\\', "'" => '\\\''); + $tr = array("\\" => '\\\\', "'" => '\\\''); $out = '$'.$var."['".$this->_out_key()."'] = '".strtr($this->_local, $tr)."';\n"; } @@ -362,8 +362,35 @@ if (!class_exists('setting')) { } } +if (!class_exists('setting_string')) { + class setting_string extends setting { + function html(&$plugin, $echo=false) { + $value = ''; + $disable = ''; + + if ($this->is_protected()) { + $value = $this->_protected; + $disable = 'disabled="disabled"'; + } else { + if ($echo && $this->_error) { + $value = $this->_input; + } else { + $value = is_null($this->_local) ? $this->_default : $this->_local; + } + } + + $key = htmlspecialchars($this->_key); + $value = htmlspecialchars($value); + + $label = '<label for="config__'.$key.'">'.$this->prompt($plugin).'</label>'; + $input = '<input id="config__'.$key.'" name="config['.$key.']" type="text" class="edit" value="'.$value.'" '.$disable.'/>'; + return array($label,$input); + } + } +} + if (!class_exists('setting_password')) { - class setting_password extends setting { + class setting_password extends setting_string { function update($input) { if ($this->is_protected()) return false; @@ -394,13 +421,13 @@ if (!class_exists('setting_password')) { } if (!class_exists('setting_email')) { - class setting_email extends setting { + class setting_email extends setting_string { var $_pattern = '#([a-z0-9\-_.]+?)@([\w\-]+\.([\w\-\.]+\.)*[\w]+)#i'; } } if (!class_exists('setting_numeric')) { - class setting_numeric extends setting { + class setting_numeric extends setting_string { var $_pattern = '/^[-+\/*0-9 ]*$/'; function out($var, $fmt='php') { @@ -454,8 +481,8 @@ if (!class_exists('setting_onoff')) { } } -if (!class_exists('setting_mulitchoice')) { - class setting_multichoice extends setting { +if (!class_exists('setting_multichoice')) { + class setting_multichoice extends setting_string { var $_choices = array(); function html(&$plugin) { diff --git a/lib/plugins/config/settings/config.metadata.php b/lib/plugins/config/settings/config.metadata.php index 7aa570f63f0a2e88aeb6eaeb05db810fa19d7e8b..c34f9fc0b55b8a6ede9daabb7c97ff10ea2dfa3d 100644 --- a/lib/plugins/config/settings/config.metadata.php +++ b/lib/plugins/config/settings/config.metadata.php @@ -66,25 +66,26 @@ $file['protected'] = "DOKU_CONF.'local.protected.php'"; // optional // - any settings not mentioned will come after the last setting listed and // will use the default class with no parameters -$meta['title'] = array(''); -$meta['start'] = array(''); +$meta['title'] = array('string'); +$meta['start'] = array('string'); $meta['savedir'] = array('savedir'); $meta['lang'] = array('dirchoice','_dir' => DOKU_INC.'inc/lang/'); $meta['template'] = array('dirchoice','_dir' => DOKU_INC.'lib/tpl/'); $meta['dmode'] = array('numeric','_pattern' => '/0[0-7]{3}/'); // only accept octal representation $meta['fmode'] = array('numeric','_pattern' => '/0[0-7]{3}/'); // only accept octal representation -$meta['basedir'] = array(''); -$meta['baseurl'] = array(''); +$meta['basedir'] = array('string'); +$meta['baseurl'] = array('string'); $meta['fullpath'] = array('onoff'); $meta['recent'] = array('numeric'); $meta['breadcrumbs'] = array('numeric'); +$meta['youarehere'] = array('onoff'); $meta['typography'] = array('onoff'); $meta['htmlok'] = array('onoff'); $meta['phpok'] = array('onoff'); -$meta['dformat'] = array(''); -$meta['signature'] = array(''); +$meta['dformat'] = array('string'); +$meta['signature'] = array('string'); $meta['toptoclevel'] = array('multichoice','_choices' => array(1,2,3,4,5)); // 5 toc levels $meta['maxtoclevel'] = array('multichoice','_choices' => array(0,1,2,3,4,5)); $meta['maxseclevel'] = array('multichoice','_choices' => array(0,1,2,3,4,5)); // 0 for no sec edit buttons @@ -106,8 +107,8 @@ $meta['autopasswd'] = array('onoff'); $meta['resendpasswd'] = array('onoff'); $meta['authtype'] = array('authtype'); $meta['passcrypt'] = array('multichoice','_choices' => array('smd5','md5','sha1','ssha','crypt','mysql','my411')); -$meta['defaultgroup']= array(''); -$meta['superuser'] = array(''); +$meta['defaultgroup']= array('string'); +$meta['superuser'] = array('string'); $meta['profileconfirm'] = array('onoff'); $meta['userewrite'] = array('multichoice','_choices' => array(0,1,2)); @@ -126,29 +127,29 @@ $meta['im_convert'] = array('im_convert'); $meta['spellchecker']= array('onoff'); $meta['subscribers'] = array('onoff'); $meta['compress'] = array('onoff'); -$meta['hidepages'] = array(''); +$meta['hidepages'] = array('string'); $meta['send404'] = array('onoff'); $meta['sitemap'] = array('numeric'); $meta['rss_type'] = array('multichoice','_choices' => array('rss','rss1','rss2','atom')); $meta['rss_linkto'] = array('multichoice','_choices' => array('diff','page','rev','current')); -$meta['target____wiki'] = array(''); -$meta['target____interwiki'] = array(''); -$meta['target____extern'] = array(''); -$meta['target____media'] = array(''); -$meta['target____windows'] = array(''); +$meta['target____wiki'] = array('string'); +$meta['target____interwiki'] = array('string'); +$meta['target____extern'] = array('string'); +$meta['target____media'] = array('string'); +$meta['target____windows'] = array('string'); -$meta['proxy____host'] = array('','_pattern' => '#^[a-z0-9\-\.+]+?#i'); +$meta['proxy____host'] = array('string','_pattern' => '#^[a-z0-9\-\.+]+?#i'); $meta['proxy____port'] = array('numeric'); -$meta['proxy____user'] = array(''); +$meta['proxy____user'] = array('string'); $meta['proxy____pass'] = array('password'); $meta['proxy____ssl'] = array('onoff'); $meta['safemodehack'] = array('onoff'); -$meta['ftp____host'] = array('','_pattern' => '#^[a-z0-9\-\.+]+?#i'); +$meta['ftp____host'] = array('string','_pattern' => '#^[a-z0-9\-\.+]+?#i'); $meta['ftp____port'] = array('numeric'); -$meta['ftp____user'] = array(''); +$meta['ftp____user'] = array('string'); $meta['ftp____pass'] = array('password'); -$meta['ftp____root'] = array(''); +$meta['ftp____root'] = array('string'); diff --git a/lib/plugins/config/settings/extra.class.php b/lib/plugins/config/settings/extra.class.php index 805806e8bfb3d425cc95c59c754c8cc1f23bf3d4..0aafd2400b16ae2c025ee64c0c4dac1d43450fac 100644 --- a/lib/plugins/config/settings/extra.class.php +++ b/lib/plugins/config/settings/extra.class.php @@ -19,7 +19,7 @@ if (!class_exists('setting_sepchar')) { } if (!class_exists('setting_savedir')) { - class setting_savedir extends setting { + class setting_savedir extends setting_string { function update($input) { if ($this->is_protected()) return false; @@ -57,7 +57,7 @@ if (!class_exists('setting_authtype')) { } if (!class_exists('setting_im_convert')) { - class setting_im_convert extends setting { + class setting_im_convert extends setting_string { function update($input) { if ($this->is_protected()) return false; diff --git a/lib/plugins/config/style.css b/lib/plugins/config/style.css index 00160ec612a35344fde656c06e6f3f9d4ff8ea8b..fe0a1e4deb26da462f505cf6ede1623829285d69 100644 --- a/lib/plugins/config/style.css +++ b/lib/plugins/config/style.css @@ -12,15 +12,18 @@ #config__manager table {margin: 1em 0;} #config__manager td input.edit {width: 30em;} #config__manager td select.edit { } +#config__manager td textarea.edit {width: 27.5em; height: 4em;} #config__manager tr.default .input, #config__manager tr.default input, +#config__manager tr.default textarea, #config__manager tr.default select { background-color: #ccddff; } #config__manager tr.protected .input, #config__manager tr.protected input, +#config__manager tr.default textarea, #config__manager tr.protected select { background-color: #ffcccc; }