forked from Wavyzz/dolibarr
Conflicts: htdocs/compta/bank/annuel.php htdocs/compta/bank/categ.php htdocs/compta/bank/releve.php htdocs/core/class/hookmanager.class.php htdocs/core/class/html.formfile.class.php htdocs/core/modules/livraison/pdf/pdf_typhon.modules.php htdocs/core/tpl/contacts.tpl.php htdocs/cron/list.php htdocs/main.inc.php htdocs/public/paybox/paymentko.php htdocs/public/paybox/paymentok.php htdocs/public/paypal/paymentko.php htdocs/public/paypal/paymentok.php htdocs/theme/bureau2crea/style.css.php htdocs/theme/eldy/style.css.php htdocs/user/class/user.class.php htdocs/viewimage.php
174 lines
5.3 KiB
PHP
174 lines
5.3 KiB
PHP
<?php
|
|
/* Copyright (C) 2006 Andre Cianfarani <acianfa@free.fr>
|
|
* Copyright (C) 2005-2013 Regis Houssin <regis.houssin@capnetworks.com>
|
|
* Copyright (C) 2007-2011 Laurent Destailleur <eldy@users.sourceforge.net>
|
|
*
|
|
* 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/ajax/products.php
|
|
* \brief File to return Ajax response on product list request
|
|
*/
|
|
|
|
if (! defined('NOTOKENRENEWAL')) define('NOTOKENRENEWAL',1); // Disables token renewal
|
|
if (! defined('NOREQUIREMENU')) define('NOREQUIREMENU','1');
|
|
if (! defined('NOREQUIREHTML')) define('NOREQUIREHTML','1');
|
|
if (! defined('NOREQUIREAJAX')) define('NOREQUIREAJAX','1');
|
|
if (! defined('NOREQUIRESOC')) define('NOREQUIRESOC','1');
|
|
if (! defined('NOCSRFCHECK')) define('NOCSRFCHECK','1');
|
|
if (empty($_GET['keysearch']) && ! defined('NOREQUIREHTML')) define('NOREQUIREHTML','1');
|
|
|
|
require '../../main.inc.php';
|
|
|
|
$htmlname=GETPOST('htmlname','alpha');
|
|
$socid=GETPOST('socid','int');
|
|
$type=GETPOST('type','int');
|
|
$mode=GETPOST('mode','int');
|
|
$status=((GETPOST('status','int') >= 0) ? GETPOST('status','int') : -1);
|
|
$outjson=(GETPOST('outjson','int') ? GETPOST('outjson','int') : 0);
|
|
$price_level=GETPOST('price_level','int');
|
|
$action=GETPOST('action', 'alpha');
|
|
$id=GETPOST('id', 'int');
|
|
$price_by_qty_rowid=GETPOST('pbq', 'int');
|
|
|
|
/*
|
|
* View
|
|
*/
|
|
|
|
//print '<!-- Ajax page called with url '.$_SERVER["PHP_SELF"].'?'.$_SERVER["QUERY_STRING"].' -->'."\n";
|
|
|
|
dol_syslog(join(',',$_GET));
|
|
//print_r($_GET);
|
|
|
|
if (! empty($action) && $action == 'fetch' && ! empty($id))
|
|
{
|
|
require DOL_DOCUMENT_ROOT . '/product/class/product.class.php';
|
|
|
|
$outjson=array();
|
|
|
|
$object = new Product($db);
|
|
$ret=$object->fetch($id);
|
|
if ($ret > 0)
|
|
{
|
|
$outref=$object->ref;
|
|
$outlabel=$object->label;
|
|
$outdesc=$object->description;
|
|
$outtype=$object->type;
|
|
$outqty=1;
|
|
$outdiscount=0;
|
|
|
|
$found=false;
|
|
|
|
// Price by qty
|
|
if (!empty($price_by_qty_rowid) && $price_by_qty_rowid >= 1) // If we need a particular price related to qty
|
|
{
|
|
$sql = "SELECT price, unitprice, quantity, remise_percent";
|
|
$sql.= " FROM ".MAIN_DB_PREFIX."product_price_by_qty ";
|
|
$sql.= " WHERE rowid=".$price_by_qty_rowid."";
|
|
|
|
$result = $db->query($sql);
|
|
if ($result)
|
|
{
|
|
$objp = $db->fetch_object($result);
|
|
if ($objp)
|
|
{
|
|
$found=true;
|
|
$outprice_ht=price($objp->unitprice);
|
|
$outprice_ttc=price($objp->unitprice * (1 + ($object->tva_tx / 100)));
|
|
$outpricebasetype=$object->price_base_type;
|
|
$outtva_tx=$object->tva_tx;
|
|
$outqty=$objp->quantity;
|
|
$outdiscount=$objp->remise_percent;
|
|
}
|
|
}
|
|
}
|
|
|
|
// Multiprice
|
|
if (! $found && isset($price_level) && $price_level >= 1) // If we need a particular price level (from 1 to 6)
|
|
{
|
|
$sql = "SELECT price, price_ttc, price_base_type, tva_tx";
|
|
$sql.= " FROM ".MAIN_DB_PREFIX."product_price ";
|
|
$sql.= " WHERE fk_product='".$id."'";
|
|
$sql.= " AND entity IN (".getEntity('productprice', 1).")";
|
|
$sql.= " AND price_level=".$price_level;
|
|
$sql.= " ORDER BY date_price";
|
|
$sql.= " DESC LIMIT 1";
|
|
|
|
$result = $db->query($sql);
|
|
if ($result)
|
|
{
|
|
$objp = $db->fetch_object($result);
|
|
if ($objp)
|
|
{
|
|
$found=true;
|
|
$outprice_ht=price($objp->price);
|
|
$outprice_ttc=price($objp->price_ttc);
|
|
$outpricebasetype=$objp->price_base_type;
|
|
$outtva_tx=$objp->tva_tx;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (! $found)
|
|
{
|
|
$outprice_ht=price($object->price);
|
|
$outprice_ttc=price($object->price_ttc);
|
|
$outpricebasetype=$object->price_base_type;
|
|
$outtva_tx=$object->tva_tx;
|
|
}
|
|
|
|
$outjson = array('ref'=>$outref, 'label'=>$outlabel, 'desc'=>$outdesc, 'type'=>$outtype, 'price_ht'=>$outprice_ht, 'price_ttc'=>$outprice_ttc, 'pricebasetype'=>$outpricebasetype, 'tva_tx'=>$outtva_tx, 'qty'=>$outqty, 'discount'=>$outdiscount);
|
|
}
|
|
|
|
echo json_encode($outjson);
|
|
|
|
}
|
|
else
|
|
{
|
|
require_once DOL_DOCUMENT_ROOT.'/core/class/html.form.class.php';
|
|
|
|
$langs->load("products");
|
|
$langs->load("main");
|
|
|
|
top_httphead();
|
|
|
|
if (empty($htmlname)) return;
|
|
|
|
$match = preg_grep('/('.$htmlname.'[0-9]+)/',array_keys($_GET));
|
|
sort($match);
|
|
$idprod = (! empty($match[0]) ? $match[0] : '');
|
|
|
|
if (! GETPOST($htmlname) && ! GETPOST($idprod)) return;
|
|
|
|
// When used from jQuery, the search term is added as GET param "term".
|
|
$searchkey=(GETPOST($idprod)?GETPOST($idprod):(GETPOST($htmlname)?GETPOST($htmlname):''));
|
|
|
|
$form = new Form($db);
|
|
if (empty($mode) || $mode == 1)
|
|
{
|
|
$arrayresult=$form->select_produits_list("",$htmlname,$type,"",$price_level,$searchkey,$status,2,$outjson);
|
|
}
|
|
elseif ($mode == 2)
|
|
{
|
|
$arrayresult=$form->select_produits_fournisseurs_list($socid,"",$htmlname,$type,"",$searchkey,$status,$outjson);
|
|
}
|
|
|
|
$db->close();
|
|
|
|
if ($outjson) print json_encode($arrayresult);
|
|
}
|
|
|
|
?>
|