From: Bernd Bleßmann Date: Mon, 15 Apr 2019 09:07:35 +0000 (+0200) Subject: Presenter::Tag: radio_button_tag aus Plugin/L verschoben X-Git-Tag: kivitendo-mebil_0.1-0~9^2~463 X-Git-Url: http://wagnertech.de/git?a=commitdiff_plain;h=94ca5d5182fbe9e07ac9217f191751a156bd230f;p=kivitendo-erp.git Presenter::Tag: radio_button_tag aus Plugin/L verschoben --- diff --git a/SL/Presenter/Tag.pm b/SL/Presenter/Tag.pm index 8929dc5e2..ab4586546 100644 --- a/SL/Presenter/Tag.pm +++ b/SL/Presenter/Tag.pm @@ -11,7 +11,7 @@ our @EXPORT_OK = qw( html_tag input_tag hidden_tag javascript man_days_tag name_to_id select_tag checkbox_tag button_tag submit_tag ajax_submit_tag input_number_tag stringify_attributes restricted_html textarea_tag link_tag date_tag - div_tag); + div_tag radio_button_tag); our %EXPORT_TAGS = (ALL => \@EXPORT_OK); use Carp; @@ -259,6 +259,28 @@ sub checkbox_tag { return $code; } +sub radio_button_tag { + my ($name, %attributes) = @_; + + $attributes{value} = 1 unless exists $attributes{value}; + + _set_id_attribute(\%attributes, $name, 1); + my $label = delete $attributes{label}; + + _set_id_attribute(\%attributes, $name . '_' . $attributes{value}); + + if ($attributes{checked}) { + $attributes{checked} = 'checked'; + } else { + delete $attributes{checked}; + } + + my $code = html_tag('input', undef, %attributes, name => $name, type => 'radio'); + $code .= html_tag('label', $label, for => $attributes{id}) if $label; + + return $code; +} + sub button_tag { my ($onclick, $value, %attributes) = @_; @@ -540,6 +562,16 @@ If C<%attributes> contains a key C then the value is taken as a JQuery selector and clicking this checkbox will also toggle all checkboxes matching the selector. +=item C + +Creates a HTML 'input type=radio' tag named C<$name> with arbitrary +HTML attributes from C<%attributes>. The tag's C defaults to +C<1>. The tag's C defaults to C. + +If C<%attributes> contains a key C