From: Moritz Bunkus Date: Fri, 1 Apr 2016 08:28:41 +0000 (+0200) Subject: Presenter: hidden_tag, javascript, checkbox_tag von L → Presenter::Tag verschoben X-Git-Tag: release-3.4.1~269 X-Git-Url: http://wagnertech.de/git?a=commitdiff_plain;h=b5f4fac196509681df791bc5e4ee3d8c7d2a4a41;p=kivitendo-erp.git Presenter: hidden_tag, javascript, checkbox_tag von L → Presenter::Tag verschoben Damit sind diese Funktionen auch direkt aus Perl-Code verfügbar, und man muss nicht mehr das unsägliche CGI benutzen, um Checkboxen zu rendern. --- diff --git a/SL/Presenter/Tag.pm b/SL/Presenter/Tag.pm index 1c25f38c8..e1a041d09 100644 --- a/SL/Presenter/Tag.pm +++ b/SL/Presenter/Tag.pm @@ -7,7 +7,7 @@ use SL::HTML::Restrict; use parent qw(Exporter); use Exporter qw(import); -our @EXPORT = qw(html_tag input_tag man_days_tag name_to_id select_tag stringify_attributes restricted_html); +our @EXPORT = qw(html_tag input_tag hidden_tag javascript man_days_tag name_to_id select_tag checkbox_tag stringify_attributes restricted_html); use Carp; @@ -62,6 +62,11 @@ sub input_tag { return $self->html_tag('input', undef, %attributes, name => $name, value => $value); } +sub hidden_tag { + my ($self, $name, $value, %attributes) = @_; + return $self->input_tag($name, $value, %attributes, type => 'hidden'); +} + sub man_days_tag { my ($self, $name, $object, %attributes) = @_; @@ -189,6 +194,36 @@ sub select_tag { return $self->html_tag('select', $code, %attributes, name => $name); } +sub checkbox_tag { + my ($self, $name, %attributes) = @_; + + _set_id_attribute(\%attributes, $name); + + $attributes{value} = 1 unless defined $attributes{value}; + my $label = delete $attributes{label}; + my $checkall = delete $attributes{checkall}; + my $for_submit = delete $attributes{for_submit}; + + if ($attributes{checked}) { + $attributes{checked} = 'checked'; + } else { + delete $attributes{checked}; + } + + my $code = ''; + $code .= $self->hidden_tag($name, 0, %attributes, id => $attributes{id} . '_hidden') if $for_submit; + $code .= $self->html_tag('input', undef, %attributes, name => $name, type => 'checkbox'); + $code .= $self->html_tag('label', $label, for => $attributes{id}) if $label; + $code .= $self->javascript(qq|\$('#$attributes{id}').checkall('$checkall');|) if $checkall; + + return $code; +} + +sub javascript { + my ($self, $data) = @_; + return $self->html_tag('script', $data, type => 'text/javascript'); +} + sub _set_id_attribute { my ($attributes, $name, $unique) = @_; diff --git a/SL/Template/Plugin/L.pm b/SL/Template/Plugin/L.pm index 48960097a..bd3edda55 100644 --- a/SL/Template/Plugin/L.pm +++ b/SL/Template/Plugin/L.pm @@ -62,8 +62,11 @@ sub _call_presenter { sub name_to_id { return _call_presenter('name_to_id', @_); } sub html_tag { return _call_presenter('html_tag', @_); } +sub hidden_tag { return _call_presenter('hidden_tag', @_); } sub select_tag { return _call_presenter('select_tag', @_); } +sub checkbox_tag { return _call_presenter('checkbox_tag', @_); } sub input_tag { return _call_presenter('input_tag', @_); } +sub javascript { return _call_presenter('javascript', @_); } sub truncate { return _call_presenter('truncate', @_); } sub simple_format { return _call_presenter('simple_format', @_); } sub part_picker { return _call_presenter('part_picker', @_); } @@ -95,30 +98,6 @@ sub textarea_tag { return $self->html_tag('textarea', $content, %attributes, name => $name); } -sub checkbox_tag { - my ($self, $name, %attributes) = _hashify(2, @_); - - _set_id_attribute(\%attributes, $name); - $attributes{value} = 1 unless defined $attributes{value}; - my $label = delete $attributes{label}; - my $checkall = delete $attributes{checkall}; - my $for_submit = delete $attributes{for_submit}; - - if ($attributes{checked}) { - $attributes{checked} = 'checked'; - } else { - delete $attributes{checked}; - } - - my $code = ''; - $code .= $self->hidden_tag($name, 0, %attributes, id => $attributes{id} . '_hidden') if $for_submit; - $code .= $self->html_tag('input', undef, %attributes, name => $name, type => 'checkbox'); - $code .= $self->html_tag('label', $label, for => $attributes{id}) if $label; - $code .= $self->javascript(qq|\$('#$attributes{id}').checkall('$checkall');|) if $checkall; - - return $code; -} - sub radio_button_tag { my ($self, $name, %attributes) = _hashify(2, @_); @@ -141,11 +120,6 @@ sub radio_button_tag { return $code; } -sub hidden_tag { - my ($self, $name, $value, %attributes) = _hashify(3, @_); - return $self->input_tag($name, $value, %attributes, type => 'hidden'); -} - sub div_tag { my ($self, $content, @slurp) = @_; return $self->html_tag('div', $content, @slurp); @@ -206,11 +180,6 @@ sub yes_no_tag { return $self->select_tag($name, [ [ 1 => $::locale->text('Yes') ], [ 0 => $::locale->text('No') ] ], default => $value ? 1 : 0, %attributes); } -sub javascript { - my ($self, $data) = @_; - return $self->html_tag('script', $data, type => 'text/javascript'); -} - sub stylesheet_tag { my $self = shift; my $code = '';