dolibarr 23.0.3
commande_fournisseur.php
Go to the documentation of this file.
1<?php
2/* Copyright (C) 2003-2007 Rodolphe Quiedeville <rodolphe@quiedeville.org>
3 * Copyright (C) 2004-2009 Laurent Destailleur <eldy@users.sourceforge.net>
4 * Copyright (C) 2005-2012 Regis Houssin <regis.houssin@inodbox.com>
5 * Copyright (C) 2014 Florian Henry <florian.henry@open-concept.pro>
6 * Copyright (C) 2024-2025 Frédéric France <frederic.france@free.fr>
7 * Copyright (C) 2024 Charlene Benke <charlene@patas-monkey.com>
8 * Copyright (C) 2025 MDW <mdeweerd@users.noreply.github.com>
9 *
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 3 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program. If not, see <https://www.gnu.org/licenses/>.
22 */
23
29require '../../main.inc.php';
30require_once DOL_DOCUMENT_ROOT.'/core/lib/product.lib.php';
31require_once DOL_DOCUMENT_ROOT.'/fourn/class/fournisseur.commande.class.php';
32require_once DOL_DOCUMENT_ROOT.'/product/class/product.class.php';
33require_once DOL_DOCUMENT_ROOT.'/core/class/html.formother.class.php';
34require_once DOL_DOCUMENT_ROOT.'/core/class/html.formorder.class.php';
35
44// Load translation files required by the page
45$langs->loadLangs(array('orders', 'products', 'companies', 'sendings'));
46
47$id = GETPOSTINT('id');
48$ref = GETPOST('ref', 'alpha');
49
50// Security check
51$fieldvalue = (!empty($id) ? $id : (!empty($ref) ? $ref : ''));
52$fieldtype = (!empty($ref) ? 'ref' : 'rowid');
53$socid = '';
54if (!empty($user->socid)) {
55 $socid = $user->socid;
56}
57
58// Initialize a technical object to manage hooks of page. Note that conf->hooks_modules contains an array of hook context
59$hookmanager->initHooks(array('productstatssupplierorder'));
60
61$mesg = '';
62
63// Load variable for pagination
64$limit = GETPOSTINT('limit') ? GETPOSTINT('limit') : $conf->liste_limit;
65$sortfield = GETPOST('sortfield', 'aZ09comma');
66$sortorder = GETPOST('sortorder', 'aZ09comma');
67$page = GETPOSTISSET('pageplusone') ? (GETPOSTINT('pageplusone') - 1) : GETPOSTINT("page");
68if (empty($page) || $page == -1) {
69 $page = 0;
70} // If $page is not defined, or '' or -1
71$offset = $limit * $page;
72$pageprev = $page - 1;
73$pagenext = $page + 1;
74if (!$sortorder) {
75 $sortorder = "DESC";
76}
77if (!$sortfield) {
78 $sortfield = "c.date_commande";
79}
80$search_month = GETPOSTINT('search_month');
81$search_year = GETPOSTINT('search_year');
82if (GETPOSTISARRAY('search_status')) {
83 $search_status = implode(',', GETPOST('search_status', 'array:intcomma'));
84} else {
85 $search_status = (GETPOST('search_status', 'intcomma') != '' ? GETPOST('search_status', 'intcomma') : GETPOST('statut', 'intcomma'));
86}
87
88if (GETPOST('button_removefilter_x', 'alpha') || GETPOST('button_removefilter', 'alpha')) {
89 $search_month = '';
90 $search_year = '';
91 $search_status = '';
92}
93
94$result = restrictedArea($user, 'produit|service', $fieldvalue, 'product&product', '', '', $fieldtype);
95
96
97/*
98 * View
99 */
100
101$supplierorderstatic = new CommandeFournisseur($db);
102$societestatic = new Societe($db);
103
104$form = new Form($db);
105$formother = new FormOther($db);
106$formorder = new FormOrder($db);
107
108if ($id > 0 || !empty($ref)) {
109 $product = new Product($db);
110 $result = $product->fetch($id, $ref);
111
112 $object = $product;
113
114 $parameters = array('id' => $id);
115 $reshook = $hookmanager->executeHooks('doActions', $parameters, $product, $action); // Note that $action and $object may have been modified by some hooks
116 if ($reshook < 0) {
117 setEventMessages($hookmanager->error, $hookmanager->errors, 'errors');
118 }
119
120 llxHeader("", "", $langs->trans("CardProduct".$product->type), '', 0, 0, '', '', 'mod-product page-stats_commande_fournisseur');
121
122 if ($result > 0) {
123 $head = product_prepare_head($product);
124 $titre = $langs->trans("CardProduct".$product->type);
125 $picto = ($product->type == Product::TYPE_SERVICE ? 'service' : 'product');
126 print dol_get_fiche_head($head, 'referers', $titre, -1, $picto);
127
128 $reshook = $hookmanager->executeHooks('formObjectOptions', $parameters, $product, $action); // Note that $action and $object may have been modified by hook
129 print $hookmanager->resPrint;
130 if ($reshook < 0) {
131 setEventMessages($hookmanager->error, $hookmanager->errors, 'errors');
132 }
133
134 $linkback = '<a href="'.DOL_URL_ROOT.'/product/list.php?restore_lastsearch_values=1">'.$langs->trans("BackToList").'</a>';
135
136 $shownav = 1;
137 if ($user->socid && !in_array('product', explode(',', getDolGlobalString('MAIN_MODULES_FOR_EXTERNAL')))) {
138 $shownav = 0;
139 }
140
141 dol_banner_tab($object, 'ref', $linkback, $shownav, 'ref');
142
143 print '<div class="fichecenter">';
144
145 print '<div class="underbanner clearboth"></div>';
146 print '<table class="border tableforfield" width="100%">';
147
148 $nboflines = show_stats_for_company($product, $socid);
149
150 print "</table>";
151
152 print '</div>';
153 print '<div class="clearboth"></div>';
154
155 print dol_get_fiche_end();
156
157
158 if ($user->hasRight('fournisseur', 'commande', 'lire')) {
159 $sql = "SELECT DISTINCT s.nom as name, s.rowid as socid, s.code_client,";
160 $sql .= " c.rowid, d.total_ht as total_ht, c.ref,";
161 $sql .= " c.date_livraison as delivery_date,";
162 $sql .= " c.date_commande, c.fk_statut as status, c.billed, c.rowid as commandeid, d.rowid, d.qty, d.subprice as unitprice";
163 if (!$user->hasRight('societe', 'client', 'voir')) {
164 $sql .= ", sc.fk_soc, sc.fk_user ";
165 }
166 $sql .= " FROM ".MAIN_DB_PREFIX."societe as s";
167 $sql .= ", ".MAIN_DB_PREFIX."commande_fournisseur as c";
168 $sql .= ", ".MAIN_DB_PREFIX."commande_fournisseurdet as d";
169 if (!$user->hasRight('societe', 'client', 'voir')) {
170 $sql .= ", ".MAIN_DB_PREFIX."societe_commerciaux as sc";
171 }
172 $sql .= " WHERE c.fk_soc = s.rowid";
173 $sql .= " AND c.entity IN (".getEntity('supplier_order').")";
174 $sql .= " AND d.fk_commande = c.rowid";
175 $sql .= " AND d.fk_product = ".((int) $product->id);
176 if (!empty($search_month)) {
177 $sql .= " AND MONTH(c.date_commande) = ".((int) $search_month);
178 }
179 if (!empty($search_year)) {
180 $sql .= " AND YEAR(c.date_commande) = ".((int) $search_year);
181 }
182 if (!$user->hasRight('societe', 'client', 'voir')) {
183 $sql .= " AND s.rowid = sc.fk_soc AND sc.fk_user = ".((int) $user->id);
184 }
185 if ($socid) {
186 $sql .= " AND c.fk_soc = ".((int) $socid);
187 }
188
189 if ($search_status != '') {
190 $sql .= " AND c.fk_statut IN (".$db->sanitize($search_status).")";
191 }
192
193 $sql .= $db->order($sortfield, $sortorder);
194
195 // Calcul total qty and amount for global if full scan list
196 $total_ht = 0;
197 $total_qty = 0;
198
199 // Count total nb of records
200 $totalofrecords = '';
201 if (!getDolGlobalInt('MAIN_DISABLE_FULL_SCANLIST')) {
202 $result = $db->query($sql);
203 $totalofrecords = $db->num_rows($result);
204 }
205
206 $sql .= $db->plimit($limit + 1, $offset);
207
208 $result = $db->query($sql);
209 if ($result) {
210 $num = $db->num_rows($result);
211
212 $option = '&id='.$product->id;
213
214 if ($limit > 0 && $limit != $conf->liste_limit) {
215 $option .= '&limit='.((int) $limit);
216 }
217 if (!empty($search_month)) {
218 $option .= '&search_month='.urlencode((string) ($search_month));
219 }
220 if (!empty($search_year)) {
221 $option .= '&search_year='.urlencode((string) ($search_year));
222 }
223
224 if ($search_status != '') {
225 $param .= '&search_status='.urlencode($search_status);
226 }
227
228 print '<form method="post" action="'.$_SERVER['PHP_SELF'].'?id='.$product->id.'" name="search_form">'."\n";
229 print '<input type="hidden" name="token" value="'.newToken().'">';
230 if (!empty($sortfield)) {
231 print '<input type="hidden" name="sortfield" value="'.$sortfield.'"/>';
232 }
233 if (!empty($sortorder)) {
234 print '<input type="hidden" name="sortorder" value="'.$sortorder.'"/>';
235 }
236
237 // @phan-suppress-next-line PhanPluginSuspiciousParamOrder
238 print_barre_liste($langs->trans("SuppliersOrders"), $page, $_SERVER["PHP_SELF"], $option, $sortfield, $sortorder, '', $num, $totalofrecords, '', 0, '', '', $limit, 0, 0, 1);
239
240 if (!empty($page)) {
241 $option .= '&page='.urlencode((string) ($page));
242 }
243
244 print '<div class="liste_titre liste_titre_bydiv centpercent">';
245 print '<div class="divsearchfield">';
246 print $langs->trans('Period').' ('.$langs->trans("OrderDate").') - ';
247 print $langs->trans('Month').':<input class="flat" type="text" size="4" name="search_month" value="'.($search_month > 0 ? $search_month : '').'"> ';
248 print $langs->trans('Year').':'.$formother->selectyear(($search_year ? (string) $search_year : '-1'), 'search_year', 1, 20, 5);
249 print $langs->trans('Status');
250 $formorder->selectSupplierOrderStatus($search_status, 1, 'search_status');
251 print '<div style="vertical-align: middle; display: inline-block">';
252 print '<input type="image" class="liste_titre" name="button_search" src="'.img_picto($langs->trans("Search"), 'search.png', '', 0, 1).'" value="'.dol_escape_htmltag($langs->trans("Search")).'" title="'.dol_escape_htmltag($langs->trans("Search")).'">';
253 print '<input type="image" class="liste_titre" name="button_removefilter" src="'.img_picto($langs->trans("Search"), 'searchclear.png', '', 0, 1).'" value="'.dol_escape_htmltag($langs->trans("RemoveFilter")).'" title="'.dol_escape_htmltag($langs->trans("RemoveFilter")).'">';
254 print '</div>';
255 print '</div>';
256 print '</div>';
257
258 $i = 0;
259 print '<div class="div-table-responsive">';
260 print '<table class="tagtable liste listwithfilterbefore centpercent">';
261 print '<tr class="liste_titre">';
262 print_liste_field_titre("Ref", $_SERVER["PHP_SELF"], "c.rowid", "", $option, '', $sortfield, $sortorder);
263 print_liste_field_titre("Company", $_SERVER["PHP_SELF"], "s.nom", "", $option, '', $sortfield, $sortorder);
264 print_liste_field_titre("SupplierCode", $_SERVER["PHP_SELF"], "s.code_client", "", $option, '', $sortfield, $sortorder);
265 print_liste_field_titre("OrderDate", $_SERVER["PHP_SELF"], "c.date_commande", "", $option, 'align="center"', $sortfield, $sortorder);
266 print_liste_field_titre('DateDeliveryPlanned', $_SERVER['PHP_SELF'], 'c.date_livraison', '', $option, 'align="center"', $sortfield, $sortorder);
267 print_liste_field_titre("Qty", $_SERVER["PHP_SELF"], "d.qty", "", $option, 'align="center"', $sortfield, $sortorder);
268 print_liste_field_titre("UnitPrice", $_SERVER["PHP_SELF"], "d.unitprice", "", $option, 'align="right"', $sortfield, $sortorder);
269 print_liste_field_titre("AmountHT", $_SERVER["PHP_SELF"], "d.total_ht", "", $option, 'align="right"', $sortfield, $sortorder);
270 print_liste_field_titre("Status", $_SERVER["PHP_SELF"], "c.fk_statut", "", $option, 'align="right"', $sortfield, $sortorder);
271 print "</tr>\n";
272
273 if ($num > 0) {
274 while ($i < min($num, $limit)) {
275 $objp = $db->fetch_object($result);
276
277 $total_ht += $objp->total_ht;
278 $total_qty += $objp->qty;
279
280 $supplierorderstatic->id = $objp->commandeid;
281 $supplierorderstatic->ref = $objp->ref;
282
283 $supplierorderstatic->statut = $objp->status; // deprecated
284 $supplierorderstatic->status = $objp->status;
285 $supplierorderstatic->billed = $objp->billed;
286
287 $societestatic->fetch($objp->socid);
288
289 print '<tr class="oddeven">';
290 print '<td>';
291 print $supplierorderstatic->getNomUrl(1);
292 print "</td>\n";
293 print '<td>'.$societestatic->getNomUrl(1).'</td>';
294 print "<td>".$objp->code_client."</td>\n";
295 print '<td class="center">';
296 print dol_print_date($db->jdate($objp->date_commande), 'dayhour')."</td>";
297 // delivery planned date
298 print '<td class="center">';
299 print dol_print_date($db->jdate($objp->delivery_date), 'dayhour');
300 print '</td>';
301 print '<td class="center">'.$objp->qty."</td>\n";
302 print '<td align="right">'.price($objp->unitprice)."</td>\n";
303 print '<td align="right">'.price($objp->total_ht)."</td>\n";
304 print '<td align="right">'.$supplierorderstatic->getLibStatut(4).'</td>';
305 print "</tr>\n";
306 $i++;
307 }
308 }
309 print '<tr class="liste_total">';
310 if ($num < $limit && empty($offset)) {
311 print '<td>'.$langs->trans("Total").'</td>';
312 } else {
313 print '<td>'.$form->textwithpicto($langs->trans("Total"), $langs->trans("Totalforthispage")).'</td>';
314 }
315 print '<td colspan="3"></td>';
316 // delivery planned date
317 print '<td></td>';
318 print '<td class="center">'.$total_qty.'</td>';
319 print '<td></td>';
320 print '<td align="right">'.price($total_ht).'</td>';
321 print '<td></td>';
322 print "</table>";
323 print '</div>';
324 print '</form>';
325 } else {
326 dol_print_error($db);
327 }
328 $db->free($result);
329 }
330 }
331} else {
333}
334
335// End of page
336llxFooter();
337$db->close();
$id
Support class for third parties, contacts, members, users or resources.
Definition account.php:47
if(! $sortfield) if(! $sortorder) $object
Definition account.php:100
llxFooter($comment='', $zone='private', $disabledoutputofmessages=0)
Empty footer.
Definition wrapper.php:91
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.
Definition wrapper.php:73
Class to manage predefined suppliers products.
Class to manage generation of HTML components Only common components must be here.
Class to manage HTML output components for orders Before adding component here, check they are not in...
Class permettant la generation de composants html autre Only common components are here.
Class to manage products or services.
const TYPE_SERVICE
Service.
Class to manage third parties objects (customers, suppliers, prospects...)
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
print_liste_field_titre($name, $file="", $field="", $begin="", $param="", $moreattrib="", $sortfield="", $sortorder="", $prefix="", $tooltip="", $forcenowrapcolumntitle=0)
Show title line of an array.
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.
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, $morecssdiv='')
Show tabs of a record.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
GETPOSTISARRAY($paramname, $method=0)
Return true if the parameter $paramname is submit from a POST OR GET as an array.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
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...
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
dol_escape_htmltag($stringtoescape, $keepb=0, $keepn=0, $noescapetags='', $escapeonlyhtmltags=0, $cleanalsojavascript=0)
Returns text escaped for inclusion in HTML alt or title or value tags, or into values of HTML input f...
product_prepare_head($object)
Prepare array with list of tabs.
show_stats_for_company($product, $socid)
Show stats for a product.
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.