25 require
'../main.inc.php';
26 require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formcompany.class.php';
27 require_once DOL_DOCUMENT_ROOT.
'/core/lib/admin.lib.php';
28 require_once DOL_DOCUMENT_ROOT.
'/core/lib/date.lib.php';
29 require_once DOL_DOCUMENT_ROOT.
'/core/lib/company.lib.php';
30 require_once DOL_DOCUMENT_ROOT.
'/core/class/emailsenderprofile.class.php';
33 $langs->loadLangs(array(
"errors",
"admin",
"mails",
"languages"));
35 $action =
GETPOST(
'action',
'aZ09') ?
GETPOST(
'action',
'aZ09') :
'view';
36 $massaction =
GETPOST(
'massaction',
'alpha');
37 $show_files =
GETPOST(
'show_files',
'int');
38 $confirm =
GETPOST(
'confirm',
'alpha');
39 $cancel =
GETPOST(
'cancel',
'alpha');
40 $toselect =
GETPOST(
'toselect',
'array');
41 $contextpage =
GETPOST(
'contextpage',
'aZ') ?
GETPOST(
'contextpage',
'aZ') :
'emailsenderprofilelist';
42 $backtopage =
GETPOST(
'backtopage',
'alpha');
43 $optioncss =
GETPOST(
'optioncss',
'aZ');
46 $rowid =
GETPOST(
'rowid',
'alpha');
49 $limit =
GETPOST(
'limit',
'int') ?
GETPOST(
'limit',
'int') : $conf->liste_limit;
50 $sortfield =
GETPOST(
'sortfield',
'aZ09comma');
51 $sortorder =
GETPOST(
'sortorder',
'aZ09comma');
53 if (empty($page) || $page == -1 ||
GETPOST(
'button_search',
'alpha') ||
GETPOST(
'button_removefilter',
'alpha') || (empty($toselect) && $massaction ===
'0')) {
56 $offset = $limit * $page;
57 $pageprev = $page - 1;
58 $pagenext = $page + 1;
63 $diroutputmassaction = $conf->admin->dir_output.
'/temp/massgeneration/'.$user->id;
64 $hookmanager->initHooks(array(
'emailsenderprofilelist'));
67 $extrafields->fetch_name_optionals_label($object->table_element);
69 $search_array_options = $extrafields->getOptionalsFromPost($object->table_element,
'',
'search_');
73 $sortfield =
"t.".key($object->fields);
80 $search_all =
GETPOST(
"search_all",
'alpha');
82 foreach ($object->fields as $key => $val) {
83 if (
GETPOST(
'search_'.$key,
'alpha')) {
84 $search[$key] =
GETPOST(
'search_'.$key,
'alpha');
89 $fieldstosearchall = array();
90 foreach ($object->fields as $key => $val) {
91 if (!empty($val[
'searchall'])) {
92 $fieldstosearchall[
't.'.$key] = $val[
'label'];
97 $arrayfields = array();
98 foreach ($object->fields as $key => $val) {
100 if (!empty($val[
'visible'])) {
101 $arrayfields[
't.'.$key] = array(
'label'=>$val[
'label'],
'checked'=>(($val[
'visible'] < 0) ? 0 : 1),
'enabled'=>($val[
'enabled'] && ($val[
'visible'] != 3)),
'position'=>$val[
'position']);
105 if (!empty($extrafields->attributes[$object->table_element][
'label']) && is_array($extrafields->attributes[$object->table_element][
'label']) && count($extrafields->attributes[$object->table_element][
'label']) > 0) {
106 foreach ($extrafields->attributes[$object->table_element][
'label'] as $key => $val) {
107 if (!empty($extrafields->attributes[$object->table_element][
'list'][$key])) {
108 $arrayfields[
"ef.".$key] = array(
109 'label'=>$extrafields->attributes[$object->table_element][
'label'][$key],
110 'checked'=>(($extrafields->attributes[$object->table_element][
'list'][$key] < 0) ? 0 : 1),
111 'position'=>$extrafields->attributes[$object->table_element][
'pos'][$key],
112 'enabled'=>(abs($extrafields->attributes[$object->table_element][
'list'][$key]) != 3 && $extrafields->attributes[$object->table_element][
'perms'][$key])
120 $permissiontoread = $user->admin;
121 $permissiontoadd = $user->admin;
122 $permissiontodelete = $user->admin;
130 if ($user->socid > 0) {
136 if ($object->id > 0 && $object->private != $user->id) {
146 if (
GETPOST(
'cancel',
'alpha')) {
147 $action =
'list'; $massaction =
'';
149 if (!
GETPOST(
'confirmmassaction',
'alpha') && $massaction !=
'presend' && $massaction !=
'confirm_presend') {
153 $parameters = array();
154 $reshook = $hookmanager->executeHooks(
'doActions', $parameters, $object, $action);
159 if (empty($reshook)) {
161 $backurlforlist = $_SERVER[
"PHP_SELF"].
'?action=list';
162 include DOL_DOCUMENT_ROOT.
'/core/actions_addupdatedelete.inc.php';
165 include DOL_DOCUMENT_ROOT.
'/core/actions_changeselectedfields.inc.php';
168 if (
GETPOST(
'button_removefilter_x',
'alpha') ||
GETPOST(
'button_removefilter.x',
'alpha') ||
GETPOST(
'button_removefilter',
'alpha')) {
169 foreach ($object->fields as $key => $val) {
173 $search_array_options = array();
175 if (
GETPOST(
'button_removefilter_x',
'alpha') ||
GETPOST(
'button_removefilter.x',
'alpha') ||
GETPOST(
'button_removefilter',
'alpha')
176 ||
GETPOST(
'button_search_x',
'alpha') ||
GETPOST(
'button_search.x',
'alpha') ||
GETPOST(
'button_search',
'alpha')) {
181 $objectclass =
'EmailSenderProfile';
182 $objectlabel =
'EmailSenderProfile';
183 $uploaddir = $conf->admin->dir_output.
'/senderprofiles';
184 include DOL_DOCUMENT_ROOT.
'/core/actions_massactions.inc.php';
186 if ($action ==
'delete') {
187 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.
"c_email_senderprofile WHERE rowid = ".
GETPOST(
'id',
'int');
188 $resql = $db->query($sql);
192 setEventMessages($langs->trans(
"Error").
' '.$db->lasterror(),
null,
'errors');
209 $title = $langs->trans(
"EMailsSetup");
214 $titlepicto =
'title_setup';
222 print
'<span class="opacitymedium">'.$langs->trans(
"EMailsSenderProfileDesc").
"</span><br>\n";
228 foreach ($object->fields as $key => $val) {
229 $sql .=
"t.".$key.
", ";
232 if (!empty($extrafields->attributes[$object->table_element][
'label'])) {
233 foreach ($extrafields->attributes[$object->table_element][
'label'] as $key => $val) {
234 $sql .= ($extrafields->attributes[$object->table_element][
'type'][$key] !=
'separate' ?
"ef.".$key.
" as options_".$key.
', ' :
'');
238 $parameters = array();
239 $reshook = $hookmanager->executeHooks(
'printFieldListSelect', $parameters, $object);
240 $sql .= preg_replace(
'/^,/',
'', $hookmanager->resPrint);
241 $sql = preg_replace(
'/,\s*$/',
'', $sql);
242 $sql .=
" FROM ".MAIN_DB_PREFIX.$object->table_element.
" as t";
243 if (!empty($extrafields->attributes[$object->table_element][
'label']) && is_array($extrafields->attributes[$object->table_element][
'label']) && count($extrafields->attributes[$object->table_element][
'label'])) {
244 $sql .=
" LEFT JOIN ".MAIN_DB_PREFIX.$object->table_element.
"_extrafields as ef on (t.rowid = ef.fk_object)";
246 if ($object->ismultientitymanaged == 1) {
247 $sql .=
" WHERE t.entity IN (".getEntity($object->element).
")";
249 $sql .=
" WHERE 1 = 1";
251 foreach ($search as $key => $val) {
252 if ($key ==
'status' && $search[$key] == -1) {
255 $mode_search = (($object->isInt($object->fields[$key]) || $object->isFloat($object->fields[$key])) ? 1 : 0);
256 if (strpos($object->fields[$key][
'type'],
'integer:') === 0 || $key ==
'active') {
257 if ($search[$key] ==
'-1') {
262 if ($search[$key] !=
'') {
263 $sql .=
natural_search($key, $search[$key], (($key ==
'status') ? 2 : $mode_search));
267 $sql .=
natural_search(array_keys($fieldstosearchall), $search_all);
270 if (empty($user->admin)) {
271 $sql .=
" AND private = ".((int) $user->id);
275 include DOL_DOCUMENT_ROOT.
'/core/tpl/extrafields_list_search_sql.tpl.php';
277 $parameters = array();
278 $reshook = $hookmanager->executeHooks(
'printFieldListWhere', $parameters, $object);
279 $sql .= $hookmanager->resPrint;
298 $sql .= $db->order($sortfield, $sortorder);
301 $nbtotalofrecords =
'';
302 if (empty($conf->global->MAIN_DISABLE_FULL_SCANLIST)) {
303 $resql = $db->query($sql);
304 $nbtotalofrecords = $db->num_rows(
$resql);
305 if (($page * $limit) > $nbtotalofrecords) {
311 if (is_numeric($nbtotalofrecords) && ($limit > $nbtotalofrecords || empty($limit))) {
312 $num = $nbtotalofrecords;
315 $sql .= $db->plimit($limit + 1, $offset);
318 $resql = $db->query($sql);
324 $num = $db->num_rows(
$resql);
331 $arrayofselected = is_array($toselect) ? $toselect : array();
334 if (!empty($contextpage) && $contextpage != $_SERVER[
"PHP_SELF"]) {
335 $param .=
'&contextpage='.urlencode($contextpage);
337 if ($limit > 0 && $limit != $conf->liste_limit) {
338 $param .=
'&limit='.urlencode($limit);
340 foreach ($search as $key => $val) {
341 if (is_array($search[$key]) && count($search[$key])) {
342 foreach ($search[$key] as $skey) {
343 $param .=
'&search_'.$key.
'[]='.urlencode($skey);
346 $param .=
'&search_'.$key.
'='.urlencode($search[$key]);
349 if ($optioncss !=
'') {
350 $param .=
'&optioncss='.urlencode($optioncss);
353 include DOL_DOCUMENT_ROOT.
'/core/tpl/extrafields_list_search_param.tpl.php';
356 $arrayofmassactions = array(
362 $massactionbutton =
$form->selectMassAction(
'', $arrayofmassactions);
364 print
'<form method="POST" id="searchFormList" action="'.$_SERVER[
"PHP_SELF"].
'">';
365 if ($optioncss !=
'') {
366 print
'<input type="hidden" name="optioncss" value="'.$optioncss.
'">';
368 print
'<input type="hidden" name="token" value="'.newToken().
'">';
369 print
'<input type="hidden" name="formfilteraction" id="formfilteraction" value="list">';
370 print
'<input type="hidden" name="action" value="'.($action ==
'create' ?
'add' : ($action ==
'edit' ?
'update' :
'list')).
'">';
371 print
'<input type="hidden" name="sortfield" value="'.$sortfield.
'">';
372 print
'<input type="hidden" name="sortorder" value="'.$sortorder.
'">';
373 print
'<input type="hidden" name="page" value="'.$page.
'">';
374 print
'<input type="hidden" name="id" value="'.$id.
'">';
375 print
'<input type="hidden" name="contextpage" value="'.$contextpage.
'">';
378 if ($action !=
'create') {
379 $newcardbutton =
dolGetButtonTitle($langs->trans(
'New'),
'',
'fa fa-plus-circle', $_SERVER[
'PHP_SELF'].
'?action=create',
'', $permissiontoadd);
381 if ($action ==
'edit') {
382 print
'<table class="border centpercent tableforfield">';
383 print
'<tr><td class="fieldrequired">'.$langs->trans(
"Label").
'</td><td><input type="text" name="label" value="'.(
GETPOSTISSET(
'label') ?
GETPOST(
'label',
'alphanohtml') : $object->label).
'"></td></tr>';
384 print
'<tr><td>'.$langs->trans(
"Email").
'</td><td><input type="text" name="email" value="'.(
GETPOSTISSET(
'email') ?
GETPOST(
'email',
'alphanohtml') : $object->email).
'"></td></tr>';
385 print
'<tr><td>'.$langs->trans(
"Signature").
'</td><td>';
386 require_once DOL_DOCUMENT_ROOT.
'/core/class/doleditor.class.php';
387 $doleditor =
new DolEditor(
'signature', (
GETPOSTISSET(
'signature') ?
GETPOST(
'signature',
'restricthtml') : $object->signature),
'', 138,
'dolibarr_notes',
'In',
true,
true, empty($conf->global->FCKEDITOR_ENABLE_USERSIGN) ? 0 : 1, ROWS_4,
'90%');
388 print $doleditor->Create(1);
390 print
'<tr><td>'.$langs->trans(
"User").
'</td><td>';
391 print
$form->select_dolusers((
GETPOSTISSET(
'private') ?
GETPOST(
'private',
'int') : $object->private),
'private', 1,
null, 0, ($user->admin ?
'' : $user->id));
393 print
'<tr><td>'.$langs->trans(
"Position").
'</td><td><input type="text" name="position" class="maxwidth50" value="'.(
GETPOSTISSET(
'position') ?
GETPOST(
'position',
'int') : $object->position).
'"></td></tr>';
394 print
'<tr><td>'.$langs->trans(
"Status").
'</td><td>';
395 print
$form->selectarray(
'active', $object->fields[
'active'][
'arrayofkeyval'], (
GETPOSTISSET(
'active') ?
GETPOST(
'active',
'int') : $object->active), 0, 0, 0,
'', 1);
399 print
$form->buttonsSaveCancel();
411 print
'<table class="border centpercent tableforfield">';
412 print
'<tr><td class="fieldrequired">'.$langs->trans(
"Label").
'</td><td><input type="text" name="label" value="'.
GETPOST(
'label',
'alphanohtml').
'" autofocus></td></tr>';
413 print
'<tr><td class="fieldrequired">'.$langs->trans(
"Email").
'</td><td><input type="text" name="email" value="'.
GETPOST(
'email',
'alphanohtml').
'"></td></tr>';
414 print
'<tr><td>'.$langs->trans(
"Signature").
'</td><td>';
415 require_once DOL_DOCUMENT_ROOT.
'/core/class/doleditor.class.php';
416 $doleditor =
new DolEditor(
'signature',
GETPOST(
'signature'),
'', 138,
'dolibarr_notes',
'In',
true,
true, empty($conf->global->FCKEDITOR_ENABLE_USERSIGN) ? 0 : 1, ROWS_4,
'90%');
417 print $doleditor->Create(1);
419 print
'<tr><td>'.$langs->trans(
"User").
'</td><td>';
420 print
$form->select_dolusers((
GETPOSTISSET(
'private') ?
GETPOST(
'private',
'int') : -1),
'private', 1,
null, 0, ($user->admin ?
'' : $user->id));
422 print
'<tr><td>'.$langs->trans(
"Position").
'</td><td><input type="text" name="position" class="maxwidth50" value="'.
GETPOST(
'position',
'int').
'"></td></tr>';
423 print
'<tr><td>'.$langs->trans(
"Status").
'</td><td>';
424 print
$form->selectarray(
'active', $object->fields[
'active'][
'arrayofkeyval'],
GETPOST(
'active',
'int'), 0);
428 print
$form->buttonsSaveCancel();
432 print_barre_liste(
'', $page, $_SERVER[
"PHP_SELF"], $param, $sortfield, $sortorder, $massactionbutton, $num, $nbtotalofrecords,
'title_companies', 0, $newcardbutton,
'', $limit);
435 $topicmail =
"Information";
439 include DOL_DOCUMENT_ROOT.
'/core/tpl/massactions_pre.tpl.php';
442 foreach ($fieldstosearchall as $key => $val) {
443 $fieldstosearchall[$key] = $langs->trans($val);
445 print
'<div class="divsearchfieldfilter">'.$langs->trans(
"FilterOnInto", $search_all).join(
', ', $fieldstosearchall).
'</div>';
453 $parameters = array();
454 $reshook = $hookmanager->executeHooks(
'printFieldPreListTitle', $parameters, $object);
455 if (empty($reshook)) {
456 $moreforfilter .= $hookmanager->resPrint;
458 $moreforfilter = $hookmanager->resPrint;
461 if (!empty($moreforfilter)) {
462 print
'<div class="liste_titre liste_titre_bydiv centpercent">';
463 print $moreforfilter;
467 $varpage = empty($contextpage) ? $_SERVER[
"PHP_SELF"] : $contextpage;
468 $selectedfields =
$form->multiSelectArrayWithCheckbox(
'selectedfields', $arrayfields, $varpage);
469 $selectedfields .= (count($arrayofmassactions) ?
$form->showCheckAddButtons(
'checkforselect', 1) :
'');
471 print
'<div class="div-table-responsive">';
472 print
'<table class="tagtable liste'.($moreforfilter ?
" listwithfilterbefore" :
"").
'">'.
"\n";
477 print
'<tr class="liste_titre">';
478 foreach ($object->fields as $key => $val) {
479 $cssforfield = (empty($val[
'css']) ?
'' : $val[
'css']);
480 if ($key ==
'status') {
481 $cssforfield .= ($cssforfield ?
' ' :
'').
'center';
482 } elseif (in_array($val[
'type'], array(
'date',
'datetime',
'timestamp'))) {
483 $cssforfield .= ($cssforfield ?
' ' :
'').
'center';
484 } elseif (in_array($val[
'type'], array(
'timestamp'))) {
485 $cssforfield .= ($cssforfield ?
' ' :
'').
'nowrap';
486 } elseif (in_array($val[
'type'], array(
'double(24,8)',
'double(6,3)',
'integer',
'real',
'price')) && $val[
'label'] !=
'TechnicalID') {
487 $cssforfield .= ($cssforfield ?
' ' :
'').
'right';
489 if (!empty($arrayfields[
't.'.$key][
'checked'])) {
490 print
'<td class="liste_titre'.($cssforfield ?
' '.$cssforfield :
'').
'">';
491 if (!empty($val[
'arrayofkeyval']) && is_array($val[
'arrayofkeyval'])) {
492 print
$form->selectarray(
'search_'.$key, $val[
'arrayofkeyval'], empty($search[$key]) ?
'' : $search[$key], $val[
'notnull'], 0, 0,
'', 1, 0, 0,
'',
'maxwidth100', 1);
493 } elseif (strpos($val[
'type'],
'integer:') === 0) {
494 print $object->showInputField($val, $key, empty($search[$key]) ?
'' : $search[$key],
'',
'',
'search_',
'maxwidth150', 1);
495 } elseif (!preg_match(
'/^(date|timestamp)/', $val[
'type'])) {
496 print
'<input type="text" class="flat maxwidth75" name="search_'.$key.
'" value="'.
dol_escape_htmltag(empty($search[$key]) ?
'' : $search[$key]).
'">';
502 include DOL_DOCUMENT_ROOT.
'/core/tpl/extrafields_list_search_input.tpl.php';
504 $parameters = array(
'arrayfields'=>$arrayfields);
505 $reshook = $hookmanager->executeHooks(
'printFieldListOption', $parameters, $object);
506 print $hookmanager->resPrint;
508 print
'<td class="liste_titre maxwidthsearch">';
509 $searchpicto =
$form->showFilterButtons();
517 print
'<tr class="liste_titre">';
518 foreach ($object->fields as $key => $val) {
519 $cssforfield = (empty($val[
'css']) ?
'' : $val[
'css']);
520 if ($key ==
'status') {
521 $cssforfield .= ($cssforfield ?
' ' :
'').
'center';
522 } elseif (in_array($val[
'type'], array(
'date',
'datetime',
'timestamp'))) {
523 $cssforfield .= ($cssforfield ?
' ' :
'').
'center';
524 } elseif (in_array($val[
'type'], array(
'timestamp'))) {
525 $cssforfield .= ($cssforfield ?
' ' :
'').
'nowrap';
526 } elseif (in_array($val[
'type'], array(
'double(24,8)',
'double(6,3)',
'integer',
'real',
'price')) && $val[
'label'] !=
'TechnicalID') {
527 $cssforfield .= ($cssforfield ?
' ' :
'').
'right';
529 if (!empty($arrayfields[
't.'.$key][
'checked'])) {
530 print
getTitleFieldOfList($arrayfields[
't.'.$key][
'label'], 0, $_SERVER[
'PHP_SELF'],
't.'.$key,
'', $param, ($cssforfield ?
'class="'.$cssforfield.
'"' :
''), $sortfield, $sortorder, ($cssforfield ? $cssforfield.
' ' :
'')).
"\n";
534 include DOL_DOCUMENT_ROOT.
'/core/tpl/extrafields_list_search_title.tpl.php';
537 $parameters = array(
'arrayfields'=>$arrayfields,
'param'=>$param,
'sortfield'=>$sortfield,
'sortorder'=>$sortorder);
538 $reshook = $hookmanager->executeHooks(
'printFieldListTitle', $parameters, $object);
539 print $hookmanager->resPrint;
541 print
getTitleFieldOfList($selectedfields, 0, $_SERVER[
"PHP_SELF"],
'',
'',
'',
'', $sortfield, $sortorder,
'center maxwidthsearch ').
"\n";
546 $needToFetchEachLine = 0;
547 if (!empty($extrafields->attributes[$object->table_element][
'computed']) && is_array($extrafields->attributes[$object->table_element][
'computed']) && count($extrafields->attributes[$object->table_element][
'computed']) > 0) {
548 foreach ($extrafields->attributes[$object->table_element][
'computed'] as $key => $val) {
549 if (preg_match(
'/\$object/', $val)) {
550 $needToFetchEachLine++;
559 $totalarray = array();
560 while ($i < ($limit ? min($num, $limit) : $num)) {
561 $obj = $db->fetch_object(
$resql);
567 $object->setVarsFromFetchObj($obj);
570 print
'<tr class="oddeven">';
571 foreach ($object->fields as $key => $val) {
572 $cssforfield = (empty($val[
'css']) ?
'' : $val[
'css']);
573 if (in_array($val[
'type'], array(
'date',
'datetime',
'timestamp'))) {
574 $cssforfield .= ($cssforfield ?
' ' :
'').
'center';
575 } elseif ($key ==
'status') {
576 $cssforfield .= ($cssforfield ?
' ' :
'').
'center';
579 if (in_array($val[
'type'], array(
'timestamp'))) {
580 $cssforfield .= ($cssforfield ?
' ' :
'').
'nowrap';
581 } elseif ($key ==
'ref') {
582 $cssforfield .= ($cssforfield ?
' ' :
'').
'nowrap';
585 if (in_array($val[
'type'], array(
'double(24,8)',
'double(6,3)',
'integer',
'real',
'price')) && $key !=
'status') {
586 $cssforfield .= ($cssforfield ?
' ' :
'').
'right';
589 if (!empty($arrayfields[
't.'.$key][
'checked'])) {
590 print
'<td'.($cssforfield ?
' class="'.$cssforfield.
'"' :
'').
'>';
591 if ($key ==
'status' || $key ==
'active') {
592 print $object->getLibStatut(5);
594 print $object->showOutputField($val, $key, $object->$key,
'');
598 $totalarray[
'nbfield']++;
600 if (!empty($val[
'isameasure']) && $val[
'isameasure'] == 1) {
602 $totalarray[
'pos'][$totalarray[
'nbfield']] =
't.'.$key;
604 if (!isset($totalarray[
'val'])) {
605 $totalarray[
'val'] = array();
607 if (!isset($totalarray[
'val'][
't.'.$key])) {
608 $totalarray[
'val'][
't.'.$key] = 0;
610 $totalarray[
'val'][
't.'.$key] += $object->$key;
615 include DOL_DOCUMENT_ROOT.
'/core/tpl/extrafields_list_print_fields.tpl.php';
617 $parameters = array(
'arrayfields'=>$arrayfields,
'object'=>$object,
'obj'=>$obj,
'i'=>$i,
'totalarray'=>&$totalarray);
618 $reshook = $hookmanager->executeHooks(
'printFieldListValue', $parameters, $object);
619 print $hookmanager->resPrint;
621 print
'<td class="nowrap center">';
622 $url = $_SERVER[
"PHP_SELF"].
'?id='.$obj->rowid;
624 $url .=
'&limit='.urlencode($limit);
627 $url .=
'&page='.urlencode($page);
630 $url .=
'&sortfield='.urlencode($sortfield);
633 $url .=
'&page='.urlencode($sortorder);
635 print
'<a class="editfielda reposition marginrightonly marginleftonly" href="'.$url.
'&action=edit&token='.
newToken().
'&rowid='.$obj->rowid.
'">'.
img_edit().
'</a>';
637 print
'<a class=" marginrightonly marginleftonly" href="'.$url.
'&action=delete&token='.
newToken().
'">'.
img_delete().
'</a> ';
638 if ($massactionbutton || $massaction) {
640 if (in_array($object->id, $arrayofselected)) {
643 print
'<input id="cb'.$object->id.
'" class="flat checkforselect" type="checkbox" name="toselect[]" value="'.$object->rowid.
'"'.($selected ?
' checked="checked"' :
'').
'>';
647 $totalarray[
'nbfield']++;
656 include DOL_DOCUMENT_ROOT.
'/core/tpl/list_print_total.tpl.php';
662 foreach ($arrayfields as $key => $val) {
663 if (!empty($val[
'checked'])) {
667 print
'<tr><td colspan="'.$colspan.
'" class="opacitymedium">'.$langs->trans(
"NoRecordFound").
'</td></tr>';
673 $parameters = array(
'arrayfields'=>$arrayfields,
'sql'=>$sql);
674 $reshook = $hookmanager->executeHooks(
'printFieldListFooter', $parameters, $object);
675 print $hookmanager->resPrint;
677 print
'</table>'.
"\n";
680 print
'</form>'.
"\n";
682 if (in_array(
'builddoc', $arrayofmassactions) && ($nbtotalofrecords ===
'' || $nbtotalofrecords)) {
683 $hidegeneratedfilelistifempty = 1;
684 if ($massaction ==
'builddoc' || $action ==
'remove_file' || $show_files) {
685 $hidegeneratedfilelistifempty = 0;
688 require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formfile.class.php';
692 $urlsource = $_SERVER[
'PHP_SELF'].
'?sortfield='.$sortfield.
'&sortorder='.$sortorder;
693 $urlsource .= str_replace(
'&',
'&', $param);
695 $filedir = $diroutputmassaction;
696 $genallowed = $permissiontoread;
697 $delallowed = $permissiontoadd;
699 print $formfile->showdocuments(
'massfilesarea_emailsenderprofile',
'', $filedir, $urlsource, 0, $delallowed,
'', 1, 1, 0, 48, 1, $param, $title,
'',
'',
'',
null, $hidegeneratedfilelistifempty);