'."\n";
-
- // Lines with input filters
- print '';
+ // Action column
if (!empty($conf->global->MAIN_CHECKBOX_LEFT_COLUMN)) {
- print '| ';
- $searchpicto = $form->showFilterButtons('left');
- print $searchpicto;
+ print ' | ';
+ if ($massactionbutton || $massaction) { // If we are in select mode (massactionbutton defined) or if we have already selected and sent an action ($massaction) defined
+ $selected = 0;
+ if (in_array($obj->rowid, $arrayofselected)) {
+ $selected = 1;
+ }
+ print '';
+ }
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+ // Ref
if (!empty($arrayfields['p.rowid']['checked'])) {
- print '';
- print '';
- print ' | ';
+ print '';
+ print $product_static->id;
+ print " | \n";
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+
+ // Ref
if (!empty($arrayfields['p.ref']['checked'])) {
- print '';
- print '';
- print ' | ';
+ print '';
+ print $product_static->getNomUrl(1);
+ print " | \n";
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+
+ // Ref supplier
if (!empty($arrayfields['pfp.ref_fourn']['checked'])) {
- print '';
- print '';
- print ' | ';
+ print '';
+ print $product_static->getNomUrl(1);
+ print " | \n";
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+
// Thumbnail
if (!empty($arrayfields['thumbnail']['checked'])) {
- print '';
- print ' | ';
+ $product_thumbnail_html = '';
+ if (!empty($product_static->entity)) {
+ $product_thumbnail = $product_static->show_photos('product', $conf->product->multidir_output[$product_static->entity], 1, 1, 0, 0, 0, 80);
+ if ($product_static->nbphoto > 0) {
+ $product_thumbnail_html = $product_thumbnail;
+ }
+ }
+
+ print '' . $product_thumbnail_html . ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+
+ // Label
if (!empty($arrayfields['p.label']['checked'])) {
- print '';
- print '';
- print ' | ';
+ print ''.$obj->label.' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+
// Type
if (!empty($arrayfields['p.fk_product_type']['checked'])) {
- print '';
- $array = array('-1'=>' ', '0'=>$langs->trans('Product'), '1'=>$langs->trans('Service'));
- print $form->selectarray('search_type', $array, $search_type);
+ print ' | ';
+ $s = '';
+ if ($obj->fk_product_type == 0) {
+ $s .= img_picto($langs->trans("Product"), 'product', 'class="paddingleftonly paddingrightonly colorgrey"');
+ } else {
+ $s .= img_picto($langs->trans("Service"), 'service', 'class="paddingleftonly paddingrightonly colorgrey"');
+ }
+ print $s;
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+
// Barcode
if (!empty($arrayfields['p.barcode']['checked'])) {
- print '';
- print '';
- print ' | ';
+ print ''.$obj->barcode.' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+
// Duration
if (!empty($arrayfields['p.duration']['checked'])) {
- print '';
+ print ' | ';
+
+ if (preg_match('/([^a-z]+)[a-z]$/i', $obj->duration)) {
+ $duration_value = substr($obj->duration, 0, dol_strlen($obj->duration) - 1);
+ $duration_unit = substr($obj->duration, -1);
+
+ if ((float) $duration_value > 1) {
+ $dur = array("i"=>$langs->trans("Minutes"), "h"=>$langs->trans("Hours"), "d"=>$langs->trans("Days"), "w"=>$langs->trans("Weeks"), "m"=>$langs->trans("Months"), "y"=>$langs->trans("Years"));
+ } elseif ((float) $duration_value > 0) {
+ $dur = array("i"=>$langs->trans("Minute"), "h"=>$langs->trans("Hour"), "d"=>$langs->trans("Day"), "w"=>$langs->trans("Week"), "m"=>$langs->trans("Month"), "y"=>$langs->trans("Year"));
+ }
+ print $duration_value;
+ print ((!empty($duration_unit) && isset($dur[$duration_unit]) && $duration_value != '') ? ' '.$langs->trans($dur[$duration_unit]) : '');
+ } elseif (!preg_match('/^[a-z]$/i', $obj->duration)) { // If duration is a simple char (like 's' of 'm'), we do not show value
+ print $obj->duration;
+ }
+
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
// Finished
if (!empty($arrayfields['p.finished']['checked'])) {
- print '';
- print $formproduct->selectProductNature('search_finished', $search_finished);
+ print ' | ';
+ print $product_static->getLibFinished();
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+
// Weight
if (!empty($arrayfields['p.weight']['checked'])) {
- print '';
+ print ' | ';
+ print $obj->weight;
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
// Weight units
if (!empty($arrayfields['p.weight_units']['checked'])) {
- print '';
+ print ' | ';
+ if ($product_static->weight != '') {
+ print measuringUnitString(0, 'weight', $product_static->weight_units);
+ }
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
// Length
if (!empty($arrayfields['p.length']['checked'])) {
- print '';
+ print ' | ';
+ print $obj->length;
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
// Length units
if (!empty($arrayfields['p.length_units']['checked'])) {
- print '';
+ print ' | ';
+ if ($product_static->length != '') {
+ print measuringUnitString(0, 'size', $product_static->length_units);
+ }
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
// Width
if (!empty($arrayfields['p.width']['checked'])) {
- print '';
+ print ' | ';
+ print $obj->width;
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
// Width units
if (!empty($arrayfields['p.width_units']['checked'])) {
- print '';
+ print ' | ';
+ if ($product_static->width != '') {
+ print measuringUnitString(0, 'size', $product_static->width_units);
+ }
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
// Height
if (!empty($arrayfields['p.height']['checked'])) {
- print '';
+ print ' | ';
+ print $obj->height;
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
// Height units
if (!empty($arrayfields['p.height_units']['checked'])) {
- print '';
+ print ' | ';
+ if ($product_static->height != '') {
+ print measuringUnitString(0, 'size', $product_static->height_units);
+ }
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
// Surface
if (!empty($arrayfields['p.surface']['checked'])) {
- print '';
+ print ' | ';
+ print $obj->surface;
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
// Surface units
if (!empty($arrayfields['p.surface_units']['checked'])) {
- print '';
+ print ' | ';
+ if ($product_static->surface != '') {
+ print measuringUnitString(0, 'surface', $product_static->surface_units);
+ }
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
// Volume
if (!empty($arrayfields['p.volume']['checked'])) {
- print '';
+ print ' | ';
+ print $obj->volume;
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
// Volume units
if (!empty($arrayfields['p.volume_units']['checked'])) {
- print '';
+ print ' | ';
+ if ($product_static->volume != '') {
+ print measuringUnitString(0, 'volume', $product_static->volume_units);
+ }
print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
-
// Unit
if (!empty($arrayfields['cu.label']['checked'])) {
- print '';
+ print ' | ';
+ if (!empty($obj->cu_label)) {
+ print $langs->trans($obj->cu_label);
+ }
print ' | ';
- }
-
- // Sell price
- if (!empty($arrayfields['p.sellprice']['checked'])) {
- print '';
- print ' | ';
- }
-
- // Multiprice
- if (!empty($conf->global->PRODUIT_MULTIPRICES)) {
- foreach ($arraypricelevel as $key => $value) {
- if (!empty($arrayfields['p.sellprice'.$key]['checked'])) {
- print '';
- print ' | ';
- }
+ if (!$i) {
+ $totalarray['nbfield']++;
}
}
- // Minimum buying Price
- if (!empty($arrayfields['p.minbuyprice']['checked'])) {
- print '';
- print ' ';
- print ' | ';
- }
- // Number buying Price
- if (!empty($arrayfields['p.numbuyprice']['checked'])) {
- print '';
- print ' ';
- print ' | ';
- }
// Sell price
- if (!empty($arrayfields['p.tva_tx']['checked'])) {
- print '';
- print '';
- print ' | ';
- }
- // WAP
- if (!empty($arrayfields['p.pmp']['checked'])) {
- print '';
- print ' ';
- print ' | ';
- }
- // cost_price
- if (!empty($arrayfields['p.cost_price']['checked'])) {
- print '';
- print ' ';
- print ' | ';
- }
- // Limit for alert
- if (!empty($arrayfields['p.seuil_stock_alerte']['checked'])) {
- print '';
- print ' ';
- print ' | ';
- }
- // Desired stock
- if (!empty($arrayfields['p.desiredstock']['checked'])) {
- print '';
- print ' ';
- print ' | ';
- }
- // Stock
- if (!empty($arrayfields['p.stock']['checked'])) {
- print ' | ';
- }
- // Stock
- if (!empty($arrayfields['stock_virtual']['checked'])) {
- print ' | ';
- }
- // To batch
- if (!empty($arrayfields['p.tobatch']['checked'])) {
- print '';
- $statutarray = array(
- '-1' => '',
- '0' => $langs->trans("ProductStatusNotOnBatchShort"),
- '1' => $langs->trans("ProductStatusOnBatchShort"),
- '2' => $langs->trans("ProductStatusOnSerialShort")
- );
- print $form->selectarray('search_tobatch', $statutarray, $search_tobatch);
- print ' | ';
- }
- // Country
- if (!empty($arrayfields['p.fk_country']['checked'])) {
- print '';
- print $form->select_country($search_country, 'search_country', '', 0);
- print ' | ';
- }
- // State
- if (!empty($arrayfields['p.fk_state']['checked'])) {
- print '';
- print $formcompany->select_state($search_state, $search_country);
- print ' | ';
- }
- // Accountancy code sell
- if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_sell']['checked'])) {
- print ' | ';
- }
- if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_sell_intra']['checked'])) {
- print ' | ';
- }
- if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_sell_export']['checked'])) {
- print ' | ';
- }
- // Accountancy code buy
- if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_buy']['checked'])) {
- print ' | ';
- }
- if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_buy_intra']['checked'])) {
- print ' | ';
- }
- if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_buy_export']['checked'])) {
- print ' | ';
- }
- // Extra fields
- include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_search_input.tpl.php';
- // Fields from hook
- $parameters = array('arrayfields'=>$arrayfields);
- $reshook = $hookmanager->executeHooks('printFieldListOption', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
- print $hookmanager->resPrint;
- // Date creation
- if (!empty($arrayfields['p.datec']['checked'])) {
- print '';
- print ' | ';
- }
- // Date modification
- if (!empty($arrayfields['p.tms']['checked'])) {
- print '';
- print ' | ';
- }
- if (!empty($arrayfields['p.tosell']['checked'])) {
- print '';
- print $form->selectarray('search_tosell', array('0'=>$langs->trans('ProductStatusNotOnSellShort'), '1'=>$langs->trans('ProductStatusOnSellShort')), $search_tosell, 1);
- print ' | ';
- }
- if (!empty($arrayfields['p.tobuy']['checked'])) {
- print '';
- print $form->selectarray('search_tobuy', array('0'=>$langs->trans('ProductStatusNotOnBuyShort'), '1'=>$langs->trans('ProductStatusOnBuyShort')), $search_tobuy, 1);
- print ' | ';
- }
- if (empty($conf->global->MAIN_CHECKBOX_LEFT_COLUMN)) {
- print '';
- $searchpicto = $form->showFilterButtons();
- print $searchpicto;
- print ' | ';
- }
- print '
';
-
- print '';
- if (!empty($conf->global->MAIN_CHECKBOX_LEFT_COLUMN)) {
- print_liste_field_titre($selectedfields, $_SERVER["PHP_SELF"], "", '', '', '', $sortfield, $sortorder, 'center maxwidthsearch ');
- }
- if (!empty($arrayfields['p.rowid']['checked'])) {
- print_liste_field_titre($arrayfields['p.rowid']['label'], $_SERVER["PHP_SELF"], "p.rowid", "", $param, "", $sortfield, $sortorder);
- }
- if (!empty($arrayfields['p.ref']['checked'])) {
- print_liste_field_titre($arrayfields['p.ref']['label'], $_SERVER["PHP_SELF"], "p.ref", "", $param, "", $sortfield, $sortorder);
- }
- if (!empty($arrayfields['pfp.ref_fourn']['checked'])) {
- print_liste_field_titre($arrayfields['pfp.ref_fourn']['label'], $_SERVER["PHP_SELF"], "pfp.ref_fourn", "", $param, "", $sortfield, $sortorder);
- }
- if (!empty($arrayfields['thumbnail']['checked'])) {
- print_liste_field_titre($arrayfields['thumbnail']['label'], $_SERVER["PHP_SELF"], '', '', $param, '', $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['p.label']['checked'])) {
- print_liste_field_titre($arrayfields['p.label']['label'], $_SERVER["PHP_SELF"], "p.label", "", $param, "", $sortfield, $sortorder);
- }
- if (!empty($arrayfields['p.fk_product_type']['checked'])) {
- print_liste_field_titre($arrayfields['p.fk_product_type']['label'], $_SERVER["PHP_SELF"], "p.fk_product_type", "", $param, "", $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['p.barcode']['checked'])) {
- print_liste_field_titre($arrayfields['p.barcode']['label'], $_SERVER["PHP_SELF"], "p.barcode", "", $param, "", $sortfield, $sortorder);
- }
- if (!empty($arrayfields['p.duration']['checked'])) {
- print_liste_field_titre($arrayfields['p.duration']['label'], $_SERVER["PHP_SELF"], "p.duration", "", $param, '', $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['p.finished']['checked'])) {
- print_liste_field_titre($arrayfields['p.finished']['label'], $_SERVER["PHP_SELF"], "p.finished", "", $param, '', $sortfield, $sortorder, 'center ');
- }
-
- if (!empty($arrayfields['p.weight']['checked'])) {
- print_liste_field_titre($arrayfields['p.weight']['label'], $_SERVER['PHP_SELF'], 'p.weight', '', $param, '', $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['p.weight_units']['checked'])) {
- print_liste_field_titre($arrayfields['p.weight_units']['label'], $_SERVER['PHP_SELF'], 'p.weight_units', '', $param, '', $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['p.length']['checked'])) {
- print_liste_field_titre($arrayfields['p.length']['label'], $_SERVER['PHP_SELF'], 'p.length', '', $param, '', $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['p.length_units']['checked'])) {
- print_liste_field_titre($arrayfields['p.length_units']['label'], $_SERVER['PHP_SELF'], 'p.length_units', '', $param, '', $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['p.width']['checked'])) {
- print_liste_field_titre($arrayfields['p.width']['label'], $_SERVER['PHP_SELF'], 'p.width', '', $param, '', $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['p.width_units']['checked'])) {
- print_liste_field_titre($arrayfields['p.width_units']['label'], $_SERVER['PHP_SELF'], 'p.width_units', '', $param, '', $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['p.height']['checked'])) {
- print_liste_field_titre($arrayfields['p.height']['label'], $_SERVER['PHP_SELF'], 'p.height', '', $param, '', $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['p.height_units']['checked'])) {
- print_liste_field_titre($arrayfields['p.height_units']['label'], $_SERVER['PHP_SELF'], 'p.height_units', '', $param, '', $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['p.surface']['checked'])) {
- print_liste_field_titre($arrayfields['p.surface']['label'], $_SERVER['PHP_SELF'], "p.surface", '', $param, '', $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['p.surface_units']['checked'])) {
- print_liste_field_titre($arrayfields['p.surface_units']['label'], $_SERVER['PHP_SELF'], 'p.surface_units', '', $param, '', $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['p.volume']['checked'])) {
- print_liste_field_titre($arrayfields['p.volume']['label'], $_SERVER['PHP_SELF'], 'p.volume', '', $param, '', $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['p.volume_units']['checked'])) {
- print_liste_field_titre($arrayfields['p.volume_units']['label'], $_SERVER['PHP_SELF'], 'p.volume_units', '', $param, '', $sortfield, $sortorder, 'center ');
- }
- if (!empty($arrayfields['cu.label']['checked'])) {
- print_liste_field_titre($arrayfields['cu.label']['label'], $_SERVER['PHP_SELF'], '', '', $param, '', $sortfield, $sortorder, 'center ');
- }
if (!empty($arrayfields['p.sellprice']['checked'])) {
- print_liste_field_titre($arrayfields['p.sellprice']['label'], $_SERVER["PHP_SELF"], "", "", $param, '', $sortfield, $sortorder, 'right ');
+ print '| ';
+ if ($obj->tosell && $usercancreadprice) {
+ if ($obj->price_base_type == 'TTC') {
+ print ''.price($obj->price_ttc).' '.$langs->trans("TTC").'';
+ } else {
+ print ''.price($obj->price).' '.$langs->trans("HT").'';
+ }
+ }
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+
// Multiprices
if (!empty($conf->global->PRODUIT_MULTIPRICES)) {
+ if (! isset($productpricescache)) {
+ $productpricescache=array();
+ }
+ if (! isset($productpricescache[$obj->rowid])) {
+ $productpricescache[$obj->rowid] = array();
+ }
+
+ if ($obj->tosell && $usercancreadprice) {
+ // Make 1 request for all price levels (without filter on price_level) and saved result into an cache array
+ // then reuse the cache array if we need prices for other price levels
+ $sqlp = "SELECT p.rowid, p.fk_product, p.price, p.price_ttc, p.price_level, p.date_price, p.price_base_type";
+ $sqlp .= " FROM ".MAIN_DB_PREFIX."product_price as p";
+ $sqlp .= " WHERE fk_product = ".((int) $obj->rowid);
+ $sqlp .= " ORDER BY p.date_price DESC, p.rowid DESC, p.price_level ASC";
+ $resultp = $db->query($sqlp);
+ if ($resultp) {
+ $nump = $db->num_rows($resultp);
+ $j = 0;
+ while ($j < $nump) {
+ $objp = $db->fetch_object($resultp);
+
+ if (empty($productpricescache[$obj->rowid][$objp->price_level])) {
+ $productpricescache[$obj->rowid][$objp->price_level]['price'] = $objp->price;
+ $productpricescache[$obj->rowid][$objp->price_level]['price_ttc'] = $objp->price_ttc;
+ $productpricescache[$obj->rowid][$objp->price_level]['price_base_type'] = $objp->price_base_type;
+ }
+
+ $j++;
+ }
+
+ $db->free($resultp);
+ } else {
+ dol_print_error($db);
+ }
+ }
+
foreach ($arraypricelevel as $key => $value) {
if (!empty($arrayfields['p.sellprice'.$key]['checked'])) {
- print_liste_field_titre($arrayfields['p.sellprice'.$key]['label'], $_SERVER["PHP_SELF"], "", "", $param, '', $sortfield, $sortorder, 'right ');
+ print '';
+ if (!empty($productpricescache[$obj->rowid])) {
+ if ($productpricescache[$obj->rowid][$key]['price_base_type'] == 'TTC') {
+ print ''.price($productpricescache[$obj->rowid][$key]['price_ttc']).' '.$langs->trans("TTC").'';
+ } else {
+ print ''.price($productpricescache[$obj->rowid][$key]['price']).' '.$langs->trans("HT").'';
+ }
+ }
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
}
}
+ // Better buy price
if (!empty($arrayfields['p.minbuyprice']['checked'])) {
- print_liste_field_titre($arrayfields['p.minbuyprice']['label'], $_SERVER["PHP_SELF"], "", "", $param, '', $sortfield, $sortorder, 'right ');
+ print '';
+ if ($obj->tobuy && $obj->minsellprice != '' && $usercancreadprice) {
+ //print price($obj->minsellprice).' '.$langs->trans("HT");
+ if ($product_fourn->find_min_price_product_fournisseur($obj->rowid) > 0) {
+ if ($product_fourn->product_fourn_price_id > 0) {
+ if ((isModEnabled("fournisseur") && !empty($user->rights->fournisseur->lire) && empty($conf->global->MAIN_USE_NEW_SUPPLIERMOD)) || (isModEnabled("supplier_order") && !empty($user->rights->supplier_order->lire)) || (isModEnabled("supplier_invoice") && !empty($user->rights->supplier_invoice->lire))) {
+ $htmltext = $product_fourn->display_price_product_fournisseur(1, 1, 0, 1);
+ print ''.$form->textwithpicto(price($product_fourn->fourn_unitprice * (1 - $product_fourn->fourn_remise_percent / 100) - $product_fourn->fourn_remise).' '.$langs->trans("HT"), $htmltext).'';
+ } else {
+ print ''.price($product_fourn->fourn_unitprice).' '.$langs->trans("HT").'';
+ }
+ }
+ }
+ }
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+
+ // Number of buy prices
if (!empty($arrayfields['p.numbuyprice']['checked'])) {
- print_liste_field_titre($arrayfields['p.numbuyprice']['label'], $_SERVER["PHP_SELF"], "", "", $param, '', $sortfield, $sortorder, 'right ');
+ print '';
+ if ($obj->tobuy && $usercancreadprice) {
+ if (count($productFournList = $product_fourn->list_product_fournisseur_price($obj->rowid)) > 0) {
+ $htmltext = $product_fourn->display_price_product_fournisseur(1, 1, 0, 1, $productFournList);
+ print $form->textwithpicto(count($productFournList), $htmltext);
+ }
+ }
+ print ' | ';
}
+
+ // VAT or Sell Tax Rate
if (!empty($arrayfields['p.tva_tx']['checked'])) {
- print_liste_field_titre($arrayfields['p.tva_tx']['label'], $_SERVER["PHP_SELF"], 'p.tva_tx', "", $param, '', $sortfield, $sortorder, 'right ');
+ print '';
+ print vatrate($obj->tva_tx, true);
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+
+ // WAP
if (!empty($arrayfields['p.pmp']['checked'])) {
- print_liste_field_titre($arrayfields['p.pmp']['label'], $_SERVER["PHP_SELF"], "", "", $param, '', $sortfield, $sortorder, 'right ');
+ print '';
+ if ($usercancreadprice) {
+ print ''.price($product_static->pmp, 1, $langs)."";
+ }
+ print ' | ';
}
+ // Cost price
if (!empty($arrayfields['p.cost_price']['checked'])) {
- print_liste_field_titre($arrayfields['p.cost_price']['label'], $_SERVER["PHP_SELF"], "", "", $param, '', $sortfield, $sortorder, 'right ');
+ print '';
+ //print $obj->cost_price;
+ if ($usercancreadprice) {
+ print ''.price($obj->cost_price).' '.$langs->trans("HT").'';
+ }
+ print ' | ';
}
+
+ // Limit alert
if (!empty($arrayfields['p.seuil_stock_alerte']['checked'])) {
- print_liste_field_titre($arrayfields['p.seuil_stock_alerte']['label'], $_SERVER["PHP_SELF"], "p.seuil_stock_alerte", "", $param, '', $sortfield, $sortorder, 'right ');
+ print '';
+ if ($obj->fk_product_type != 1) {
+ print $obj->seuil_stock_alerte;
+ }
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+ // Desired stock
if (!empty($arrayfields['p.desiredstock']['checked'])) {
- print_liste_field_titre($arrayfields['p.desiredstock']['label'], $_SERVER["PHP_SELF"], "p.desiredstock", "", $param, '', $sortfield, $sortorder, 'right ');
+ print '';
+ if ($obj->fk_product_type != 1) {
+ print $obj->desiredstock;
+ }
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+ // Stock real
if (!empty($arrayfields['p.stock']['checked'])) {
- print_liste_field_titre($arrayfields['p.stock']['label'], $_SERVER["PHP_SELF"], "p.stock", "", $param, '', $sortfield, $sortorder, 'right ');
+ print '';
+ if ($obj->fk_product_type != 1) {
+ if ($obj->seuil_stock_alerte != '' && $product_static->stock_reel < (float) $obj->seuil_stock_alerte) {
+ print img_warning($langs->trans("StockLowerThanLimit", $obj->seuil_stock_alerte)).' ';
+ }
+ if ($usercancreadprice) {
+ print price(price2num($product_static->stock_reel, 'MS'));
+ }
+ }
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+ // Stock virtual
if (!empty($arrayfields['stock_virtual']['checked'])) {
- print_liste_field_titre($arrayfields['stock_virtual']['label'], $_SERVER["PHP_SELF"], "", "", $param, '', $sortfield, $sortorder, 'right ');
+ print '';
+ if ($obj->fk_product_type != 1) {
+ if ($obj->seuil_stock_alerte != '' && $product_static->stock_theorique < (float) $obj->seuil_stock_alerte) {
+ print img_warning($langs->trans("StockLowerThanLimit", $obj->seuil_stock_alerte)).' ';
+ }
+ if ($usercancreadprice) {
+ print price(price2num($product_static->stock_theorique, 'MS'));
+ }
+ }
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+ // Lot/Serial
if (!empty($arrayfields['p.tobatch']['checked'])) {
- print_liste_field_titre($arrayfields['p.tobatch']['label'], $_SERVER["PHP_SELF"], "p.tobatch", "", $param, '', $sortfield, $sortorder, 'center ');
+ print '';
+ print $product_static->getLibStatut(1, 2);
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+ // Country
if (!empty($arrayfields['p.fk_country']['checked'])) {
- print_liste_field_titre($arrayfields['p.fk_country']['label'], $_SERVER["PHP_SELF"], "p.fk_country", "", $param, '', $sortfield, $sortorder);
+ print ''.getCountry($obj->fk_country, 0, $db).' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+ // State
if (!empty($arrayfields['p.fk_state']['checked'])) {
- print_liste_field_titre($arrayfields['p.fk_state']['label'], $_SERVER["PHP_SELF"], "p.fk_state", "", $param, '', $sortfield, $sortorder);
+ print '';
+ if (!empty($obj->fk_state)) {
+ print getState($obj->fk_state, 0, $db);
+ }
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+ // Accountancy code sell
if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_sell']['checked'])) {
- print_liste_field_titre($arrayfields[$alias_product_perentity . '.accountancy_code_sell']['label'], $_SERVER["PHP_SELF"], $alias_product_perentity . ".accountancy_code_sell", "", $param, '', $sortfield, $sortorder);
+ print ''.$obj->accountancy_code_sell.' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_sell_intra']['checked'])) {
- print_liste_field_titre($arrayfields[$alias_product_perentity . '.accountancy_code_sell_intra']['label'], $_SERVER["PHP_SELF"], $alias_product_perentity . ".accountancy_code_sell_intra", "", $param, '', $sortfield, $sortorder);
+ print ''.$obj->accountancy_code_sell_intra.' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_sell_export']['checked'])) {
- print_liste_field_titre($arrayfields[$alias_product_perentity . '.accountancy_code_sell_export']['label'], $_SERVER["PHP_SELF"], $alias_product_perentity . ".accountancy_code_sell_export", "", $param, '', $sortfield, $sortorder);
+ print ''.$obj->accountancy_code_sell_export.' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+ // Accountancy code buy
if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_buy']['checked'])) {
- print_liste_field_titre($arrayfields[$alias_product_perentity . '.accountancy_code_buy']['label'], $_SERVER["PHP_SELF"], $alias_product_perentity . ".accountancy_code_buy", "", $param, '', $sortfield, $sortorder);
+ print ''.$obj->accountancy_code_buy.' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_buy_intra']['checked'])) {
- print_liste_field_titre($arrayfields[$alias_product_perentity . '.accountancy_code_buy_intra']['label'], $_SERVER["PHP_SELF"], $alias_product_perentity . ".accountancy_code_buy_intra", "", $param, '', $sortfield, $sortorder);
+ print ''.$obj->accountancy_code_buy_intra.' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_buy_export']['checked'])) {
- print_liste_field_titre($arrayfields[$alias_product_perentity . '.accountancy_code_buy_export']['label'], $_SERVER["PHP_SELF"], $alias_product_perentity . ".accountancy_code_buy_export", "", $param, '', $sortfield, $sortorder);
+ print ''.$obj->accountancy_code_buy_export.' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
// Extra fields
- include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_search_title.tpl.php';
- // Hook fields
- $parameters = array('arrayfields'=>$arrayfields, 'param'=>$param, 'sortfield'=>$sortfield, 'sortorder'=>$sortorder);
- $reshook = $hookmanager->executeHooks('printFieldListTitle', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
+ include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_print_fields.tpl.php';
+ // Fields from hook
+ $parameters = array('arrayfields'=>$arrayfields, 'obj'=>$obj, 'i'=>$i, 'totalarray'=>&$totalarray);
+ $reshook = $hookmanager->executeHooks('printFieldListValue', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
print $hookmanager->resPrint;
+ // Date creation
if (!empty($arrayfields['p.datec']['checked'])) {
- print_liste_field_titre($arrayfields['p.datec']['label'], $_SERVER["PHP_SELF"], "p.datec", "", $param, '', $sortfield, $sortorder, 'center nowrap ');
+ print '';
+ print dol_print_date($db->jdate($obj->date_creation), 'dayhour', 'tzuser');
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+ // Date modification
if (!empty($arrayfields['p.tms']['checked'])) {
- print_liste_field_titre($arrayfields['p.tms']['label'], $_SERVER["PHP_SELF"], "p.tms", "", $param, '', $sortfield, $sortorder, 'center nowrap ');
+ print '';
+ print dol_print_date($db->jdate($obj->date_update), 'dayhour', 'tzuser');
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+
+ // Status (to sell)
if (!empty($arrayfields['p.tosell']['checked'])) {
- print_liste_field_titre($arrayfields['p.tosell']['label'], $_SERVER["PHP_SELF"], "p.tosell", "", $param, '', $sortfield, $sortorder, 'center ');
+ print '';
+ if (!empty($conf->use_javascript_ajax) && $user->hasRight("produit", "creer") && !empty($conf->global->MAIN_DIRECT_STATUS_UPDATE)) {
+ print ajax_object_onoff($product_static, 'status', 'tosell', 'ProductStatusOnSell', 'ProductStatusNotOnSell');
+ } else {
+ print $product_static->LibStatut($obj->tosell, 5, 0);
+ }
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+ // Status (to buy)
if (!empty($arrayfields['p.tobuy']['checked'])) {
- print_liste_field_titre($arrayfields['p.tobuy']['label'], $_SERVER["PHP_SELF"], "p.tobuy", "", $param, '', $sortfield, $sortorder, 'center ');
+ print '';
+ if (!empty($conf->use_javascript_ajax) && $user->hasRight("produit", "creer") && !empty($conf->global->MAIN_DIRECT_STATUS_UPDATE)) {
+ print ajax_object_onoff($product_static, 'status_buy', 'tobuy', 'ProductStatusOnBuy', 'ProductStatusNotOnBuy');
+ } else {
+ print $product_static->LibStatut($obj->tobuy, 5, 1);
+ }
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+
+ // Action column
if (empty($conf->global->MAIN_CHECKBOX_LEFT_COLUMN)) {
- print_liste_field_titre($selectedfields, $_SERVER["PHP_SELF"], "", '', '', '', $sortfield, $sortorder, 'center maxwidthsearch ');
+ print '';
+ if ($massactionbutton || $massaction) { // If we are in select mode (massactionbutton defined) or if we have already selected and sent an action ($massaction) defined
+ $selected = 0;
+ if (in_array($obj->rowid, $arrayofselected)) {
+ $selected = 1;
+ }
+ print '';
+ }
+ print ' | ';
+ if (!$i) {
+ $totalarray['nbfield']++;
+ }
}
+
print "
\n";
-
-
- $product_static = new Product($db);
- $product_fourn = new ProductFournisseur($db);
-
- $i = 0;
- $totalarray = array();
- $totalarray['nbfield'] = 0;
- while ($i < min($num, $limit)) {
- $obj = $db->fetch_object($resql);
-
- // Multilangs
- if (getDolGlobalInt('MAIN_MULTILANGS')) { // If multilang is enabled
- $sql = "SELECT label";
- $sql .= " FROM ".MAIN_DB_PREFIX."product_lang";
- $sql .= " WHERE fk_product = ".((int) $obj->rowid);
- $sql .= " AND lang = '".$db->escape($langs->getDefaultLang())."'";
- $sql .= " LIMIT 1";
-
- $result = $db->query($sql);
- if ($result) {
- $objtp = $db->fetch_object($result);
- if (!empty($objtp->label)) {
- $obj->label = $objtp->label;
- }
- }
- }
-
- $product_static->id = $obj->rowid;
- $product_static->ref = $obj->ref;
- $product_static->ref_fourn = empty($obj->ref_supplier) ? '' : $obj->ref_supplier; // deprecated
- $product_static->ref_supplier = empty($obj->ref_supplier) ? '' : $obj->ref_supplier;
- $product_static->label = $obj->label;
- $product_static->finished = $obj->finished;
- $product_static->type = $obj->fk_product_type;
- $product_static->status_buy = $obj->tobuy;
- $product_static->status = $obj->tosell;
- $product_static->status_batch = $obj->tobatch;
- $product_static->entity = $obj->entity;
- $product_static->pmp = $obj->pmp;
- $product_static->accountancy_code_sell = $obj->accountancy_code_sell;
- $product_static->accountancy_code_sell_export = $obj->accountancy_code_sell_export;
- $product_static->accountancy_code_sell_intra = $obj->accountancy_code_sell_intra;
- $product_static->accountancy_code_buy = $obj->accountancy_code_buy;
- $product_static->accountancy_code_buy_intra = $obj->accountancy_code_buy_intra;
- $product_static->accountancy_code_buy_export = $obj->accountancy_code_buy_export;
- $product_static->length = $obj->length;
- $product_static->length_units = $obj->length_units;
- $product_static->width = $obj->width;
- $product_static->width_units = $obj->width_units;
- $product_static->height = $obj->height;
- $product_static->height_units = $obj->height_units;
- $product_static->weight = $obj->weight;
- $product_static->weight_units = $obj->weight_units;
- $product_static->volume = $obj->volume;
- $product_static->volume_units = $obj->volume_units;
- $product_static->surface = $obj->surface;
- $product_static->surface_units = $obj->surface_units;
- if (!empty($conf->global->PRODUCT_USE_UNITS)) {
- $product_static->fk_unit = $obj->fk_unit;
- }
-
- // STOCK_DISABLE_OPTIM_LOAD can be set to force load_stock whatever is permissions on stock.
- if ((isModEnabled('stock') && $user->rights->stock->lire && $search_type != 1) || !empty($conf->global->STOCK_DISABLE_OPTIM_LOAD)) { // To optimize call of load_stock
- if ($obj->fk_product_type != 1 || !empty($conf->global->STOCK_SUPPORTS_SERVICES)) { // Not a service
- $option = 'nobatch';
- if (empty($arrayfields['stock_virtual']['checked'])) {
- $option .= ',novirtual';
- }
- $product_static->load_stock($option); // Load stock_reel + stock_warehouse. This can also call load_virtual_stock()
- }
- }
-
- $usercancreadprice = getDolGlobalString('MAIN_USE_ADVANCED_PERMS')?$user->hasRight('product', 'product_advance', 'read_prices'):$user->hasRight('product', 'lire');
- if ($product_static->isService()) {
- $usercancreadprice = getDolGlobalString('MAIN_USE_ADVANCED_PERMS')?$user->hasRight('service', 'service_advance', 'read_prices'):$user->hasRight('service', 'lire');
- }
-
- print '';
-
- // Action column
- if (!empty($conf->global->MAIN_CHECKBOX_LEFT_COLUMN)) {
- print '| ';
- if ($massactionbutton || $massaction) { // If we are in select mode (massactionbutton defined) or if we have already selected and sent an action ($massaction) defined
- $selected = 0;
- if (in_array($obj->rowid, $arrayofselected)) {
- $selected = 1;
- }
- print '';
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Ref
- if (!empty($arrayfields['p.rowid']['checked'])) {
- print '';
- print $product_static->id;
- print " | \n";
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- // Ref
- if (!empty($arrayfields['p.ref']['checked'])) {
- print '';
- print $product_static->getNomUrl(1);
- print " | \n";
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- // Ref supplier
- if (!empty($arrayfields['pfp.ref_fourn']['checked'])) {
- print '';
- print $product_static->getNomUrl(1);
- print " | \n";
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- // Thumbnail
- if (!empty($arrayfields['thumbnail']['checked'])) {
- $product_thumbnail_html = '';
- if (!empty($product_static->entity)) {
- $product_thumbnail = $product_static->show_photos('product', $conf->product->multidir_output[$product_static->entity], 1, 1, 0, 0, 0, 80);
- if ($product_static->nbphoto > 0) {
- $product_thumbnail_html = $product_thumbnail;
- }
- }
-
- print '' . $product_thumbnail_html . ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- // Label
- if (!empty($arrayfields['p.label']['checked'])) {
- print ''.$obj->label.' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- // Type
- if (!empty($arrayfields['p.fk_product_type']['checked'])) {
- print '';
- $s = '';
- if ($obj->fk_product_type == 0) {
- $s .= img_picto($langs->trans("Product"), 'product', 'class="paddingleftonly paddingrightonly colorgrey"');
- } else {
- $s .= img_picto($langs->trans("Service"), 'service', 'class="paddingleftonly paddingrightonly colorgrey"');
- }
- print $s;
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- // Barcode
- if (!empty($arrayfields['p.barcode']['checked'])) {
- print ''.$obj->barcode.' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- // Duration
- if (!empty($arrayfields['p.duration']['checked'])) {
- print '';
-
- if (preg_match('/([^a-z]+)[a-z]$/i', $obj->duration)) {
- $duration_value = substr($obj->duration, 0, dol_strlen($obj->duration) - 1);
- $duration_unit = substr($obj->duration, -1);
-
- if ((float) $duration_value > 1) {
- $dur = array("i"=>$langs->trans("Minutes"), "h"=>$langs->trans("Hours"), "d"=>$langs->trans("Days"), "w"=>$langs->trans("Weeks"), "m"=>$langs->trans("Months"), "y"=>$langs->trans("Years"));
- } elseif ((float) $duration_value > 0) {
- $dur = array("i"=>$langs->trans("Minute"), "h"=>$langs->trans("Hour"), "d"=>$langs->trans("Day"), "w"=>$langs->trans("Week"), "m"=>$langs->trans("Month"), "y"=>$langs->trans("Year"));
- }
- print $duration_value;
- print ((!empty($duration_unit) && isset($dur[$duration_unit]) && $duration_value != '') ? ' '.$langs->trans($dur[$duration_unit]) : '');
- } elseif (!preg_match('/^[a-z]$/i', $obj->duration)) { // If duration is a simple char (like 's' of 'm'), we do not show value
- print $obj->duration;
- }
-
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- // Finished
- if (!empty($arrayfields['p.finished']['checked'])) {
- print '';
- print $product_static->getLibFinished();
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- // Weight
- if (!empty($arrayfields['p.weight']['checked'])) {
- print '';
- print $obj->weight;
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Weight units
- if (!empty($arrayfields['p.weight_units']['checked'])) {
- print '';
- if ($product_static->weight != '') {
- print measuringUnitString(0, 'weight', $product_static->weight_units);
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Length
- if (!empty($arrayfields['p.length']['checked'])) {
- print '';
- print $obj->length;
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Length units
- if (!empty($arrayfields['p.length_units']['checked'])) {
- print '';
- if ($product_static->length != '') {
- print measuringUnitString(0, 'size', $product_static->length_units);
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Width
- if (!empty($arrayfields['p.width']['checked'])) {
- print '';
- print $obj->width;
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Width units
- if (!empty($arrayfields['p.width_units']['checked'])) {
- print '';
- if ($product_static->width != '') {
- print measuringUnitString(0, 'size', $product_static->width_units);
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Height
- if (!empty($arrayfields['p.height']['checked'])) {
- print '';
- print $obj->height;
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Height units
- if (!empty($arrayfields['p.height_units']['checked'])) {
- print '';
- if ($product_static->height != '') {
- print measuringUnitString(0, 'size', $product_static->height_units);
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Surface
- if (!empty($arrayfields['p.surface']['checked'])) {
- print '';
- print $obj->surface;
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Surface units
- if (!empty($arrayfields['p.surface_units']['checked'])) {
- print '';
- if ($product_static->surface != '') {
- print measuringUnitString(0, 'surface', $product_static->surface_units);
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Volume
- if (!empty($arrayfields['p.volume']['checked'])) {
- print '';
- print $obj->volume;
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Volume units
- if (!empty($arrayfields['p.volume_units']['checked'])) {
- print '';
- if ($product_static->volume != '') {
- print measuringUnitString(0, 'volume', $product_static->volume_units);
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Unit
- if (!empty($arrayfields['cu.label']['checked'])) {
- print '';
- if (!empty($obj->cu_label)) {
- print $langs->trans($obj->cu_label);
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- // Sell price
- if (!empty($arrayfields['p.sellprice']['checked'])) {
- print '';
- if ($obj->tosell && $usercancreadprice) {
- if ($obj->price_base_type == 'TTC') {
- print ''.price($obj->price_ttc).' '.$langs->trans("TTC").'';
- } else {
- print ''.price($obj->price).' '.$langs->trans("HT").'';
- }
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
-
- // Multiprices
- if (!empty($conf->global->PRODUIT_MULTIPRICES)) {
- if (! isset($productpricescache)) {
- $productpricescache=array();
- }
- if (! isset($productpricescache[$obj->rowid])) {
- $productpricescache[$obj->rowid] = array();
- }
-
- if ($obj->tosell && $usercancreadprice) {
- // Make 1 request for all price levels (without filter on price_level) and saved result into an cache array
- // then reuse the cache array if we need prices for other price levels
- $sqlp = "SELECT p.rowid, p.fk_product, p.price, p.price_ttc, p.price_level, p.date_price, p.price_base_type";
- $sqlp .= " FROM ".MAIN_DB_PREFIX."product_price as p";
- $sqlp .= " WHERE fk_product = ".((int) $obj->rowid);
- $sqlp .= " ORDER BY p.date_price DESC, p.rowid DESC, p.price_level ASC";
- $resultp = $db->query($sqlp);
- if ($resultp) {
- $nump = $db->num_rows($resultp);
- $j = 0;
- while ($j < $nump) {
- $objp = $db->fetch_object($resultp);
-
- if (empty($productpricescache[$obj->rowid][$objp->price_level])) {
- $productpricescache[$obj->rowid][$objp->price_level]['price'] = $objp->price;
- $productpricescache[$obj->rowid][$objp->price_level]['price_ttc'] = $objp->price_ttc;
- $productpricescache[$obj->rowid][$objp->price_level]['price_base_type'] = $objp->price_base_type;
- }
-
- $j++;
- }
-
- $db->free($resultp);
- } else {
- dol_print_error($db);
- }
- }
-
- foreach ($arraypricelevel as $key => $value) {
- if (!empty($arrayfields['p.sellprice'.$key]['checked'])) {
- print '';
- if (!empty($productpricescache[$obj->rowid])) {
- if ($productpricescache[$obj->rowid][$key]['price_base_type'] == 'TTC') {
- print ''.price($productpricescache[$obj->rowid][$key]['price_ttc']).' '.$langs->trans("TTC").'';
- } else {
- print ''.price($productpricescache[$obj->rowid][$key]['price']).' '.$langs->trans("HT").'';
- }
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- }
- }
-
- // Better buy price
- if (!empty($arrayfields['p.minbuyprice']['checked'])) {
- print '';
- if ($obj->tobuy && $obj->minsellprice != '' && $usercancreadprice) {
- //print price($obj->minsellprice).' '.$langs->trans("HT");
- if ($product_fourn->find_min_price_product_fournisseur($obj->rowid) > 0) {
- if ($product_fourn->product_fourn_price_id > 0) {
- if ((isModEnabled("fournisseur") && !empty($user->rights->fournisseur->lire) && empty($conf->global->MAIN_USE_NEW_SUPPLIERMOD)) || (isModEnabled("supplier_order") && !empty($user->rights->supplier_order->lire)) || (isModEnabled("supplier_invoice") && !empty($user->rights->supplier_invoice->lire))) {
- $htmltext = $product_fourn->display_price_product_fournisseur(1, 1, 0, 1);
- print ''.$form->textwithpicto(price($product_fourn->fourn_unitprice * (1 - $product_fourn->fourn_remise_percent / 100) - $product_fourn->fourn_remise).' '.$langs->trans("HT"), $htmltext).'';
- } else {
- print ''.price($product_fourn->fourn_unitprice).' '.$langs->trans("HT").'';
- }
- }
- }
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- // Number of buy prices
- if (!empty($arrayfields['p.numbuyprice']['checked'])) {
- print '';
- if ($obj->tobuy && $usercancreadprice) {
- if (count($productFournList = $product_fourn->list_product_fournisseur_price($obj->rowid)) > 0) {
- $htmltext = $product_fourn->display_price_product_fournisseur(1, 1, 0, 1, $productFournList);
- print $form->textwithpicto(count($productFournList), $htmltext);
- }
- }
- print ' | ';
- }
-
- // VAT or Sell Tax Rate
- if (!empty($arrayfields['p.tva_tx']['checked'])) {
- print '';
- print vatrate($obj->tva_tx, true);
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- // WAP
- if (!empty($arrayfields['p.pmp']['checked'])) {
- print '';
- if ($usercancreadprice) {
- print ''.price($product_static->pmp, 1, $langs)."";
- }
- print ' | ';
- }
- // Cost price
- if (!empty($arrayfields['p.cost_price']['checked'])) {
- print '';
- //print $obj->cost_price;
- if ($usercancreadprice) {
- print ''.price($obj->cost_price).' '.$langs->trans("HT").'';
- }
- print ' | ';
- }
-
- // Limit alert
- if (!empty($arrayfields['p.seuil_stock_alerte']['checked'])) {
- print '';
- if ($obj->fk_product_type != 1) {
- print $obj->seuil_stock_alerte;
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Desired stock
- if (!empty($arrayfields['p.desiredstock']['checked'])) {
- print '';
- if ($obj->fk_product_type != 1) {
- print $obj->desiredstock;
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Stock real
- if (!empty($arrayfields['p.stock']['checked'])) {
- print '';
- if ($obj->fk_product_type != 1) {
- if ($obj->seuil_stock_alerte != '' && $product_static->stock_reel < (float) $obj->seuil_stock_alerte) {
- print img_warning($langs->trans("StockLowerThanLimit", $obj->seuil_stock_alerte)).' ';
- }
- if ($usercancreadprice) {
- print price(price2num($product_static->stock_reel, 'MS'));
- }
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Stock virtual
- if (!empty($arrayfields['stock_virtual']['checked'])) {
- print '';
- if ($obj->fk_product_type != 1) {
- if ($obj->seuil_stock_alerte != '' && $product_static->stock_theorique < (float) $obj->seuil_stock_alerte) {
- print img_warning($langs->trans("StockLowerThanLimit", $obj->seuil_stock_alerte)).' ';
- }
- if ($usercancreadprice) {
- print price(price2num($product_static->stock_theorique, 'MS'));
- }
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Lot/Serial
- if (!empty($arrayfields['p.tobatch']['checked'])) {
- print '';
- print $product_static->getLibStatut(1, 2);
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Country
- if (!empty($arrayfields['p.fk_country']['checked'])) {
- print ''.getCountry($obj->fk_country, 0, $db).' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // State
- if (!empty($arrayfields['p.fk_state']['checked'])) {
- print '';
- if (!empty($obj->fk_state)) {
- print getState($obj->fk_state, 0, $db);
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Accountancy code sell
- if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_sell']['checked'])) {
- print ''.$obj->accountancy_code_sell.' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_sell_intra']['checked'])) {
- print ''.$obj->accountancy_code_sell_intra.' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_sell_export']['checked'])) {
- print ''.$obj->accountancy_code_sell_export.' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Accountancy code buy
- if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_buy']['checked'])) {
- print ''.$obj->accountancy_code_buy.' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_buy_intra']['checked'])) {
- print ''.$obj->accountancy_code_buy_intra.' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- if (!empty($arrayfields[$alias_product_perentity . '.accountancy_code_buy_export']['checked'])) {
- print ''.$obj->accountancy_code_buy_export.' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Extra fields
- include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_print_fields.tpl.php';
- // Fields from hook
- $parameters = array('arrayfields'=>$arrayfields, 'obj'=>$obj, 'i'=>$i, 'totalarray'=>&$totalarray);
- $reshook = $hookmanager->executeHooks('printFieldListValue', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
- print $hookmanager->resPrint;
- // Date creation
- if (!empty($arrayfields['p.datec']['checked'])) {
- print '';
- print dol_print_date($db->jdate($obj->date_creation), 'dayhour', 'tzuser');
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Date modification
- if (!empty($arrayfields['p.tms']['checked'])) {
- print '';
- print dol_print_date($db->jdate($obj->date_update), 'dayhour', 'tzuser');
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- // Status (to sell)
- if (!empty($arrayfields['p.tosell']['checked'])) {
- print '';
- if (!empty($conf->use_javascript_ajax) && $user->hasRight("produit", "creer") && !empty($conf->global->MAIN_DIRECT_STATUS_UPDATE)) {
- print ajax_object_onoff($product_static, 'status', 'tosell', 'ProductStatusOnSell', 'ProductStatusNotOnSell');
- } else {
- print $product_static->LibStatut($obj->tosell, 5, 0);
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
- // Status (to buy)
- if (!empty($arrayfields['p.tobuy']['checked'])) {
- print '';
- if (!empty($conf->use_javascript_ajax) && $user->hasRight("produit", "creer") && !empty($conf->global->MAIN_DIRECT_STATUS_UPDATE)) {
- print ajax_object_onoff($product_static, 'status_buy', 'tobuy', 'ProductStatusOnBuy', 'ProductStatusNotOnBuy');
- } else {
- print $product_static->LibStatut($obj->tobuy, 5, 1);
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- // Action column
- if (empty($conf->global->MAIN_CHECKBOX_LEFT_COLUMN)) {
- print '';
- if ($massactionbutton || $massaction) { // If we are in select mode (massactionbutton defined) or if we have already selected and sent an action ($massaction) defined
- $selected = 0;
- if (in_array($obj->rowid, $arrayofselected)) {
- $selected = 1;
- }
- print '';
- }
- print ' | ';
- if (!$i) {
- $totalarray['nbfield']++;
- }
- }
-
- print "
\n";
- $i++;
- }
-
- $db->free($resql);
-
- // If no record found
- if ($num == 0) {
- $colspan = 1;
- foreach ($arrayfields as $key => $val) {
- if (!empty($val['checked'])) {
- $colspan++;
- }
- }
- print '| '.$langs->trans("NoRecordFound").' |
';
- }
-
- print "