dolibarr 23.0.3
list.php
Go to the documentation of this file.
1<?php
2/* Copyright (C) 2007-2017 Laurent Destailleur <eldy@users.sourceforge.net>
3 * Copyright (C) 2018-2024 Alexandre Spangaro <alexandre@inovea-conseil.com>
4 * Copyright (C) 2024 Frédéric France <frederic.france@free.fr>
5 * Copyright (C) 2024-2025 MDW <mdeweerd@users.noreply.github.com>
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program. If not, see <https://www.gnu.org/licenses/>.
19 */
20
27// Load Dolibarr environment
28require '../../main.inc.php';
29require_once DOL_DOCUMENT_ROOT.'/core/class/html.formcompany.class.php';
30require_once DOL_DOCUMENT_ROOT.'/core/lib/date.lib.php';
31require_once DOL_DOCUMENT_ROOT.'/core/lib/company.lib.php';
32require_once DOL_DOCUMENT_ROOT.'/asset/class/assetmodel.class.php';
33
43// Load translation files required by the page
44$langs->loadLangs(array("assets", "other"));
45
46$action = GETPOST('action', 'aZ09') ? GETPOST('action', 'aZ09') : 'view'; // The action 'add', 'create', 'edit', 'update', 'view', ...
47$massaction = GETPOST('massaction', 'alpha'); // The bulk action (combo box choice into lists)
48$show_files = GETPOSTINT('show_files'); // Show files area generated by bulk actions ?
49$confirm = GETPOST('confirm', 'alpha'); // Result of a confirmation
50$cancel = GETPOST('cancel', 'alpha'); // We click on a Cancel button
51$toselect = GETPOST('toselect', 'array:int'); // Array of ids of elements selected into a list
52$contextpage = GETPOST('contextpage', 'aZ') ? GETPOST('contextpage', 'aZ') : 'assetmodellist'; // To manage different context of search
53$backtopage = GETPOST('backtopage', 'alpha'); // Go back to a dedicated page
54$optioncss = GETPOST('optioncss', 'aZ'); // Option for the css output (always '' except when 'print')
55
56$id = GETPOSTINT('id');
57
58// Load variable for pagination
59$limit = GETPOSTINT('limit') ? GETPOSTINT('limit') : $conf->liste_limit;
60$sortfield = GETPOST('sortfield', 'aZ09comma');
61$sortorder = GETPOST('sortorder', 'aZ09comma');
62$page = GETPOSTISSET('pageplusone') ? (GETPOSTINT('pageplusone') - 1) : GETPOSTINT("page");
63if (empty($page) || $page < 0 || GETPOST('button_search', 'alpha') || GETPOST('button_removefilter', 'alpha') || (empty($toselect) && $massaction === '0')) {
64 $page = 0;
65} // If $page is not defined, or '' or -1 or if we click on clear filters or if we select empty mass action
66$offset = $limit * $page;
67$pageprev = $page - 1;
68$pagenext = $page + 1;
69
70// Initialize a technical objects
71$object = new AssetModel($db);
72$extrafields = new ExtraFields($db);
73$diroutputmassaction = $conf->asset->dir_output.'/temp/massgeneration/'.$user->id;
74$hookmanager->initHooks(array('assetmodellist')); // Note that conf->hooks_modules contains array
75
76// Fetch optionals attributes and labels
77$extrafields->fetch_name_optionals_label($object->table_element);
78//$extrafields->fetch_name_optionals_label($object->table_element_line);
79
80$search_array_options = $extrafields->getOptionalsFromPost($object->table_element, '', 'search_');
81
82// Default sort order (if not yet defined by previous GETPOST)
83if (!$sortfield) {
84 reset($object->fields); // Reset is required to avoid key() to return null.
85 $sortfield = "t.".key($object->fields); // Set here default search field. By default 1st field in definition.
86}
87if (!$sortorder) {
88 $sortorder = "ASC";
89}
90
91// Initialize array of search criteria
92$search_all = GETPOST('search_all', 'alphanohtml');
93$search = array();
94foreach ($object->fields as $key => $val) {
95 if ($key == 'fk_pays' && !GETPOSTISSET('search_'.$key)) {
96 $search[$key] = $mysoc->country_id;
97 } elseif (GETPOST('search_'.$key, 'alpha') !== '') {
98 $search[$key] = GETPOST('search_'.$key, 'alpha');
99 }
100 if (preg_match('/^(date|timestamp|datetime)/', $val['type'])) {
101 $search[$key.'_dtstart'] = dol_mktime(0, 0, 0, GETPOSTINT('search_'.$key.'_dtstartmonth'), GETPOSTINT('search_'.$key.'_dtstartday'), GETPOSTINT('search_'.$key.'_dtstartyear'));
102 $search[$key.'_dtend'] = dol_mktime(23, 59, 59, GETPOSTINT('search_'.$key.'_dtendmonth'), GETPOSTINT('search_'.$key.'_dtendday'), GETPOSTINT('search_'.$key.'_dtendyear'));
103 }
104}
105
106// List of fields to search into when doing a "search in all"
107$fieldstosearchall = array();
108foreach ($object->fields as $key => $val) {
109 if (!empty($val['searchall'])) {
110 $fieldstosearchall['t.'.$key] = $val['label'];
111 }
112}
113
114// Definition of array of fields for columns
115$arrayfields = array();
116foreach ($object->fields as $key => $val) {
117 // If $val['visible']==0, then we never show the field
118 if (!empty($val['visible'])) {
119 $visible = (int) dol_eval((string) $val['visible'], 1);
120 $arrayfields['t.'.$key] = array(
121 'label' => $val['label'],
122 'checked' => (($visible < 0) ? 0 : 1),
123 'enabled' => (abs($visible) != 3 && (bool) dol_eval((string) $val['enabled'], 1)),
124 'position' => $val['position'],
125 'help' => isset($val['help']) ? $val['help'] : ''
126 );
127 }
128}
129// Extra fields
130include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_array_fields.tpl.php';
131
132$object->fields = dol_sort_array($object->fields, 'position');
133$arrayfields = dol_sort_array($arrayfields, 'position');
134
135$permissiontoread = ((!getDolGlobalString('MAIN_USE_ADVANCED_PERMS') && $user->hasRight('asset', 'read')) || (getDolGlobalString('MAIN_USE_ADVANCED_PERMS') && $user->hasRight('asset', 'model_advance', 'read')));
136$permissiontoadd = ((!getDolGlobalString('MAIN_USE_ADVANCED_PERMS') && $user->hasRight('asset', 'write')) || (getDolGlobalString('MAIN_USE_ADVANCED_PERMS') && $user->hasRight('asset', 'model_advance', 'write')));
137$permissiontodelete = ((!getDolGlobalString('MAIN_USE_ADVANCED_PERMS') && $user->hasRight('asset', 'delete')) || (getDolGlobalString('MAIN_USE_ADVANCED_PERMS') && $user->hasRight('asset', 'model_advance', 'delete')));
138
139// Security check
140if (!isModEnabled('asset')) {
141 accessforbidden('Module not enabled');
142}
143
144// Security check (enable the most restrictive one)
145if ($user->socid > 0) {
147}
148$socid = 0;
149if ($user->socid > 0) {
150 $socid = $user->socid;
151}
152$isdraft = (($object->status == $object::STATUS_DRAFT) ? 1 : 0);
153restrictedArea($user, 'asset', $object->id, $object->table_element, '', 'fk_soc', 'rowid', $isdraft);
154if (!isModEnabled('asset')) {
156}
157if (!$permissiontoread) {
159}
160
161/*
162 * Actions
163 */
164
165if (GETPOST('cancel', 'alpha')) {
166 $action = 'list';
167 $massaction = '';
168}
169if (!GETPOST('confirmmassaction', 'alpha') && $massaction != 'presend' && $massaction != 'confirm_presend') {
170 $massaction = '';
171}
172
173$parameters = array();
174$reshook = $hookmanager->executeHooks('doActions', $parameters, $object, $action); // Note that $action and $object may have been modified by some hooks
175if ($reshook < 0) {
176 setEventMessages($hookmanager->error, $hookmanager->errors, 'errors');
177}
178
179if (empty($reshook)) {
180 // Selection of new fields
181 include DOL_DOCUMENT_ROOT.'/core/actions_changeselectedfields.inc.php';
182
183 // Purge search criteria
184 if (GETPOST('button_removefilter_x', 'alpha') || GETPOST('button_removefilter.x', 'alpha') || GETPOST('button_removefilter', 'alpha')) { // All tests are required to be compatible with all browsers
185 foreach ($object->fields as $key => $val) {
186 $search[$key] = '';
187 if ($key == 'fk_pays') {
188 $search[$key] = $mysoc->country_id;
189 }
190 if (preg_match('/^(date|timestamp|datetime)/', $val['type'])) {
191 $search[$key.'_dtstart'] = '';
192 $search[$key.'_dtend'] = '';
193 }
194 }
195 $toselect = array();
196 $search_array_options = array();
197 }
198 if (GETPOST('button_removefilter_x', 'alpha') || GETPOST('button_removefilter.x', 'alpha') || GETPOST('button_removefilter', 'alpha')
199 || GETPOST('button_search_x', 'alpha') || GETPOST('button_search.x', 'alpha') || GETPOST('button_search', 'alpha')) {
200 $massaction = ''; // Protection to avoid mass action if we force a new search during a mass action confirmation
201 }
202
203 // Mass actions
204 $objectclass = 'AssetModel';
205 $objectlabel = 'AssetModel';
206 $uploaddir = $conf->asset->dir_output;
207 include DOL_DOCUMENT_ROOT.'/core/actions_massactions.inc.php';
208}
209
210
211
212/*
213 * View
214 */
215
216$form = new Form($db);
217
218$now = dol_now();
219
220$help_url = '';
221$title = $langs->trans('ListOf', $langs->transnoentitiesnoconv("AssetModels"));
222$morejs = array();
223$morecss = array();
224
225
226// Build and execute select
227// --------------------------------------------------------------------
228$sql = 'SELECT ';
229$sql .= $object->getFieldList('t');
230// Add fields from extrafields
231if (!empty($extrafields->attributes[$object->table_element]['label'])) {
232 foreach ($extrafields->attributes[$object->table_element]['label'] as $key => $val) {
233 $sql .= ($extrafields->attributes[$object->table_element]['type'][$key] != 'separate' ? ", ef.".$key." as options_".$key : '');
234 }
235}
236// Add fields from hooks
237$parameters = array();
238$reshook = $hookmanager->executeHooks('printFieldListSelect', $parameters, $object); // Note that $action and $object may have been modified by hook
239$sql .= $hookmanager->resPrint;
240$sql = preg_replace('/,\s*$/', '', $sql);
241$sql .= " FROM ".MAIN_DB_PREFIX.$object->table_element." as t";
242if (isset($extrafields->attributes[$object->table_element]['label']) && is_array($extrafields->attributes[$object->table_element]['label']) && count($extrafields->attributes[$object->table_element]['label'])) {
243 $sql .= " LEFT JOIN ".MAIN_DB_PREFIX.$object->table_element."_extrafields as ef on (t.rowid = ef.fk_object)";
244}
245// Add table from hooks
246$parameters = array();
247$reshook = $hookmanager->executeHooks('printFieldListFrom', $parameters, $object); // Note that $action and $object may have been modified by hook
248$sql .= $hookmanager->resPrint;
249if ($object->ismultientitymanaged == 1) {
250 $sql .= " WHERE t.entity IN (".getEntity($object->element).")";
251} else {
252 $sql .= " WHERE 1 = 1";
253}
254foreach ($search as $key => $val) {
255 if (array_key_exists($key, $object->fields)) {
256 if ($key == 'status' && $search[$key] == -1) {
257 continue;
258 }
259 $mode_search = (($object->isInt($object->fields[$key]) || $object->isFloat($object->fields[$key])) ? 1 : 0);
260 if ((strpos($object->fields[$key]['type'], 'integer:') === 0) || (strpos($object->fields[$key]['type'], 'sellist:') === 0) || !empty($object->fields[$key]['arrayofkeyval'])) {
261 if ($search[$key] == '-1' || ($search[$key] === '0' && (empty($object->fields[$key]['arrayofkeyval']) || !array_key_exists('0', $object->fields[$key]['arrayofkeyval'])))) {
262 $search[$key] = '';
263 }
264 $mode_search = 2;
265 }
266 if ($search[$key] != '') {
267 $sql .= natural_search($key, $search[$key], (($key == 'status') ? 2 : $mode_search));
268 }
269 } else {
270 if (preg_match('/(_dtstart|_dtend)$/', $key) && $search[$key] != '') {
271 $columnName = preg_replace('/(_dtstart|_dtend)$/', '', $key);
272 if (preg_match('/^(date|timestamp|datetime)/', $object->fields[$columnName]['type'])) {
273 if (preg_match('/_dtstart$/', $key)) {
274 $sql .= " AND t.".$columnName." >= '".$db->idate($search[$key])."'";
275 }
276 if (preg_match('/_dtend$/', $key)) {
277 $sql .= " AND t." . $columnName . " <= '" . $db->idate($search[$key]) . "'";
278 }
279 }
280 }
281 }
282}
283if ($search_all) {
284 $sql .= natural_search(array_keys($fieldstosearchall), $search_all);
285}
286//$sql.= dolSqlDateFilter("t.field", $search_xxxday, $search_xxxmonth, $search_xxxyear);
287// Add where from extra fields
288include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_search_sql.tpl.php';
289// Add where from hooks
290$parameters = array();
291$reshook = $hookmanager->executeHooks('printFieldListWhere', $parameters, $object); // Note that $action and $object may have been modified by hook
292$sql .= $hookmanager->resPrint;
293
294// Count total nb of records
295$nbtotalofrecords = '';
296if (!getDolGlobalInt('MAIN_DISABLE_FULL_SCANLIST')) {
297 /* This old and fast method to get and count full list returns all record so use a high amount of memory.
298 $result = $db->query($sql);
299 $nbtotalofrecords = $db->num_rows($result);
300 */
301 /* The fast and low memory method to get and count full list converts the sql into a sql count */
302 $sqlforcount = preg_replace('/^SELECT[a-z0-9\._\s\‍(\‍),]+FROM/Ui', 'SELECT COUNT(*) as nbtotalofrecords FROM', $sql);
303
304 $resql = $db->query($sqlforcount);
305 if ($resql) {
306 $objforcount = $db->fetch_object($resql);
307 $nbtotalofrecords = $objforcount->nbtotalofrecords;
308 } else {
309 dol_print_error($db);
310 }
311
312 if (($page * $limit) > (int) $nbtotalofrecords) { // if total of record found is smaller than page * limit, goto and load page 0
313 $page = 0;
314 $offset = 0;
315 }
316 $db->free($resql);
317}
318
319// Complete request and execute it with limit
320$sql .= $db->order($sortfield, $sortorder);
321if ($limit) {
322 $sql .= $db->plimit($limit + 1, $offset);
323}
324
325$resql = $db->query($sql);
326if (!$resql) {
327 dol_print_error($db);
328 exit;
329}
330
331$num = $db->num_rows($resql);
332
333
334// Direct jump if only one record found
335if ($num == 1 && getDolGlobalString('MAIN_SEARCH_DIRECT_OPEN_IF_ONLY_ONE') && $search_all && !$page) {
336 $obj = $db->fetch_object($resql);
337 $id = $obj->rowid;
338 header("Location: ".DOL_URL_ROOT.'/asset/model/card.php?id='.$id);
339 exit;
340}
341
342
343// Output page
344// --------------------------------------------------------------------
345
346llxHeader('', $title, $help_url, '', 0, 0, $morejs, $morecss, '', 'bodyforlist mod-asset page-model-list');
347
348$arrayofselected = is_array($toselect) ? $toselect : array();
349
350$param = '';
351if (!empty($contextpage) && $contextpage != $_SERVER["PHP_SELF"]) {
352 $param .= '&contextpage='.urlencode($contextpage);
353}
354if ($limit > 0 && $limit != $conf->liste_limit) {
355 $param .= '&limit='.((int) $limit);
356}
357foreach ($search as $key => $val) {
358 if (is_array($search[$key]) && count($search[$key])) {
359 foreach ($search[$key] as $skey) {
360 if ($skey != '') {
361 $param .= '&search_'.$key.'[]='.urlencode($skey);
362 }
363 }
364 } elseif ($search[$key] != '') {
365 $param .= '&search_'.$key.'='.urlencode($search[$key]);
366 }
367}
368if ($optioncss != '') {
369 $param .= '&optioncss='.urlencode($optioncss);
370}
371// Add $param from extra fields
372include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_search_param.tpl.php';
373// Add $param from hooks
374$parameters = array('param' => &$param);
375$reshook = $hookmanager->executeHooks('printFieldListSearchParam', $parameters, $object); // Note that $action and $object may have been modified by hook
376$param .= $hookmanager->resPrint;
377
378// List of mass actions available
379$arrayofmassactions = array(
380 //'validate'=>img_picto('', 'check', 'class="pictofixedwidth"').$langs->trans("Validate"),
381 //'generate_doc'=>img_picto('', 'pdf', 'class="pictofixedwidth"').$langs->trans("ReGeneratePDF"),
382 //'builddoc'=>img_picto('', 'pdf', 'class="pictofixedwidth"').$langs->trans("PDFMerge"),
383 //'presend'=>img_picto('', 'email', 'class="pictofixedwidth"').$langs->trans("SendByMail"),
384);
385if ($permissiontodelete) {
386 $arrayofmassactions['predelete'] = img_picto('', 'delete', 'class="pictofixedwidth"').$langs->trans("Delete");
387}
388if (GETPOSTINT('nomassaction') || in_array($massaction, array('presend', 'predelete'))) {
389 $arrayofmassactions = array();
390}
391$massactionbutton = $form->selectMassAction('', $arrayofmassactions);
392
393print '<form method="POST" id="searchFormList" action="'.$_SERVER["PHP_SELF"].'">'."\n";
394if ($optioncss != '') {
395 print '<input type="hidden" name="optioncss" value="'.$optioncss.'">';
396}
397print '<input type="hidden" name="token" value="'.newToken().'">';
398print '<input type="hidden" name="formfilteraction" id="formfilteraction" value="list">';
399print '<input type="hidden" name="action" value="list">';
400print '<input type="hidden" name="sortfield" value="'.$sortfield.'">';
401print '<input type="hidden" name="sortorder" value="'.$sortorder.'">';
402print '<input type="hidden" name="page" value="'.$page.'">';
403print '<input type="hidden" name="contextpage" value="'.$contextpage.'">';
404
405$newcardbutton = '';
406$newcardbutton .= dolGetButtonTitle($langs->trans('New'), '', 'fa fa-plus-circle', DOL_URL_ROOT.'/asset/model/card.php?action=create&backtopage='.urlencode($_SERVER['PHP_SELF']), '', (int) $permissiontoadd);
407
408print_barre_liste($title, $page, $_SERVER["PHP_SELF"], $param, $sortfield, $sortorder, $massactionbutton, $num, $nbtotalofrecords, 'object_'.$object->picto, 0, $newcardbutton, '', $limit, 0, 0, 1);
409
410// Add code for pre mass action (confirmation or email presend form)
411$topicmail = "SendAssetModelRef";
412$modelmail = "assetmodel";
413$objecttmp = new AssetModel($db);
414$trackid = 'assetmodel'.$object->id;
415include DOL_DOCUMENT_ROOT.'/core/tpl/massactions_pre.tpl.php';
416
417if ($search_all) {
418 foreach ($fieldstosearchall as $key => $val) {
419 $fieldstosearchall[$key] = $langs->trans($val);
420 }
421 print '<div class="divsearchfieldfilter">'.$langs->trans("FilterOnInto", $search_all).implode(', ', $fieldstosearchall).'</div>';
422}
423
424$moreforfilter = '';
425/*$moreforfilter.='<div class="divsearchfield">';
426$moreforfilter.= $langs->trans('MyFilter') . ': <input type="text" name="search_myfield" value="'.dol_escape_htmltag($search_myfield).'">';
427$moreforfilter.= '</div>';*/
428
429$parameters = array();
430$reshook = $hookmanager->executeHooks('printFieldPreListTitle', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
431if (empty($reshook)) {
432 $moreforfilter .= $hookmanager->resPrint;
433} else {
434 $moreforfilter = $hookmanager->resPrint;
435}
436
437if (!empty($moreforfilter)) {
438 print '<div class="liste_titre liste_titre_bydiv centpercent">';
439 print $moreforfilter;
440 print '</div>';
441}
442
443$varpage = empty($contextpage) ? $_SERVER["PHP_SELF"] : $contextpage;
444$selectedfields = $form->multiSelectArrayWithCheckbox('selectedfields', $arrayfields, $varpage); // This also change content of $arrayfields
445$selectedfields .= (count($arrayofmassactions) ? $form->showCheckAddButtons('checkforselect', 1) : '');
446
447print '<div class="div-table-responsive">'; // You can use div-table-responsive-no-min if you don't need reserved height for your table
448print '<table class="tagtable nobottomiftotal noborder liste'.($moreforfilter ? " listwithfilterbefore" : "").'">'."\n";
449
450
451// Fields title search
452// --------------------------------------------------------------------
453print '<tr class="liste_titre">';
454foreach ($object->fields as $key => $val) {
455 $cssforfield = (empty($val['csslist']) ? (empty($val['css']) ? '' : $val['css']) : $val['csslist']);
456 if ($key == 'status') {
457 $cssforfield .= ($cssforfield ? ' ' : '').'center';
458 } elseif (in_array($val['type'], array('date', 'datetime', 'timestamp'))) {
459 $cssforfield .= ($cssforfield ? ' ' : '').'center';
460 } elseif (in_array($val['type'], array('timestamp'))) {
461 $cssforfield .= ($cssforfield ? ' ' : '').'nowrap';
462 } elseif (in_array($val['type'], array('double(24,8)', 'double(6,3)', 'integer', 'real', 'price')) && $val['label'] != 'TechnicalID' && empty($val['arrayofkeyval'])) {
463 $cssforfield .= ($cssforfield ? ' ' : '').'right';
464 }
465 if (!empty($arrayfields['t.'.$key]['checked'])) {
466 print '<td class="liste_titre'.($cssforfield ? ' '.$cssforfield : '').'">';
467 if (!empty($val['arrayofkeyval']) && is_array($val['arrayofkeyval'])) {
468 print $form->selectarray('search_'.$key, $val['arrayofkeyval'], (isset($search[$key]) ? $search[$key] : ''), $val['notnull'], 0, 0, '', 1, 0, 0, '', 'maxwidth100', 1);
469 } elseif ((strpos($val['type'], 'integer:') === 0) || (strpos($val['type'], 'sellist:') === 0)) {
470 print $object->showInputField($val, $key, (isset($search[$key]) ? $search[$key] : ''), '', '', 'search_', 'maxwidth125', 1);
471 } elseif (preg_match('/^(date|timestamp|datetime)/', $val['type'])) {
472 print '<div class="nowrap">';
473 $form->selectDate($search[$key.'_dtstart'] ? $search[$key.'_dtstart'] : '', "search_".$key."_dtstart", 0, 0, 1, '', 1, 0, 0, '', '', '', '', 1, '', $langs->trans('From'));
474 print '</div>';
475 print '<div class="nowrap">';
476 print $form->selectDate($search[$key.'_dtend'] ? $search[$key.'_dtend'] : '', "search_".$key."_dtend", 0, 0, 1, '', 1, 0, 0, '', '', '', '', 1, '', $langs->trans('to'));
477 print '</div>';
478 } elseif ($key == 'lang') {
479 require_once DOL_DOCUMENT_ROOT.'/core/class/html.formadmin.class.php';
480 $formadmin = new FormAdmin($db);
481 print $formadmin->select_language($search[$key], 'search_lang', 0, array(), 1, 0, 0, 'minwidth100imp maxwidth125', 2);
482 } else {
483 print '<input type="text" class="flat maxwidth'.($val['type'] == 'integer' ? '50' : '75').'" name="search_'.$key.'" value="'.dol_escape_htmltag(isset($search[$key]) ? $search[$key] : '').'">';
484 }
485 print '</td>';
486 }
487}
488// Extra fields
489include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_search_input.tpl.php';
490
491// Fields from hook
492$parameters = array('arrayfields' => $arrayfields);
493$reshook = $hookmanager->executeHooks('printFieldListOption', $parameters, $object); // Note that $action and $object may have been modified by hook
494print $hookmanager->resPrint;
495// Action column
496print '<td class="liste_titre maxwidthsearch">';
497$searchpicto = $form->showFilterButtons();
498print $searchpicto;
499print '</td>';
500print '</tr>'."\n";
501
502
503// Fields title label
504// --------------------------------------------------------------------
505print '<tr class="liste_titre">';
506foreach ($object->fields as $key => $val) {
507 $cssforfield = (empty($val['csslist']) ? (empty($val['css']) ? '' : $val['css']) : $val['csslist']);
508 if ($key == 'status') {
509 $cssforfield .= ($cssforfield ? ' ' : '').'center';
510 } elseif (in_array($val['type'], array('date', 'datetime', 'timestamp'))) {
511 $cssforfield .= ($cssforfield ? ' ' : '').'center';
512 } elseif (in_array($val['type'], array('timestamp'))) {
513 $cssforfield .= ($cssforfield ? ' ' : '').'nowrap';
514 } elseif (in_array($val['type'], array('double(24,8)', 'double(6,3)', 'integer', 'real', 'price')) && $val['label'] != 'TechnicalID' && empty($val['arrayofkeyval'])) {
515 $cssforfield .= ($cssforfield ? ' ' : '').'right';
516 }
517 if (!empty($arrayfields['t.'.$key]['checked'])) {
518 print getTitleFieldOfList($arrayfields['t.'.$key]['label'], 0, $_SERVER['PHP_SELF'], 't.'.$key, '', $param, ($cssforfield ? 'class="'.$cssforfield.'"' : ''), $sortfield, $sortorder, ($cssforfield ? $cssforfield.' ' : ''))."\n";
519 }
520}
521// Extra fields
522include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_search_title.tpl.php';
523// Hook fields
524$parameters = array('arrayfields' => $arrayfields, 'param' => $param, 'sortfield' => $sortfield, 'sortorder' => $sortorder);
525$reshook = $hookmanager->executeHooks('printFieldListTitle', $parameters, $object); // Note that $action and $object may have been modified by hook
526print $hookmanager->resPrint;
527// Action column
528print getTitleFieldOfList($selectedfields, 0, $_SERVER["PHP_SELF"], '', '', '', '', $sortfield, $sortorder, 'center maxwidthsearch ')."\n";
529print '</tr>'."\n";
530
531
532// Detect if we need a fetch on each output line
533$needToFetchEachLine = 0;
534if (isset($extrafields->attributes[$object->table_element]['computed']) && is_array($extrafields->attributes[$object->table_element]['computed']) && count($extrafields->attributes[$object->table_element]['computed']) > 0) {
535 foreach ($extrafields->attributes[$object->table_element]['computed'] as $key => $val) {
536 if (!is_null($val) && preg_match('/\$object/', $val)) {
537 $needToFetchEachLine++; // There is at least one compute field that use $object
538 }
539 }
540}
541
542
543// Loop on record
544// --------------------------------------------------------------------
545$i = 0;
546$totalarray = array();
547$totalarray['nbfield'] = 0;
548while ($i < ($limit ? min($num, $limit) : $num)) {
549 $obj = $db->fetch_object($resql);
550 if (empty($obj)) {
551 break; // Should not happen
552 }
553
554 // Store properties in $object
555 $object->setVarsFromFetchObj($obj);
556
557 // Show here line of result
558 print '<tr class="oddeven">';
559 foreach ($object->fields as $key => $val) {
560 $cssforfield = (empty($val['csslist']) ? (empty($val['css']) ? '' : $val['css']) : $val['csslist']);
561 if (in_array($val['type'], array('date', 'datetime', 'timestamp'))) {
562 $cssforfield .= ($cssforfield ? ' ' : '').'center';
563 } elseif ($key == 'status') {
564 $cssforfield .= ($cssforfield ? ' ' : '').'center';
565 }
566
567 if (in_array($val['type'], array('timestamp'))) {
568 $cssforfield .= ($cssforfield ? ' ' : '').'nowrap';
569 } elseif ($key == 'ref') {
570 $cssforfield .= ($cssforfield ? ' ' : '').'nowrap';
571 }
572
573 if (in_array($val['type'], array('double(24,8)', 'double(6,3)', 'integer', 'real', 'price')) && !in_array($key, array('rowid', 'status')) && empty($val['arrayofkeyval'])) {
574 $cssforfield .= ($cssforfield ? ' ' : '').'right';
575 }
576 //if (in_array($key, array('fk_soc', 'fk_user', 'fk_warehouse'))) $cssforfield = 'tdoverflowmax100';
577
578 if (!empty($arrayfields['t.'.$key]['checked'])) {
579 print '<td'.($cssforfield ? ' class="'.$cssforfield.'"' : '').'>';
580 if ($key == 'status') {
581 print $object->getLibStatut(5);
582 } elseif ($key == 'rowid') {
583 print $object->showOutputField($val, $key, (string) $object->id, '');
584 } else {
585 print $object->showOutputField($val, $key, $object->$key, '');
586 }
587 print '</td>';
588 if (!$i) {
589 $totalarray['nbfield']++;
590 }
591 if (!empty($val['isameasure']) && $val['isameasure'] == 1) {
592 if (!$i) {
593 $totalarray['pos'][$totalarray['nbfield']] = 't.'.$key;
594 }
595 if (!isset($totalarray['val'])) {
596 $totalarray['val'] = array();
597 }
598 if (!isset($totalarray['val']['t.'.$key])) {
599 $totalarray['val']['t.'.$key] = 0;
600 }
601 $totalarray['val']['t.'.$key] += $object->$key;
602 }
603 }
604 }
605 // Extra fields
606 include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_print_fields.tpl.php';
607 // Fields from hook
608 $parameters = array('arrayfields' => $arrayfields, 'object' => $object, 'obj' => $obj, 'i' => $i, 'totalarray' => &$totalarray);
609 $reshook = $hookmanager->executeHooks('printFieldListValue', $parameters, $object); // Note that $action and $object may have been modified by hook
610 print $hookmanager->resPrint;
611 // Action column
612 print '<td class="nowrap center">';
613 if ($massactionbutton || $massaction) { // If we are in select mode (massactionbutton defined) or if we have already selected and sent an action ($massaction) defined
614 $selected = 0;
615 if (in_array($object->id, $arrayofselected)) {
616 $selected = 1;
617 }
618 print '<input id="cb'.$object->id.'" class="flat checkforselect" type="checkbox" name="toselect[]" value="'.$object->id.'"'.($selected ? ' checked="checked"' : '').'>';
619 }
620 print '</td>';
621 if (!$i) {
622 $totalarray['nbfield']++;
623 }
624
625 print '</tr>'."\n";
626
627 $i++;
628}
629
630// Show total line
631include DOL_DOCUMENT_ROOT.'/core/tpl/list_print_total.tpl.php';
632
633// If no record found
634if ($num == 0) {
635 $colspan = 1;
636 foreach ($arrayfields as $key => $val) {
637 if (!empty($val['checked'])) {
638 $colspan++;
639 }
640 }
641 print '<tr><td colspan="'.$colspan.'"><span class="opacitymedium">'.$langs->trans("NoRecordFound").'</span></td></tr>';
642}
643
644
645$db->free($resql);
646
647$parameters = array('arrayfields' => $arrayfields, 'sql' => $sql);
648$reshook = $hookmanager->executeHooks('printFieldListFooter', $parameters, $object); // Note that $action and $object may have been modified by hook
649print $hookmanager->resPrint;
650
651print '</table>'."\n";
652print '</div>'."\n";
653
654print '</form>'."\n";
655
656if (in_array('builddoc', array_keys($arrayofmassactions)) && ($nbtotalofrecords === '' || $nbtotalofrecords)) {
657 $hidegeneratedfilelistifempty = 1;
658 if ($massaction == 'builddoc' || $action == 'remove_file' || $show_files) {
659 $hidegeneratedfilelistifempty = 0;
660 }
661
662 require_once DOL_DOCUMENT_ROOT.'/core/class/html.formfile.class.php';
663 $formfile = new FormFile($db);
664
665 // Show list of available documents
666 $urlsource = $_SERVER['PHP_SELF'].'?sortfield='.$sortfield.'&sortorder='.$sortorder;
667 $urlsource .= str_replace('&amp;', '&', $param);
668
669 $filedir = $diroutputmassaction;
670 $genallowed = $permissiontoread;
671 $delallowed = $permissiontoadd;
672
673 print $formfile->showdocuments('massfilesarea_asset', '', $filedir, $urlsource, 0, (int) $delallowed, '', 1, 1, 0, 48, 1, $param, $title, '', '', '', null, $hidegeneratedfilelistifempty);
674}
675
676// End of page
677llxFooter();
678$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
$totalarray
Definition export.php:1216
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 for AssetModel.
Class to manage standard extra fields.
Class to generate html code for admin pages.
Class to offer components to list and upload files.
Class to manage generation of HTML components Only common components must be here.
global $mysoc
dol_now($mode='gmt')
Return date for now.
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm='auto', $check=1)
Return a timestamp date built from detailed information (by default a local PHP server timestamp) Rep...
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
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.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2, $allowothertags=array())
Show picto whatever it's its name (generic function)
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dolGetButtonTitle($label, $helpText='', $iconClass='fa fa-file', $url='', $id='', $status=1, $params=array())
Function dolGetButtonTitle : this kind of buttons are used in title in list.
dol_eval($s, $returnvalue=1, $hideerrors=1, $onlysimplestring='1')
Replace eval function to add more security.
natural_search($fields, $value, $mode=0, $nofirstand=0, $sqltoadd='')
Generate natural SQL search string for a criteria (this criteria can be tested on one or several fiel...
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
dol_sort_array(&$array, $index, $order='asc', $natsort=0, $case_sensitive=0, $keepindex=0)
Advanced sort array by the value of a given key, which produces ascending (default) or descending out...
getTitleFieldOfList($name, $thead=0, $file="", $field="", $begin="", $moreparam="", $moreattrib="", $sortfield="", $sortorder="", $prefix="", $disablesortlink=0, $tooltip='', $forcenowrapcolumntitle=0)
Get title line of an array.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
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.
isModEnabled($module)
Is Dolibarr module enabled.
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...
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.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.