X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/8177c1504c953111d190d91a90523f6042bea711..0e0ff15052f7cb7ed1a2b04235a8a217da97a183:/SL/Template/Plugin/L.pm diff --git a/SL/Template/Plugin/L.pm b/SL/Template/Plugin/L.pm index 40e132a86..d1ecdbd8c 100644 --- a/SL/Template/Plugin/L.pm +++ b/SL/Template/Plugin/L.pm @@ -5,6 +5,24 @@ use Template::Plugin; use strict; +{ # This will give you an id for identifying html tags and such. + # It's guaranteed to be unique unless you exceed 10 mio calls per request. + # Do not use these id's to store information across requests. +my $_id_sequence = int rand 1e7; +sub _tag_id { + return $_id_sequence = ($_id_sequence + 1) % 1e7; +} +} + +sub _H { + my $string = shift; + return $::locale->quote_special_chars('HTML', $string); +} + +sub _hashify { + return (@_ && (ref($_[0]) eq 'HASH')) ? %{ $_[0] } : @_; +} + sub new { my $class = shift; my $context = shift; @@ -12,15 +30,25 @@ sub new { return bless { }, $class; } +sub name_to_id { + my $self = shift; + my $name = shift; + + $name =~ s/[^\w_]/_/g; + $name =~ s/_+/_/g; + + return $name; +} + sub attributes { my $self = shift; - my $options = shift || {}; + my %options = _hashify(@_); my @result = (); - while (my ($name, $value) = each %{ $options }) { + while (my ($name, $value) = each %options) { next unless $name; $value ||= ''; - push @result, "${name}=\"" . $::locale->quote_special_chars('HTML', $value) . '"'; + push @result, _H($name) . '="' . _H($value) . '"'; } return @result ? ' ' . join(' ', @result) : ''; @@ -30,33 +58,67 @@ sub html_tag { my $self = shift; my $tag = shift; my $content = shift; - my $attributes = $self->attributes(shift || {}); + my $attributes = $self->attributes(@_); return "<${tag}${attributes}/>" unless $content; return "<${tag}${attributes}>${content}"; } sub select_tag { - my $self = shift; - my $name = shift; - my $options_str = shift; - my $attributes = shift || {}; + my $self = shift; + my $name = shift; + my $options_str = shift; + my %attributes = _hashify(@_); - $attributes->{name} = $name; - $attributes->{id} ||= $name; + $attributes{id} ||= $self->name_to_id($name); - return $self->html_tag('select', $options_str, $attributes); + return $self->html_tag('select', $options_str, %attributes, name => $name); +} + +sub checkbox_tag { + my $self = shift; + my $name = shift; + my %attributes = _hashify(@_); + + $attributes{id} ||= $self->name_to_id($name); + $attributes{value} = 1 unless defined $attributes{value}; + my $label = delete $attributes{label}; + + if ($attributes{checked}) { + $attributes{checked} = 'checked'; + } else { + delete $attributes{checked}; + } + + my $code = $self->html_tag('input', undef, %attributes, name => $name, type => 'checkbox'); + $code .= $self->html_tag('label', $label, for => $attributes{id}) if $label; + + return $code; +} + +sub input_tag { + my $self = shift; + my $name = shift; + my $value = shift; + my %attributes = _hashify(@_); + + $attributes{id} ||= $self->name_to_id($name); + $attributes{type} ||= 'text'; + + return $self->html_tag('input', undef, %attributes, name => $name, value => $value); } sub options_for_select { my $self = shift; my $collection = shift; - my $options = shift || {}; + my %options = _hashify(@_); - my $value_key = $options->{value} || 'id'; - my $title_key = $options->{title} || $value_key; + my $value_key = $options{value} || 'id'; + my $title_key = $options{title} || $value_key; + + my @elements = (); + push @elements, [ undef, $options{empty_title} || '' ] if $options{with_empty}; - my @tags = (); if ($collection && (ref $collection eq 'ARRAY')) { foreach my $element (@{ $collection }) { my @result = !ref $element ? ( $element, $element ) @@ -64,14 +126,49 @@ sub options_for_select { : ref $element eq 'HASH' ? ( $element->{$value_key}, $element->{$title_key} ) : ( $element->$value_key, $element->$title_key ); - my %attributes = ( value => $result[0] ); - $attributes{selected} = 'selected' if $options->{default} && ($options->{default} eq ($result[0] || '')); - - push @tags, $self->html_tag('option', $result[1], \%attributes); + push @elements, \@result; } } - return join('', @tags); + my $code = ''; + foreach my $result (@elements) { + my %attributes = ( value => $result->[0] ); + $attributes{selected} = 'selected' if $options{default} && ($options{default} eq ($result->[0] || '')); + + $code .= $self->html_tag('option', _H($result->[1]), %attributes); + } + + return $code; +} + +sub javascript { + my ($self, $data) = @_; + return $self->html_tag('script', $data, type => 'text/javascript'); +} + +sub date_tag { + my ($self, $name, $value, @slurp) = @_; + my %params = _hashify(@slurp); + my $name_e = _H($name); + my $seq = _tag_id(); + + $params{cal_align} ||= 'BR'; + + $self->input_tag($name, $value, + size => 11, + title => _H($::myconfig{dateformat}), + onBlur => 'check_right_date_format(this)', + %params, + ) . ((!$params{no_cal}) ? + $self->html_tag('img', undef, + src => 'image/calendar.png', + id => "trigger$seq", + title => _H($::myconfig{dateformat}), + %params, + ) . + $self->javascript( + "Calendar.setup({ inputField: '$name_e', ifFormat: '$::myconfig{jsc_dateformat}', align: '$params{cal_align}', button: 'trigger$seq' });" + ) : ''); } 1; @@ -101,22 +198,77 @@ functions that create HTML tags from various kinds of data sources. =head1 FUNCTIONS +=head2 LOW-LEVEL FUNCTIONS + =over 4 -=item C +=item C + +Converts a name to a HTML id by replacing various characters. -Creates a string from all elements in C<\%items> suitable for usage as +=item C + +Creates a string from all elements in C<%items> suitable for usage as HTML tag attributes. Keys and values are HTML escaped even though keys must not contain non-ASCII characters for browsers to accept them. -=item C +=item C Creates an opening and closing HTML tag for C<$tag_name> and puts C<$content_string> between the two. If C<$content_string> is undefined or empty then only a Etag/E tag will be created. Attributes are key/value pairs added to the opening tag. -=item C +C<$content_string> is not HTML escaped. + +=back + +=head2 HIGH-LEVEL FUNCTIONS + +=over 4 + +=item C + +Creates a HTML 'select' tag named C<$name> with the contents +C<$options_string> and with arbitrary HTML attributes from +C<%attributes>. The tag's C defaults to C. + +The $options_string is usually created by the C +function. + +=item C + +Creates a HTML 'input type=text' tag named C<$name> with the value +C<$value> and with arbitrary HTML attributes from C<%attributes>. The +tag's C defaults to C. + +=item C + +Creates a HTML 'input type=checkbox' tag named C<$name> with arbitrary +HTML attributes from C<%attributes>. The tag's C defaults to +C. The tag's C defaults to C<1>. + +If C<%attributes> contains a key C