mirror of
https://github.com/YunoHost-Apps/dolibarr_ynh.git
synced 2024-09-03 18:35:53 +02:00
1378 lines
52 KiB
PHP
1378 lines
52 KiB
PHP
<?php
|
|
/* Copyright (C) 2001-2007 Rodolphe Quiedeville <rodolphe@quiedeville.org>
|
|
* Copyright (C) 2004-2014 Laurent Destailleur <eldy@users.sourceforge.net>
|
|
* Copyright (C) 2005 Eric Seigne <eric.seigne@ryxeo.com>
|
|
* Copyright (C) 2005-2015 Regis Houssin <regis.houssin@capnetworks.com>
|
|
* Copyright (C) 2006 Andre Cianfarani <acianfa@free.fr>
|
|
* Copyright (C) 2014 Florian Henry <florian.henry@open-concept.pro>
|
|
* Copyright (C) 2014 Juanjo Menent <jmenent@2byte.es>
|
|
* Copyright (C) 2014 Philippe Grand <philippe.grand@atoo-net.com>
|
|
* Copyright (C) 2014 Ion agorria <ion@agorria.com>
|
|
* Copyright (C) 2015 Alexandre Spangaro <aspangaro.dolibarr@gmail.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/**
|
|
* \file htdocs/product/price.php
|
|
* \ingroup product
|
|
* \brief Page to show product prices
|
|
*/
|
|
require '../main.inc.php';
|
|
require_once DOL_DOCUMENT_ROOT . '/core/lib/product.lib.php';
|
|
require_once DOL_DOCUMENT_ROOT . '/product/class/product.class.php';
|
|
require_once DOL_DOCUMENT_ROOT . '/product/dynamic_price/class/price_expression.class.php';
|
|
require_once DOL_DOCUMENT_ROOT . '/product/dynamic_price/class/price_parser.class.php';
|
|
|
|
if (! empty($conf->global->PRODUIT_CUSTOMER_PRICES)) {
|
|
require_once DOL_DOCUMENT_ROOT . '/product/class/productcustomerprice.class.php';
|
|
|
|
$prodcustprice = new Productcustomerprice($db);
|
|
}
|
|
|
|
$langs->load("products");
|
|
$langs->load("bills");
|
|
|
|
$mesg=''; $error=0; $errors=array();
|
|
|
|
$id = GETPOST('id', 'int');
|
|
$ref = GETPOST('ref', 'alpha');
|
|
$action = GETPOST('action', 'alpha');
|
|
$cancel = GETPOST('cancel', 'alpha');
|
|
$eid = GETPOST('eid', 'int');
|
|
|
|
// Security check
|
|
$fieldvalue = (! empty($id) ? $id : (! empty($ref) ? $ref : ''));
|
|
$fieldtype = (! empty($ref) ? 'ref' : 'rowid');
|
|
if ($user->societe_id) $socid = $user->societe_id;
|
|
$result = restrictedArea($user, 'produit|service', $fieldvalue, 'product&product', '', '', $fieldtype);
|
|
|
|
if ($id > 0 || ! empty($ref))
|
|
{
|
|
$object = new Product($db);
|
|
$object->fetch($id, $ref);
|
|
}
|
|
|
|
// Clean param
|
|
if (! empty($conf->global->PRODUIT_MULTIPRICES) && empty($conf->global->PRODUIT_MULTIPRICES_LIMIT)) $conf->global->PRODUIT_MULTIPRICES_LIMIT = 5;
|
|
|
|
// Initialize technical object to manage hooks of thirdparties. Note that conf->hooks_modules contains array array
|
|
$hookmanager->initHooks(array('productpricecard','globalcard'));
|
|
|
|
|
|
/*
|
|
* Actions
|
|
*/
|
|
|
|
if ($cancel) $action='';
|
|
|
|
$parameters=array('id'=>$id, 'ref'=>$ref);
|
|
$reshook=$hookmanager->executeHooks('doActions',$parameters,$object,$action); // Note that $action and $object may have been modified by some hooks
|
|
if ($reshook < 0) setEventMessages($hookmanager->error, $hookmanager->errors, 'errors');
|
|
|
|
if (empty($reshook))
|
|
{
|
|
if ($action == 'update_price' && !$cancel && ($user->rights->produit->creer || $user->rights->service->creer))
|
|
{
|
|
$maxpricesupplier = $object->min_recommended_price();
|
|
$object->fk_price_expression = empty($eid) ? 0 : $eid; //0 discards expression
|
|
|
|
// MultiPrix
|
|
if (! empty($conf->global->PRODUIT_MULTIPRICES))
|
|
{
|
|
$newprice = '';
|
|
$newprice_min = '';
|
|
$newpricebase = '';
|
|
$newvat = '';
|
|
|
|
for ($i = 1; $i <= $conf->global->PRODUIT_MULTIPRICES_LIMIT; $i ++)
|
|
{
|
|
if (isset($_POST ["price_" . $i]))
|
|
{
|
|
$level = $i;
|
|
$newprice = price2num($_POST ["price_" . $i], 'MU');
|
|
$newprice_min = price2num($_POST ["price_min_" . $i], 'MU');
|
|
$newpricebase = $_POST ["multiprices_base_type_" . $i];
|
|
$newnpr = (preg_match('/\*/', $_POST ["tva_tx_" . $i]) ? 1 : 0);
|
|
$newvat = str_replace('*', '', $_POST ["tva_tx_" . $i]);
|
|
$newpsq = GETPOST('psqflag');
|
|
$newpsq = empty($newpsq) ? 0 : $newpsq;
|
|
break; // We found submited price
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$level = 0;
|
|
$newprice = price2num($_POST ["price"], 'MU');
|
|
$newprice_min = price2num($_POST ["price_min"], 'MU');
|
|
$newpricebase = $_POST ["price_base_type"];
|
|
$newnpr = (preg_match('/\*/', $_POST ["tva_tx"]) ? 1 : 0);
|
|
$newvat = str_replace('*', '', $_POST ["tva_tx"]);
|
|
$newpsq = GETPOST('psqflag');
|
|
$newpsq = empty($newpsq) ? 0 : $newpsq;
|
|
}
|
|
|
|
if (! empty($conf->global->PRODUCT_MINIMUM_RECOMMENDED_PRICE) && $newprice_min < $maxpricesupplier)
|
|
{
|
|
setEventMessage($langs->trans("MinimumPriceLimit",price($maxpricesupplier,0,'',1,-1,-1,'auto')),'errors');
|
|
$error++;
|
|
$action='edit_price';
|
|
}
|
|
|
|
if ($newprice < $newprice_min && ! empty($object->fk_price_expression))
|
|
{
|
|
$newprice = $newprice_min; //Set price same as min, the user will not see the
|
|
}
|
|
|
|
if ($object->updatePrice($newprice, $newpricebase, $user, $newvat, $newprice_min, $level, $newnpr, $newpsq) > 0)
|
|
{
|
|
if ($object->fk_price_expression != 0) {
|
|
//Check the expression validity by parsing it
|
|
$priceparser = new PriceParser($db);
|
|
$price_result = $priceparser->parseProduct($object);
|
|
if ($price_result < 0) { //Expression is not valid
|
|
$error++;
|
|
$action='edit_price';
|
|
setEventMessage($priceparser->translatedError(), 'errors');
|
|
}
|
|
}
|
|
if (empty($error) && ! empty($conf->dynamicprices->enabled))
|
|
{
|
|
$ret=$object->setPriceExpression($object->fk_price_expression);
|
|
if ($ret < 0)
|
|
{
|
|
$error++;
|
|
$action='edit_price';
|
|
setEventMessage($object->error, 'errors');
|
|
}
|
|
}
|
|
if (empty($error))
|
|
{
|
|
$action = '';
|
|
setEventMessage($langs->trans("RecordSaved"));
|
|
}
|
|
} else {
|
|
$action = 'edit_price';
|
|
setEventMessage($object->error, 'errors');
|
|
}
|
|
}
|
|
|
|
if ($action == 'delete' && $user->rights->produit->supprimer)
|
|
{
|
|
$result = $object->log_price_delete($user, $_GET ["lineid"]);
|
|
if ($result < 0) {
|
|
setEventMessage($object->error, 'errors');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* ***************************************************
|
|
* Price by quantity
|
|
* ***************************************************
|
|
*/
|
|
if ($action == 'activate_price_by_qty') { // Activating product price by quantity add a new price, specified as by quantity
|
|
|
|
$level = GETPOST('level');
|
|
|
|
$object->updatePrice(0, $object->price_base_type, $user, $object->tva_tx, 0, $level, $object->tva_npr, 1);
|
|
}
|
|
|
|
if ($action == 'edit_price_by_qty')
|
|
{ // Edition d'un prix par quantité
|
|
$rowid = GETPOST('rowid');
|
|
}
|
|
|
|
if ($action == 'update_price_by_qty')
|
|
{ // Ajout / Mise à jour d'un prix par quantité
|
|
|
|
// Récupération des variables
|
|
$rowid = GETPOST('rowid');
|
|
$priceid = GETPOST('priceid');
|
|
$newprice = price2num(GETPOST("price"), 'MU');
|
|
// $newminprice=price2num(GETPOST("price_min"),'MU'); // TODO : Add min price management
|
|
$quantity = GETPOST('quantity');
|
|
$remise_percent = price2num(GETPOST('remise_percent'));
|
|
$remise = 0; // TODO : allow discount by amount when available on documents
|
|
|
|
if (empty($quantity)) {
|
|
$error ++;
|
|
setEventMessage($langs->trans("ErrorFieldRequired", $langs->transnoentities("Qty")), 'errors');
|
|
}
|
|
if (empty($newprice)) {
|
|
$error ++;
|
|
setEventMessage($langs->trans("ErrorFieldRequired", $langs->transnoentities("Price")), 'errors');
|
|
}
|
|
if (! $error) {
|
|
// Calcul du prix HT et du prix unitaire
|
|
if ($object->price_base_type == 'TTC') {
|
|
$price = price2num($newprice) / (1 + ($object->tva_tx / 100));
|
|
}
|
|
|
|
$price = price2num($newprice, 'MU');
|
|
$unitPrice = price2num($price / $quantity, 'MU');
|
|
|
|
// Ajout / mise à jour
|
|
if ($rowid > 0) {
|
|
$sql = "UPDATE " . MAIN_DB_PREFIX . "product_price_by_qty SET";
|
|
$sql .= " price='" . $price . "',";
|
|
$sql .= " unitprice=" . $unitPrice . ",";
|
|
$sql .= " quantity=" . $quantity . ",";
|
|
$sql .= " remise_percent=" . $remise_percent . ",";
|
|
$sql .= " remise=" . $remise;
|
|
$sql .= " WHERE rowid = " . GETPOST('rowid');
|
|
|
|
$result = $db->query($sql);
|
|
} else {
|
|
$sql = "INSERT INTO " . MAIN_DB_PREFIX . "product_price_by_qty (fk_product_price,price,unitprice,quantity,remise_percent,remise) values (";
|
|
$sql .= $priceid . ',' . $price . ',' . $unitPrice . ',' . $quantity . ',' . $remise_percent . ',' . $remise . ')';
|
|
|
|
$result = $db->query($sql);
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($action == 'delete_price_by_qty')
|
|
{
|
|
$rowid = GETPOST('rowid');
|
|
|
|
$sql = "DELETE FROM " . MAIN_DB_PREFIX . "product_price_by_qty";
|
|
$sql .= " WHERE rowid = " . GETPOST('rowid');
|
|
|
|
$result = $db->query($sql);
|
|
}
|
|
|
|
if ($action == 'delete_all_price_by_qty')
|
|
{
|
|
$priceid = GETPOST('priceid');
|
|
|
|
$sql = "DELETE FROM " . MAIN_DB_PREFIX . "product_price_by_qty";
|
|
$sql .= " WHERE fk_product_price = " . $priceid;
|
|
|
|
$result = $db->query($sql);
|
|
}
|
|
|
|
/**
|
|
* ***************************************************
|
|
* Price by customer
|
|
* ****************************************************
|
|
*/
|
|
if ($action == 'add_customer_price_confirm' && !$cancel && ($user->rights->produit->creer || $user->rights->service->creer)) {
|
|
|
|
$maxpricesupplier = $object->min_recommended_price();
|
|
|
|
$update_child_soc = GETPOST('updatechildprice');
|
|
|
|
// add price by customer
|
|
$prodcustprice->fk_soc = GETPOST('socid', 'int');
|
|
$prodcustprice->fk_product = $object->id;
|
|
$prodcustprice->price = price2num(GETPOST("price"), 'MU');
|
|
$prodcustprice->price_min = price2num(GETPOST("price_min"), 'MU');
|
|
$prodcustprice->price_base_type = GETPOST("price_base_type", 'alpha');
|
|
$prodcustprice->tva_tx = str_replace('*', '', GETPOST("tva_tx"));
|
|
$prodcustprice->recuperableonly = (preg_match('/\*/', GETPOST("tva_tx")) ? 1 : 0);
|
|
|
|
if (! empty($conf->global->PRODUCT_MINIMUM_RECOMMENDED_PRICE) && $prodcustprice->price_min<$maxpricesupplier)
|
|
{
|
|
setEventMessage($langs->trans("MinimumPriceLimit",price($maxpricesupplier,0,'',1,-1,-1,'auto')),'errors');
|
|
$error++;
|
|
$action='add_customer_price';
|
|
}
|
|
|
|
if (! $error)
|
|
{
|
|
$result = $prodcustprice->create($user, 0, $update_child_soc);
|
|
|
|
if ($result < 0) {
|
|
setEventMessage($prodcustprice->error, 'errors');
|
|
} else {
|
|
setEventMessage($langs->trans('RecordSaved'), 'mesgs');
|
|
}
|
|
|
|
$action = '';
|
|
}
|
|
}
|
|
|
|
if ($action == 'delete_customer_price' && ($user->rights->produit->supprimer || $user->rights->service->supprimer))
|
|
{
|
|
// Delete price by customer
|
|
$prodcustprice->id = GETPOST('lineid');
|
|
$result = $prodcustprice->delete($user);
|
|
|
|
if ($result < 0) {
|
|
setEventMessage($prodcustprice->error, 'mesgs');
|
|
} else {
|
|
setEventMessage($langs->trans('RecordDeleted'), 'errors');
|
|
}
|
|
$action = '';
|
|
}
|
|
|
|
if ($action == 'update_customer_price_confirm' && !$cancel && ($user->rights->produit->creer || $user->rights->service->creer))
|
|
{
|
|
$maxpricesupplier = $object->min_recommended_price();
|
|
|
|
$update_child_soc = GETPOST('updatechildprice');
|
|
|
|
$prodcustprice->fetch(GETPOST('lineid', 'int'));
|
|
|
|
// update price by customer
|
|
$prodcustprice->price = price2num(GETPOST("price"), 'MU');
|
|
$prodcustprice->price_min = price2num(GETPOST("price_min"), 'MU');
|
|
$prodcustprice->price_base_type = GETPOST("price_base_type", 'alpha');
|
|
$prodcustprice->tva_tx = str_replace('*', '', GETPOST("tva_tx"));
|
|
$prodcustprice->recuperableonly = (preg_match('/\*/', GETPOST("tva_tx")) ? 1 : 0);
|
|
|
|
if ($prodcustprice->price_min<$maxpricesupplier && !empty($conf->global->PRODUCT_MINIMUM_RECOMMENDED_PRICE))
|
|
{
|
|
setEventMessage($langs->trans("MinimumPriceLimit",price($maxpricesupplier,0,'',1,-1,-1,'auto')),'errors');
|
|
$error++;
|
|
$action='update_customer_price';
|
|
}
|
|
|
|
if ( ! $error)
|
|
{
|
|
$result = $prodcustprice->update($user, 0, $update_child_soc);
|
|
|
|
if ($result < 0) {
|
|
setEventMessage($prodcustprice->error, 'errors');
|
|
} else {
|
|
setEventMessage($langs->trans('Save'), 'mesgs');
|
|
}
|
|
|
|
$action = '';
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
* View
|
|
*/
|
|
|
|
$form = new Form($db);
|
|
|
|
if (! empty($id) || ! empty($ref))
|
|
{
|
|
// fetch updated prices
|
|
$object->fetch($id, $ref);
|
|
}
|
|
llxHeader("", "", $langs->trans("CardProduct" . $object->type));
|
|
|
|
$head = product_prepare_head($object);
|
|
$titre = $langs->trans("CardProduct" . $object->type);
|
|
$picto = ($object->type == Product::TYPE_SERVICE ? 'service' : 'product');
|
|
dol_fiche_head($head, 'price', $titre, 0, $picto);
|
|
|
|
print '<table class="border" width="100%">';
|
|
|
|
// Ref
|
|
print '<tr>';
|
|
print '<td width="15%">' . $langs->trans("Ref") . '</td><td colspan="2">';
|
|
print $form->showrefnav($object, 'ref', '', 1, 'ref');
|
|
print '</td>';
|
|
print '</tr>';
|
|
|
|
// Label
|
|
print '<tr><td>' . $langs->trans("Label") . '</td><td>' . $object->label . '</td>';
|
|
|
|
$isphoto = $object->is_photo_available($conf->product->multidir_output [$object->entity]);
|
|
|
|
$nblignes = 5;
|
|
if ($isphoto) {
|
|
// Photo
|
|
print '<td valign="middle" align="center" width="30%" rowspan="' . $nblignes . '">';
|
|
print $object->show_photos($conf->product->multidir_output [$object->entity], 1, 1, 0, 0, 0, 80);
|
|
print '</td>';
|
|
}
|
|
|
|
print '</tr>';
|
|
|
|
// MultiPrix
|
|
if (! empty($conf->global->PRODUIT_MULTIPRICES))
|
|
{
|
|
// Price and min price are variable (depends on level of company).
|
|
if (! empty($socid))
|
|
{
|
|
$soc = new Societe($db);
|
|
$soc->id = $socid;
|
|
$soc->fetch($socid);
|
|
|
|
// Selling price
|
|
print '<tr><td>' . $langs->trans("SellingPrice") . '</td>';
|
|
print '<td>';
|
|
if ($object->multiprices_base_type["$soc->price_level"] == 'TTC') {
|
|
print price($object->multiprices_ttc["$soc->price_level"]);
|
|
} else {
|
|
print price($object->multiprices["$soc->price_level"]);
|
|
}
|
|
if ($object->multiprices_base_type["$soc->price_level"]) {
|
|
print ' ' . $langs->trans($object->multiprices_base_type["$soc->price_level"]);
|
|
} else {
|
|
print ' ' . $langs->trans($object->price_base_type);
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// Price min
|
|
print '<tr><td>' . $langs->trans("MinPrice") . '</td><td>';
|
|
if ($object->multiprices_base_type["$soc->price_level"] == 'TTC')
|
|
{
|
|
print price($object->multiprices_min_ttc["$soc->price_level"]) . ' ' . $langs->trans($object->multiprices_base_type["$soc->price_level"]);
|
|
} else {
|
|
print price($object->multiprices_min["$soc->price_level"]) . ' ' . $langs->trans(empty($object->multiprices_base_type["$soc->price_level"])?'HT':$object->multiprices_base_type["$soc->price_level"]);
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// TVA
|
|
print '<tr><td>' . $langs->trans("VATRate") . '</td><td>' . vatrate($object->multiprices_tva_tx["$soc->price_level"], true) . '</td></tr>';
|
|
}
|
|
else
|
|
{
|
|
for($i = 1; $i <= $conf->global->PRODUIT_MULTIPRICES_LIMIT; $i ++)
|
|
{
|
|
// TVA
|
|
if ($i == 1) // We show only vat for level 1
|
|
{
|
|
print '<tr><td>' . $langs->trans("VATRate") . '</td><td>' . vatrate($object->multiprices_tva_tx [1], true) . '</td></tr>';
|
|
}
|
|
|
|
print '<tr>';
|
|
|
|
// Label of price
|
|
print '<td>' . $langs->trans("SellingPrice") . ' ' . $i;
|
|
$keyforlabel='PRODUIT_MULTIPRICES_LABEL'.$i;
|
|
if (! empty($conf->global->$keyforlabel)) print ' - '.$langs->trans($conf->global->$keyforlabel);
|
|
print '</td>';
|
|
|
|
if ($object->multiprices_base_type ["$i"] == 'TTC') {
|
|
print '<td>' . price($object->multiprices_ttc["$i"]);
|
|
} else {
|
|
print '<td>' . price($object->multiprices["$i"]);
|
|
}
|
|
|
|
if ($object->multiprices_base_type["$i"]) {
|
|
print ' ' . $langs->trans($object->multiprices_base_type ["$i"]);
|
|
} else {
|
|
print ' ' . $langs->trans($object->price_base_type);
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// Prix mini
|
|
print '<tr><td>' . $langs->trans("MinPrice") . ' ' . $i . '</td><td>';
|
|
if (empty($object->multiprices_base_type["$i"])) $object->multiprices_base_type["$i"]="HT";
|
|
if ($object->multiprices_base_type["$i"] == 'TTC')
|
|
{
|
|
print price($object->multiprices_min_ttc["$i"]) . ' ' . $langs->trans($object->multiprices_base_type["$i"]);
|
|
}
|
|
else
|
|
{
|
|
print price($object->multiprices_min["$i"]) . ' ' . $langs->trans($object->multiprices_base_type["$i"]);
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// Price by quantity
|
|
if (! empty($conf->global->PRODUIT_CUSTOMER_PRICES_BY_QTY))
|
|
{
|
|
print '<tr><td>' . $langs->trans("PriceByQuantity") . ' ' . $i;
|
|
print '</td><td>';
|
|
|
|
if ($object->prices_by_qty [$i] == 1) {
|
|
print '<table width="50%" class="border" summary="List of quantities">';
|
|
|
|
print '<tr class="liste_titre">';
|
|
print '<td>' . $langs->trans("PriceByQuantityRange") . ' ' . $i . '</td>';
|
|
print '<td align="right">' . $langs->trans("HT") . '</td>';
|
|
print '<td align="right">' . $langs->trans("UnitPrice") . '</td>';
|
|
print '<td align="right">' . $langs->trans("Discount") . '</td>';
|
|
print '<td> </td>';
|
|
print '</tr>';
|
|
foreach ($object->prices_by_qty_list [$i] as $ii => $prices) {
|
|
if ($action == 'edit_price_by_qty' && $rowid == $prices['rowid'] && ($user->rights->produit->creer || $user->rights->service->creer)) {
|
|
print '<form action="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '" method="POST">';
|
|
print '<input type="hidden" name="action" value="update_price_by_qty">';
|
|
print '<input type="hidden" name="priceid" value="' . $object->prices_by_qty_id[$i] . '">';
|
|
print '<input type="hidden" value="' . $prices['rowid'] . '" name="rowid">';
|
|
print '<tr class="' . ($ii % 2 == 0 ? 'pair' : 'impair') . '">';
|
|
print '<td><input size="5" type="text" value="' . $prices['quantity'] . '" name="quantity"></td>';
|
|
print '<td align="right" colspan="2"><input size="10" type="text" value="' . price2num($prices['price'], 'MU') . '" name="price"> ' . $object->price_base_type . '</td>';
|
|
// print '<td align="right"> </td>';
|
|
print '<td align="right"><input size="5" type="text" value="' . $prices['remise_percent'] . '" name="remise_percent"> %</td>';
|
|
print '<td align="center"><input type="submit" value="' . $langs->trans("Modify") . '" class="button"></td>';
|
|
print '</tr>';
|
|
print '</form>';
|
|
} else {
|
|
print '<tr class="' . ($ii % 2 == 0 ? 'pair' : 'impair') . '">';
|
|
print '<td>' . $prices ['quantity'] . '</td>';
|
|
print '<td align="right">' . price($prices['price']) . '</td>';
|
|
print '<td align="right">' . price($prices['unitprice']) . '</td>';
|
|
print '<td align="right">' . price($prices['remise_percent']) . ' %</td>';
|
|
print '<td align="center">';
|
|
if (($user->rights->produit->creer || $user->rights->service->creer)) {
|
|
print '<a href="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '&action=edit_price_by_qty&rowid=' . $prices["rowid"] . '">';
|
|
print img_edit() . '</a>';
|
|
print '<a href="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '&action=delete_price_by_qty&rowid=' . $prices["rowid"] . '">';
|
|
print img_delete() . '</a>';
|
|
} else {
|
|
print ' ';
|
|
}
|
|
print '</td>';
|
|
print '</tr>';
|
|
}
|
|
}
|
|
if ($action != 'edit_price_by_qty' && ($user->rights->produit->creer || $user->rights->service->creer)) {
|
|
print '<form action="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '" method="POST">';
|
|
print '<input type="hidden" name="action" value="update_price_by_qty">';
|
|
print '<input type="hidden" name="priceid" value="' . $object->prices_by_qty_id[$i] . '">';
|
|
print '<input type="hidden" value="0" name="rowid">';
|
|
print '<tr class="' . ($ii % 2 == 0 ? 'pair' : 'impair') . '">';
|
|
print '<td><input size="5" type="text" value="1" name="quantity"></td>';
|
|
print '<td align="right" colspan="2"><input size="10" type="text" value="0" name="price"> ' . $object->price_base_type . '</td>';
|
|
// print '<td align="right"> </td>';
|
|
print '<td align="right"><input size="5" type="text" value="0" name="remise_percent"> %</td>';
|
|
print '<td align="center"><input type="submit" value="' . $langs->trans("Add") . '" class="button"></td>';
|
|
print '</tr>';
|
|
print '</form>';
|
|
}
|
|
|
|
print '</table>';
|
|
} else {
|
|
print $langs->trans("No");
|
|
print ' <a href="' . $_SERVER['PHP_SELF'] . '?id=' . $object->id . '&action=activate_price_by_qty&level=' . $i . '">(' . $langs->trans("Activate") . ')</a>';
|
|
}
|
|
print '</td></tr>';
|
|
}
|
|
}
|
|
}
|
|
} else {
|
|
// TVA
|
|
print '<tr><td>' . $langs->trans("VATRate") . '</td><td>' . vatrate($object->tva_tx . ($object->tva_npr ? '*' : ''), true) . '</td></tr>';
|
|
|
|
// Price
|
|
print '<tr><td>' . $langs->trans("SellingPrice") . '</td><td>';
|
|
if ($object->price_base_type == 'TTC') {
|
|
print price($object->price_ttc) . ' ' . $langs->trans($object->price_base_type);
|
|
} else {
|
|
print price($object->price) . ' ' . $langs->trans($object->price_base_type);
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// Price minimum
|
|
print '<tr><td>' . $langs->trans("MinPrice") . '</td><td>';
|
|
if ($object->price_base_type == 'TTC') {
|
|
print price($object->price_min_ttc) . ' ' . $langs->trans($object->price_base_type);
|
|
} else {
|
|
print price($object->price_min) . ' ' . $langs->trans($object->price_base_type);
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// Price by quantity
|
|
if (! empty($conf->global->PRODUIT_CUSTOMER_PRICES_BY_QTY))
|
|
{
|
|
print '<tr><td>' . $langs->trans("PriceByQuantity");
|
|
if ($object->prices_by_qty [0] == 0) {
|
|
print ' <a href="' . $_SERVER['PHP_SELF'] . '?id=' . $object->id . '&action=activate_price_by_qty&level=1">' . $langs->trans("Activate");
|
|
}
|
|
print '</td><td>';
|
|
|
|
if ($object->prices_by_qty [0] == 1) {
|
|
print '<table width="50%" class="border" summary="List of quantities">';
|
|
print '<tr class="liste_titre">';
|
|
print '<td>' . $langs->trans("PriceByQuantityRange") . '</td>';
|
|
print '<td align="right">' . $langs->trans("HT") . '</td>';
|
|
print '<td align="right">' . $langs->trans("UnitPrice") . '</td>';
|
|
print '<td align="right">' . $langs->trans("Discount") . '</td>';
|
|
print '<td> </td>';
|
|
print '</tr>';
|
|
foreach ($object->prices_by_qty_list [0] as $ii => $prices)
|
|
{
|
|
if ($action == 'edit_price_by_qty' && $rowid == $prices['rowid'] && ($user->rights->produit->creer || $user->rights->service->creer))
|
|
{
|
|
print '<form action="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '" method="POST">';
|
|
print '<input type="hidden" name="action" value="update_price_by_qty">';
|
|
print '<input type="hidden" name="priceid" value="' . $object->prices_by_qty_id[0] . '">';
|
|
print '<input type="hidden" value="' . $prices['rowid'] . '" name="rowid">';
|
|
print '<tr class="' . ($ii % 2 == 0 ? 'pair' : 'impair') . '">';
|
|
print '<td><input size="5" type="text" value="' . $prices['quantity'] . '" name="quantity"></td>';
|
|
print '<td align="right" colspan="2"><input size="10" type="text" value="' . price2num($prices['price'], 'MU') . '" name="price"> ' . $object->price_base_type . '</td>';
|
|
// print '<td align="right"> </td>';
|
|
print '<td align="right"><input size="5" type="text" value="' . $prices['remise_percent'] . '" name="remise_percent"> %</td>';
|
|
print '<td align="center"><input type="submit" value="' . $langs->trans("Modify") . '" class="button"></td>';
|
|
print '</tr>';
|
|
print '</form>';
|
|
} else {
|
|
print '<tr class="' . ($ii % 2 == 0 ? 'pair' : 'impair') . '">';
|
|
print '<td>' . $prices['quantity'] . '</td>';
|
|
print '<td align="right">' . price($prices['price']) . '</td>';
|
|
print '<td align="right">' . price($prices['unitprice']) . '</td>';
|
|
print '<td align="right">' . price($prices['remise_percent']) . ' %</td>';
|
|
print '<td align="center">';
|
|
if (($user->rights->produit->creer || $user->rights->service->creer)) {
|
|
print '<a href="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '&action=edit_price_by_qty&rowid=' . $prices["rowid"] . '">';
|
|
print img_edit() . '</a>';
|
|
print '<a href="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '&action=delete_price_by_qty&rowid=' . $prices["rowid"] . '">';
|
|
print img_delete() . '</a>';
|
|
} else {
|
|
print ' ';
|
|
}
|
|
print '</td>';
|
|
print '</tr>';
|
|
}
|
|
}
|
|
if ($action != 'edit_price_by_qty') {
|
|
print '<form action="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '" method="POST">';
|
|
print '<input type="hidden" name="action" value="update_price_by_qty">';
|
|
print '<input type="hidden" name="priceid" value="' . $object->prices_by_qty_id [0] . '">';
|
|
print '<input type="hidden" value="0" name="rowid">';
|
|
print '<tr class="' . ($ii % 2 == 0 ? 'pair' : 'impair') . '">';
|
|
print '<td><input size="5" type="text" value="1" name="quantity"></td>';
|
|
print '<td align="right" colspan="2"><input size="10" type="text" value="0" name="price"> ' . $object->price_base_type . '</td>';
|
|
// print '<td align="right"> </td>';
|
|
print '<td align="right"><input size="5" type="text" value="0" name="remise_percent"> %</td>';
|
|
print '<td align="center"><input type="submit" value="' . $langs->trans("Add") . '" class="button"></td>';
|
|
print '</tr>';
|
|
print '</form>';
|
|
}
|
|
|
|
print '</table>';
|
|
} else {
|
|
print $langs->trans("No");
|
|
}
|
|
print '</td></tr>';
|
|
}
|
|
}
|
|
|
|
// Status (to sell)
|
|
print '<tr><td>' . $langs->trans("Status") . ' (' . $langs->trans("Sell") . ')</td><td>';
|
|
print $object->getLibStatut(2, 0);
|
|
print '</td></tr>';
|
|
|
|
print "</table>\n";
|
|
|
|
dol_fiche_end();
|
|
|
|
|
|
/* ************************************************************************** */
|
|
/* */
|
|
/* Barre d'action */
|
|
/* */
|
|
/* ************************************************************************** */
|
|
|
|
if (! $action || $action == 'delete' || $action == 'showlog_customer_price' || $action == 'add_customer_price')
|
|
{
|
|
print "\n" . '<div class="tabsAction">' . "\n";
|
|
|
|
if ($user->rights->produit->creer || $user->rights->service->creer) {
|
|
print '<div class="inline-block divButAction"><a class="butAction" href="' . $_SERVER['PHP_SELF'] . '?action=edit_price&id=' . $object->id . '">' . $langs->trans("UpdatePrice") . '</a></div>';
|
|
}
|
|
|
|
print "\n</div>\n";
|
|
}
|
|
|
|
/*
|
|
* Edition du prix
|
|
*/
|
|
if ($action == 'edit_price' && ($user->rights->produit->creer || $user->rights->service->creer))
|
|
{
|
|
print_fiche_titre($langs->trans("NewPrice"), '');
|
|
|
|
if (empty($conf->global->PRODUIT_MULTIPRICES))
|
|
{
|
|
print '<form action="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '" method="POST">';
|
|
print '<input type="hidden" name="token" value="' . $_SESSION ['newtoken'] . '">';
|
|
print '<input type="hidden" name="action" value="update_price">';
|
|
print '<input type="hidden" name="id" value="' . $object->id . '">';
|
|
|
|
dol_fiche_head('');
|
|
|
|
print '<table class="border" width="100%">';
|
|
|
|
// VAT
|
|
print '<tr><td>' . $langs->trans("VATRate") . '</td><td>';
|
|
print $form->load_tva("tva_tx", $object->tva_tx, $mysoc, '', $object->id, $object->tva_npr);
|
|
print '</td></tr>';
|
|
|
|
// Price base
|
|
print '<tr><td width="15%">';
|
|
print $langs->trans('PriceBase');
|
|
print '</td>';
|
|
print '<td>';
|
|
print $form->selectPriceBaseType($object->price_base_type, "price_base_type");
|
|
print '</td>';
|
|
print '</tr>';
|
|
|
|
// Only show price mode and expression selector if module is enabled
|
|
if (! empty($conf->dynamicprices->enabled)) {
|
|
// Price mode selector
|
|
print '<tr><td>'.$langs->trans("PriceMode").'</td><td>';
|
|
$price_expression = new PriceExpression($db);
|
|
$price_expression_list = array(0 => $langs->trans("PriceNumeric")); //Put the numeric mode as first option
|
|
foreach ($price_expression->list_price_expression() as $entry) {
|
|
$price_expression_list[$entry->id] = $entry->title;
|
|
}
|
|
$price_expression_preselection = GETPOST('eid') ? GETPOST('eid') : ($object->fk_price_expression ? $object->fk_price_expression : '0');
|
|
print $form->selectarray('eid', $price_expression_list, $price_expression_preselection);
|
|
print ' <div id="expression_editor" class="button">'.$langs->trans("PriceExpressionEditor").'</div>';
|
|
print '</td></tr>';
|
|
// This code hides the numeric price input if is not selected, loads the editor page if editor button is pressed
|
|
print '<script type="text/javascript">
|
|
jQuery(document).ready(run);
|
|
function run() {
|
|
jQuery("#expression_editor").click(on_click);
|
|
jQuery("#eid").change(on_change);
|
|
on_change();
|
|
}
|
|
function on_click() {
|
|
window.location = "'.DOL_URL_ROOT.'/product/dynamic_price/editor.php?id='.$id.'&tab=price&eid=" + $("#eid").attr("value");
|
|
}
|
|
function on_change() {
|
|
if ($("#eid").attr("value") == 0) {
|
|
jQuery("#price_numeric").show();
|
|
} else {
|
|
jQuery("#price_numeric").hide();
|
|
}
|
|
}
|
|
</script>';
|
|
}
|
|
|
|
// Price
|
|
$product = new Product($db);
|
|
$product->fetch($id, $ref, '', 1); //Ignore the math expression when getting the price
|
|
print '<tr id="price_numeric"><td width="20%">';
|
|
$text = $langs->trans('SellingPrice');
|
|
print $form->textwithpicto($text, $langs->trans("PrecisionUnitIsLimitedToXDecimals", $conf->global->MAIN_MAX_DECIMALS_UNIT), 1, 1);
|
|
print '</td><td>';
|
|
if ($object->price_base_type == 'TTC') {
|
|
print '<input name="price" size="10" value="' . price($product->price_ttc) . '">';
|
|
} else {
|
|
print '<input name="price" size="10" value="' . price($product->price) . '">';
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// Price minimum
|
|
print '<tr><td>';
|
|
$text = $langs->trans('MinPrice');
|
|
print $form->textwithpicto($text, $langs->trans("PrecisionUnitIsLimitedToXDecimals", $conf->global->MAIN_MAX_DECIMALS_UNIT), 1, 1);
|
|
if ($object->price_base_type == 'TTC') {
|
|
print '<td><input name="price_min" size="10" value="' . price($object->price_min_ttc) . '">';
|
|
} else {
|
|
print '<td><input name="price_min" size="10" value="' . price($object->price_min) . '">';
|
|
}
|
|
if ( !empty($conf->global->PRODUCT_MINIMUM_RECOMMENDED_PRICE))
|
|
{
|
|
print '<td align="left">'.$langs->trans("MinimumRecommendedPrice", price($maxpricesupplier,0,'',1,-1,-1,'auto')).' '.img_warning().'</td>';
|
|
}
|
|
print '</td></tr>';
|
|
|
|
print '</table>';
|
|
|
|
dol_fiche_end();
|
|
|
|
print '<div class="center">';
|
|
print '<input type="submit" class="button" value="' . $langs->trans("Save") . '">';
|
|
print ' ';
|
|
print '<input type="submit" class="button" name="cancel" value="' . $langs->trans("Cancel") . '">';
|
|
print '</div>';
|
|
|
|
print '<br></form>';
|
|
}
|
|
else
|
|
{
|
|
for($i = 1; $i <= $conf->global->PRODUIT_MULTIPRICES_LIMIT; $i ++)
|
|
{
|
|
print '<form action="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '" method="POST">';
|
|
print '<input type="hidden" name="token" value="' . $_SESSION ['newtoken'] . '">';
|
|
print '<input type="hidden" name="action" value="update_price">';
|
|
print '<input type="hidden" name="id" value="' . $object->id . '">';
|
|
|
|
dol_fiche_head('');
|
|
|
|
print '<table class="border" width="100%">';
|
|
|
|
// VAT
|
|
if ($i == 1) {
|
|
print '<tr><td>' . $langs->trans("VATRate") . '</td><td>';
|
|
print $form->load_tva("tva_tx_" . $i, $object->multiprices_tva_tx ["$i"], $mysoc, '', $object->id);
|
|
print '</td></tr>';
|
|
} else { // We always use the vat rate of price level 1 (A vat rate does not depends on customer)
|
|
print '<input type="hidden" name="tva_tx_' . $i . '" value="' . $object->multiprices_tva_tx [1] . '">';
|
|
}
|
|
|
|
// Selling price
|
|
print '<tr><td width="20%">';
|
|
$text = $langs->trans('SellingPrice') . ' ' . $i;
|
|
print $form->textwithpicto($text, $langs->trans("PrecisionUnitIsLimitedToXDecimals", $conf->global->MAIN_MAX_DECIMALS_UNIT), 1, 1);
|
|
print '</td><td>';
|
|
if ($object->multiprices_base_type ["$i"] == 'TTC') {
|
|
print '<input name="price_' . $i . '" size="10" value="' . price($object->multiprices_ttc ["$i"]) . '">';
|
|
} else {
|
|
print '<input name="price_' . $i . '" size="10" value="' . price($object->multiprices ["$i"]) . '">';
|
|
}
|
|
print $form->selectPriceBaseType($object->multiprices_base_type ["$i"], "multiprices_base_type_" . $i);
|
|
print '</td></tr>';
|
|
|
|
// Min price
|
|
print '<tr><td>';
|
|
$text = $langs->trans('MinPrice') . ' ' . $i;
|
|
print $form->textwithpicto($text, $langs->trans("PrecisionUnitIsLimitedToXDecimals", $conf->global->MAIN_MAX_DECIMALS_UNIT), 1, 1);
|
|
if ($object->multiprices_base_type ["$i"] == 'TTC') {
|
|
print '<td><input name="price_min_' . $i . '" size="10" value="' . price($object->multiprices_min_ttc ["$i"]) . '">';
|
|
} else {
|
|
print '<td><input name="price_min_' . $i . '" size="10" value="' . price($object->multiprices_min ["$i"]) . '">';
|
|
}
|
|
if ( !empty($conf->global->PRODUCT_MINIMUM_RECOMMENDED_PRICE))
|
|
{
|
|
print '<td align="left">'.$langs->trans("MinimumRecommendedPrice", price($maxpricesupplier,0,'',1,-1,-1,'auto')).' '.img_warning().'</td>';
|
|
}
|
|
print '</td></tr>';
|
|
|
|
print '<tr><td colspan="2" align="center"><input type="submit" class="button" value="' . $langs->trans("Save") . '">';
|
|
print ' ';
|
|
print '<input type="submit" class="button" name="cancel" value="' . $langs->trans("Cancel") . '"></td></tr>';
|
|
|
|
print '</table>';
|
|
|
|
dol_fiche_end();
|
|
|
|
print '</form>';
|
|
}
|
|
}
|
|
}
|
|
|
|
// List of price changes (ordered by descending date)
|
|
$sql = "SELECT p.rowid, p.price, p.price_ttc, p.price_base_type, p.tva_tx, p.recuperableonly,";
|
|
$sql .= " p.price_level, p.price_min, p.price_min_ttc,p.price_by_qty,";
|
|
$sql .= " p.date_price as dp, p.fk_price_expression, u.rowid as user_id, u.login";
|
|
$sql .= " FROM " . MAIN_DB_PREFIX . "product_price as p,";
|
|
$sql .= " " . MAIN_DB_PREFIX . "user as u";
|
|
$sql .= " WHERE fk_product = " . $object->id;
|
|
$sql .= " AND p.entity IN (" . getEntity('productprice', 1) . ")";
|
|
$sql .= " AND p.fk_user_author = u.rowid";
|
|
if (! empty($socid) && ! empty($conf->global->PRODUIT_MULTIPRICES)) $sql .= " AND p.price_level = " . $soc->price_level;
|
|
$sql .= " ORDER BY p.date_price DESC, p.price_level ASC, p.rowid DESC";
|
|
// $sql .= $db->plimit();
|
|
|
|
$result = $db->query($sql);
|
|
if ($result)
|
|
{
|
|
$num = $db->num_rows($result);
|
|
|
|
if (! $num)
|
|
{
|
|
$db->free($result);
|
|
|
|
// Il doit au moins y avoir la ligne de prix initial.
|
|
// On l'ajoute donc pour remettre a niveau (pb vieilles versions)
|
|
$object->updatePrice($object->price, $object->price_base_type, $user, $newprice_min);
|
|
|
|
$result = $db->query($sql);
|
|
$num = $db->num_rows($result);
|
|
}
|
|
|
|
if ($num > 0)
|
|
{
|
|
if (! empty($conf->global->PRODUIT_CUSTOMER_PRICES)) print_fiche_titre($langs->trans("DefaultPrice"),'','');
|
|
|
|
print '<table class="noborder" width="100%">';
|
|
|
|
print '<tr class="liste_titre">';
|
|
print '<td>' . $langs->trans("AppliedPricesFrom") . '</td>';
|
|
|
|
if (! empty($conf->global->PRODUIT_MULTIPRICES)) {
|
|
print '<td align="center">' . $langs->trans("MultiPriceLevelsName") . '</td>';
|
|
}
|
|
if (! empty($conf->global->PRODUIT_CUSTOMER_PRICES_BY_QTY)) {
|
|
print '<td align="center">' . $langs->trans("Type") . '</td>';
|
|
}
|
|
|
|
print '<td align="center">' . $langs->trans("PriceBase") . '</td>';
|
|
print '<td align="right">' . $langs->trans("VAT") . '</td>';
|
|
print '<td align="right">' . $langs->trans("HT") . '</td>';
|
|
print '<td align="right">' . $langs->trans("TTC") . '</td>';
|
|
if (! empty($conf->dynamicprices->enabled)) {
|
|
print '<td align="right">' . $langs->trans("PriceExpressionSelected") . '</td>';
|
|
}
|
|
print '<td align="right">' . $langs->trans("MinPrice") . ' ' . $langs->trans("HT") . '</td>';
|
|
print '<td align="right">' . $langs->trans("MinPrice") . ' ' . $langs->trans("TTC") . '</td>';
|
|
print '<td align="right">' . $langs->trans("ChangedBy") . '</td>';
|
|
if ($user->rights->produit->supprimer)
|
|
print '<td align="right"> </td>';
|
|
print '</tr>';
|
|
|
|
$var = True;
|
|
$i = 0;
|
|
while ($i < $num)
|
|
{
|
|
$objp = $db->fetch_object($result);
|
|
$var = ! $var;
|
|
print "<tr $bc[$var]>";
|
|
// Date
|
|
print "<td>" . dol_print_date($db->jdate($objp->dp), "dayhour") . "</td>";
|
|
|
|
// Price level
|
|
if (! empty($conf->global->PRODUIT_MULTIPRICES)) {
|
|
print '<td align="center">' . $objp->price_level . "</td>";
|
|
}
|
|
// Price by quantity
|
|
if (! empty($conf->global->PRODUIT_CUSTOMER_PRICES_BY_QTY))
|
|
{
|
|
$type = ($objp->price_by_qty == 1) ? 'PriceByQuantity' : 'Standard';
|
|
print '<td align="center">' . $langs->trans($type) . "</td>";
|
|
}
|
|
|
|
print '<td align="center">' . $langs->trans($objp->price_base_type) . "</td>";
|
|
print '<td align="right">' . vatrate($objp->tva_tx, true, $objp->recuperableonly) . "</td>";
|
|
|
|
//Price
|
|
if (! empty($objp->fk_price_expression) && ! empty($conf->dynamicprices->enabled))
|
|
{
|
|
$price_expression = new PriceExpression($db);
|
|
$res = $price_expression->fetch($objp->fk_price_expression);
|
|
$title = $price_expression->title;
|
|
print '<td align="right"></td>';
|
|
print '<td align="right"></td>';
|
|
print '<td align="right">' . $title . "</td>";
|
|
}
|
|
else
|
|
{
|
|
print '<td align="right">' . price($objp->price) . "</td>";
|
|
print '<td align="right">' . price($objp->price_ttc) . "</td>";
|
|
if (! empty($conf->dynamicprices->enabled)) { //Only if module is enabled
|
|
print '<td align="right"></td>';
|
|
}
|
|
}
|
|
print '<td align="right">' . price($objp->price_min) . '</td>';
|
|
print '<td align="right">' . price($objp->price_min_ttc) . '</td>';
|
|
|
|
// User
|
|
print '<td align="right"><a href="' . DOL_URL_ROOT . '/user/card.php?id=' . $objp->user_id . '">' . img_object($langs->trans("ShowUser"), 'user') . ' ' . $objp->login . '</a></td>';
|
|
|
|
// Action
|
|
if ($user->rights->produit->supprimer)
|
|
{
|
|
print '<td align="right">';
|
|
if ($i > 0) {
|
|
print '<a href="' . $_SERVER["PHP_SELF"] . '?action=delete&id=' . $object->id . '&lineid=' . $objp->rowid . '">';
|
|
print img_delete();
|
|
print '</a>';
|
|
} else
|
|
print ' '; // Can not delete last price (it's current price)
|
|
print '</td>';
|
|
}
|
|
|
|
print "</tr>\n";
|
|
$i ++;
|
|
}
|
|
$db->free($result);
|
|
print "</table>";
|
|
print "<br>";
|
|
}
|
|
} else {
|
|
dol_print_error($db);
|
|
}
|
|
|
|
|
|
// Add area to show/add/edit a price for a dedicated customer
|
|
if (! empty($conf->global->PRODUIT_CUSTOMER_PRICES))
|
|
{
|
|
$prodcustprice = new Productcustomerprice($db);
|
|
|
|
$sortfield = GETPOST("sortfield", 'alpha');
|
|
$sortorder = GETPOST("sortorder", 'alpha');
|
|
$page = GETPOST("page", 'int');
|
|
if ($page == - 1) {
|
|
$page = 0;
|
|
}
|
|
$offset = $conf->liste_limit * $page;
|
|
$pageprev = $page - 1;
|
|
$pagenext = $page + 1;
|
|
if (! $sortorder)
|
|
$sortorder = "ASC";
|
|
if (! $sortfield)
|
|
$sortfield = "soc.nom";
|
|
|
|
// Build filter to diplay only concerned lines
|
|
$filter = array('t.fk_product' => $object->id);
|
|
|
|
$search_soc = GETPOST('search_soc');
|
|
if (! empty($search_soc)) {
|
|
$filter['soc.nom'] = $search_soc;
|
|
}
|
|
|
|
if ($action == 'add_customer_price')
|
|
{
|
|
// Create mode
|
|
$maxpricesupplier = $object->min_recommended_price();
|
|
|
|
print_fiche_titre($langs->trans('PriceByCustomer'));
|
|
|
|
print '<form action="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '" method="POST">';
|
|
print '<input type="hidden" name="token" value="' . $_SESSION ['newtoken'] . '">';
|
|
print '<input type="hidden" name="action" value="add_customer_price_confirm">';
|
|
print '<input type="hidden" name="id" value="' . $object->id . '">';
|
|
print '<table class="border" width="100%">';
|
|
print '<tr>';
|
|
print '<td>' . $langs->trans('ThirdParty') . '</td>';
|
|
print '<td>';
|
|
print $form->select_company('', 'socid', 's.client in (1,2,3) AND s.rowid NOT IN (SELECT fk_soc FROM ' . MAIN_DB_PREFIX . 'product_customer_price WHERE fk_product='.$object->id.')', 1, 0, 0, array(), 0, 'minwidth300');
|
|
print '</td>';
|
|
print '</tr>';
|
|
|
|
// VAT
|
|
print '<tr><td>' . $langs->trans("VATRate") . '</td><td>';
|
|
print $form->load_tva("tva_tx", $object->tva_tx, $mysoc, '', $object->id, $object->tva_npr);
|
|
print '</td></tr>';
|
|
|
|
// Price base
|
|
print '<tr><td width="15%">';
|
|
print $langs->trans('PriceBase');
|
|
print '</td>';
|
|
print '<td>';
|
|
print $form->selectPriceBaseType($object->price_base_type, "price_base_type");
|
|
print '</td>';
|
|
print '</tr>';
|
|
|
|
// Price
|
|
print '<tr><td width="20%">';
|
|
$text = $langs->trans('SellingPrice');
|
|
print $form->textwithpicto($text, $langs->trans("PrecisionUnitIsLimitedToXDecimals", $conf->global->MAIN_MAX_DECIMALS_UNIT), 1, 1);
|
|
print '</td><td>';
|
|
if ($object->price_base_type == 'TTC') {
|
|
print '<input name="price" size="10" value="' . price($object->price_ttc) . '">';
|
|
} else {
|
|
print '<input name="price" size="10" value="' . price($object->price) . '">';
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// Price minimum
|
|
print '<tr><td>';
|
|
$text = $langs->trans('MinPrice');
|
|
print $form->textwithpicto($text, $langs->trans("PrecisionUnitIsLimitedToXDecimals", $conf->global->MAIN_MAX_DECIMALS_UNIT), 1, 1);
|
|
if ($object->price_base_type == 'TTC') {
|
|
print '<td><input name="price_min" size="10" value="' . price($object->price_min_ttc) . '">';
|
|
} else {
|
|
print '<td><input name="price_min" size="10" value="' . price($object->price_min) . '">';
|
|
}
|
|
if ( !empty($conf->global->PRODUCT_MINIMUM_RECOMMENDED_PRICE))
|
|
{
|
|
print '<td align="left">'.$langs->trans("MinimumRecommendedPrice", price($maxpricesupplier,0,'',1,-1,-1,'auto')).' '.img_warning().'</td>';
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// Update all child soc
|
|
print '<tr><td width="15%">';
|
|
print $langs->trans('ForceUpdateChildPriceSoc');
|
|
print '</td>';
|
|
print '<td>';
|
|
print '<input type="checkbox" name="updatechildprice" value="1">';
|
|
print '</td>';
|
|
print '</tr>';
|
|
|
|
print '</table>';
|
|
|
|
print '<br><div class="center">';
|
|
print '<input type="submit" class="button" value="' . $langs->trans("Save") . '">';
|
|
print ' ';
|
|
print '<input type="submit" class="button" name="cancel" value="' . $langs->trans("Cancel") . '">';
|
|
print '</div>';
|
|
|
|
print '<br></form>';
|
|
}
|
|
elseif ($action == 'edit_customer_price')
|
|
{
|
|
// Edit mode
|
|
$maxpricesupplier = $object->min_recommended_price();
|
|
|
|
print_fiche_titre($langs->trans('PriceByCustomer'));
|
|
|
|
$result = $prodcustprice->fetch(GETPOST('lineid', 'int'));
|
|
if ($result < 0) {
|
|
setEventMessage($prodcustprice->error, 'errors');
|
|
}
|
|
|
|
print '<form action="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '" method="POST">';
|
|
print '<input type="hidden" name="token" value="' . $_SESSION ['newtoken'] . '">';
|
|
print '<input type="hidden" name="action" value="update_customer_price_confirm">';
|
|
print '<input type="hidden" name="lineid" value="' . $prodcustprice->id . '">';
|
|
print '<table class="border" width="100%">';
|
|
print '<tr>';
|
|
print '<td>' . $langs->trans('ThirdParty') . '</td>';
|
|
$staticsoc = new Societe($db);
|
|
$staticsoc->fetch($prodcustprice->fk_soc);
|
|
print "<td colspan='2'>" . $staticsoc->getNomUrl(1) . "</td>";
|
|
print '</tr>';
|
|
|
|
// VAT
|
|
print '<tr><td>' . $langs->trans("VATRate") . '</td><td colspan="2">';
|
|
print $form->load_tva("tva_tx", $prodcustprice->tva_tx, $mysoc, '', $object->id, $prodcustprice->recuperableonly);
|
|
print '</td></tr>';
|
|
|
|
// Price base
|
|
print '<tr><td width="15%">';
|
|
print $langs->trans('PriceBase');
|
|
print '</td>';
|
|
print '<td>';
|
|
print $form->selectPriceBaseType($prodcustprice->price_base_type, "price_base_type");
|
|
print '</td>';
|
|
print '</tr>';
|
|
|
|
// Price
|
|
print '<tr><td width="20%">';
|
|
$text = $langs->trans('SellingPrice');
|
|
print $form->textwithpicto($text, $langs->trans("PrecisionUnitIsLimitedToXDecimals", $conf->global->MAIN_MAX_DECIMALS_UNIT), 1, 1);
|
|
print '</td><td>';
|
|
if ($prodcustprice->price_base_type == 'TTC') {
|
|
print '<input name="price" size="10" value="' . price($prodcustprice->price_ttc) . '">';
|
|
} else {
|
|
print '<input name="price" size="10" value="' . price($prodcustprice->price) . '">';
|
|
}
|
|
print '</td></tr>';
|
|
|
|
// Price minimum
|
|
print '<tr><td>';
|
|
$text = $langs->trans('MinPrice');
|
|
print $form->textwithpicto($text, $langs->trans("PrecisionUnitIsLimitedToXDecimals", $conf->global->MAIN_MAX_DECIMALS_UNIT), 1, 1);
|
|
print '</td><td>';
|
|
if ($prodcustprice->price_base_type == 'TTC') {
|
|
print '<input name="price_min" size="10" value="' . price($prodcustprice->price_min_ttc) . '">';
|
|
} else {
|
|
print '<input name="price_min" size="10" value="' . price($prodcustprice->price_min) . '">';
|
|
}
|
|
print '</td>';
|
|
if ( !empty($conf->global->PRODUCT_MINIMUM_RECOMMENDED_PRICE))
|
|
{
|
|
print '<td align="left">'.$langs->trans("MinimumRecommendedPrice", price($maxpricesupplier,0,'',1,-1,-1,'auto')).' '.img_warning().'</td>';
|
|
}
|
|
print '</tr>';
|
|
|
|
// Update all child soc
|
|
print '<tr><td width="15%">';
|
|
print $langs->trans('ForceUpdateChildPriceSoc');
|
|
print '</td>';
|
|
print '<td>';
|
|
print '<input type="checkbox" name="updatechildprice" value="1">';
|
|
print '</td>';
|
|
print '</tr>';
|
|
|
|
print '</table>';
|
|
|
|
print '<br><div class="center">';
|
|
print '<input type="submit" class="button" value="' . $langs->trans("Save") . '">';
|
|
print ' ';
|
|
print '<input type="submit" class="button" name="cancel" value="' . $langs->trans("Cancel") . '">';
|
|
print '</div>';
|
|
|
|
print '<br></form>';
|
|
}
|
|
elseif ($action == 'showlog_customer_price')
|
|
{
|
|
$filter = array('t.fk_product' => $object->id,'t.fk_soc' => GETPOST('socid', 'int'));
|
|
|
|
// Count total nb of records
|
|
$nbtotalofrecords = 0;
|
|
if (empty($conf->global->MAIN_DISABLE_FULL_SCANLIST)) {
|
|
$nbtotalofrecords = $prodcustprice->fetch_all_log($sortorder, $sortfield, $conf->liste_limit, $offset, $filter);
|
|
}
|
|
|
|
$result = $prodcustprice->fetch_all_log($sortorder, $sortfield, $conf->liste_limit, $offset, $filter);
|
|
if ($result < 0) {
|
|
setEventMessage($prodcustprice->error, 'errors');
|
|
}
|
|
|
|
$option = '&socid=' . GETPOST('socid', 'int') . '&id=' . $object->id;
|
|
|
|
print_barre_liste($langs->trans('PriceByCustomerLog'), $page, $_SERVEUR['PHP_SELF'], $option, $sortfield, $sortorder, '', count($prodcustprice->lines), $nbtotalofrecords, '');
|
|
|
|
if (count($prodcustprice->lines) > 0)
|
|
{
|
|
|
|
print '<form action="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '" method="POST">';
|
|
print '<input type="hidden" name="id" value="' . $object->id . '">';
|
|
|
|
print '<table class="noborder" width="100%">';
|
|
|
|
print '<tr class="liste_titre">';
|
|
print '<td>' . $langs->trans("ThirdParty") . '</td>';
|
|
print '<td>' . $langs->trans("AppliedPricesFrom") . '</td>';
|
|
print '<td align="center">' . $langs->trans("PriceBase") . '</td>';
|
|
print '<td align="right">' . $langs->trans("VAT") . '</td>';
|
|
print '<td align="right">' . $langs->trans("HT") . '</td>';
|
|
print '<td align="right">' . $langs->trans("TTC") . '</td>';
|
|
print '<td align="right">' . $langs->trans("MinPrice") . ' ' . $langs->trans("HT") . '</td>';
|
|
print '<td align="right">' . $langs->trans("MinPrice") . ' ' . $langs->trans("TTC") . '</td>';
|
|
print '<td align="right">' . $langs->trans("ChangedBy") . '</td>';
|
|
print '<td> </td>';
|
|
print '</tr>';
|
|
|
|
$var = True;
|
|
|
|
foreach ($prodcustprice->lines as $line)
|
|
{
|
|
$var = ! $var;
|
|
print "<tr ".$bc[$var].">";
|
|
// Date
|
|
$staticsoc = new Societe($db);
|
|
$staticsoc->fetch($line->fk_soc);
|
|
|
|
print "<td>" . $staticsoc->getNomUrl(1) . "</td>";
|
|
print "<td>" . dol_print_date($line->datec, "dayhour") . "</td>";
|
|
|
|
print '<td align="center">' . $langs->trans($line->price_base_type) . "</td>";
|
|
print '<td align="right">' . vatrate($line->tva_tx, true, $line->recuperableonly) . "</td>";
|
|
print '<td align="right">' . price($line->price) . "</td>";
|
|
print '<td align="right">' . price($line->price_ttc) . "</td>";
|
|
print '<td align="right">' . price($line->price_min) . '</td>';
|
|
print '<td align="right">' . price($line->price_min_ttc) . '</td>';
|
|
|
|
// User
|
|
$userstatic = new User($db);
|
|
$userstatic->fetch($line->fk_user);
|
|
print '<td align="right">';
|
|
print $userstatic->getLoginUrl(1);
|
|
print '</td>';
|
|
}
|
|
print "</table>";
|
|
} else {
|
|
print $langs->trans('None');
|
|
}
|
|
|
|
print "\n" . '<div class="tabsAction">' . "\n";
|
|
print '<div class="inline-block divButAction"><a class="butAction" href="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '">' . $langs->trans("Back") . '</a></div>';
|
|
print "\n</div><br>\n";
|
|
}
|
|
else
|
|
{
|
|
// View mode
|
|
|
|
// Count total nb of records
|
|
$nbtotalofrecords = 0;
|
|
if (empty($conf->global->MAIN_DISABLE_FULL_SCANLIST)) {
|
|
$nbtotalofrecords = $prodcustprice->fetch_all($sortfield, $sortorder, 0, 0, $filter);
|
|
}
|
|
|
|
$result = $prodcustprice->fetch_all($sortorder, $sortfield, $conf->liste_limit, $offset, $filter);
|
|
if ($result < 0) {
|
|
setEventMessage($prodcustprice->error, 'errors');
|
|
}
|
|
|
|
$option = '&search_soc=' . $search_soc . '&id=' . $object->id;
|
|
|
|
print_barre_liste($langs->trans('PriceByCustomer'), $page, $_SERVEUR ['PHP_SELF'], $option, $sortfield, $sortorder, '', count($prodcustprice->lines), $nbtotalofrecords, '');
|
|
|
|
print '<form action="' . $_SERVER["PHP_SELF"] . '?id=' . $object->id . '" method="POST">';
|
|
print '<input type="hidden" name="id" value="' . $object->id . '">';
|
|
|
|
print '<table class="noborder" width="100%">';
|
|
|
|
print '<tr class="liste_titre">';
|
|
print '<td>' . $langs->trans("ThirdParty") . '</td>';
|
|
print '<td>' . $langs->trans("AppliedPricesFrom") . '</td>';
|
|
print '<td align="center">' . $langs->trans("PriceBase") . '</td>';
|
|
print '<td align="right">' . $langs->trans("VAT") . '</td>';
|
|
print '<td align="right">' . $langs->trans("HT") . '</td>';
|
|
print '<td align="right">' . $langs->trans("TTC") . '</td>';
|
|
print '<td align="right">' . $langs->trans("MinPrice") . ' ' . $langs->trans("HT") . '</td>';
|
|
print '<td align="right">' . $langs->trans("MinPrice") . ' ' . $langs->trans("TTC") . '</td>';
|
|
print '<td align="right">' . $langs->trans("ChangedBy") . '</td>';
|
|
print '<td> </td>';
|
|
print '</tr>';
|
|
|
|
print '<tr class="liste_titre">';
|
|
print '<td><input type="text" class="flat" name="search_soc" value="' . $search_soc . '" size="20"></td>';
|
|
print '<td colspan="8"> </td>';
|
|
// Print the search button
|
|
print '<td class="liste_titre" align="right">';
|
|
print '<input class="liste_titre" name="button_search" type="image" src="' . DOL_URL_ROOT . '/theme/' . $conf->theme . '/img/search.png" value="' . dol_escape_htmltag($langs->trans("Search")) . '" title="' . dol_escape_htmltag($langs->trans("Search")) . '">';
|
|
print '</td>';
|
|
print '</tr>';
|
|
|
|
if (count($prodcustprice->lines) > 0)
|
|
{
|
|
$var = False;
|
|
|
|
foreach ($prodcustprice->lines as $line)
|
|
{
|
|
print "<tr ".$bc[$var].">";
|
|
// Date
|
|
$staticsoc = new Societe($db);
|
|
$staticsoc->fetch($line->fk_soc);
|
|
|
|
print "<td>" . $staticsoc->getNomUrl(1) . "</td>";
|
|
print "<td>" . dol_print_date($line->datec, "dayhour") . "</td>";
|
|
|
|
print '<td align="center">' . $langs->trans($line->price_base_type) . "</td>";
|
|
print '<td align="right">' . vatrate($line->tva_tx, true, $line->recuperableonly) . "</td>";
|
|
print '<td align="right">' . price($line->price) . "</td>";
|
|
print '<td align="right">' . price($line->price_ttc) . "</td>";
|
|
print '<td align="right">' . price($line->price_min) . '</td>';
|
|
print '<td align="right">' . price($line->price_min_ttc) . '</td>';
|
|
|
|
// User
|
|
$userstatic = new User($db);
|
|
$userstatic->fetch($line->fk_user);
|
|
print '<td align="right">';
|
|
print $userstatic->getLoginUrl(1);
|
|
print '</td>';
|
|
|
|
// Todo Edit or delete button
|
|
// Action
|
|
if ($user->rights->produit->supprimer || $user->rights->service->supprimer)
|
|
{
|
|
print '<td align="right">';
|
|
print '<a href="' . $_SERVER["PHP_SELF"] . '?action=showlog_customer_price&id=' . $object->id . '&socid=' . $line->fk_soc . '">';
|
|
print img_info();
|
|
print '</a>';
|
|
print ' ';
|
|
print '<a href="' . $_SERVER["PHP_SELF"] . '?action=edit_customer_price&id=' . $object->id . '&lineid=' . $line->id . '">';
|
|
print img_edit('default', 0, 'style="vertical-align: middle;"');
|
|
print '</a>';
|
|
print ' ';
|
|
print '<a href="' . $_SERVER["PHP_SELF"] . '?action=delete_customer_price&id=' . $object->id . '&lineid=' . $line->id . '">';
|
|
print img_delete('default', 'style="vertical-align: middle;"');
|
|
print '</a>';
|
|
print '</td>';
|
|
}
|
|
|
|
print "</tr>\n";
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$colspan=9;
|
|
if ($user->rights->produit->supprimer || $user->rights->service->supprimer) $colspan+=1;
|
|
print "<tr ".$bc[false].">";
|
|
print '<td colspan="'.$colspan.'">'.$langs->trans('None').'</td>';
|
|
print "</tr>";
|
|
}
|
|
|
|
print "</table>";
|
|
|
|
print "</form>";
|
|
|
|
/* ************************************************************************** */
|
|
/* */
|
|
/* Barre d'action */
|
|
/* */
|
|
/* ************************************************************************** */
|
|
|
|
print "\n" . '<div class="tabsAction">' . "\n";
|
|
|
|
if ($user->rights->produit->creer || $user->rights->service->creer) {
|
|
print '<div class="inline-block divButAction"><a class="butAction" href="' . $_SERVER["PHP_SELF"] . '?action=add_customer_price&id=' . $object->id . '">' . $langs->trans("AddCustomerPrice") . '</a></div>';
|
|
}
|
|
print "\n</div><br>\n";
|
|
}
|
|
}
|
|
|
|
llxFooter();
|
|
|
|
$db->close();
|