diff --git a/htdocs/comm/propal.php b/htdocs/comm/propal.php
index 7f7a1be2fa7..0d137b70ea8 100644
--- a/htdocs/comm/propal.php
+++ b/htdocs/comm/propal.php
@@ -643,13 +643,13 @@ if ($_POST['action'] == "addline" && $user->rights->propale->creer)
$mesg='
'.$langs->trans("ErrorFieldRequired",$langs->transnoentitiesnoconv("Type")).'
';
$result = -1 ;
}
- if ((empty($_POST['idprod']) && $_POST["type"] < 2) && (! isset($_POST["np_price"]) || $_POST["np_price"]=='')) // Unit price can be 0 but not ''
+ if (empty($_POST['idprod']) && (! isset($_POST["np_price"]) || $_POST["np_price"]=='')) // Unit price can be 0 but not ''
{
$mesg=''.$langs->trans("ErrorFieldRequired",$langs->transnoentitiesnoconv("UnitPriceHT")).'
';
$result = -1 ;
}
- if ($result >= 0)
+ if ($result >= 0 && isset($_POST['qty']) && (($_POST['np_price']!='' && ($_POST['np_desc'] || $_POST['dp_desc'])) || $_POST['idprod']))
{
$ret=$propal->fetch($_POST['propalid']);
if ($ret < 0)
@@ -658,133 +658,110 @@ if ($_POST['action'] == "addline" && $user->rights->propale->creer)
exit;
}
$ret=$propal->fetch_client();
-
- if ($_POST["type"] < 2 && isset($_POST['qty']) && (($_POST['np_price']!='' && ($_POST['np_desc'] || $_POST['dp_desc'])) || $_POST['idprod']))
+
+ $price_base_type = 'HT';
+
+ // Ecrase $pu par celui du produit
+ // Ecrase $desc par celui du produit
+ // Ecrase $txtva par celui du produit
+ if ($_POST['idprod'])
{
- $price_base_type = 'HT';
-
- // Ecrase $pu par celui du produit
- // Ecrase $desc par celui du produit
- // Ecrase $txtva par celui du produit
- if ($_POST['idprod'])
+ $prod = new Product($db, $_POST['idprod']);
+ $prod->fetch($_POST['idprod']);
+
+ $tva_tx = get_default_tva($mysoc,$propal->client,$prod->tva_tx);
+ $tva_npr = get_default_npr($mysoc,$propal->client,$prod->tva_tx);
+
+ // On defini prix unitaire
+ if ($conf->global->PRODUIT_MULTIPRICES && $propal->client->price_level)
{
- $prod = new Product($db, $_POST['idprod']);
- $prod->fetch($_POST['idprod']);
-
- $tva_tx = get_default_tva($mysoc,$propal->client,$prod->tva_tx);
- $tva_npr = get_default_npr($mysoc,$propal->client,$prod->tva_tx);
-
- // On defini prix unitaire
- if ($conf->global->PRODUIT_MULTIPRICES && $propal->client->price_level)
+ $pu_ht = $prod->multiprices[$propal->client->price_level];
+ $pu_ttc = $prod->multiprices_ttc[$propal->client->price_level];
+ $price_base_type = $prod->multiprices_base_type[$propal->client->price_level];
+ }
+ else
+ {
+ $pu_ht = $prod->price;
+ $pu_ttc = $prod->price_ttc;
+ $price_base_type = $prod->price_base_type;
+ }
+
+ // On reevalue prix selon taux tva car taux tva transaction peut etre different
+ // de ceux du produit par defaut (par exemple si pays different entre vendeur et acheteur).
+ if ($tva_tx != $prod->tva_tx)
+ {
+ if ($price_base_type != 'HT')
{
- $pu_ht = $prod->multiprices[$propal->client->price_level];
- $pu_ttc = $prod->multiprices_ttc[$propal->client->price_level];
- $price_base_type = $prod->multiprices_base_type[$propal->client->price_level];
+ $pu_ht = price2num($pu_ttc / (1 + ($tva_tx/100)), 'MU');
}
else
{
- $pu_ht = $prod->price;
- $pu_ttc = $prod->price_ttc;
- $price_base_type = $prod->price_base_type;
+ $pu_ttc = price2num($pu_ht * (1 + ($tva_tx/100)), 'MU');
}
-
- // On reevalue prix selon taux tva car taux tva transaction peut etre different
- // de ceux du produit par defaut (par exemple si pays different entre vendeur et acheteur).
- if ($tva_tx != $prod->tva_tx)
- {
- if ($price_base_type != 'HT')
- {
- $pu_ht = price2num($pu_ttc / (1 + ($tva_tx/100)), 'MU');
- }
- else
- {
- $pu_ttc = price2num($pu_ht * (1 + ($tva_tx/100)), 'MU');
- }
- }
-
- $desc = $prod->description;
- $desc.= ($prod->description && $_POST['np_desc']) ? "\n" : "";
- $desc.= $_POST['np_desc'];
- $type = $prod->type;
- }
- else
- {
- $pu_ht=$_POST['np_price'];
- $tva_tx=str_replace('*','',$_POST['np_tva_tx']);
- $tva_npr=preg_match('/\*/',$_POST['np_tva_tx'])?1:0;
- $desc=$_POST['dp_desc'];
- $type=$_POST["type"];
- }
-
- $info_bits=0;
- if ($tva_npr) $info_bits |= 0x01;
-
- if ($prod->price_min && (price2num($pu_ht)*(1-price2num($_POST['remise_percent'])/100) < price2num($prod->price_min)))
- {
- $mesg = ''.$langs->trans("CantBeLessThanMinPrice",price2num($prod->price_min,'MU').' '.$langs->trans("Currency".$conf->monnaie)).'
' ;
- }
- else
- {
- // Insert line
- $result=$propal->addline(
- $_POST['propalid'],
- $desc,
- $pu_ht,
- $_POST['qty'],
- $tva_tx,
- $_POST['idprod'],
- $_POST['remise_percent'],
- $price_base_type,
- $pu_ttc,
- $info_bits,
- $type
- );
}
+
+ $desc = $prod->description;
+ $desc.= ($prod->description && $_POST['np_desc']) ? "\n" : "";
+ $desc.= $_POST['np_desc'];
+ $type = $prod->type;
}
- else if($_POST["type"] == 9 && $_POST['dp_desc'])
+ else
{
+ $pu_ht=$_POST['np_price'];
+ $tva_tx=str_replace('*','',$_POST['np_tva_tx']);
+ $tva_npr=preg_match('/\*/',$_POST['np_tva_tx'])?1:0;
$desc=$_POST['dp_desc'];
$type=$_POST["type"];
-
+ }
+
+ $info_bits=0;
+ if ($tva_npr) $info_bits |= 0x01;
+
+ if ($prod->price_min && (price2num($pu_ht)*(1-price2num($_POST['remise_percent'])/100) < price2num($prod->price_min)))
+ {
+ $mesg = ''.$langs->trans("CantBeLessThanMinPrice",price2num($prod->price_min,'MU').' '.$langs->trans("Currency".$conf->monnaie)).'
' ;
+ }
+ else
+ {
// Insert line
$result=$propal->addline(
$_POST['propalid'],
$desc,
- 0,
- 0,
- 0,
- 0,
- 0,
- 'HT',
- 0,
- 0,
+ $pu_ht,
+ $_POST['qty'],
+ $tva_tx,
+ $_POST['idprod'],
+ $_POST['remise_percent'],
+ $price_base_type,
+ $pu_ttc,
+ $info_bits,
$type
);
- }
-
- if ($result > 0)
- {
- // Define output language
- $outputlangs = $langs;
- $newlang='';
- if ($conf->global->MAIN_MULTILANGS && empty($newlang) && ! empty($_REQUEST['lang_id'])) $newlang=$_REQUEST['lang_id'];
- if ($conf->global->MAIN_MULTILANGS && empty($newlang)) $newlang=$propal->client->default_lang;
- if (! empty($newlang))
+
+ if ($result > 0)
{
- $outputlangs = new Translate("",$conf);
- $outputlangs->setDefaultLang($newlang);
+ // Define output language
+ $outputlangs = $langs;
+ $newlang='';
+ if ($conf->global->MAIN_MULTILANGS && empty($newlang) && ! empty($_REQUEST['lang_id'])) $newlang=$_REQUEST['lang_id'];
+ if ($conf->global->MAIN_MULTILANGS && empty($newlang)) $newlang=$propal->client->default_lang;
+ if (! empty($newlang))
+ {
+ $outputlangs = new Translate("",$conf);
+ $outputlangs->setDefaultLang($newlang);
+ }
+ propale_pdf_create($db, $propal->id, $propal->modelpdf, $outputlangs);
+
+ unset($_POST['qty']);
+ unset($_POST['type']);
+ unset($_POST['np_price']);
+ unset($_POST['dp_desc']);
+ unset($_POST['np_tva_tx']);
+ }
+ else
+ {
+ $mesg=''.$propal->error.'
';
}
- propale_pdf_create($db, $propal->id, $propal->modelpdf, $outputlangs);
-
- unset($_POST['qty']);
- unset($_POST['type']);
- unset($_POST['np_price']);
- unset($_POST['dp_desc']);
- unset($_POST['np_tva_tx']);
- }
- else
- {
- $mesg=''.$propal->error.'
';
}
}
}
@@ -794,8 +771,6 @@ if ($_POST['action'] == "addline" && $user->rights->propale->creer)
*/
if ($_POST['action'] == 'updateligne' && $user->rights->propale->creer && $_POST["save"] == $langs->trans("Save"))
{
- $error=0;
-
$propal = new Propal($db);
if (! $propal->fetch($_POST['propalid']) > 0)
{
@@ -803,53 +778,37 @@ if ($_POST['action'] == 'updateligne' && $user->rights->propale->creer && $_POST
exit;
}
$propal->fetch_client();
-
- if ($_POST['type'] < 2)
+
+ // Define info_bits
+ $info_bits=0;
+ if (preg_match('/\*/',$_POST['tva_tx'])) $info_bits |= 0x01;
+
+ // Define vat_rate
+ $vat_rate=$_POST['tva_tx'];
+ $vat_rate=str_replace('*','',$vat_rate);
+
+ // On verifie que le prix minimum est respecte
+ $productid = $_POST['productid'] ;
+ if ($productid)
{
- // Define info_bits
- $info_bits=0;
- if (preg_match('/\*/',$_POST['tva_tx'])) $info_bits |= 0x01;
-
- // Define vat_rate
- $vat_rate=$_POST['tva_tx'];
- $vat_rate=str_replace('*','',$vat_rate);
-
- // On verifie que le prix minimum est respecte
- $productid = $_POST['productid'] ;
- if ($productid)
- {
- $product = new Product($db);
- $res=$product->fetch($productid);
- }
- if ($productid && $product->price_min && ( price2num($_POST['subprice'])*(1-price2num($_POST['remise_percent'])/100) < price2num($product->price_min)))
- {
- $mesg = ''.$langs->trans("CantBeLessThanMinPrice",price2num($product->price_min,'MU').' '.$langs->trans("Currency".$conf->monnaie)).'
' ;
- $error++;
- }
- else
- {
- $result = $propal->updateline($_POST['lineid'],
- $_POST['subprice'],
- $_POST['qty'],
- $_POST['remise_percent'],
- $vat_rate,
- $_POST['desc'],
- 'HT',
- $info_bits);
- }
+ $product = new Product($db) ;
+ $res=$product->fetch($productid) ;
}
- else if ($_POST['type'] == 9 && $_POST['desc'])
+ if ($productid && $product->price_min && ( price2num($_POST['subprice'])*(1-price2num($_POST['remise_percent'])/100) < price2num($product->price_min)))
+ {
+ $mesg = ''.$langs->trans("CantBeLessThanMinPrice",price2num($product->price_min,'MU').' '.$langs->trans("Currency".$conf->monnaie)).'
' ;
+ }
+ else
{
$result = $propal->updateline($_POST['lineid'],
- 0,
- 0,
- 0,
- 0,
- $_POST['desc']);
- }
-
- if (!$error)
- {
+ $_POST['subprice'],
+ $_POST['qty'],
+ $_POST['remise_percent'],
+ $vat_rate,
+ $_POST['desc'],
+ 'HT',
+ $info_bits);
+
// Define output language
$outputlangs = $langs;
$newlang='';
@@ -1515,7 +1474,6 @@ if ($id > 0 || ! empty($ref))
else
{
if ($type==1) $text = img_object($langs->trans('Service'),'service');
- else if ($type==9) $text = img_object($langs->trans('Notes'),'generic');
else $text = img_object($langs->trans('Product'),'product');
print $text.' '.nl2br($objp->description);
@@ -1578,48 +1536,41 @@ if ($id > 0 || ! empty($ref))
print '';
print '';
}
-
- if ($objp->product_type < 2)
+
+ // VAT Rate
+ print ''.vatrate($objp->tva_tx,'%',$objp->info_bits).' ';
+
+ // U.P HT
+ print ''.price($objp->subprice)." \n";
+
+ // Qty
+ print '';
+ if ((($objp->info_bits & 2) != 2) && $objp->special_code != 3)
{
- // VAT Rate
- print ' '.vatrate($objp->tva_tx,'%',$objp->info_bits).' ';
-
- // U.P HT
- print ''.price($objp->subprice)." \n";
-
- // Qty
- print '';
- if ((($objp->info_bits & 2) != 2) && $objp->special_code != 3)
- {
- print $objp->qty;
- }
- else print ' ';
- print ' ';
-
- // Remise percent (negative or positive)
- if (!empty($objp->remise_percent) && $objp->special_code != 3)
- {
- print ''.dol_print_reduction($objp->remise_percent,$langs)." \n";
- }
- else
- {
- print ' ';
- }
-
- // Montant total HT
- if ($objp->special_code == 3)
- {
- // Si ligne en option
- print ''.$langs->trans('Option').' ';
- }
- else
- {
- print ''.price($objp->total_ht)." \n";
- }
+ print $objp->qty;
+ }
+ else print ' ';
+ print '';
+
+ // Remise percent (negative or positive)
+ if (!empty($objp->remise_percent) && $objp->special_code != 3)
+ {
+ print ''.dol_print_reduction($objp->remise_percent,$langs)." \n";
}
else
{
- print ' ';
+ print ' ';
+ }
+
+ // Montant total HT
+ if ($objp->special_code == 3)
+ {
+ // Si ligne en option
+ print ''.$langs->trans('Option').' ';
+ }
+ else
+ {
+ print ''.price($objp->total_ht)." \n";
}
// Icone d'edition et suppression
@@ -1675,7 +1626,6 @@ if ($id > 0 || ! empty($ref))
print ' ';
print ' ';
print ' ';
- print ' ';
print '';
print '';
print ' '; // ancre pour retourner sur la ligne
@@ -1683,56 +1633,51 @@ if ($id > 0 || ! empty($ref))
{
print ' ';
print '';
- if ($objp->product_type==1) print img_object($langs->trans('ShowService'),'service');
+ if ($objp->fk_product_type==1) print img_object($langs->trans('ShowService'),'service');
else print img_object($langs->trans('ShowProduct'),'product');
print ' '.$objp->ref.' ';
print ' - '.nl2br($objp->product_label);
print ' ';
}
- // editeur wysiwyg
- if ($conf->fckeditor->enabled && $conf->global->FCKEDITOR_ENABLE_DETAILS)
+ if ($_GET["action"] == 'editline')
{
- require_once(DOL_DOCUMENT_ROOT."/lib/doleditor.class.php");
- $doleditor=new DolEditor('desc',$objp->description,164,'dolibarr_details');
- $doleditor->Create();
- }
- else
- {
- $nbrows=ROWS_2;
- if (! empty($conf->global->MAIN_INPUT_DESC_HEIGHT)) $nbrows=$conf->global->MAIN_INPUT_DESC_HEIGHT;
- print '';
+ // editeur wysiwyg
+ if ($conf->fckeditor->enabled && $conf->global->FCKEDITOR_ENABLE_DETAILS)
+ {
+ require_once(DOL_DOCUMENT_ROOT."/lib/doleditor.class.php");
+ $doleditor=new DolEditor('desc',$objp->description,164,'dolibarr_details');
+ $doleditor->Create();
+ }
+ else
+ {
+ $nbrows=ROWS_2;
+ if (! empty($conf->global->MAIN_INPUT_DESC_HEIGHT)) $nbrows=$conf->global->MAIN_INPUT_DESC_HEIGHT;
+ print '';
+ }
}
print ' ';
- if ($objp->product_type < 2)
+ if ($conf->global->PRODUIT_USE_MARKUP)
{
- if ($conf->global->PRODUIT_USE_MARKUP)
- {
- print ''.vatrate($objp->marge_tx).'% ';
- }
- print '';
- print $html->select_tva('tva_tx',$objp->tva_tx,$mysoc,$societe,'',$objp->info_bits);
- print ' ';
- print ' ';
- print '';
- if (($objp->info_bits & 2) != 2)
- {
- print ' ';
- }
- else print ' ';
- print ' ';
- print '';
- if (($objp->info_bits & 2) != 2)
- {
- print ' %';
- }
- else print ' ';
- print ' ';
+ print ''.vatrate($objp->marge_tx).'% ';
}
- else
+ print '';
+ print $html->select_tva('tva_tx',$objp->tva_tx,$mysoc,$societe,'',$objp->info_bits);
+ print ' ';
+ print ' ';
+ print '';
+ if (($objp->info_bits & 2) != 2)
{
- print ' ';
+ print ' ';
}
-
+ else print ' ';
+ print '';
+ print '';
+ if (($objp->info_bits & 2) != 2)
+ {
+ print ' %';
+ }
+ else print ' ';
+ print ' ';
print ' ';
print ' ';
print ' ' . "\n";
diff --git a/htdocs/core/class/html.form.class.php b/htdocs/core/class/html.form.class.php
index 891302c3eb4..49d1c0f737d 100644
--- a/htdocs/core/class/html.form.class.php
+++ b/htdocs/core/class/html.form.class.php
@@ -479,13 +479,6 @@ class Form
if (1 == $selected) print ' selected="true"';
print '>'.$langs->trans("Service");
- if ($conf->global->MAIN_USE_NOTES_IN_DETAILS)
- {
- print ''.$langs->trans("Notes");
- }
-
print '';
//if ($user->admin) print info_admin($langs->trans("YouCanChangeValuesForThisListFromDictionnarySetup"),1);
}
diff --git a/htdocs/includes/modules/propale/pdf_propale_azur.modules.php b/htdocs/includes/modules/propale/pdf_propale_azur.modules.php
index 85cd912abcb..4f6b8bd5a70 100644
--- a/htdocs/includes/modules/propale/pdf_propale_azur.modules.php
+++ b/htdocs/includes/modules/propale/pdf_propale_azur.modules.php
@@ -250,43 +250,40 @@ class pdf_propale_azur extends ModelePDFPropales
$pdf->SetFont('Arial','', 9); // On repositionne la police par defaut
$nexY = $pdf->GetY();
-
- if ($propale->lignes[$i]->product_type < 2)
+
+ // TVA
+ if (empty($conf->global->MAIN_GENERATE_DOCUMENTS_WITHOUT_VAT))
{
- // TVA
- if (empty($conf->global->MAIN_GENERATE_DOCUMENTS_WITHOUT_VAT))
- {
- $pdf->SetXY ($this->posxtva, $curY);
- $pdf->MultiCell($this->posxup-$this->posxtva-1, 4, vatrate($propale->lignes[$i]->tva_tx,1,$propale->lignes[$i]->info_bits), 0, 'R');
- }
-
- // Prix unitaire HT avant remise
- $pdf->SetXY ($this->posxup, $curY);
- $pdf->MultiCell($this->posxqty-$this->posxup-1, 4, price($propale->lignes[$i]->subprice), 0, 'R', 0);
-
- // Quantity
- $pdf->SetXY ($this->posxqty, $curY);
- if ($propale->lignes[$i]->special_code != 3) $pdf->MultiCell($this->posxdiscount-$this->posxqty-1, 4, $propale->lignes[$i]->qty, 0, 'R');
-
- // Remise sur ligne
- $pdf->SetXY ($this->posxdiscount, $curY);
- if ($propale->lignes[$i]->remise_percent && $propale->lignes[$i]->special_code != 3)
- {
- $pdf->MultiCell($this->postotalht-$this->posxdiscount-1, 4, dol_print_reduction($propale->lignes[$i]->remise_percent,$outputlangs), 0, 'R');
- }
-
- // Total HT ligne
- $pdf->SetXY ($this->postotalht, $curY);
- if ($propale->lignes[$i]->special_code == 3)
- {
- // Ligne produit en option
- $pdf->MultiCell(26, 4, $outputlangs->transnoentities("Option"), 0, 'R', 0);
- }
- else
- {
- $total = price($propale->lignes[$i]->total_ht);
- $pdf->MultiCell(26, 4, $total, 0, 'R', 0);
- }
+ $pdf->SetXY ($this->posxtva, $curY);
+ $pdf->MultiCell($this->posxup-$this->posxtva-1, 4, vatrate($propale->lignes[$i]->tva_tx,1,$propale->lignes[$i]->info_bits), 0, 'R');
+ }
+
+ // Prix unitaire HT avant remise
+ $pdf->SetXY ($this->posxup, $curY);
+ $pdf->MultiCell($this->posxqty-$this->posxup-1, 4, price($propale->lignes[$i]->subprice), 0, 'R', 0);
+
+ // Quantity
+ $pdf->SetXY ($this->posxqty, $curY);
+ if ($propale->lignes[$i]->special_code != 3) $pdf->MultiCell($this->posxdiscount-$this->posxqty-1, 4, $propale->lignes[$i]->qty, 0, 'R');
+
+ // Remise sur ligne
+ $pdf->SetXY ($this->posxdiscount, $curY);
+ if ($propale->lignes[$i]->remise_percent && $propale->lignes[$i]->special_code != 3)
+ {
+ $pdf->MultiCell($this->postotalht-$this->posxdiscount-1, 4, dol_print_reduction($propale->lignes[$i]->remise_percent,$outputlangs), 0, 'R');
+ }
+
+ // Total HT ligne
+ $pdf->SetXY ($this->postotalht, $curY);
+ if ($propale->lignes[$i]->special_code == 3)
+ {
+ // Ligne produit en option
+ $pdf->MultiCell(26, 4, $outputlangs->transnoentities("Option"), 0, 'R', 0);
+ }
+ else
+ {
+ $total = price($propale->lignes[$i]->total_ht);
+ $pdf->MultiCell(26, 4, $total, 0, 'R', 0);
}
// Collecte des totaux par valeur de tva dans $this->tva["taux"]=total_tva