X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/d8d6602479931e667fc6844b3bb59dd7a5219138..c21d2acca00997c4ca0be66f053dfdd0180f68f8:/SL/DB/Helper/PriceTaxCalculator.pm diff --git a/SL/DB/Helper/PriceTaxCalculator.pm b/SL/DB/Helper/PriceTaxCalculator.pm index bedc69aad..07ad5b11d 100644 --- a/SL/DB/Helper/PriceTaxCalculator.pm +++ b/SL/DB/Helper/PriceTaxCalculator.pm @@ -37,7 +37,7 @@ sub calculate_prices_and_taxes { exchangerate => undef, is_sales => $self->can('customer') && $self->customer, is_invoice => (ref($self) =~ /Invoice/) || $params{invoice}, - items => { }, + items => [ ], ); _get_exchangerate($self, \%data, %params); @@ -57,7 +57,7 @@ sub calculate_prices_and_taxes { return $self unless wantarray; - return map { ($_ => $data{$_}) } qw(taxes amounts amounts_cogs allocated exchangerate assembly_items); + return map { ($_ => $data{$_}) } qw(taxes amounts amounts_cogs allocated exchangerate assembly_items items); } sub _get_exchangerate { @@ -149,12 +149,12 @@ sub _calculate_item { $data->{last_incex_chart_id} = $chart->id if $data->{is_sales}; - $data->{items}->{ $item->id } = { + push @{ $data->{items} }, { linetotal => $linetotal, linetotal_cost => $linetotal_cost, sellprice => $sellprice, tax_amount => $tax_amount, - taxkey => $taxkey, + taxkey_id => $taxkey->id, }; _dbg("CALCULATE! ${idx} i.qty " . $item->qty . " i.sellprice " . $item->sellprice . " sellprice $sellprice num_dec $num_dec taxamount $tax_amount " . @@ -351,12 +351,21 @@ The exchangerate used for the calculation. =item C -A hashref. For each line item this hashref contains an entry with -additional values that have been calculated for that item but that -aren't stored in the item object itself. These include C, -C, C, C and C. +An array reference. For each line item this array contains a hash ref +entry with additional values that have been calculated for that item +but that aren't stored in the item object itself. These include +C, C, C, C and +C. -The items are hashed by their IDs. +The items are stored in the same order the items are stored in the +object that L has been called on. + +For example: + + my $invoice = SL::DB::Invoice->new(id => 12345)->load; + my %data = $invoice->calculate_prices_and_taxes; + + print "line total of second item: " . $data{items}->[1]->{linetotal}; =back