X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FForm.pm;h=d155a0d7f13d9c775b8f54e8b1137ef40bc8bd54;hb=5df2b57a097f66f6cecba0aa577c7aaba3422ab6;hp=9936630f3c733b63215cf26f5c6f731584745e40;hpb=696aad9cd711ed3a92721db045ad0b7067bb1a17;p=kivitendo-erp.git diff --git a/SL/Form.pm b/SL/Form.pm index 9936630f3..d155a0d7f 100644 --- a/SL/Form.pm +++ b/SL/Form.pm @@ -41,7 +41,7 @@ use Data::Dumper; use CGI; use CGI::Ajax; use Cwd; -use List::Util qw(min max); +use IO::File; use SL::Auth; use SL::Auth::DB; use SL::Auth::LDAP; @@ -471,7 +471,7 @@ sub isblank { my ($self, $name, $msg) = @_; my $curr = $self; - foreach my $part (split /\./, $name) { + foreach my $part (split m/\./, $name) { if (!$curr->{$part} || ($curr->{$part} =~ /^\s*$/)) { $self->error($msg); } @@ -512,7 +512,7 @@ sub create_http_response { } my %cgi_params = ('-type' => $params{content_type}); - $cgi_params{'-charset'} = $params{charset} if ($parmas{charset}); + $cgi_params{'-charset'} = $params{charset} if ($params{charset}); my $output = $cgi->header('-cookie' => $session_cookie, %cgi_params); @@ -730,13 +730,26 @@ sub parse_html_template { map { $additional_params->{$_} ||= $self->{$_} } keys %{ $self }; + my $in = IO::File->new($file, 'r'); + + if (!$in) { + print STDERR "Error opening template file: $!"; + $main::lxdebug->leave_sub(); + return ''; + } + + my $input = join('', <$in>); + $in->close(); + + if ($main::locale) { + $input = $main::locale->{iconv}->convert($input); + } + my $output; - if (!$template->process($file, $additional_params, \$output)) { + if (!$template->process(\$input, $additional_params, \$output)) { print STDERR $template->error(); } - $output = $main::locale->{iconv}->convert($output) if ($main::locale); - $main::lxdebug->leave_sub(); return $output; @@ -920,16 +933,19 @@ sub format_amount_units { my $self = shift; my %params = @_; - Common::check_params(\%params, qw(amount part_unit)); - my $myconfig = \%main::myconfig; - my $amount = $params{amount}; + my $amount = $params{amount} * 1; my $places = $params{places}; my $part_unit_name = $params{part_unit}; my $amount_unit_name = $params{amount_unit}; my $conv_units = $params{conv_units}; my $max_places = $params{max_places}; + if (!$part_unit_name) { + $main::lxdebug->leave_sub(); + return ''; + } + AM->retrieve_all_units(); my $all_units = $main::all_units; @@ -1898,6 +1914,12 @@ sub _get_contacts { $key = "all_contacts" unless ($key); + if (!$id) { + $self->{$key} = []; + $main::lxdebug->leave_sub(); + return; + } + my $query = qq|SELECT cp_id, cp_cv_id, cp_name, cp_givenname, cp_abteilung | . qq|FROM contacts | . @@ -1966,10 +1988,15 @@ sub _get_shipto { $key = "all_shipto" unless ($key); - # get shipping addresses - my $query = qq|SELECT * FROM shipto WHERE trans_id = ?|; + if ($vc_id) { + # get shipping addresses + my $query = qq|SELECT * FROM shipto WHERE trans_id = ?|; + + $self->{$key} = selectall_hashref_query($self, $dbh, $query, $vc_id); - $self->{$key} = selectall_hashref_query($self, $dbh, $query, $vc_id); + } else { + $self->{$key} = []; + } $main::lxdebug->leave_sub(); }