X-Git-Url: http://git.shiar.net/perl/html-form-simple.git/blobdiff_plain/b01a7f21ade2de12b620970a9e7ae78cbabd95da..80de26e2b6b53f54ffb5232472e56c3225a101e1:/lib/HTML/Form/Simple.pm diff --git a/lib/HTML/Form/Simple.pm b/lib/HTML/Form/Simple.pm index 2c8ce8d..66958c3 100644 --- a/lib/HTML/Form/Simple.pm +++ b/lib/HTML/Form/Simple.pm @@ -71,8 +71,9 @@ sub hidden { my $self = shift; my ($name, $value, $attr) = $self->_attr(2, @_); - $attr = {type => 'hidden', name => $name, value => $value}; - #TODO: $attr + $attr->{name } = $name if defined $name; + $attr->{value} = $value if defined $value; + $attr->{type} = 'hidden' unless defined $attr->{type}; return $self->tag(input => $attr); } @@ -122,7 +123,7 @@ sub select { return wantarray ? @return : join('', @return); } else { - if (defined $attr->{id}) { + if (defined $attr->{id} and $attr->{id} ne '') { defined $_->{id} or defined $_->{value} and $_->{id} = $attr->{id}.'_'.$_->{value} for @options; } @@ -150,20 +151,46 @@ sub select { sub radio { my $self = shift; - my ($name, $value, $attr) = $self->_attr(2, @_); + my ($name, $label, $value, $attr) = $self->_attr(3, @_); - $self->select($name, [$value], {%$attr, type => 'radio'}); + if (not defined $value) { + if (defined $label) { + $value = ref $label eq 'ARRAY' ? [1 .. $#$label+1] : [1]; + } + else { + $value = [{}]; + } + } + elsif (ref $value ne 'ARRAY') { + $value = [$value]; + } + + if (defined $label) { + $_ = ref $_ eq 'HASH' ? {%$_} : {value => $_} for @$value; + $_->{label} = ref $label eq 'ARRAY' ? shift @$label : $label for @$value; + } + + $self->select($name, $value, {%$attr, type => 'radio'}); } sub check { my $self = shift; my ($name, $label, $checked, $attr) = $self->_attr(3, @_); - $attr->{label } = $label if defined $label; - $attr->{checked} = $checked if defined $checked; - $attr->{value } = '1' unless exists $attr->{value}; + my $rows = defined $label ? ref $label eq 'ARRAY' ? $label : [$label] : [{}]; + ref $_ eq 'HASH' or $_ = {label => $_} for @$rows; + if (defined $checked) { + if (ref $checked eq 'ARRAY') { + $_->{checked} = shift @$checked for @$rows; + push @$rows, map { {checked => $_} } @$checked; + } + else { + $_->{checked} = $checked for @$rows; + } + } + exists $rows->[$_]->{value} or $rows->[$_]->{value} = $_ + 1 for 0 .. $#$rows; - $self->select($name, [$attr], {type => 'checkbox'}); + $self->select($name, $rows, {%$attr, type => 'checkbox'}); } 1;