dolibarr  x.y.z
index.php
Go to the documentation of this file.
1 <?php
2 /* Copyright (C) 2003-2006 Rodolphe Quiedeville <rodolphe@quiedeville.org>
3  * Copyright (C) 2004-2016 Laurent Destailleur <eldy@users.sourceforge.net>
4  * Copyright (C) 2005-2009 Regis Houssin <regis.houssin@inodbox.com>
5  * Copyright (C) 2019 Nicolas ZABOURI <info@inovea-conseil.com>
6  * Copyright (C) 2020 Tobias Sekan <tobias.sekan@startmail.com>
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; either version 3 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program. If not, see <https://www.gnu.org/licenses/>.
20  */
21 
28 // Load Dolibarr environment
29 require '../../main.inc.php';
30 require_once DOL_DOCUMENT_ROOT.'/product/stock/class/entrepot.class.php';
31 require_once DOL_DOCUMENT_ROOT.'/product/class/product.class.php';
32 require_once DOL_DOCUMENT_ROOT.'/product/stock/class/productlot.class.php';
33 
34 $hookmanager = new HookManager($db);
35 
36 // Initialize technical object to manage hooks. Note that conf->hooks_modules contains array
37 $hookmanager->initHooks(array('stockindex'));
38 
39 // Load translation files required by the page
40 $langs->loadLangs(array('stocks', 'productbatch'));
41 
42 // Security check
43 $result = restrictedArea($user, 'stock');
44 
45 
46 /*
47  * View
48  */
49 
50 $producttmp = new Product($db);
51 $warehouse = new Entrepot($db);
52 
53 $help_url = 'EN:Module_Stocks_En|FR:Module_Stock|ES:M&oacute;dulo_Stocks';
54 llxHeader("", $langs->trans("Stocks"), $help_url);
55 
56 print load_fiche_titre($langs->trans("StocksArea"), '', 'stock');
57 
58 
59 //print '<table border="0" width="100%" class="notopnoleftnoright">';
60 //print '<tr><td valign="top" width="30%" class="notopnoleft">';
61 print '<div class="fichecenter"><div class="fichethirdleft">';
62 
63 
64 if (!empty($conf->global->MAIN_SEARCH_FORM_ON_HOME_AREAS)) { // This may be useless due to the global search combo
65  print '<form method="post" action="'.DOL_URL_ROOT.'/product/stock/list.php">';
66  print '<input type="hidden" name="token" value="'.newToken().'">';
67  print '<div class="div-table-responsive-no-min">';
68  print '<table class="noborder nohover centpercent">';
69  print "<tr class=\"liste_titre\">";
70  print '<td colspan="3">'.$langs->trans("Search").'</td></tr>';
71  print '<tr class="oddevene"><td>';
72  print $langs->trans("Warehouse").':</td><td><input class="flat" type="text" size="18" name="sall"></td><td rowspan="2"><input type="submit" value="'.$langs->trans("Search").'" class="button"></td></tr>';
73  print "</table></div></form><br>";
74 }
75 
76 $max = 15;
77 
78 $sql = "SELECT e.rowid, e.ref as label, e.lieu, e.statut as status";
79 $sql .= " FROM ".MAIN_DB_PREFIX."entrepot as e";
80 $sql .= " WHERE e.statut in (".Entrepot::STATUS_CLOSED.",".Entrepot::STATUS_OPEN_ALL.")";
81 $sql .= " AND e.entity IN (".getEntity('stock').")";
82 $sql .= $db->order('e.statut', 'DESC');
83 $sql .= $db->plimit($max + 1, 0);
84 
85 $result = $db->query($sql);
86 
87 if ($result) {
88  $num = $db->num_rows($result);
89 
90  print '<div class="div-table-responsive-no-min">';
91  print '<table class="noborder centpercent">';
92  print '<tr class="liste_titre">';
93  print '<th colspan="2">';
94  print $langs->trans("Warehouses").' ';
95  print '<a href="'.DOL_URL_ROOT.'/product/stock/list.php">';
96  // TODO: "search_status" on "/product/stock/list.php" currently only accept a single integer value
97  //print '<a href="'.DOL_URL_ROOT.'/product/stock/list.php?search_status='.Entrepot::STATUS_CLOSED.','.Entrepot::STATUS_OPEN_ALL.'">';
98  print '<span class="badge">'.$num.'</span>';
99  print '</a>';
100  print '</th>';
101  print '</tr>';
102 
103  $i = 0;
104  if ($num) {
105  while ($i < min($max, $num)) {
106  $objp = $db->fetch_object($result);
107 
108  $warehouse->id = $objp->rowid;
109  $warehouse->statut = $objp->status;
110  $warehouse->label = $objp->label;
111  $warehouse->lieu = $objp->lieu;
112 
113  print '<tr class="oddeven">';
114  print '<td>';
115  print $warehouse->getNomUrl(1);
116  print '</td>'."\n";
117  print '<td class="right">';
118  print $warehouse->getLibStatut(5);
119  print '</td>';
120  print "</tr>\n";
121  $i++;
122  }
123  $db->free($result);
124  } else {
125  print '<tr><td>'.$langs->trans("None").'</td><td></td></tr>';
126  }
127  if ($num > $max) {
128  print '<tr><td><span class="opacitymedium">'.$langs->trans("More").'...</span></td><td></td></tr>';
129  }
130 
131  print "</table>";
132  print '</div>';
133 } else {
134  dol_print_error($db);
135 }
136 
137 
138 print '</div><div class="fichetwothirdright">';
139 
140 
141 // Latest movements
142 $max = 10;
143 $sql = "SELECT p.rowid, p.label as produit, p.tobatch, p.tosell, p.tobuy,";
144 $sql .= " e.ref as warehouse_ref, e.rowid as warehouse_id, e.ref as warehouse_label, e.lieu, e.statut as warehouse_status,";
145 $sql .= " m.rowid as mid, m.value as qty, m.datem, m.batch, m.eatby, m.sellby";
146 $sql .= " FROM ".MAIN_DB_PREFIX."entrepot as e";
147 $sql .= ", ".MAIN_DB_PREFIX."stock_mouvement as m";
148 $sql .= ", ".MAIN_DB_PREFIX."product as p";
149 $sql .= " WHERE m.fk_product = p.rowid";
150 $sql .= " AND m.fk_entrepot = e.rowid";
151 $sql .= " AND e.entity IN (".getEntity('stock').")";
152 if (empty($conf->global->STOCK_SUPPORTS_SERVICES)) {
153  $sql .= " AND p.fk_product_type = ".Product::TYPE_PRODUCT;
154 }
155 $sql .= $db->order("datem", "DESC");
156 $sql .= $db->plimit($max, 0);
157 
158 dol_syslog("Index:list stock movements", LOG_DEBUG);
159 $resql = $db->query($sql);
160 if ($resql) {
161  $num = $db->num_rows($resql);
162 
163  print '<div class="div-table-responsive-no-min">';
164  print '<table class="noborder centpercent">';
165  print '<tr class="liste_titre">';
166  print '<th>'.$langs->trans("LastMovements", min($num, $max)).'</th>';
167  print '<th>'.$langs->trans("Product").'</th>';
168  if (isModEnabled('productbatch')) {
169  print '<th>'.$langs->trans("Batch").'</th>';
170  /*if (empty($conf->global->PRODUCT_DISABLE_SELLBY)) {
171  print '<th>'.$langs->trans("SellByDate").'</th>';
172  }
173  if (empty($conf->global->PRODUCT_DISABLE_EATBY)) {
174  print '<th>'.$langs->trans("EatByDate").'</th>';
175  }*/
176  }
177  print '<th>'.$langs->trans("Warehouse").'</th>';
178  print '<th class="right"><a class="notasortlink" href="'.DOL_URL_ROOT.'/product/stock/movement_list.php">'.$langs->trans("FullList").'</a></th>';
179  print "</tr>\n";
180 
181  $tmplotstatic = new Productlot($db);
182 
183  $i = 0;
184  while ($i < min($num, $max)) {
185  $objp = $db->fetch_object($resql);
186 
187  $producttmp->id = $objp->rowid;
188  $producttmp->ref = $objp->produit;
189  $producttmp->status_batch = $objp->tobatch;
190  $producttmp->status_sell = $objp->tosell;
191  $producttmp->status_buy = $objp->tobuy;
192 
193  $warehouse->id = $objp->warehouse_id;
194  $warehouse->ref = $objp->warehouse_ref;
195  $warehouse->statut = $objp->warehouse_status;
196  $warehouse->label = $objp->warehouse_label;
197  $warehouse->lieu = $objp->lieu;
198 
199  $tmplotstatic->batch = $objp->batch;
200  $tmplotstatic->sellby = $objp->sellby;
201  $tmplotstatic->eatby = $objp->eatby;
202 
203  print '<tr class="oddeven">';
204  print '<td class="nowraponall">'.img_picto($langs->trans("Ref").' '.$objp->mid, 'movement', 'class="pictofixedwidth"').dol_print_date($db->jdate($objp->datem), 'dayhour').'</td>';
205  print '<td class="tdoverflowmax150">';
206  print $producttmp->getNomUrl(1);
207  print "</td>\n";
208  if (isModEnabled('productbatch')) {
209  print '<td>';
210  print $tmplotstatic->getNomUrl(0, 'nolink');
211  print '</td>';
212  /*if (empty($conf->global->PRODUCT_DISABLE_SELLBY)) {
213  print '<td>'.dol_print_date($db->jdate($objp->sellby), 'day').'</td>';
214  }
215  if (empty($conf->global->PRODUCT_DISABLE_EATBY)) {
216  print '<td>'.dol_print_date($db->jdate($objp->eatby), 'day').'</td>';
217  }*/
218  }
219  print '<td class="tdoverflowmax150">';
220  print $warehouse->getNomUrl(1);
221  print "</td>\n";
222  print '<td class="right">';
223  if ($objp->qty > 0) {
224  print '+';
225  }
226  print $objp->qty.'</td>';
227  print "</tr>\n";
228  $i++;
229  }
230  $db->free($resql);
231 
232  print "</table>";
233  print '</div>';
234 } else {
235  dol_print_error($db);
236 }
237 
238 print '</div></div>';
239 
240 $parameters = array('user' => $user);
241 $reshook = $hookmanager->executeHooks('dashboardWarehouse', $parameters, $object); // Note that $action and $object may have been modified by hook
242 
243 // End of page
244 llxFooter();
245 $db->close();
if(GETPOST('button_removefilter_x', 'alpha')||GETPOST('button_removefilter.x', 'alpha')||GETPOST('button_removefilter', 'alpha')) if(GETPOST('button_search_x', 'alpha')||GETPOST('button_search.x', 'alpha')||GETPOST('button_search', 'alpha')) if($action=="save" &&empty($cancel)) $help_url
View.
Definition: agenda.php:118
Class to manage warehouses.
const STATUS_OPEN_ALL
Warehouse open and operations for customer shipping, supplier dispatch, internal stock transfers/corr...
Class to manage hooks.
Class to manage products or services.
Class with list of lots and properties.
if(isModEnabled('facture') &&!empty($user->rights->facture->lire)) if((isModEnabled('fournisseur') &&empty($conf->global->MAIN_USE_NEW_SUPPLIERMOD) && $user->hasRight("fournisseur", "facture", "lire"))||(isModEnabled('supplier_invoice') && $user->hasRight("supplier_invoice", "lire"))) if(isModEnabled('don') &&!empty($user->rights->don->lire)) if(isModEnabled('tax') &&!empty($user->rights->tax->charges->lire)) if(isModEnabled('facture') &&isModEnabled('commande') && $user->hasRight("commande", "lire") &&empty($conf->global->WORKFLOW_DISABLE_CREATE_INVOICE_FROM_ORDER)) $resql
Social contributions to pay.
Definition: index.php:745
load_fiche_titre($titre, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='')
Load a title with picto.
dol_print_error($db='', $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
isModEnabled($module)
Is Dolibarr module enabled.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
llxFooter()
Footer empty.
Definition: index.php:71
if(!defined('NOTOKENRENEWAL')) if(!defined('NOLOGIN')) if(!defined('NOCSRFCHECK')) if(!defined('NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined('NOREQUIREAJAX')) if(!defined('NOIPCHECK')) if(!defined('NOBROWSERNOTIF')) llxHeader()
Header empty.
Definition: index.php:63
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.