use Carp;
use List::Util qw(first);
-use List::MoreUtils qw(pairwise);
+
+use Rose::DB::Object::Helpers ();
use SL::DB::MetaSetup::Invoice;
use SL::DB::Manager::Invoice;
use SL::DB::Helper::PriceTaxCalculator;
use SL::DB::Helper::PriceUpdater;
use SL::DB::Helper::TransNumberGenerator;
-use SL::DB::CustomVariable;
__PACKAGE__->meta->add_relationship(
invoiceitems => {
return $self->paid >= $self->amount;
}
+sub _clone_orderitem_delivery_order_item_cvar {
+ my ($cvar) = @_;
+
+ my $cloned = Rose::DB::Object::Helpers::clone_and_reset($_);
+ $cloned->sub_module('invoice');
+
+ return $cloned;
+}
+
sub new_from {
my ($class, $source, %params) = @_;
my $invoice = $class->new(%args, %params);
my @items = map {
- my $source_item = $_;
+ my $source_item = $_;
+ my @custom_variables = map { _clone_orderitem_delivery_order_item_cvar($_) } @{ $source_item->custom_variables };
+
SL::DB::InvoiceItem->new(map({ ( $_ => $source_item->$_ ) }
qw(parts_id description qty sellprice discount project_id serialnumber pricegroup_id ordnumber transdate cusordnumber unit
base_qty longdescription lastcost price_factor_id), @item_columns),
- deliverydate => $source_item->reqdate,
- fxsellprice => $source_item->sellprice,);
- } @{ $source->items_sorted };
+ deliverydate => $source_item->reqdate,
+ fxsellprice => $source_item->sellprice,
+ custom_variables => \@custom_variables,
+ );
- my $i = 0;
- foreach my $item (@items) {
- my $source_cvars = $source->items_sorted->[$i]->cvars_by_config;
- my $target_cvars = $item->cvars_by_config;
- pairwise { $a->value($b->value) } @{ $target_cvars }, @{ $source_cvars };
- $i++;
- }
+ } @{ $source->items_sorted };
$invoice->invoiceitems(\@items);