From 7658a86bc963133349d9b83cfeed28092705d2b4 Mon Sep 17 00:00:00 2001 From: Alexis Algoud Date: Mon, 25 Apr 2016 15:31:49 +0200 Subject: [PATCH] NEW show detail per warehouse into reassort --- htdocs/product/reassort.php | 92 ++++++++++++++++++++++--------------- 1 file changed, 56 insertions(+), 36 deletions(-) diff --git a/htdocs/product/reassort.php b/htdocs/product/reassort.php index 27f85cd90ab..6642c1e3550 100644 --- a/htdocs/product/reassort.php +++ b/htdocs/product/reassort.php @@ -29,6 +29,7 @@ require '../main.inc.php'; require_once DOL_DOCUMENT_ROOT.'/product/class/product.class.php'; require_once DOL_DOCUMENT_ROOT.'/core/class/html.formother.class.php'; require_once DOL_DOCUMENT_ROOT.'/categories/class/categorie.class.php'; +require_once DOL_DOCUMENT_ROOT.'/product/class/html.formproduct.class.php'; $langs->load("products"); $langs->load("stocks"); @@ -242,6 +243,12 @@ if ($resql) $param="&tosell=$tosell&tobuy=$tobuy".(isset($type)?"&type=$type":"")."&fourn_id=$fourn_id&snom=$snom&sref=$sref"; + $formProduct = new FormProduct($db); + $formProduct->loadWarehouses(); + $warehouses_list = $formProduct->cache_warehouses; + $nb_warehouse = count($warehouses_list); + $colspan_warehouse = $nb_warehouse > 1 ? $nb_warehouse+1 : 1; + print ''; // Lignes des titres @@ -252,6 +259,19 @@ if ($resql) print_liste_field_titre($langs->trans("StockLimit"), $_SERVER["PHP_SELF"], "p.seuil_stock_alerte",$param,"",'align="right"',$sortfield,$sortorder); print_liste_field_titre($langs->trans("DesiredStock"), $_SERVER["PHP_SELF"], "p.desiredstock",$param,"",'align="right"',$sortfield,$sortorder); print_liste_field_titre($langs->trans("PhysicalStock"), $_SERVER["PHP_SELF"], "stock_physique",$param,"",'align="right"',$sortfield,$sortorder); + + /* + * Details per warehouse + */ + + if($nb_warehouse>1) { + + foreach($warehouses_list as &$wh) { + print_liste_field_titre($wh['label'], '', '','','','align="right"'); + } + + } + // TODO Add info of running suppliers/customers orders //print_liste_field_titre($langs->trans("TheoreticalStock"),$_SERVER["PHP_SELF"], "stock_theorique",$param,"",'align="right"',$sortfield,$sortorder); print_liste_field_titre(''); @@ -278,48 +298,29 @@ if ($resql) print ''; print ''; print ''; - print ''; - print ''; + print ''; + print ''; print ''; - $product_static=new Product($db); - $var=True; while ($i < min($num,$limit)) { $objp = $db->fetch_object($resql); - // Multilangs - if (! empty($conf->global->MAIN_MULTILANGS)) // si l'option est active - { - $sql = "SELECT label"; - $sql.= " FROM ".MAIN_DB_PREFIX."product_lang"; - $sql.= " WHERE fk_product=".$objp->rowid; - $sql.= " AND lang='". $langs->getDefaultLang() ."'"; - $sql.= " LIMIT 1"; - - $result = $db->query($sql); - if ($result) - { - $objtp = $db->fetch_object($result); - if (! empty($objtp->label)) $objp->label = $objtp->label; - } - } - $var=!$var; print ''; - print ''; + print ''; if (! empty($conf->service->enabled) && $type == 1) { @@ -334,12 +335,31 @@ if ($resql) print ''; print ''; print ''; - print ''; - print ''; - print ''; + + /* + * Details per warehouse + */ + + if($nb_warehouse>1) { + + foreach($warehouses_list as &$wh) { + + print ''; + } + + } + + + + + print ''; + print ''; + print ''; print "\n"; $i++; }
    '; - $searchpitco=$form->showFilterAndCheckAddButtons(0); - print $searchpitco; - print ' '; + $searchpitco=$form->showFilterAndCheckAddButtons(0); + print $searchpitco; + print '
'; - $product_static->ref=$objp->ref; - $product_static->id=$objp->rowid; - $product_static->label = $objp->label; - $product_static->type=$objp->fk_product_type; - $product_static->entity=$objp->entity; - print $product_static->getNomUrl(1,'',16); + + $product=new Product($db); + $product->fetch($objp->rowid); + $product->load_stock(); + + print $product->getNomUrl(1,'',16); //if ($objp->stock_theorique < $objp->seuil_stock_alerte) print ' '.img_warning($langs->trans("StockTooLow")); print ''.$objp->label.''.$product->label.''.$objp->seuil_stock_alerte.''.$objp->desiredstock.''; - if ($objp->seuil_stock_alerte && ($objp->stock_physique < $objp->seuil_stock_alerte)) print img_warning($langs->trans("StockTooLow")).' '; - print $objp->stock_physique; + if ($objp->seuil_stock_alerte && ($objp->stock_physique < $objp->seuil_stock_alerte)) print img_warning($langs->trans("StockTooLow")).' '; + print $product->stock_reel; print ''.$langs->trans("Movements").''.$product_static->LibStatut($objp->statut,5,0).''.$product_static->LibStatut($objp->tobuy,5,1).''; + print empty($product->stock_warehouse[$wh['id']]->real) ? '0' : $product->stock_warehouse[$wh['id']]->real; + print ''.$langs->trans("Movements").''.$product->LibStatut($objp->statut,5,0).''.$product->LibStatut($objp->tobuy,5,1).'