Fix: Bad local taxes if price base type is TTC

This commit is contained in:
simnandez 2012-07-13 15:02:02 +02:00
parent 10e632375f
commit 8014713795

View File

@ -95,13 +95,14 @@ function calcul_price_total($qty, $pu, $remise_percent_ligne, $txtva, $txlocalta
if ($txlocaltax1>0)
{
$result[14] = price2num(($result[6] * ( 1 + ( $txlocaltax1 / 100))) - $result[6], 'MT');
$result[8] = $result[8] + $result[14];
$result[8] = price2num($result[8] + $result[14], 'MT');
$result[9] = price2num(($result[0] * ( 1 + ( $txlocaltax1 / 100))) - $result[0], 'MT');
$result[2] = $result[2] + $result[9];
$result[2] = price2num($result[2] + $result[9], 'MT');
$result[11] = price2num(($result[3] * ( 1 + ( $txlocaltax1 / 100))) - $pu, 'MT');
$result[5] = $result[5] + $result[11];
$result[5] = price2num($result[5] + $result[11], 'MT');
}
else
{
@ -111,23 +112,23 @@ function calcul_price_total($qty, $pu, $remise_percent_ligne, $txtva, $txlocalta
}
if ($txlocaltax2>0)
{
$result[15] = price2num(($result[6] * ( 1 + ( $txlocaltax2 / 100))) - $result[6], 'MT');
$result[10] = price2num(($result[0] * ( 1 + ( $txlocaltax2 / 100))) - $result[0], 'MT');
{
$result[15] = price2num(($result[6] * ( 1 + ( $txlocaltax2 / 100))) - $result[6], 'MT');
$result[10] = price2num(($result[0] * ( 1 + ( $txlocaltax2 / 100))) - $result[0], 'MT');
$result[12] = price2num(($result[3] * ( 1 + ( $txlocaltax2 / 100))) - $pu, 'MT');
//If Country is Spain, localtax2 (IRPF) will be subtracted
if ($mysoc->pays_code=='ES')
if ($mysoc->country_code=='ES')
{
$result[8] = $result[8] - $result[15];
$result[2] = $result[2] - $result[10];
$result[5] = $result[5] - $result[12];
$result[8] = price2num($result[8] - $result[15], 'MT');
$result[2] = price2num($result[2] - $result[10], 'MT');
$result[5] = price2num($result[5] - $result[12], 'MU');
}
else
{
$result[8] = $result[8] + $result[15];
$result[2] = $result[2] + $result[10];
$result[5] = $result[5] + $result[12];
$result[8] = price2num($result[8] + $result[15], 'MT');
$result[2] = price2num($result[2] + $result[10], 'MT');
$result[5] = price2num($result[5] + $result[12], 'MU');
}
}
else
@ -136,7 +137,7 @@ function calcul_price_total($qty, $pu, $remise_percent_ligne, $txtva, $txlocalta
$result[10] = 0;
$result[12] = 0;
}
// If rounding is not using base 10 (rare)
if (! empty($conf->global->MAIN_ROUNDING_RULE_TOT))
{