32require
'../main.inc.php';
33require_once DOL_DOCUMENT_ROOT.
'/product/class/product.class.php';
44$langs->loadLangs(array(
'commande',
'propal',
'bills',
'other',
'products'));
46$backtopage =
GETPOST(
'backtopage',
'alpha');
47$backtopageforcancel =
GETPOST(
'backtopageforcancel',
'alpha');
49$type =
GETPOST(
'type',
'intcomma');
53if (!empty($user->socid)) {
54 $socid = $user->socid;
58$sortfield =
GETPOST(
'sortfield',
'aZ09comma');
59$sortorder =
GETPOST(
'sortorder',
'aZ09comma');
61if (empty($page) || $page == -1) {
70$offset = $limit * $page;
74restrictedArea($user,
'produit|service', 0,
'product&product',
'',
'');
86 $helpurl =
'EN:Module_Products|FR:Module_Produits|ES:Módulo_Productos';
88 $helpurl =
'EN:Module_Services_En|FR:Module_Services|ES:Módulo_Servicios';
90$title = $langs->trans(
"Statistics");
93llxHeader(
'', $title, $helpurl,
'', 0, 0,
'',
'',
'',
'mod-product page-popuprop');
99$title = $langs->trans(
"ListProductServiceByPopularity");
100if ((
string) $type ==
'1') {
101 $title = $langs->trans(
"ListServiceByPopularity");
103if ((
string) $type ==
'0') {
104 $title = $langs->trans(
"ListProductByPopularity");
108 $param .=
'&type='.urlencode($type);
111 $param .=
'&mode='.urlencode($mode);
118$head[$h][0] = DOL_URL_ROOT.
'/product/stats/card.php?id=all';
119$head[$h][1] = $langs->trans(
"Chart");
120$head[$h][2] =
'chart';
123$head[$h][0] = DOL_URL_ROOT.
'/product/popuprop.php';
124$head[$h][1] = $langs->trans(
"ProductsServicesPerPopularity");
125if ((
string) $type ==
'0') {
126 $head[$h][1] = $langs->trans(
"ProductsPerPopularity");
128if ((
string) $type ==
'1') {
129 $head[$h][1] = $langs->trans(
"ServicesPerPopularity");
131$head[$h][2] =
'popularity';
143$sql =
"SELECT p.rowid, p.label, p.ref, p.fk_product_type as type, p.tobuy, p.tosell, p.tobatch, p.barcode, SUM(pd.qty) as c";
145if ($mode ==
'facture') {
146 $sql .=
" FROM ".MAIN_DB_PREFIX.
"facturedet as pd";
147} elseif ($mode ==
'commande') {
148 $textforqty =
'NbOfQtyInOrders';
149 $sql .=
" FROM ".MAIN_DB_PREFIX.
"commandedet as pd";
150} elseif ($mode ==
'propal') {
151 $textforqty =
'NbOfQtyInProposals';
152 $sql .=
" FROM ".MAIN_DB_PREFIX.
"propaldet as pd";
154$sql .=
", ".MAIN_DB_PREFIX.
"product as p";
155$sql .=
' WHERE p.entity IN ('.getEntity(
'product').
')';
156$sql .=
" AND p.rowid = pd.fk_product";
158 $sql .=
" AND fk_product_type = ".((int) $type);
160$sql .=
" GROUP BY p.rowid, p.label, p.ref, p.fk_product_type, p.tobuy, p.tosell, p.tobatch, p.barcode";
165if (!empty($mode) && $mode !=
'-1') {
166 $result = $db->query($sql);
168 $totalnboflines = $db->num_rows($result);
171 $sql .= $db->order($sortfield, $sortorder);
172 $sql .= $db->plimit($limit + 1, $offset);
174 $resql = $db->query($sql);
176 $num = $db->num_rows($resql);
180 $objp = $db->fetch_object($resql);
182 $infoprod[$objp->rowid] = array(
'type' => $objp->type,
'ref' => $objp->ref,
'label' => $objp->label,
'tobuy' => $objp->tobuy,
'tosell' => $objp->tobuy,
'tobatch' => $objp->tobatch,
'barcode' => $objp->barcode);
183 $infoprod[$objp->rowid][
'nbline'] = $objp->c;
196 'propal' =>
'Proposals',
197 'commande' =>
'Orders',
198 'facture' =>
'Facture'
200$title .=
' '.$form->selectarray(
'mode', $arrayofmode, $mode, 1, 0, 0,
'', 1);
201$title .=
' <input type="submit" class="button small" name="refresh" value="'.$langs->trans(
"Refresh").
'">';
204print
'<form method="POST" action="'.$_SERVER[
"PHP_SELF"].
'">';
205print
'<input type="hidden" name="token" value="'.newToken().
'">';
206print
'<input type="hidden" name="mode" value="'.$mode.
'">';
207print
'<input type="hidden" name="type" value="'.$type.
'">';
208print
'<input type="hidden" name="action" value="add">';
210 print
'<input type="hidden" name="backtopage" value="'.$backtopage.
'">';
212if ($backtopageforcancel) {
213 print
'<input type="hidden" name="backtopageforcancel" value="'.$backtopageforcancel.
'">';
217print_barre_liste($title, $page, $_SERVER[
"PHP_SELF"], $param, $sortfield, $sortorder,
"", $num, $totalnboflines,
'', 0,
'',
'', -1, 0, 0, 1);
219print
'<table class="noborder centpercent">';
221print
'<tr class="liste_titre">';
223print_liste_field_titre(
'Type', $_SERVER[
"PHP_SELF"],
'p.fk_product_type',
'', $param,
'', $sortfield, $sortorder,
'center ');
225print_liste_field_titre($textforqty, $_SERVER[
"PHP_SELF"],
'c',
'', $param,
'', $sortfield, $sortorder,
'right ');
228if ($mode && $mode !=
'-1') {
229 foreach ($infoprod as $prodid => $vals) {
232 $sql =
"SELECT label";
233 $sql .=
" FROM ".MAIN_DB_PREFIX.
"product_lang";
234 $sql .=
" WHERE fk_product = ".((int) $prodid);
235 $sql .=
" AND lang = '".$db->escape($langs->getDefaultLang()).
"'";
238 $resultp = $db->query($sql);
240 $objtp = $db->fetch_object($resultp);
241 if (!empty($objtp->label)) {
242 $vals[
'label'] = $objtp->label;
247 $tmpproduct->id = $prodid;
248 $tmpproduct->ref = $vals[
'ref'];
249 $tmpproduct->label = $vals[
'label'];
250 $tmpproduct->type = $vals[
'type'];
251 $tmpproduct->status = $vals[
'tosell'];
252 $tmpproduct->status_buy = $vals[
'tobuy'];
253 $tmpproduct->status_batch = $vals[
'tobatch'];
254 $tmpproduct->barcode = $vals[
'barcode'];
260 print $tmpproduct->getNomUrl(1);
264 print
'<td class="center">';
266 if ($vals[
'type'] == 1) {
267 $s .=
img_picto($langs->trans(
"Service"),
'service',
'class="paddingleftonly paddingrightonly colorgrey"');
269 $s .=
img_picto($langs->trans(
"Product"),
'product',
'class="paddingleftonly paddingrightonly colorgrey"');
273 print
'<td>'.dol_escape_htmltag($vals[
'label']).
'</td>';
274 print
'<td class="right">'.$vals[
'nbline'].
'</td>';
278 print
'<tr><td colspan="4"><span class="opacitymedium">'.$langs->trans(
"SelectTheTypeOfObjectToAnalyze").
'</span></td></tr>';
llxFooter($comment='', $zone='private', $disabledoutputofmessages=0)
Empty footer.
if(!defined('NOREQUIRESOC')) if(!defined( 'NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined( 'NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined( 'NOREQUIREAJAX')) llxHeader($head='', $title='', $help_url='', $target='', $disablejs=0, $disablehead=0, $arrayofjs='', $arrayofcss='', $morequerystring='', $morecssonbody='', $replacemainareaby='', $disablenofollow=0, $disablenoindex=0)
Empty header.
Class to manage products or services.
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='')
Load a title with picto.
print_barre_liste($title, $page, $file, $options='', $sortfield='', $sortorder='', $morehtmlcenter='', $num=-1, $totalnboflines='', $picto='generic', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limit=-1, $selectlimitsuffix=0, $hidenavigation=0, $pagenavastextinput=0, $morehtmlrightbeforearrow='')
Print a title with navigation controls for pagination.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='', $dragdropfile=0)
Show tabs of a record.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
print_liste_field_titre($name, $file="", $field="", $begin="", $moreparam="", $moreattrib="", $sortfield="", $sortorder="", $prefix="", $tooltip="", $forcenowrapcolumntitle=0)
Show title line of an array.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
global $conf
The following vars must be defined: $type2label $form $conf, $lang, The following vars may also be de...
restrictedArea(User $user, $features, $object=0, $tableandshare='', $feature2='', $dbt_keyfield='fk_soc', $dbt_select='rowid', $isdraft=0, $mode=0)
Check permissions of a user to show a page and an object.