30require
'../main.inc.php';
38require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formfile.class.php';
39require_once DOL_DOCUMENT_ROOT.
'/core/class/notify.class.php';
40require_once DOL_DOCUMENT_ROOT.
'/societe/class/client.class.php';
41require_once DOL_DOCUMENT_ROOT.
'/commande/class/commande.class.php';
42require_once DOL_DOCUMENT_ROOT.
'/core/lib/order.lib.php';
46$langs->loadLangs(array(
'orders',
'bills'));
49if (!$user->hasRight(
'commande',
'lire')) {
54$hookmanager->initHooks(array(
'ordersindex'));
59if ($user->socid > 0) {
61 $socid = $user->socid;
67$maxLatestEditCount = 5;
79$help_url =
"EN:Module_Customers_Orders|FR:Module_Commandes_Clients|ES:Módulo_Pedidos_de_clientes";
81llxHeader(
'', $langs->trans(
"Orders"), $help_url,
'', 0, 0,
'',
'',
'',
'mod-commande page-index');
87print
'<div class="fichecenter"><div class="fichethirdleft">';
100 $sql =
"SELECT c.rowid, c.ref, s.nom as name, s.rowid as socid";
101 $sql .=
", s.client";
102 $sql .=
", s.code_client";
103 $sql .=
", s.canvas";
104 $sql .=
" FROM ".MAIN_DB_PREFIX.
"commande as c";
105 $sql .=
", ".MAIN_DB_PREFIX.
"societe as s";
106 if (empty($user->socid) && !$user->hasRight(
'societe',
'client',
'voir')) {
107 $sql .=
", ".MAIN_DB_PREFIX.
"societe_commerciaux as sc";
109 $sql .=
" WHERE c.fk_soc = s.rowid";
110 $sql .=
" AND c.entity IN (".getEntity(
'commande').
")";
111 $sql .=
" AND c.fk_statut = 0";
113 $sql .=
" AND c.fk_soc = ".((int) $socid);
115 if (empty($user->socid) && !$user->hasRight(
'societe',
'client',
'voir')) {
116 $sql .=
" AND s.rowid = sc.fk_soc AND sc.fk_user = ".((int) $user->id);
119 $parameters = array(
'socid' => $user->socid);
120 $reshook = $hookmanager->executeHooks(
'printFieldListWhere', $parameters, $commandestatic);
121 $sql .= $hookmanager->resPrint;
122 $resql =
$db->query($sql);
124 print
'<div class="div-table-responsive-no-min">';
125 print
'<table class="noborder centpercent">';
126 print
'<tr class="liste_titre">';
127 print
'<th colspan="2">'.$langs->trans(
"DraftOrders").
'</th></tr>';
128 $langs->load(
"orders");
129 $num =
$db->num_rows($resql);
133 $obj =
$db->fetch_object($resql);
135 $commandestatic->id = $obj->rowid;
136 $commandestatic->ref = $obj->ref;
138 $companystatic->id = $obj->socid;
139 $companystatic->name = $obj->name;
140 $companystatic->client = $obj->client;
141 $companystatic->code_client = $obj->code_client;
142 $companystatic->canvas = $obj->canvas;
144 print
'<tr class="oddeven">';
145 print
'<td class="nowrap">';
146 print $commandestatic->getNomUrl(1);
148 print
'<td class="nowrap">';
149 print $companystatic->getNomUrl(1,
'company', 16);
154 print
'<tr class="oddeven"><td colspan="3">'.$langs->trans(
"NoOrder").
'</td></tr>';
156 print
"</table></div><br>";
161print
'</div><div class="fichetwothirdright">';
168$sql =
"SELECT c.rowid, c.entity, c.ref, c.fk_statut as status, c.facture, c.date_cloture as datec, c.tms as datem,";
169$sql .=
" s.nom as name, s.rowid as socid";
171$sql .=
", s.code_client";
173$sql .=
" FROM ".MAIN_DB_PREFIX.
"commande as c,";
174$sql .=
" ".MAIN_DB_PREFIX.
"societe as s";
175if (empty($user->socid) && !$user->hasRight(
'societe',
'client',
'voir')) {
176 $sql .=
", ".MAIN_DB_PREFIX.
"societe_commerciaux as sc";
178$sql .=
" WHERE c.fk_soc = s.rowid";
179$sql .=
" AND c.entity IN (".getEntity(
'commande').
")";
182 $sql .=
" AND c.fk_soc = ".((int) $socid);
184if (empty($user->socid) && !$user->hasRight(
'societe',
'client',
'voir')) {
185 $sql .=
" AND s.rowid = sc.fk_soc AND sc.fk_user = ".((int) $user->id);
188$parameters = array(
'socid' => $user->socid);
189$reshook = $hookmanager->executeHooks(
'printFieldListWhere', $parameters, $commandestatic);
190$sql .= $hookmanager->resPrint;
191$sql .=
" ORDER BY c.tms DESC";
192$sql .=
$db->plimit($max, 0);
194$resql =
$db->query($sql);
196 $num =
$db->num_rows($resql);
198 startSimpleTable($langs->trans(
"LastModifiedOrders", $max),
"commande/list.php",
"sortfield=c.tms&sortorder=DESC", 2, -1,
'order');
203 $obj =
$db->fetch_object($resql);
205 print
'<tr class="oddeven">';
206 print
'<td width="20%" class="nowrap">';
208 $commandestatic->id = $obj->rowid;
209 $commandestatic->ref = $obj->ref;
211 $companystatic->id = $obj->socid;
212 $companystatic->name = $obj->name;
213 $companystatic->client = $obj->client;
214 $companystatic->code_client = $obj->code_client;
215 $companystatic->canvas = $obj->canvas;
217 print
'<table class="nobordernopadding"><tr class="nocellnopadd">';
218 print
'<td width="96" class="nobordernopadding nowrap">';
219 print $commandestatic->getNomUrl(1);
222 print
'<td width="16" class="nobordernopadding nowrap">';
226 print
'<td width="16" class="nobordernopadding hideonsmartphone right">';
229 $urlsource = $_SERVER[
'PHP_SELF'].
'?id='.$obj->rowid;
230 print $formfile->getDocumentsLink($commandestatic->element, $filename, $filedir);
231 print
'</td></tr></table>';
235 print
'<td class="nowrap">';
236 print $companystatic->getNomUrl(1,
'company', 16);
239 $datem =
$db->jdate($obj->datem);
240 print
'<td class="center" title="'.dol_escape_htmltag($langs->trans(
"DateModification").
': '.
dol_print_date($datem,
'dayhour',
'tzuserrel')).
'">';
244 print
'<td class="right">'.$commandestatic->LibStatut($obj->status, $obj->facture, 3).
'</td>';
249 finishSimpleTable(
true);
259 $sql =
"SELECT c.rowid, c.entity, c.ref, c.fk_statut as status, c.facture, c.date_commande as date, s.nom as name, s.rowid as socid";
260 $sql .=
", s.client";
261 $sql .=
", s.code_client";
262 $sql .=
", s.canvas";
263 $sql .=
" FROM ".MAIN_DB_PREFIX.
"commande as c";
264 $sql .=
", ".MAIN_DB_PREFIX.
"societe as s";
265 if (empty($user->socid) && !$user->hasRight(
'societe',
'client',
'voir')) {
266 $sql .=
", ".MAIN_DB_PREFIX.
"societe_commerciaux as sc";
268 $sql .=
" WHERE c.fk_soc = s.rowid";
269 $sql .=
" AND c.entity IN (".getEntity(
'commande').
")";
270 $sql .=
" AND c.fk_statut = ".Commande::STATUS_VALIDATED;
272 $sql .=
" AND c.fk_soc = ".((int) $socid);
274 if (empty($user->socid) && !$user->hasRight(
'societe',
'client',
'voir')) {
275 $sql .=
" AND s.rowid = sc.fk_soc AND sc.fk_user = ".((int) $user->id);
278 $parameters = array(
'socid' => $user->socid);
279 $reshook = $hookmanager->executeHooks(
'printFieldListWhere', $parameters, $commandestatic);
280 $sql .= $hookmanager->resPrint;
281 $sql .=
" ORDER BY c.rowid DESC";
283 $resql =
$db->query($sql);
285 $num =
$db->num_rows($resql);
287 print
'<div class="div-table-responsive-no-min">';
288 print
'<table class="noborder centpercent">';
289 print
'<tr class="liste_titre">';
290 print
'<th colspan="4">'.$langs->trans(
"OrdersToProcess").
' <a href="'.DOL_URL_ROOT.
'/commande/list.php?search_status='.
Commande::STATUS_VALIDATED.
'"><span class="badge">'.$num.
'</span></a></th></tr>';
294 while ($i < $num && $i < $max) {
295 $obj =
$db->fetch_object($resql);
296 print
'<tr class="oddeven">';
297 print
'<td class="nowrap" width="20%">';
299 $commandestatic->id = $obj->rowid;
300 $commandestatic->ref = $obj->ref;
302 $companystatic->id = $obj->socid;
303 $companystatic->name = $obj->name;
304 $companystatic->client = $obj->client;
305 $companystatic->code_client = $obj->code_client;
306 $companystatic->canvas = $obj->canvas;
308 print
'<table class="nobordernopadding"><tr class="nocellnopadd">';
309 print
'<td width="96" class="nobordernopadding nowrap">';
310 print $commandestatic->getNomUrl(1);
313 print
'<td width="16" class="nobordernopadding nowrap">';
317 print
'<td width="16" class="nobordernopadding hideonsmartphone right">';
320 $urlsource = $_SERVER[
'PHP_SELF'].
'?id='.$obj->rowid;
321 print $formfile->getDocumentsLink($commandestatic->element, $filename, $filedir);
322 print
'</td></tr></table>';
326 print
'<td class="nowrap">';
327 print $companystatic->getNomUrl(1,
'company', 24);
330 print
'<td class="right">'.dol_print_date(
$db->jdate($obj->date),
'day').
'</td>'.
"\n";
332 print
'<td class="right">'.$commandestatic->LibStatut($obj->status, $obj->facture, 3).
'</td>';
338 print
'<tr><td><span class="opacitymedium">'.$langs->trans(
"More").
'...</span></td><td></td><td></td><td></td></tr>';
342 print
"</table></div><br>";
352 $sql =
"SELECT c.rowid, c.entity, c.ref, c.fk_statut as status, c.facture, c.date_commande as date, s.nom as name, s.rowid as socid";
353 $sql .=
", s.client";
354 $sql .=
", s.code_client";
355 $sql .=
", s.canvas";
356 $sql .=
" FROM ".MAIN_DB_PREFIX.
"commande as c";
357 $sql .=
", ".MAIN_DB_PREFIX.
"societe as s";
358 if (empty($user->socid) && !$user->hasRight(
'societe',
'client',
'voir')) {
359 $sql .=
", ".MAIN_DB_PREFIX.
"societe_commerciaux as sc";
361 $sql .=
" WHERE c.fk_soc = s.rowid";
362 $sql .=
" AND c.entity IN (".getEntity(
'commande').
")";
365 $sql .=
" AND c.fk_soc = ".((int) $socid);
367 if (empty($user->socid) && !$user->hasRight(
'societe',
'client',
'voir')) {
368 $sql .=
" AND s.rowid = sc.fk_soc AND sc.fk_user = ".((int) $user->id);
371 $parameters = array(
'socid' => $user->socid);
372 $reshook = $hookmanager->executeHooks(
'printFieldListWhere', $parameters, $commandestatic);
373 $sql .= $hookmanager->resPrint;
374 $sql .=
" ORDER BY c.rowid DESC";
376 $resql =
$db->query($sql);
378 $num =
$db->num_rows($resql);
380 print
'<div class="div-table-responsive-no-min">';
381 print
'<table class="noborder centpercent">';
382 print
'<tr class="liste_titre">';
383 print
'<th colspan="4">'.$langs->trans(
"OnProcessOrders").
' <a href="'.DOL_URL_ROOT.
'/commande/list.php?search_status='.
Commande::STATUS_SHIPMENTONPROCESS.
'"><span class="badge">'.$num.
'</span></a></th></tr>';
387 while ($i < $num && $i < $max) {
388 $obj =
$db->fetch_object($resql);
389 print
'<tr class="oddeven">';
390 print
'<td width="20%" class="nowrap">';
392 $commandestatic->id = $obj->rowid;
393 $commandestatic->ref = $obj->ref;
395 $companystatic->id = $obj->socid;
396 $companystatic->name = $obj->name;
397 $companystatic->client = $obj->client;
398 $companystatic->code_client = $obj->code_client;
399 $companystatic->canvas = $obj->canvas;
401 print
'<table class="nobordernopadding"><tr class="nocellnopadd">';
402 print
'<td width="96" class="nobordernopadding nowrap">';
403 print $commandestatic->getNomUrl(1);
406 print
'<td width="16" class="nobordernopadding nowrap">';
410 print
'<td width="16" class="nobordernopadding hideonsmartphone right">';
413 $urlsource = $_SERVER[
'PHP_SELF'].
'?id='.$obj->rowid;
414 print $formfile->getDocumentsLink($commandestatic->element, $filename, $filedir);
415 print
'</td></tr></table>';
420 print $companystatic->getNomUrl(1,
'company');
423 print
'<td class="right">'.dol_print_date(
$db->jdate($obj->date),
'day').
'</td>'.
"\n";
425 print
'<td class="right">'.$commandestatic->LibStatut($obj->status, $obj->facture, 3).
'</td>';
431 print
'<tr><td><span class="opacitymedium">'.$langs->trans(
"More").
'...</span></td><td></td><td></td><td></td></tr>';
434 print
"</table></div><br>";
443$parameters = array(
'user' => $user);
444$reshook = $hookmanager->executeHooks(
'dashboardOrders', $parameters, $object);
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 customers orders.
const STATUS_SHIPMENTONPROCESS
Shipment on process.
const STATUS_VALIDATED
Validated status.
Class to manage third parties objects (customers, suppliers, prospects...)
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_sanitizeFileName($str, $newstr='_', $unaccent=1, $includequotes=0, $allowdash=0)
Clean a string to use it as a file name.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false, $decorate=0)
Output date in a string format according to outputlangs (or langs if not defined).
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='', $morecssonpicto='widthpictotitle')
Load a title with picto.
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
isModEnabled($module)
Is Dolibarr module enabled.
getCustomerOrderPieChart($socid=0)
Return a HTML table that contains a pie chart of sales orders.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.