dolibarr 24.0.0-beta
emailcollector_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) 2024 Alexandre Spangaro <alexandre@inovea-conseil.com>
4 * Copyright (C) 2024-2026 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';
38require_once DOL_DOCUMENT_ROOT.'/core/lib/admin.lib.php';
39require_once DOL_DOCUMENT_ROOT.'/core/lib/agenda.lib.php';
40require_once DOL_DOCUMENT_ROOT.'/core/class/events.class.php';
41
42require_once DOL_DOCUMENT_ROOT.'/core/class/html.formcompany.class.php';
43require_once DOL_DOCUMENT_ROOT.'/core/lib/date.lib.php';
44require_once DOL_DOCUMENT_ROOT.'/core/lib/company.lib.php';
45
46require_once DOL_DOCUMENT_ROOT.'/emailcollector/class/emailcollector.class.php';
47
48// Load translation files required by page
49$langs->loadLangs(array("admin", "other"));
50
51$action = GETPOST('action', 'aZ09') ? GETPOST('action', 'aZ09') : 'view'; // The action 'add', 'create', 'edit', 'update', 'view', ...
52$massaction = GETPOST('massaction', 'alpha'); // The bulk action (combo box choice into lists)
53$show_files = GETPOSTINT('show_files'); // Show files area generated by bulk actions ?
54$confirm = GETPOST('confirm', 'alpha'); // Result of a confirmation
55$cancel = GETPOST('cancel', 'alpha'); // We click on a Cancel button
56$toselect = GETPOST('toselect', 'array:int'); // Array of ids of elements selected into a list
57$contextpage = GETPOST('contextpage', 'aZ') ? GETPOST('contextpage', 'aZ') : getDolDefaultContextPage(__FILE__); // To manage different context of search
58$backtopage = GETPOST('backtopage', 'alpha'); // Go back to a dedicated page
59$optioncss = GETPOST('optioncss', 'aZ'); // Option for the css output (always '' except when 'print')
60$mode = GETPOST('mode', 'aZ');
61$groupby = GETPOST('mode', 'aZ09');
62
63$id = GETPOSTINT('id');
64
65// Load variable for pagination
66$limit = GETPOSTINT('limit') ? GETPOSTINT('limit') : $conf->liste_limit;
67$sortfield = GETPOST('sortfield', 'aZ09comma');
68$sortorder = GETPOST('sortorder', 'aZ09comma');
69$page = GETPOSTISSET('pageplusone') ? (GETPOSTINT('pageplusone') - 1) : GETPOSTINT("page");
70if (empty($page) || $page < 0 || GETPOST('button_search', 'alpha') || GETPOST('button_removefilter', 'alpha') || (empty($toselect) && $massaction === '0')) {
71 // If $page is not defined, or '' or -1 or if we click on clear filters or if we select empty mass action
72 $page = 0;
73}
74$offset = $limit * $page;
75$pageprev = $page - 1;
76$pagenext = $page + 1;
77//if (! $sortfield) $sortfield="p.date_fin";
78//if (! $sortorder) $sortorder="DESC";
79
80// Initialize a technical objects
82
83$diroutputmassaction = $conf->emailcollector->dir_output.'/temp/massgeneration/'.$user->id;
84$hookmanager->initHooks(array('emailcollectorlist')); // Note that conf->hooks_modules contains array
85
86// Fetch optionals attributes and labels
87$extrafields->fetch_name_optionals_label($object->table_element);
88
89$search_array_options = $extrafields->getOptionalsFromPost($object->table_element, '', 'search_');
90
91// Default sort order (if not yet defined by previous GETPOST)
92if (!$sortfield) {
93 $sortfield = "t.ref"; // Set here default search field. By default 1st field in definition.
94}
95if (!$sortorder) {
96 $sortorder = "ASC";
97}
98
99// Security check
100$socid = 0;
101if ($user->socid > 0) { // Protection if external user
102 //$socid = $user->socid;
104}
105//restrictedArea($user, 'emailcollector', $id, '');
106
107// Initialize array of search criteria
108$search_all = trim(GETPOST('search_all', 'alphanohtml'));
109$search = array();
110foreach ($object->fields as $key => $val) {
111 if (GETPOST('search_'.$key, 'alpha') !== '') {
112 $search[$key] = GETPOST('search_'.$key, 'alpha');
113 }
114 if (preg_match('/^(date|timestamp|datetime)/', $val['type'])) {
115 $search[$key.'_dtstart'] = dol_mktime(0, 0, 0, GETPOSTINT('search_'.$key.'_dtstartmonth'), GETPOSTINT('search_'.$key.'_dtstartday'), GETPOSTINT('search_'.$key.'_dtstartyear'));
116 $search[$key.'_dtend'] = dol_mktime(23, 59, 59, GETPOSTINT('search_'.$key.'_dtendmonth'), GETPOSTINT('search_'.$key.'_dtendday'), GETPOSTINT('search_'.$key.'_dtendyear'));
117 }
118}
119
120// List of fields to search into when doing a "search in all"
121$fieldstosearchall = array();
122foreach ($object->fields as $key => $val) {
123 if (!empty($val['searchall'])) {
124 $fieldstosearchall['t.'.$key] = $val['label'];
125 }
126}
127
128// Definition of array of fields for columns
129$tableprefix = 't';
130$arrayfields = array();
131foreach ($object->fields as $key => $val) {
132 // If $val['visible']==0, then we never show the field
133 if (!empty($val['visible'])) {
134 $visible = (int) dol_eval((string) $val['visible'], 1);
135 $arrayfields[$tableprefix.'.'.$key] = array(
136 'label' => $val['label'],
137 'checked' => (($visible < 0) ? '0' : '1'),
138 'enabled' => (string) (int) (abs($visible) != 3 && (bool) dol_eval((string) $val['enabled'], 1)),
139 'position' => $val['position'],
140 'help' => isset($val['help']) ? $val['help'] : ''
141 );
142 }
143}
144
145// Extra fields
146include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_array_fields.tpl.php';
147
148$object->fields = dol_sort_array($object->fields, 'position');
149$arrayfields = dol_sort_array($arrayfields, 'position');
150
151$permissiontoread = $user->admin;
152$permissiontoadd = $user->admin;
153$permissiontodelete = $user->admin;
154
155if (!$user->admin) {
157}
158if (!isModEnabled('emailcollector')) {
159 accessforbidden('Module not enabled');
160}
161
162
163
164
165/*
166 * Actions
167 */
168
169if (GETPOST('cancel', 'alpha')) {
170 $action = 'list';
171 $massaction = '';
172}
173if (!GETPOST('confirmmassaction', 'alpha') && $massaction != 'presend' && $massaction != 'confirm_presend') {
174 $massaction = '';
175}
176
177$parameters = array('arrayfields' => &$arrayfields);
178$reshook = $hookmanager->executeHooks('doActions', $parameters, $object, $action); // Note that $action and $object may have been modified by some hooks
179if ($reshook < 0) {
180 setEventMessages($hookmanager->error, $hookmanager->errors, 'errors');
181}
182
183if (empty($reshook)) {
184 // Selection of new fields
185 include DOL_DOCUMENT_ROOT.'/core/actions_changeselectedfields.inc.php';
186
187 // Purge search criteria
188 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
189 foreach ($object->fields as $key => $val) {
190 $search[$key] = '';
191 if (preg_match('/^(date|timestamp|datetime)/', $val['type'])) {
192 $search[$key.'_dtstart'] = '';
193 $search[$key.'_dtend'] = '';
194 }
195 }
196 $search_all = '';
197 $toselect = array();
198 $search_array_options = array();
199 }
200 if (GETPOST('button_removefilter_x', 'alpha') || GETPOST('button_removefilter.x', 'alpha') || GETPOST('button_removefilter', 'alpha')
201 || GETPOST('button_search_x', 'alpha') || GETPOST('button_search.x', 'alpha') || GETPOST('button_search', 'alpha')) {
202 $massaction = ''; // Protection to avoid mass action if we force a new search during a mass action confirmation
203 }
204
205 // Mass actions
206 $objectclass = 'EmailCollector';
207 $objectlabel = 'EmailCollector';
208 $uploaddir = $conf->emailcollector->dir_output;
209
210 global $error;
211 include DOL_DOCUMENT_ROOT.'/core/actions_massactions.inc.php';
212}
213
214
215
216/*
217 * View
218 */
219
220$form = new Form($db);
221
222$now = dol_now();
223
224$help_url = "EN:Module_EMail_Collector|FR:Module_Collecteur_de_courrier_électronique|ES:Module_EMail_Collector";
225$title = $langs->trans('EmailCollectors');
226$morejs = array();
227$morecss = array();
228
229
230// Build and execute select
231// --------------------------------------------------------------------
232$sql = "SELECT";
233$sql .= " ".$object->getFieldList('t');
234// Add fields from extrafields
235if (!empty($extrafields->attributes[$object->table_element]['label'])) {
236 foreach ($extrafields->attributes[$object->table_element]['label'] as $key => $val) {
237 $sql .= ($extrafields->attributes[$object->table_element]['type'][$key] != 'separate' ? ", ef.".$key." as options_".$key : "");
238 }
239}
240// Add fields from hooks
241$parameters = array();
242$reshook = $hookmanager->executeHooks('printFieldListSelect', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
243$sql .= $hookmanager->resPrint;
244$sql = preg_replace('/,\s*$/', '', $sql);
245
246$sqlfields = $sql; // $sql fields to remove for count total
247
248$sql .= " FROM ".MAIN_DB_PREFIX.$object->table_element." as t";
249if (isset($extrafields->attributes[$object->table_element]['label']) && is_array($extrafields->attributes[$object->table_element]['label']) && count($extrafields->attributes[$object->table_element]['label'])) {
250 $sql .= " LEFT JOIN ".MAIN_DB_PREFIX.$object->table_element."_extrafields as ef on (t.rowid = ef.fk_object)";
251}
252if ($object->ismultientitymanaged == 1) {
253 $sql .= " WHERE t.entity IN (".getEntity($object->element).")";
254} else {
255 $sql .= " WHERE 1 = 1";
256}
257foreach ($search as $key => $val) {
258 if (array_key_exists($key, $object->fields)) {
259 if ($key == 'status' && $search[$key] == -1) {
260 continue;
261 }
262 $field_spec = $object->fields[$key];
263 // @phpstan-ignore-next-line PHPStan thinks that $field_spec is never null
264 if ($field_spec === null) {
265 continue;
266 }
267 $mode_search = (($object->isInt($field_spec) || $object->isFloat($field_spec)) ? 1 : 0);
268 if ((strpos($field_spec['type'], 'integer:') === 0) || (strpos($field_spec['type'], 'sellist:') === 0) || !empty($field_spec['arrayofkeyval'])) {
269 if ($search[$key] == '-1' || ($search[$key] === '0' && (empty($field_spec['arrayofkeyval']) || !array_key_exists('0', $field_spec['arrayofkeyval'])))) {
270 $search[$key] = '';
271 }
272 $mode_search = 2;
273 }
274 if ($field_spec['type'] === 'boolean') {
275 $mode_search = 1;
276 if ($search[$key] == '-1') {
277 $search[$key] = '';
278 }
279 }
280 if (empty($field_spec['searchmulti'])) {
281 if (!is_array($search[$key]) && $search[$key] != '') {
282 $sql .= natural_search("t.".$db->escape($key), $search[$key], (($key == 'status') ? 2 : $mode_search));
283 }
284 } else {
285 if (is_array($search[$key]) && !empty($search[$key])) {
286 $sql .= natural_search("t.".$db->escape($key), implode(',', $search[$key]), (($key == 'status') ? 2 : $mode_search));
287 }
288 }
289 } else {
290 if (preg_match('/(_dtstart|_dtend)$/', $key) && $search[$key] != '') {
291 $columnName = preg_replace('/(_dtstart|_dtend)$/', '', $key);
292 if (preg_match('/^(date|timestamp|datetime)/', $object->fields[$columnName]['type'])) {
293 if (preg_match('/_dtstart$/', $key)) {
294 $sql .= " AND t.".$db->sanitize($columnName)." >= '".$db->idate($search[$key])."'";
295 }
296 if (preg_match('/_dtend$/', $key)) {
297 $sql .= " AND t.".$db->sanitize($columnName)." <= '".$db->idate($search[$key])."'";
298 }
299 }
300 }
301 }
302}
303if ($search_all) {
304 $sql .= natural_search(array_keys($fieldstosearchall), $search_all);
305}
306// Add where from extra fields
307include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_search_sql.tpl.php';
308// Add where from hooks
309$parameters = array();
310$reshook = $hookmanager->executeHooks('printFieldListWhere', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
311$sql .= $hookmanager->resPrint;
312
313// Count total nb of records
314$nbtotalofrecords = '';
315if (!getDolGlobalInt('MAIN_DISABLE_FULL_SCANLIST')) {
316 /* The fast and low memory method to get and count full list converts the sql into a sql count */
317 $sqlforcount = preg_replace('/^'.preg_quote($sqlfields, '/').'/', 'SELECT COUNT(*) as nbtotalofrecords', $sql);
318 $sqlforcount = preg_replace('/GROUP BY .*$/', '', $sqlforcount);
319
320 $resql = $db->query($sqlforcount);
321 if ($resql) {
322 $objforcount = $db->fetch_object($resql);
323 $nbtotalofrecords = $objforcount->nbtotalofrecords;
324 } else {
326 }
327
328 if (($page * $limit) > (int) $nbtotalofrecords) { // if total resultset is smaller than the paging size (filtering), goto and load page 0
329 $page = 0;
330 $offset = 0;
331 }
332
333 $db->free($resql);
334}
335// Complete request and execute it with limit
336$sql .= $db->order($sortfield, $sortorder);
337if ($limit) {
338 $sql .= $db->plimit($limit + 1, $offset);
339}
340
341$resql = $db->query($sql);
342if (!$resql) {
344 exit;
345}
346
347$num = $db->num_rows($resql);
348
349// Direct jump if only one record found
350if ($num == 1 && getDolGlobalInt('MAIN_SEARCH_DIRECT_OPEN_IF_ONLY_ONE') && $search_all && !$page) {
351 $obj = $db->fetch_object($resql);
352 $id = $obj->rowid;
353 header("Location: ".DOL_URL_ROOT.'/emailcollector/emailcollector_card.php?id='.$id);
354 exit;
355}
356
357
358// Output page
359// --------------------------------------------------------------------
360
361llxHeader('', $title, $help_url, '', 0, 0, $morejs, $morecss, '', 'bodyforlist mod-user page-emailcollector_list');
362
363
364$linkback = '<a href="'.dolBuildUrl(DOL_URL_ROOT.'/admin/modules.php', ['restore_lastsearch_values' => 1]).'">'.img_picto($langs->trans("BackToModuleList"), 'back', 'class="pictofixedwidth"').'<span class="hideonsmartphone">'.$langs->trans("BackToModuleList").'</span></a>';
365
366print load_fiche_titre($title, $linkback, 'title_setup');
367
368
369$head = array();
370$h = 0;
371$head[$h][0] = DOL_URL_ROOT."/admin/emailcollector_list.php";
372$head[$h][1] = $langs->trans("Setup");
373$head[$h][2] = 'common';
374$h++;
375
376print dol_get_fiche_head($head, 'common', '', -1);
377
378
379
380$arrayofselected = is_array($toselect) ? $toselect : array();
381
382$param = '';
383if (!empty($mode)) {
384 $param .= '&mode='.urlencode($mode);
385}
386if (!empty($contextpage) && $contextpage != getDolDefaultContextPage(__FILE__)) {
387 $param .= '&contextpage='.urlencode($contextpage);
388}
389if ($limit > 0 && $limit != $conf->liste_limit) {
390 $param .= '&limit='.((int) $limit);
391}
392if ($optioncss != '') {
393 $param .= '&optioncss='.urlencode($optioncss);
394}
395if ($groupby != '') {
396 $param .= '&groupby='.urlencode($groupby);
397}
398foreach ($search as $key => $val) {
399 if (is_array($search[$key])) {
400 foreach ($search[$key] as $skey) {
401 if ($skey != '') {
402 $param .= '&search_'.$key.'[]='.urlencode($skey);
403 }
404 }
405 } elseif (preg_match('/(_dtstart|_dtend)$/', $key) && !empty($val)) {
406 $param .= '&search_'.$key.'month='.GETPOSTINT('search_'.$key.'month');
407 $param .= '&search_'.$key.'day='.GETPOSTINT('search_'.$key.'day');
408 $param .= '&search_'.$key.'year='.GETPOSTINT('search_'.$key.'year');
409 } elseif ($search[$key] != '') {
410 $param .= '&search_'.$key.'='.urlencode($search[$key]);
411 }
412}
413// Add $param from extra fields
414include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_search_param.tpl.php';
415// Add $param from hooks
416$parameters = array('param' => &$param);
417$reshook = $hookmanager->executeHooks('printFieldListSearchParam', $parameters, $object); // Note that $action and $object may have been modified by hook
418$param .= $hookmanager->resPrint;
419
420// List of mass actions available
421$arrayofmassactions = array(
422 //'presend'=>img_picto('', 'email', 'class="pictofixedwidth"').$langs->trans("SendByMail"),
423 //'builddoc'=>img_picto('', 'pdf', 'class="pictofixedwidth"').$langs->trans("PDFMerge"),
424);
425if (!empty($permissiontodelete)) {
426 $arrayofmassactions['predelete'] = img_picto('', 'delete', 'class="pictofixedwidth"').$langs->trans("Delete");
427}
428if (GETPOSTINT('nomassaction') || in_array($massaction, array('presend', 'predelete'))) {
429 $arrayofmassactions = array();
430}
431$massactionbutton = $form->selectMassAction('', $arrayofmassactions);
432
433print '<form method="POST" id="searchFormList" action="'.$_SERVER["PHP_SELF"].'">'."\n";
434if ($optioncss != '') {
435 print '<input type="hidden" name="optioncss" value="'.$optioncss.'">';
436}
437print '<input type="hidden" name="token" value="'.newToken().'">';
438print '<input type="hidden" name="formfilteraction" id="formfilteraction" value="list">';
439print '<input type="hidden" name="action" value="list">';
440print '<input type="hidden" name="sortfield" value="'.$sortfield.'">';
441print '<input type="hidden" name="sortorder" value="'.$sortorder.'">';
442print '<input type="hidden" name="page" value="'.$page.'">';
443print '<input type="hidden" name="contextpage" value="'.$contextpage.'">';
444print '<input type="hidden" name="page_y" value="">';
445print '<input type="hidden" name="mode" value="'.$mode.'">';
446
447$newcardbutton = '';
448$newcardbutton .= dolGetButtonTitle($langs->trans('New'), '', 'fa fa-plus-circle', 'emailcollector_card.php?action=create&backtopage='.urlencode($_SERVER['PHP_SELF']), '', $permissiontoadd);
449
450print_barre_liste($title, $page, $_SERVER["PHP_SELF"], $param, $sortfield, $sortorder, $massactionbutton, $num, $nbtotalofrecords, 'email', 0, $newcardbutton, '', $limit, 0, 0, 1);
451
452// Add code for pre mass action (confirmation or email presend form)
453/*$topicmail="";
454$modelmail="";
455$objecttmp=new EmailCollector($db);
456$trackid='xxxx'.$object->id;*/
457include DOL_DOCUMENT_ROOT.'/core/tpl/massactions_pre.tpl.php';
458
459$moreforfilter = '';
460/*$moreforfilter.='<div class="divsearchfield">';
461$moreforfilter.= $langs->trans('MyFilter') . ': <input type="text" name="search_myfield" value="'.dol_escape_htmltag($search_myfield).'">';
462$moreforfilter.= '</div>';*/
463
464$parameters = array();
465$reshook = $hookmanager->executeHooks('printFieldPreListTitle', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
466if (empty($reshook)) {
467 $moreforfilter .= $hookmanager->resPrint;
468} else {
469 $moreforfilter = $hookmanager->resPrint;
470}
471$parameters = array(
472 'arrayfields' => &$arrayfields,
473);
474
475if (!empty($moreforfilter)) {
476 print '<div class="liste_titre liste_titre_bydiv centpercent">';
477 print $moreforfilter;
478 print '</div>';
479}
480
481$varpage = empty($contextpage) ? $_SERVER["PHP_SELF"] : $contextpage;
482$htmlofselectarray = $form->multiSelectArrayWithCheckbox('selectedfields', $arrayfields, $varpage, $conf->main_checkbox_left_column); // This also change content of $arrayfields with user setup
483$selectedfields = (($mode != 'kanban' && $mode != 'kanbangroupby') ? $htmlofselectarray : '');
484$selectedfields .= (count($arrayofmassactions) ? $form->showCheckAddButtons('checkforselect', 1) : '');
485
486print '<div class="div-table-responsive">'; // You can use div-table-responsive-no-min if you don't need reserved height for your table
487print '<table class="tagtable nobottomiftotal noborder liste'.($moreforfilter ? " listwithfilterbefore" : "").'">'."\n";
488
489
490// Fields title search
491// --------------------------------------------------------------------
492print '<tr class="liste_titre_filter">';
493// Action column
494if ($conf->main_checkbox_left_column) {
495 print '<td class="liste_titre center maxwidthsearch">';
496 $searchpicto = $form->showFilterButtons('left');
497 print $searchpicto;
498 print '</td>';
499}
500foreach ($object->fields as $key => $val) {
501 $cssforfield = (empty($val['csslist']) ? (empty($val['css']) ? '' : $val['css']) : $val['csslist']);
502 if ($key == 'status') {
503 $cssforfield .= ($cssforfield ? ' ' : '').'center';
504 } elseif (in_array($val['type'], array('date', 'datetime', 'timestamp'))) {
505 $cssforfield .= ($cssforfield ? ' ' : '').'center';
506 } elseif (in_array($val['type'], array('timestamp'))) {
507 $cssforfield .= ($cssforfield ? ' ' : '').'nowrap';
508 } elseif (in_array($val['type'], array('double(24,8)', 'double(6,3)', 'integer', 'real', 'price')) && !in_array($key, array('id', 'rowid', 'ref', 'status')) && $val['label'] != 'TechnicalID' && empty($val['arrayofkeyval'])) {
509 $cssforfield .= ($cssforfield ? ' ' : '').'right';
510 }
511 if (!empty($arrayfields['t.'.$key]['checked'])) {
512 print '<td class="liste_titre'.($cssforfield ? ' '.$cssforfield : '').($key == 'status' ? ' parentonrightofpage' : '').'">';
513 if (!empty($val['arrayofkeyval']) && is_array($val['arrayofkeyval'])) {
514 if (empty($val['searchmulti'])) {
515 print $form->selectarray('search_'.$key, $val['arrayofkeyval'], (isset($search[$key]) ? $search[$key] : ''), 1, 0, 0, '', 1, 0, 0, '', 'maxwidth100'.($key == 'status' ? ' search_status width100 onrightofpage' : ''), 1);
516 } else {
517 print $form->multiselectarray('search_'.$key, $val['arrayofkeyval'], (isset($search[$key]) ? $search[$key] : array()), 0, 0, 'maxwidth100'.($key == 'status' ? ' search_status width100 onrightofpage' : ''), 1);
518 }
519 } elseif ((strpos($val['type'], 'integer:') === 0) || (strpos($val['type'], 'sellist:') === 0)) {
520 print $object->showInputField($val, $key, (isset($search[$key]) ? $search[$key] : ''), '', '', 'search_', $cssforfield.' maxwidth125', 1);
521 } elseif (preg_match('/^(date|timestamp|datetime)/', $val['type'])) {
522 print '<div class="nowrap">';
523 print $form->selectDate($search[$key.'_dtstart'] ? $search[$key.'_dtstart'] : '', "search_".$key."_dtstart", 0, 0, 1, '', 1, 0, 0, '', '', '', '', 1, '', $langs->trans('From'));
524 print '</div>';
525 print '<div class="nowrap">';
526 print $form->selectDate($search[$key.'_dtend'] ? $search[$key.'_dtend'] : '', "search_".$key."_dtend", 0, 0, 1, '', 1, 0, 0, '', '', '', '', 1, '', $langs->trans('to'));
527 print '</div>';
528 } elseif ($key == 'lang') {
529 require_once DOL_DOCUMENT_ROOT.'/core/class/html.formadmin.class.php';
530 $formadmin = new FormAdmin($db);
531 print $formadmin->select_language((isset($search[$key]) ? $search[$key] : ''), 'search_lang', 0, array(), 1, 0, 0, 'minwidth100imp maxwidth125', 2);
532 } elseif ($val['type'] === 'boolean') {
533 print $form->selectyesno('search_' . $key, $search[$key] ?? '', 1, false, 1);
534 } else {
535 print '<input type="text" class="flat maxwidth'.(in_array($val['type'], array('integer', 'price')) ? '50' : '75').'" name="search_'.$key.'" value="'.dol_escape_htmltag(isset($search[$key]) ? $search[$key] : '').'">';
536 }
537 print '</td>';
538 }
539}
540// Extra fields
541include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_search_input.tpl.php';
542
543// Fields from hook
544$parameters = array('arrayfields' => $arrayfields);
545$reshook = $hookmanager->executeHooks('printFieldListOption', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
546print $hookmanager->resPrint;
547// Action column
548if (!$conf->main_checkbox_left_column) {
549 print '<td class="liste_titre center maxwidthsearch">';
550 $searchpicto = $form->showFilterButtons();
551 print $searchpicto;
552 print '</td>';
553}
554print '</tr>'."\n";
555
556$totalarray = array();
557$totalarray['nbfield'] = 0;
558
559// Fields title label
560// --------------------------------------------------------------------
561print '<tr class="liste_titre">';
562// Action column
563if ($conf->main_checkbox_left_column) {
564 print getTitleFieldOfList($selectedfields, 0, $_SERVER["PHP_SELF"], '', '', '', '', $sortfield, $sortorder, 'center maxwidthsearch ')."\n";
565 $totalarray['nbfield']++;
566}
567foreach ($object->fields as $key => $val) {
568 $cssforfield = (empty($val['csslist']) ? (empty($val['css']) ? '' : $val['css']) : $val['csslist']);
569 if ($key == 'status') {
570 $cssforfield .= ($cssforfield ? ' ' : '').'center';
571 } elseif (in_array($val['type'], array('date', 'datetime', 'timestamp'))) {
572 $cssforfield .= ($cssforfield ? ' ' : '').'center';
573 } elseif (in_array($val['type'], array('timestamp'))) {
574 $cssforfield .= ($cssforfield ? ' ' : '').'nowrap';
575 } elseif (in_array($val['type'], array('double(24,8)', 'double(6,3)', 'integer', 'real', 'price')) && !in_array($key, array('id', 'rowid', 'ref', 'status')) && $val['label'] != 'TechnicalID' && empty($val['arrayofkeyval'])) {
576 $cssforfield .= ($cssforfield ? ' ' : '').'right';
577 }
578 $cssforfield = preg_replace('/small\s*/', '', $cssforfield); // the 'small' css must not be used for the title label
579 if (!empty($arrayfields['t.'.$key]['checked'])) {
580 print getTitleFieldOfList($arrayfields['t.'.$key]['label'], 0, $_SERVER['PHP_SELF'], 't.'.$key, '', $param, ($cssforfield ? 'class="'.$cssforfield.'"' : ''), $sortfield, $sortorder, ($cssforfield ? $cssforfield.' ' : ''), 0, (empty($val['helplist']) ? '' : $val['helplist']))."\n";
581 $totalarray['nbfield']++;
582 }
583}
584// Extra fields
585include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_search_title.tpl.php';
586// Hook fields
587$parameters = array('arrayfields' => $arrayfields, 'param' => $param, 'sortfield' => $sortfield, 'sortorder' => $sortorder, 'totalarray' => &$totalarray);
588$reshook = $hookmanager->executeHooks('printFieldListTitle', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
589print $hookmanager->resPrint;
590// Action column
591if (!$conf->main_checkbox_left_column) {
592 print getTitleFieldOfList(($mode != 'kanban' ? $selectedfields : ''), 0, $_SERVER["PHP_SELF"], '', '', '', '', $sortfield, $sortorder, 'center maxwidthsearch ')."\n";
593 $totalarray['nbfield']++;
594}
595print '</tr>'."\n";
596
597
598// Detect if we need a fetch on each output line
599$needToFetchEachLine = 0;
600if (isset($extrafields->attributes[$object->table_element]['computed']) && is_array($extrafields->attributes[$object->table_element]['computed']) && count($extrafields->attributes[$object->table_element]['computed']) > 0) {
601 foreach ($extrafields->attributes[$object->table_element]['computed'] as $key => $val) {
602 if (!is_null($val) && preg_match('/\$object/', $val)) {
603 $needToFetchEachLine++; // There is at least one compute field that use $object
604 }
605 }
606}
607
608
609// Loop on record
610// --------------------------------------------------------------------
611$i = 0;
612$savnbfield = $totalarray['nbfield'];
613$totalarray = array();
614$totalarray['nbfield'] = 0;
615$imaxinloop = ($limit ? min($num, $limit) : $num);
616while ($i < $imaxinloop) {
617 $obj = $db->fetch_object($resql);
618 if (empty($obj)) {
619 break; // Should not happen
620 }
621
622 // Store properties in $object
623 $object->setVarsFromFetchObj($obj);
624
625 if ($mode == 'kanban' || $mode == 'kanbangroupby') {
626 if ($i == 0) {
627 print '<tr class="trkanban"><td colspan="'.$savnbfield.'">';
628 print '<div class="box-flex-container kanban">';
629 }
630 // Output Kanban
631 $selected = -1;
632 if ($massactionbutton || $massaction) { // If we are in select mode (massactionbutton defined) or if we have already selected and sent an action ($massaction) defined
633 $selected = 0;
634 if (in_array($object->id, $arrayofselected)) {
635 $selected = 1;
636 }
637 }
638 print $object->getKanbanView('', array('selected' => $selected));
639 if ($i == ($imaxinloop - 1)) {
640 print '</div>';
641 print '</td></tr>';
642 }
643 } else {
644 // Show line of result
645 $j = 0;
646 print '<tr data-rowid="'.$object->id.'" class="oddeven">';
647 // Action column
648 if ($conf->main_checkbox_left_column) {
649 print '<td class="nowrap center">';
650 if ($massactionbutton || $massaction) { // If we are in select mode (massactionbutton defined) or if we have already selected and sent an action ($massaction) defined
651 $selected = 0;
652 if (in_array($object->id, $arrayofselected)) {
653 $selected = 1;
654 }
655 print '<input id="cb'.$object->id.'" class="flat checkforselect" type="checkbox" name="toselect[]" value="'.$object->id.'"'.($selected ? ' checked="checked"' : '').'>';
656 }
657 print '</td>';
658 if (!$i) {
659 $totalarray['nbfield']++;
660 }
661 }
662 // Fields
663 foreach ($object->fields as $key => $val) {
664 $cssforfield = (empty($val['csslist']) ? (empty($val['css']) ? '' : $val['css']) : $val['csslist']);
665 if (in_array($val['type'], array('date', 'datetime', 'timestamp'))) {
666 $cssforfield .= ($cssforfield ? ' ' : '').'center';
667 } elseif ($key == 'status') {
668 $cssforfield .= ($cssforfield ? ' ' : '').'center';
669 }
670
671 if (in_array($val['type'], array('timestamp'))) {
672 $cssforfield .= ($cssforfield ? ' ' : '').'nowraponall';
673 } elseif ($key == 'ref') {
674 $cssforfield .= ($cssforfield ? ' ' : '').'nowraponall';
675 }
676
677 if (in_array($val['type'], array('double(24,8)', 'double(6,3)', 'integer', 'real', 'price')) && !in_array($key, array('id', 'rowid', 'ref', 'status')) && empty($val['arrayofkeyval'])) {
678 $cssforfield .= ($cssforfield ? ' ' : '').'right';
679 }
680 //if (in_array($key, array('fk_soc', 'fk_user', 'fk_warehouse'))) $cssforfield = 'tdoverflowmax100';
681
682 if (!empty($arrayfields['t.'.$key]['checked'])) {
683 print '<td'.($cssforfield ? ' class="'.$cssforfield.((preg_match('/tdoverflow/', $cssforfield) && !in_array($val['type'], array('ip', 'url')) && !is_numeric($object->$key)) ? ' classfortooltip' : '').'"' : '');
684 if (preg_match('/tdoverflow/', $cssforfield) && !in_array($val['type'], array('ip', 'url')) && !is_numeric($object->$key) && !in_array($key, array('ref'))) {
685 print ' title="'.dol_escape_htmltag((string) $object->$key).'"';
686 }
687 print '>';
688 if ($key == 'status') {
689 print $object->getLibStatut(5);
690 } elseif ($key == 'rowid') {
691 print $object->showOutputField($val, $key, (string) $object->id, '');
692 } else {
693 if ($val['type'] == 'html' || $key == 'lastresult') {
694 print '<div class="small lineheightsmall twolinesmax-normallineheight">';
695 }
696 print $object->showOutputField($val, $key, (string) $object->$key, '');
697 if ($val['type'] == 'html' || $key == 'lastresult') {
698 print '</div>';
699 }
700 }
701 print '</td>';
702 if (!$i) {
703 $totalarray['nbfield']++;
704 }
705 if (!empty($val['isameasure']) && $val['isameasure'] == 1) {
706 if (!$i) {
707 $totalarray['pos'][$totalarray['nbfield']] = 't.'.$key;
708 }
709 if (!isset($totalarray['val'])) {
710 $totalarray['val'] = array();
711 }
712 if (!isset($totalarray['val']['t.'.$key])) {
713 $totalarray['val']['t.'.$key] = 0;
714 }
715 $totalarray['val']['t.'.$key] += $object->$key;
716 }
717 }
718 }
719 // Extra fields
720 include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_list_print_fields.tpl.php';
721 // Fields from hook
722 $parameters = array('arrayfields' => $arrayfields, 'object' => $object, 'obj' => $obj, 'i' => $i, 'totalarray' => &$totalarray);
723 $reshook = $hookmanager->executeHooks('printFieldListValue', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
724 print $hookmanager->resPrint;
725 // Action column
726 if (!$conf->main_checkbox_left_column) {
727 print '<td class="nowrap center">';
728 if ($massactionbutton || $massaction) { // If we are in select mode (massactionbutton defined) or if we have already selected and sent an action ($massaction) defined
729 $selected = 0;
730 if (in_array($object->id, $arrayofselected)) {
731 $selected = 1;
732 }
733 print '<input id="cb'.$object->id.'" class="flat checkforselect" type="checkbox" name="toselect[]" value="'.$object->id.'"'.($selected ? ' checked="checked"' : '').'>';
734 }
735 print '</td>';
736 if (!$i) {
737 $totalarray['nbfield']++;
738 }
739 }
740
741 print '</tr>'."\n";
742 }
743
744 $i++;
745}
746
747// Show total line
748include DOL_DOCUMENT_ROOT.'/core/tpl/list_print_total.tpl.php';
749
750
751// If no record found
752if ($num == 0) {
753 $colspan = 1;
754 foreach ($arrayfields as $key => $val) {
755 if (!empty($val['checked'])) {
756 $colspan++;
757 }
758 }
759 print '<tr><td colspan="'.$colspan.'"><span class="opacitymedium">'.$langs->trans("NoRecordFound").'</span></td></tr>';
760}
761
762
763$db->free($resql);
764
765$parameters = array('arrayfields' => $arrayfields, 'sql' => $sql);
766$reshook = $hookmanager->executeHooks('printFieldListFooter', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
767print $hookmanager->resPrint;
768
769print '</table>'."\n";
770print '</div>'."\n";
771
772print load_fiche_titre($langs->trans("Other"), '', '');
773
774
775print '<div class="div-table-responsive-no-min">'; // You can use div-table-responsive-no-min if you don't need reserved height for your table
776print '<table class="noborder centpercent">';
777
778print '<tr class="liste_titre">';
779print '<td>'.$langs->trans("Parameter").'</td>';
780print '<td></td>';
781print "</tr>\n";
782
783// MAIN_IMAP_USE_PHPIMAP: Enable use of the PHP Imap library
784print '<tr class="oddeven"><td>';
785//print $form->textwithpicto($langs->trans("MAIN_IMAP_USE_PHPIMAP"), $langs->transnoentitiesnoconv("MAIN_IMAP_USE_PHPIMAPDesc"));
786print $langs->trans("MAIN_IMAP_USE_PHPIMAP");
787print '</td>';
788print '<td class="left">';
789if ($conf->use_javascript_ajax) {
790 print ajax_constantonoff('MAIN_IMAP_USE_PHPIMAP');
791} else {
792 $arrval = array('0' => $langs->trans("No"), '1' => $langs->trans("Yes"));
793 print $form->selectarray("MAIN_IMAP_USE_PHPIMAP", $arrval, getDolGlobalString("MAIN_IMAP_USE_PHPIMAP"));
794}
795print '</td>';
796print '</tr>';
797
798// MAIN_EMAILCOLLECTOR_MAIL_WITHOUT_HEADER: Hide e-mail headers from collected messages
799print '<tr class="oddeven"><td>'.$form->textwithpicto($langs->trans("EmailCollectorHideMailHeaders"), $langs->transnoentitiesnoconv("EmailCollectorHideMailHeadersHelp")).'</td>';
800print '<td class="left">';
801if ($conf->use_javascript_ajax) {
802 print ajax_constantonoff('MAIN_EMAILCOLLECTOR_MAIL_WITHOUT_HEADER');
803} else {
804 $arrval = array('0' => $langs->trans("No"), '1' => $langs->trans("Yes"));
805 print $form->selectarray("MAIN_EMAILCOLLECTOR_MAIL_WITHOUT_HEADER", $arrval, getDolGlobalString('TICKET_AUTO_READ_WHEN_CREATED_FROM_BACKEND'));
806}
807print '</td>';
808print '</tr>';
809
810// EMAILCOLLECTOR_ISNOTANSWER_USE_REFERENCES: Consider generic References as answer for "isnotanswer" filter.
811print '<tr class="oddeven"><td>'.$form->textwithpicto($langs->trans("EmailCollectorIsNotAnswerUseReferences"), $langs->transnoentitiesnoconv("EmailCollectorIsNotAnswerUseReferencesHelp")).'</td>';
812print '<td class="left">';
813if ($conf->use_javascript_ajax) {
814 print ajax_constantonoff('EMAILCOLLECTOR_ISNOTANSWER_USE_REFERENCES');
815} else {
816 $arrval = array('0' => $langs->trans("No"), '1' => $langs->trans("Yes"));
817 print $form->selectarray("EMAILCOLLECTOR_ISNOTANSWER_USE_REFERENCES", $arrval, getDolGlobalInt('EMAILCOLLECTOR_ISNOTANSWER_USE_REFERENCES', 0));
818}
819print '</td>';
820print '</tr>';
821
822print '</table>';
823print '</div>';
824
825print '<br>';
826
827print '</form>'."\n";
828
829if (in_array('builddoc', array_keys($arrayofmassactions)) && ($nbtotalofrecords === '' || $nbtotalofrecords)) {
830 $hidegeneratedfilelistifempty = 1;
831 if ($massaction == 'builddoc' || $action == 'remove_file' || $show_files) {
832 $hidegeneratedfilelistifempty = 0;
833 }
834
835 require_once DOL_DOCUMENT_ROOT.'/core/class/html.formfile.class.php';
836 $formfile = new FormFile($db);
837
838 // Show list of available documents
839 $urlsource = $_SERVER['PHP_SELF'].'?sortfield='.$sortfield.'&sortorder='.$sortorder;
840 $urlsource .= str_replace('&amp;', '&', $param);
841
842 $filedir = $diroutputmassaction;
843 $genallowed = $permissiontoread;
844 $delallowed = $permissiontoadd;
845
846 print $formfile->showdocuments('massfilesarea_emailcollector', '', $filedir, $urlsource, 0, $delallowed, '', 1, 1, 0, 48, 1, $param, $title, '', '', '', null, $hidegeneratedfilelistifempty);
847}
848
849
851
852
853// End of page
854llxFooter();
855$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 list.php:497
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 EmailCollector.
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.
if(!isModEnabled('ai')||!getDolGlobalString('AI_ASSISTANT_ENABLED')) global $conf
The main.inc.php has been included so the following variable are now defined:
if(!isModEnabled('ai')||!getDolGlobalString('AI_ASSISTANT_ENABLED')) global $db
API class for accounts.
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.
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.
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.
getDolDefaultContextPage($s)
Return the default context page string.
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...
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.
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...
print $langs trans("Show") . '< td style="' . $timeColor . '" align="center"> s</td > badge status0 badge status4 badge status3 Error badge status8< td align="center">< span class="badge ' . $badge . '"></span ></td >< td align="center">< a href="#" class="button button-small" onclick="openLogModal(this)" data-req="' . dol_escape_htmltag($reqSafe) . '" data-res="' . dol_escape_htmltag($resSafe) . '" data-err="' . dol_escape_htmltag($errSafe) . '">< span class="fa fa-search-plus"></span ></a ></td ></tr >< tr >< td colspan="' . $colspan . '" class="opacitymedium"></td ></tr ></table ></div ></form > logModal none logModal none s a JSON string
buildzip.php
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.