Projekt

Allgemein

Profil

« Zurück | Weiter » 

Revision 96f6aa8d

Von Tamino Steinert vor etwa 2 Jahren hinzugefügt

  • ID 96f6aa8d0faf231db82411407e5b0dea3f5698cb
  • Vorgänger 725a341d
  • Nachfolger 33db5e13

PurchaseInvoice: Auswahl der Warenbuchungsmethode pro Warenzeile

Bei Artikeln(type=parts) kann der Nutzer auswählen welche
Warenbuchungsmethode dieser haben will.

Unterschiede anzeigen:

bin/mozilla/io.pl
bin stock_in_out
);
my @row2_sort = qw(
expense_chart tax inventory_chart serialnr projectnr reqdate subtotal recurring_billing_mode marge listprice lastcost onhand
tax_chart tax serialnr projectnr reqdate subtotal recurring_billing_mode marge listprice lastcost onhand
);
# serialnr is important for delivery_orders
if ($form->{type} eq 'sales_delivery_order') {
......
lastcost => { value => $locale->text('EK'), display => $show_marge, },
onhand => { value => $locale->text('On Hand'), display => 1, },
vendor_partnumber => { width => 8, value => $locale->text('Vendor Part Number'), display => $is_delivery_order && $is_purchase, },
expense_chart => { value => $locale->text('Expense Account'), display => $is_purchase && $is_invoice },
tax_chart => { value => "", display => $is_purchase && $is_invoice },
tax => { value => $locale->text('Tax'), display => $is_purchase && $is_invoice },
inventory_chart => { value => "", display => $is_purchase && $is_invoice }, # only disply for type='part'
);
my @HEADER = map { $column_def{$_} } @header_sort;
......
$column_data{stock_in_out} = calculate_stock_in_out($i);
}
$column_data{expense_chart} = SL::Presenter::Chart::chart_picker(
"expense_chart_id_$i", $form->{"expense_chart_id_$i"},
type => "AP_amount", style => "width: 150px") .
'<script type="text/javascript">
# tax_chart
my ($tax_chart_id, $chart_title, $chart_picker);
if ($record_item && $record_item->part && ($record_item->part->type eq 'part')) {
my $tax_chart_type = $form->{"tax_chart_type_$i"};
$tax_chart_type ||=
$::instance_conf->get_inventory_system eq 'periodic' ? 'expense'
: 'inventory';
$tax_chart_id = $form->{"${tax_chart_type}_chart_id_$i"};
$chart_title = SL::Presenter::Tag::select_tag("tax_chart_type_$i", [
{value => 'expense', title => $locale->text('Expense Account')},
{value => 'inventory', title => $locale->text('Inventory Account')},
],
value_key => 'value', title_key => 'title',
default => $tax_chart_type,
onchange => "kivi.io.update_tax_chart_picker(this.value, $i)",
);
$chart_picker =
SL::Presenter::Tag::html_tag('span',
SL::Presenter::Chart::chart_picker(
"expense_chart_id_$i", $form->{"expense_chart_id_$i"},
type => "AP_amount", style => "width: 150px"),
id => "expense_chart_span_$i",
style => $tax_chart_type eq 'expense' ? '' : 'display:none',
)
.
SL::Presenter::Tag::html_tag('span',
SL::Presenter::Chart::chart_picker(
"inventory_chart_id_$i", $form->{"inventory_chart_id_$i"},
type => "IC", style => "width: 150px"),
id => "inventory_chart_span_$i",
style => $tax_chart_type eq 'inventory' ? '' : 'display:none',
);
} else {
$tax_chart_id = $form->{"expense_chart_id_$i"};
$chart_title = $locale->text('Expense Account');
$chart_picker = SL::Presenter::Chart::chart_picker(
"expense_chart_id_$i", $form->{"expense_chart_id_$i"},
type => "AP_amount", style => "width: 150px");
}
# change tax dropdown after change
my $js_set_on_select_item = '<script type="text/javascript">
<!--
$(document).ready(function() {
$("#expense_chart_id_' . $i . q'").on("set_item:ChartPicker", function(e, item) {
$("#expense_chart_id_' . $i . '").on("set_item:ChartPicker", function(e, item) {
kivi.io.update_tax_ids(this);
});
$("#inventory_chart_id_' . $i . '").on("set_item:ChartPicker", function(e, item) {
kivi.io.update_tax_ids(this);
});
});
-->
</script>
'; # change tax dropdown after change
';
$column_data{tax_chart} = SL::Presenter::Tag::html_tag('span',
$chart_title . $chart_picker . $js_set_on_select_item);
my $tax_value_title_sub = sub {
my $item = shift;
......
my @taxes = ();
if ($form->{"expense_chart_id_$i"}) {
@taxes = IO->get_active_taxes_for_chart($form->{"expense_chart_id_$i"},
@taxes = IO->get_active_taxes_for_chart($tax_chart_id,
$form->{"reqdate_$i"} // $form->{deliverydate} // $form->{transdate});
}
# tax_id_ is used in io.js->update_tax_ids
......
value_title_sub => $tax_value_title_sub,
style => "width: 100px");
if ($record_item && $record_item->part && ($record_item->part->type eq 'part')) {
$column_data{inventory_chart} =
'<b>' . $locale->text('Inventory Account') . '<b> ' .
SL::Presenter::Chart::chart_picker(
"inventory_chart_id_$i", $form->{"inventory_chart_id_$i"},
type => "IC", style => "width: 150px");
}
$column_data{serialnr} = qq|<input name="serialnumber_$i" size="15" value="$form->{"serialnumber_$i"}">|;
$column_data{projectnr} = NTI($cgi->popup_menu(
'-name' => "project_id_$i",
......
invoice_id converted_from_orderitems_id
converted_from_delivery_order_items_id converted_from_invoice_id
converted_from_reclamation_items_id recurring_billing_mode
expense_chart_id tax_id inventory_chart_id
expense_chart_id inventory_chart_id tax_id tax_chart_type
);
my $ic_cvar_configs = CVar->get_configs(module => 'IC');

Auch abrufbar als: Unified diff