From: Jan Büren Date: Sat, 4 Jul 2020 10:10:20 +0000 (+0200) Subject: Merge remote-tracking branch 'origin/f-leistungsdatum' X-Git-Tag: release-3.5.6.1~160 X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/commitdiff_plain/9a14696176033f03c97244f420d93f9c15efed61?hp=b5abb626b03cbca0ec7189894375c31d7b588951 Merge remote-tracking branch 'origin/f-leistungsdatum' --- diff --git a/SL/Controller/Order.pm b/SL/Controller/Order.pm index e4644983d..689c597aa 100644 --- a/SL/Controller/Order.pm +++ b/SL/Controller/Order.pm @@ -370,7 +370,8 @@ sub action_show_email_dialog { $form->{$self->nr_key()} = $self->order->number; $form->{formname} = $self->type; $form->{type} = $self->type; - $form->{language} = 'de'; + $form->{language} = '_' . $self->order->language->template_code if $self->order->language; + $form->{language_id} = $self->order->language->id if $self->order->language; $form->{format} = 'pdf'; $email_form->{subject} = $form->generate_email_subject(); diff --git a/SL/DB/Helper/ZUGFeRD.pm b/SL/DB/Helper/ZUGFeRD.pm index 7ab425d48..211e88535 100644 --- a/SL/DB/Helper/ZUGFeRD.pm +++ b/SL/DB/Helper/ZUGFeRD.pm @@ -325,7 +325,7 @@ sub _totals { $params{xml}->dataElement("ram:LineTotalAmount", _r2($self->netamount)); $params{xml}->dataElement("ram:TaxBasisTotalAmount", _r2($self->netamount)); - $params{xml}->dataElement("ram:TaxTotalAmount", _r2(sum(values %{ $params{ptc_data}->{taxes} })), currencyID => "EUR"); + $params{xml}->dataElement("ram:TaxTotalAmount", _r2(sum(values %{ $params{ptc_data}->{taxes_by_tax_id} })), currencyID => "EUR"); $params{xml}->dataElement("ram:GrandTotalAmount", _r2($self->amount)); $params{xml}->dataElement("ram:TotalPrepaidAmount", _r2($self->paid)); $params{xml}->dataElement("ram:DuePayableAmount", _r2($self->amount - $self->paid)); diff --git a/SL/DBUpgrade2.pm b/SL/DBUpgrade2.pm index 3918ad40d..0b14eca5b 100644 --- a/SL/DBUpgrade2.pm +++ b/SL/DBUpgrade2.pm @@ -56,9 +56,10 @@ sub parse_dbupdate_controls { $file =~ s|.*/||; my $control = { - "priority" => 1000, - "depends" => [], - "locales" => [], + priority => 1000, + depends => [], + required_by => [], + locales => [], }; while () { @@ -71,8 +72,8 @@ sub parse_dbupdate_controls { my @fields = split(/\s*:\s*/, $_, 2); next unless (scalar(@fields) == 2); - if ($fields[0] eq "depends") { - push(@{$control->{"depends"}}, split(/\s+/, $fields[1])); + if ($fields[0] =~ m{^(?:depends|required_by)$}) { + push(@{$control->{$fields[0]}}, split(/\s+/, $fields[1])); } elsif ($fields[0] eq "locales") { push @{$control->{locales}}, $fields[1]; } else { @@ -100,7 +101,7 @@ sub parse_dbupdate_controls { delete @{$control}{qw(depth applied)}; - my @unknown_keys = grep { !m{^ (?: depends | description | file | ignore | locales | may_fail | priority | superuser_privileges | tag ) $}x } keys %{ $control }; + my @unknown_keys = grep { !m{^ (?: depends | required_by | description | file | ignore | locales | may_fail | priority | superuser_privileges | tag ) $}x } keys %{ $control }; if (@unknown_keys) { _control_error($form, $file_name, sprintf($locale->text("Unknown control fields: #1", join(' ', sort({ lc $a cmp lc $b } @unknown_keys))))); } @@ -114,6 +115,15 @@ sub parse_dbupdate_controls { close(IN); } + foreach my $name (keys %all_controls) { + my $control = $all_controls{$name}; + + foreach my $dependency (@{ delete $control->{required_by} }) { + _control_error($form, $control->{"file"}, sprintf($locale->text("Unknown dependency '%s'."), $dependency)) if (!defined($all_controls{$dependency})); + push @{ $all_controls{$dependency}->{depends} }, $name; + } + } + foreach my $control (values(%all_controls)) { foreach my $dependency (@{$control->{"depends"}}) { _control_error($form, $control->{"file"}, sprintf($locale->text("Unknown dependency '%s'."), $dependency)) if (!defined($all_controls{$dependency})); diff --git a/js/kivi.Order.js b/js/kivi.Order.js index f50db0462..e4cebb2f5 100644 --- a/js/kivi.Order.js +++ b/js/kivi.Order.js @@ -94,6 +94,7 @@ namespace('kivi.Order', function(ns) { if (!ns.check_cv()) return; var data = $('#order_form').serializeArray(); + data.push({ name: 'order.language_id', value: $('#language_id').val() }); // language from print options data.push({ name: 'action', value: 'Order/show_email_dialog' }); $.post("controller.pl", data, kivi.eval_json_result); diff --git a/templates/webpages/common/render_cvar_input.html b/templates/webpages/common/render_cvar_input.html index 96b69c627..d40037178 100644 --- a/templates/webpages/common/render_cvar_input.html +++ b/templates/webpages/common/render_cvar_input.html @@ -13,7 +13,7 @@ [% 'Element disabled' | $T8 %] [%- END %] [%- ELSIF ( var.config .type == 'bool' ) %] - [% L.checkbox_tag(var_name, checked = var.value) %] + [% L.checkbox_tag(var_name, checked = var.value, for_submit = 1) %] [%- ELSIF ( var.config .type == 'textfield' ) %] [% L.textarea_tag(var_name, var.value, cols = var.config.processed_options.WIDTH, rows = var.config.processed_options.HEIGHT) %] [%- ELSIF ( var.config.type == 'date' ) %] diff --git a/templates/webpages/ir/form_header.html b/templates/webpages/ir/form_header.html index 5b983c975..ab53f22b2 100644 --- a/templates/webpages/ir/form_header.html +++ b/templates/webpages/ir/form_header.html @@ -154,6 +154,7 @@ + [% 'Delivery Date' | $T8 %] [% L.date_tag('deliverydate', deliverydate) %]