Projekt

Allgemein

Profil

« Zurück | Weiter » 

Revision d10ce474

Von Jan Büren vor etwa 2 Jahren hinzugefügt

  • ID d10ce474972a0fea8ff4a2e5834ecfdef38704ed
  • Vorgänger a0877037
  • Nachfolger 9911cb13

Testfälle Verkaufsrechnung Nebenbuch und Bankzuweisung i.O. Debugs drin

Bei Wechselkursverlusten entsprechend im Nebenbuch abziehen und bei
Gewinnen addieren. Rückgabewert an Bankzuweisung auch summieren

Unterschiede anzeigen:

SL/DB/Helper/Payment.pm
memo => $params{memo},
source => $params{source},
transdate_obj => $transdate_obj );
# invoice_amount with gl booking
$return_bank_amount = _round($params{amount});
# invoice_amount add gl booking
$return_bank_amount += _round($params{amount} - $new_open_amount);
} else {
# invoice_amount without gl booking
$return_bank_amount = $new_open_amount;
# $return_bank_amount = $new_open_amount;
}
# with or without fees simply assign the new open amount for bank (fx_gain follows later)
$params{amount} = $new_open_amount;
}
$main::lxdebug->message(0, 'return0 ' . $return_bank_amount);
$main::lxdebug->message(0, 'return 1gl booking ' . $return_bank_amount); # stimmt f
# $paid_amount = $new_open_amount;
} elsif (!$self->forex) { # invoices uses default currency. no exchangerate
$exchangerate = 1;
# $return_bank_amount = _round($params{amount}); # no forex
} else {
die "Cannot calculate exchange rate, if invoices uses the default currency";
}
......
taxkey => 0,
tax_id => SL::DB::Manager::Tax->find_by(taxkey => 0)->id);
$new_acc_trans->save;
$return_bank_amount += $amount; # dont exclude fx_booking ;-)
$return_bank_amount += abs($amount); # add sign
$main::lxdebug->message(0, 'return 5 ' . $return_bank_amount);
push @new_acc_ids, $new_acc_trans->acc_trans_id;
# deal with fxtransaction ...
# if invoice exchangerate differs from exchangerate of payment
......
$main::lxdebug->message(0, 'was sagt gain loss' . $fx_gain_loss_amount);
my $gain_loss_chart = $fx_gain_loss_amount > 0 ? $fxgain_chart : $fxloss_chart;
# $paid_amount += abs($fx_gain_loss_amount); # if $fx_gain_loss_amount < 0; # only add if we have fx_loss
$paid_amount += $fx_gain_loss_amount if $fx_gain_loss_amount < 0; # only add if we have fx_loss
$paid_amount += abs($fx_gain_loss_amount) if $fx_gain_loss_amount < 0; # only add if we have fx_loss
$paid_amount -= abs($fx_gain_loss_amount) if $fx_gain_loss_amount > 0; # but extract if we have gain to match original invoice amount (ar)
$main::lxdebug->message(0, 'return 1 ' . $return_bank_amount);
$main::lxdebug->message(0, 'paid amount hier 2 ' . $paid_amount);
# $return_bank_amount += $fx_gain_loss_amount if $fx_gain_loss_amount < 0; # only add if we have fx_loss
$main::lxdebug->message(0, 'paid2 ' . $paid_amount);
$main::lxdebug->message(0, 'paid2chart ' . $fx_gain_loss_amount);
$main::lxdebug->message(0, 'return 2 ' . $return_bank_amount);
# $fx_gain_loss_amount = $gain_loss_amount;
$new_acc_trans = SL::DB::AccTransaction->new(trans_id => $self->id,

Auch abrufbar als: Unified diff