aboutsummaryrefslogtreecommitdiff
path: root/IkiWiki
diff options
context:
space:
mode:
authorJoey Hess <joey@kodama.kitenet.net>2008-08-03 20:20:25 -0400
committerJoey Hess <joey@kodama.kitenet.net>2008-08-03 20:20:25 -0400
commit2a712c8817417842ed06a7f2920c406d6ac94679 (patch)
tree6e37a4d78f1c427a41636488096b2010ad9cd3f6 /IkiWiki
parent39056453424dcb7e01f69c502192e45604d1fe84 (diff)
downloadikiwiki-2a712c8817417842ed06a7f2920c406d6ac94679.tar
ikiwiki-2a712c8817417842ed06a7f2920c406d6ac94679.tar.gz
use radio, not checkbox, for booleans
Had to do this due to one of CGI::FormBuilder's more annoying quirks -- it loses the value of a checkbox field with only one option, always treating it as checked.
Diffstat (limited to 'IkiWiki')
-rw-r--r--IkiWiki/Plugin/websetup.pm21
1 files changed, 13 insertions, 8 deletions
diff --git a/IkiWiki/Plugin/websetup.pm b/IkiWiki/Plugin/websetup.pm
index da2551489..7f4bce5e5 100644
--- a/IkiWiki/Plugin/websetup.pm
+++ b/IkiWiki/Plugin/websetup.pm
@@ -102,11 +102,14 @@ sub showfields ($$$@) { #{{{
my $name="enable.$plugin";
$form->field(
name => $name,
- label => "",
- type => "checkbox",
- options => [ [ 1 => sprintf(gettext("enable %s?"), $plugin) ] ],
+ label => sprintf(gettext("enable %s?"), $plugin),
+ type => "radio",
value => $enabled,
fieldset => $section,
+ options => [
+ [ 1 => gettext("Yes") ],
+ [ 0 => gettext("No") ]
+ ],
);
if ($plugin_forced) {
$form->field(name => $name, disabled => 1);
@@ -178,10 +181,13 @@ sub showfields ($$$@) { #{{{
elsif ($info{type} eq "boolean") {
$form->field(
name => $name,
- label => "",
- type => "checkbox",
+ label => $description,
+ type => "radio",
value => $value,
- options => [ [ 1 => $description ] ],
+ options => [
+ [ 1 => gettext("Yes") ],
+ [ 0 => gettext("No") ]
+ ],
fieldset => $section,
);
}
@@ -231,6 +237,7 @@ sub showform ($$) { #{{{
[plugins => gettext("plugins")]
],
action => $config{cgiurl},
+ table => 0,
template => {type => 'div'},
stylesheet => IkiWiki::baseurl()."style.css",
);
@@ -345,14 +352,12 @@ sub showform ($$) { #{{{
delete $rebuild{$field};
}
else {
- print STDERR ">>$key (@value) ($config{$key})\n";
$config{$key}=$value[0];
}
}
}
if (%rebuild && ! $form->field("rebuild_asked")) {
- print STDERR ">>".(join "," , keys %rebuild)."\n";
my $required=0;
foreach my $field ($form->field) {
$required=1 if $rebuild{$field};