X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FDB%2FOrder.pm;h=b7bdae070e383f5b06f3e326bd67a95ec74f4b2c;hb=c7241bf7c547d63999898dee7b5dd486e4d122d3;hp=d61ec31ebcf402f859711cbb21ad8b00b2f93cf9;hpb=a71146462873484c46a08cbb42ff31c6df86dac4;p=kivitendo-erp.git diff --git a/SL/DB/Order.pm b/SL/DB/Order.pm index d61ec31eb..b7bdae070 100644 --- a/SL/DB/Order.pm +++ b/SL/DB/Order.pm @@ -164,6 +164,22 @@ sub convert_to_delivery_order { $delivery_order->save; $custom_shipto->save if $custom_shipto; $self->link_to_record($delivery_order); + # TODO extend link_to_record for items, otherwise long-term no d.r.y. + foreach my $item (@{ $delivery_order->items }) { + foreach (qw(orderitems)) { # expand if needed (delivery_order_items) + if ($item->{"converted_from_${_}_id"}) { + die unless $item->{id}; + RecordLinks->create_links('mode' => 'ids', + 'from_table' => $_, + 'from_ids' => $item->{"converted_from_${_}_id"}, + 'to_table' => 'delivery_order_items', + 'to_id' => $item->{id}, + ) || die; + delete $item->{"converted_from_${_}_id"}; + } + } + } + $self->update_attributes(delivered => 1); 1; })) { @@ -194,6 +210,16 @@ sub date { goto &transdate; } +sub digest { + my ($self) = @_; + + sprintf "%s %s %s (%s)", + $self->number, + $self->customervendor->name, + $self->amount_as_number, + $self->date->to_kivitendo; +} + 1; __END__