1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85
|
#!/usr/bin/perl -w
=head1 NAME
Debconf::Element::Web::Multiselect - A multi select box on a form
=cut
package Debconf::Element::Web::Multiselect;
use strict;
use base qw(Debconf::Element::Multiselect);
=head1 DESCRIPTION
This element handles a multi select box on a web form.
=head1 METHODS
=over 4
=item show
Generates and returns html representing the multi select box.
=cut
sub show {
my $this=shift;
$_=$this->question->extended_description;
s/\n/\n<br>\n/g;
$_.="\n<p>\n";
my %value = map { $_ => 1 } $this->translate_default;
my $id=$this->id;
$_.="<b>".$this->question->description."</b>\n<select multiple name=\"$id\">\n";
my $c=0;
foreach my $x ($this->question->choices_split) {
if (! $value{$x}) {
$_.="<option value=".$c++.">$x\n";
}
else {
$_.="<option value=".$c++." selected>$x\n";
}
}
$_.="</select>\n";
return $_;
}
=item value
When setting a value, this expects to be passed all the values they
selected. It processes these into the form used internally.
=cut
sub value {
my $this=shift;
return $this->SUPER::value() unless @_;
# This forces the function that provides values to this method
# to be called in scalar context, so we are passed a list of
# the selected values.
my @values=@_;
# Get the choices in the C locale.
$this->question->template->i18n('');
my @choices=$this->question->choices_split;
$this->question->template->i18n(1);
$this->SUPER::value(join(', ', $this->order_values(map { $choices[$_] } @values)));
}
=back
=head1 AUTHOR
Joey Hess <joeyh@debian.org>
=cut
1
|