X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/9680897326dad8cc0b35336855f658a580d6bbe5..refs/heads/order_controller:/SL/Controller/Order.pm diff --git a/SL/Controller/Order.pm b/SL/Controller/Order.pm index 3203485fa..83e7219a6 100644 --- a/SL/Controller/Order.pm +++ b/SL/Controller/Order.pm @@ -295,19 +295,42 @@ sub action_customer_vendor_changed { : $::myconfig{taxincluded_checked}); } + $self->order->payment_id($self->order->$cv_method->payment_id); + $self->order->delivery_term_id($self->order->$cv_method->delivery_term_id); + $self->_recalc(); $self->js - ->replaceWith('#order_cp_id', $self->build_contact_select) - ->replaceWith('#order_shipto_id', $self->build_shipto_select) - ->val( '#order_taxzone_id', $self->order->taxzone_id) - ->val( '#order_taxincluded', $self->order->taxincluded) + ->replaceWith('#order_cp_id', $self->build_contact_select) + ->replaceWith('#order_shipto_id', $self->build_shipto_select) + ->val( '#order_taxzone_id', $self->order->taxzone_id) + ->val( '#order_taxincluded', $self->order->taxincluded) + ->val( '#order_payment_id', $self->order->payment_id) + ->val( '#order_delivery_term_id', $self->order->delivery_term_id) ->focus( '#order_' . $self->cv . '_id'); $self->_js_redisplay_amounts_and_taxes; $self->js->render(); } +sub action_unit_changed { + my ($self) = @_; + + my $idx = first_index { $_ eq $::form->{item_id} } @{ $::form->{orderitem_ids} }; + my $item = $self->order->items->[$idx]; + + my $old_unit_obj = SL::DB::Unit->new(name => $::form->{old_unit})->load; + $item->sellprice($item->unit_obj->convert_to($item->sellprice, $old_unit_obj)); + + $self->_recalc(); + + $self->js + ->run('update_sellprice', $::form->{item_id}, $item->sellprice_as_number); + $self->_js_redisplay_linetotals; + $self->_js_redisplay_amounts_and_taxes; + $self->js->render(); +} + sub action_add_item { my ($self) = @_; @@ -333,6 +356,7 @@ sub action_add_item { ->val('#add_item_discount_as_percent', '') ->run('row_table_scroll_down') ->run('row_set_keyboard_events_by_id', $item_id) + ->run('set_unit_change_with_oldval_by_id', $item_id) ->on('.recalc', 'change', 'recalc_amounts_and_taxes') ->on('.reformat_number', 'change', 'reformat_number') ->focus('#add_item_parts_id_name'); @@ -348,15 +372,27 @@ sub action_show_multi_items_dialog { } sub action_multi_items_update_result { - $_[0]->render('order/tabs/_multi_items_result', { layout => 0 }, - multi_items => $_[0]->multi_items_models->get); + my $max_count = 100; + my $count = $_[0]->multi_items_models->count; + + if ($count == 0) { + my $text = SL::Presenter::EscapedText->new(text => $::locale->text('No results.')); + $_[0]->render($text, { layout => 0 }); + } elsif ($count > $max_count) { + my $text = SL::Presenter::EscapedText->new(text => $::locale->text('Too many results (#1 from #2).', $count, $max_count)); + $_[0]->render($text, { layout => 0 }); + } else { + my $multi_items = $_[0]->multi_items_models->get; + $_[0]->render('order/tabs/_multi_items_result', { layout => 0 }, + multi_items => $multi_items); + } } sub action_add_multi_items { my ($self) = @_; - my @form_attr = grep { $_->{qty} } @{ $::form->{add_multi_items} }; - return unless scalar @form_attr; + my @form_attr = grep { $_->{qty_as_number} } @{ $::form->{add_multi_items} }; + return $self->js->render() unless scalar @form_attr; my @items; foreach my $attr (@form_attr) { @@ -372,7 +408,8 @@ sub action_add_multi_items { $self->js ->append('#row_table_id', $row_as_html) - ->run('row_set_keyboard_events_by_id', $item_id); + ->run('row_set_keyboard_events_by_id', $item_id) + ->run('set_unit_change_with_oldval_by_id', $item_id); } $self->js