* Copyright (C) 2005-2024 Laurent Destailleur * Copyright (C) 2005-2010 Regis Houssin * Copyright (C) 2014 Florian Henry * Copyright (C) 2024 MDW * Copyright (C) 2024 Frédéric France * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ /** * \file htdocs/comm/mailing/cibles.php * \ingroup mailing * \brief Page to define or view emailing targets */ // Load Dolibarr environment require '../../main.inc.php'; require_once DOL_DOCUMENT_ROOT.'/core/modules/mailings/modules_mailings.php'; require_once DOL_DOCUMENT_ROOT.'/comm/mailing/class/mailing.class.php'; require_once DOL_DOCUMENT_ROOT.'/core/class/html.formmailing.class.php'; require_once DOL_DOCUMENT_ROOT.'/core/lib/emailing.lib.php'; require_once DOL_DOCUMENT_ROOT.'/core/class/CMailFile.class.php'; require_once DOL_DOCUMENT_ROOT.'/core/lib/functions2.lib.php'; require_once DOL_DOCUMENT_ROOT.'/core/lib/ajax.lib.php'; ' @phan-var-force array{0:string,1:string} $bctag From main.inc '; /** * @var Conf $conf * @var DoliDB $db * @var HookManager $hookmanager * @var Translate $langs * @var User $user * @var array{0:string,1:string} $bctag From main.inc */ // Load translation files required by the page $langs->loadLangs(array("mails", "admin")); $action = GETPOST('action', 'aZ09'); $toselect = GETPOST('toselect', 'array'); // Array of ids of elements selected into a list $massaction = GETPOST('massaction', 'alpha'); // The bulk action (combo box choice into lists) $mode = GETPOST('mode', 'aZ'); // The display mode ('list', 'kanban', 'hierarchy', 'calendar', 'gantt', ...) // Load variable for pagination $limit = GETPOSTINT('limit') ? GETPOSTINT('limit') : $conf->liste_limit; $sortfield = GETPOST('sortfield', 'aZ09comma'); $sortorder = GETPOST('sortorder', 'aZ09comma'); $page = GETPOSTISSET('pageplusone') ? (GETPOSTINT('pageplusone') - 1) : GETPOSTINT("page"); if (empty($page) || $page == -1) { $page = 0; } // If $page is not defined, or '' or -1 $offset = $limit * $page; $pageprev = $page - 1; $pagenext = $page + 1; if (!$sortfield) { $sortfield = "mc.statut,email"; } if (!$sortorder) { $sortorder = "DESC,ASC"; } $id = GETPOSTINT('id'); $rowid = GETPOSTINT('rowid'); $search_lastname = GETPOST("search_lastname", 'alphanohtml'); $search_firstname = GETPOST("search_firstname", 'alphanohtml'); $search_email = GETPOST("search_email", 'alphanohtml'); $search_other = GETPOST("search_other", 'alphanohtml'); $search_dest_status = GETPOST('search_dest_status', 'int'); // Search modules dirs $modulesdir = dolGetModulesDirs('/mailings'); $object = new Mailing($db); $result = $object->fetch($id); // Initialize a technical object to manage hooks of page. Note that conf->hooks_modules contains an array of hook context $hookmanager->initHooks(array('ciblescard', 'globalcard')); $sqlmessage = ''; $mesgs = array(); // List of sending methods $listofmethods = array(); //$listofmethods['default'] = $langs->trans('DefaultOutgoingEmailSetup'); $listofmethods['mail'] = 'PHP mail function'; //$listofmethods['simplemail']='Simplemail class'; $listofmethods['smtps'] = 'SMTP/SMTPS socket library'; if (version_compare(phpversion(), '7.0', '>=')) { $listofmethods['swiftmailer'] = 'Swift Mailer socket library'; } // Security check if (!$user->hasRight('mailing', 'lire') || (!getDolGlobalString('EXTERNAL_USERS_ARE_AUTHORIZED') && $user->socid > 0)) { accessforbidden(); } if (empty($action) && empty($object->id)) { accessforbidden('Object not found'); } $permissiontoread = $user->hasRight('maling', 'lire'); $permissiontocreate = $user->hasRight('mailing', 'creer'); $permissiontovalidatesend = $user->hasRight('mailing', 'valider'); $permissiontodelete = $user->hasRight('mailing', 'supprimer'); /* * Actions */ if (GETPOST('cancel', 'alpha')) { $action = 'list'; $massaction = ''; } if (!GETPOST('confirmmassaction', 'alpha')) { $massaction = ''; } if ($action == 'add' && $permissiontocreate) { // Add recipients $module = GETPOST("module", 'alpha'); $result = -1; $obj = null; foreach ($modulesdir as $dir) { // Load modules attributes in arrays (name, numero, orders) from dir directory //print $dir."\n
"; dol_syslog("Scan directory ".$dir." for modules"); // Loading Class $file = $dir."/".$module.".modules.php"; $classname = "mailing_".$module; if (file_exists($file)) { include_once $file; // Add targets into database dol_syslog("Call add_to_target() on class ".$classname." evenunsubscribe=".$object->evenunsubscribe); $obj = null; if (class_exists($classname)) { $obj = new $classname($db); '@phan-var-force MailingTargets $obj'; $obj->evenunsubscribe = $object->evenunsubscribe; $result = $obj->add_to_target($id); $sqlmessage = $obj->sql; } else { $result = -1; break; } } } if ($result > 0) { // If status of emailing is sent completely, change to to send partially if ($object->status == $object::STATUS_SENTCOMPLETELY) { $object->setStatut($object::STATUS_SENTPARTIALY); } setEventMessages($langs->trans("XTargetsAdded", $result), null, 'mesgs'); $action = ''; } if ($result == 0) { setEventMessages($langs->trans("WarningNoEMailsAdded"), null, 'warnings'); } if ($result < 0 && is_object($obj)) { setEventMessages($langs->trans("Error").($obj->error ? ' '.$obj->error : ''), null, 'errors'); } } if (GETPOSTINT('clearlist') && $permissiontocreate) { // Loading Class $obj = new MailingTargets($db); $obj->clear_target($id); /* Avoid this to allow reposition header("Location: ".$_SERVER['PHP_SELF']."?id=".$id); exit; */ } if (GETPOSTINT('exportcsv') && $permissiontoread) { $completefilename = 'targets_emailing'.$object->id.'_'.dol_print_date(dol_now(), 'dayhourlog').'.csv'; header('Content-Type: text/csv'); header('Content-Disposition: attachment;filename='.$completefilename); // List of selected targets $sql = "SELECT mc.rowid, mc.lastname, mc.firstname, mc.email, mc.other, mc.statut as status, mc.date_envoi, mc.tms,"; $sql .= " mc.source_id, mc.source_type, mc.error_text"; $sql .= " FROM ".MAIN_DB_PREFIX."mailing_cibles as mc"; $sql .= " WHERE mc.fk_mailing = ".((int) $object->id); $sql .= $db->order($sortfield, $sortorder); $resql = $db->query($sql); if ($resql) { $num = $db->num_rows($resql); $sep = ','; while ($obj = $db->fetch_object($resql)) { print $obj->rowid.$sep; print '"'.$obj->lastname.'"'.$sep; print '"'.$obj->firstname.'"'.$sep; print $obj->email.$sep; print $obj->other.$sep; print $obj->tms.$sep; print $obj->source_type.$sep; print $obj->source_id.$sep; print $obj->date_envoi.$sep; print $obj->status.$sep; print '"'.$obj->error_text.'"'.$sep; print "\n"; } exit; } else { dol_print_error($db); } exit; } if ($action == 'delete' && $permissiontocreate) { // Ici, rowid indique le destinataire et id le mailing $sql = "DELETE FROM ".MAIN_DB_PREFIX."mailing_cibles WHERE rowid = ".((int) $rowid); $resql = $db->query($sql); if ($resql) { if (!empty($id)) { $obj = new MailingTargets($db); $obj->update_nb($id); setEventMessages($langs->trans("RecordDeleted"), null, 'mesgs'); } else { header("Location: list.php"); exit; } } else { dol_print_error($db); } } if ($action == "confirm_reset_target" && $permissiontocreate) { if ($object->id > 0) { $db->begin(); $nbok = 0; $error = 0; foreach ($toselect as $toselectid) { $result = $object->resetTargetErrorStatus($user, $toselectid); if ($result < 0) { setEventMessages($object->error, $object->errors, 'errors'); $error++; break; } elseif ($result > 0) { $nbok++; } else { setEventMessages($object->error, $object->errors, 'errors'); $error++; } } if (!$error) { setEventMessages($langs->trans("RecordsModified", $nbok), null, 'mesgs'); $db->commit(); } else { $db->rollback(); } } } // Purge search criteria 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 $search_lastname = ''; $search_firstname = ''; $search_email = ''; $search_other = ''; $search_dest_status = ''; $toselect = array(); } // Action update description of emailing if (($action == 'settitle' || $action == 'setemail_from' || $action == 'setreplyto' || $action == 'setemail_errorsto' || $action == 'setevenunsubscribe') && $permissiontocreate) { $upload_dir = $conf->mailing->dir_output."/".get_exdir($object->id, 2, 0, 1, $object, 'mailing'); if ($action == 'settitle') { // Test on permission already done $object->title = trim(GETPOST('title', 'alpha')); } elseif ($action == 'setemail_from') { // Test on permission already done $object->email_from = trim(GETPOST('email_from', 'alphawithlgt')); // Must allow 'name ' } elseif ($action == 'setemail_replyto') { // Test on permission already done $object->email_replyto = trim(GETPOST('email_replyto', 'alphawithlgt')); // Must allow 'name ' } elseif ($action == 'setemail_errorsto') { // Test on permission already done $object->email_errorsto = trim(GETPOST('email_errorsto', 'alphawithlgt')); // Must allow 'name ' } elseif ($action == 'settitle' && empty($object->title)) { // Test on permission already done $mesg = $langs->trans("ErrorFieldRequired", $langs->transnoentities("MailTitle")); } elseif ($action == 'setfrom' && empty($object->email_from)) { // Test on permission already done $mesg = $langs->trans("ErrorFieldRequired", $langs->transnoentities("MailFrom")); } elseif ($action == 'setevenunsubscribe') { // Test on permission already done $object->evenunsubscribe = (GETPOST('evenunsubscribe') ? 1 : 0); } if (!$mesg) { $result = $object->update($user); if ($result >= 0) { header("Location: ".$_SERVER['PHP_SELF']."?id=".$object->id); exit; } $mesg = $object->error; } setEventMessages($mesg, $mesgs, 'errors'); $action = ""; } /* * View */ llxHeader('', $langs->trans("Mailing"), 'EN:Module_EMailing|FR:Module_Mailing|ES:Módulo_Mailing'); $form = new Form($db); $formmailing = new FormMailing($db); $arrayofselected = is_array($toselect) ? $toselect : array(); $totalarray = [ 'nbfield' => 0, ]; if ($object->fetch($id) >= 0) { $head = emailing_prepare_head($object); print dol_get_fiche_head($head, 'targets', $langs->trans("Mailing"), -1, 'email'); $linkback = ''.$langs->trans("BackToList").''; $morehtmlref = '
'; // Ref customer $morehtmlref .= $form->editfieldkey("", 'title', $object->title, $object, 0, 'string', '', 0, 1); $morehtmlref .= $form->editfieldval("", 'title', $object->title, $object, 0, 'string', '', null, null, '', 1); $morehtmlref .= '
'; $morehtmlstatus = ''; $nbtry = $nbok = 0; if ($object->status == $object::STATUS_SENTPARTIALY || $object->status == $object::STATUS_SENTCOMPLETELY) { $nbtry = $object->countNbOfTargets('alreadysent'); $nbko = $object->countNbOfTargets('alreadysentko'); $nbok = ($nbtry - $nbko); $morehtmlstatus .= ' ('.$nbtry.'/'.$object->nbemail; if ($nbko) { $morehtmlstatus .= ' - '.$nbko.' '.$langs->trans("Error"); } $morehtmlstatus .= ')   '; } dol_banner_tab($object, 'id', $linkback, 1, 'rowid', 'ref', $morehtmlref, '', 0, '', $morehtmlstatus); print '
'; print '
'; print '
'; print ''; // From print ''; // Errors to if ($object->messtype != 'sms') { print ''; } // Reply to if ($object->messtype != 'sms') { print ''; } print '
'.$langs->trans("MailFrom").''; $emailarray = CMailFile::getArrayAddress($object->email_from); foreach ($emailarray as $email => $name) { if ($name && $name != $email) { print dol_escape_htmltag($name).' <'.$email; print '>'; if (!isValidEmail($email)) { $langs->load("errors"); print img_warning($langs->trans("ErrorBadEMail", $email)); } } else { print dol_print_email($object->email_from, 0, 0, 0, 0, 1); } } print '
'.$langs->trans("MailErrorsTo").''; $emailarray = CMailFile::getArrayAddress($object->email_errorsto); foreach ($emailarray as $email => $name) { if ($name != $email) { print dol_escape_htmltag($name).' <'.$email; print '>'; if ($email && !isValidEmail($email)) { $langs->load("errors"); print img_warning($langs->trans("ErrorBadEMail", $email)); } elseif ($email && !isValidMailDomain($email)) { $langs->load("errors"); print img_warning($langs->trans("ErrorBadMXDomain", $email)); } } else { print dol_print_email($object->email_errorsto, 0, 0, 0, 0, 1); } } print '
'; print $form->editfieldkey("MailReply", 'email_replyto', $object->email_replyto, $object, $user->hasRight('mailing', 'creer') && $object->status < $object::STATUS_SENTCOMPLETELY, 'string'); print ''; print $form->editfieldval("MailReply", 'email_replyto', $object->email_replyto, $object, $user->hasRight('mailing', 'creer') && $object->status < $object::STATUS_SENTCOMPLETELY, 'string'); $email = CMailFile::getValidAddress($object->email_replyto, 2); if ($action != 'editemail_replyto') { if ($email && !isValidEmail($email)) { $langs->load("errors"); print img_warning($langs->trans("ErrorBadEMail", $email)); } elseif ($email && !isValidMailDomain($email)) { $langs->load("errors"); print img_warning($langs->trans("ErrorBadMXDomain", $email)); } } print '
'; print '
'; print '
'; print '
'; print ''; // Number of distinct emails print ''; print ''; // Other attributes. Fields from hook formObjectOptions and Extrafields. include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_view.tpl.php'; print '
'; print $langs->trans("TotalNbOfDistinctRecipients"); print ''; $nbemail = ($object->nbemail ? $object->nbemail : 0); if (is_numeric($nbemail)) { $text = ''; if ((getDolGlobalString('MAILING_LIMIT_SENDBYWEB') && getDolGlobalInt('MAILING_LIMIT_SENDBYWEB') < $nbemail) && ($object->status == 1 || ($object->status == 2 && $nbtry < $nbemail))) { if (getDolGlobalInt('MAILING_LIMIT_SENDBYWEB') > 0) { $text .= $langs->trans('LimitSendingEmailing', getDolGlobalString('MAILING_LIMIT_SENDBYWEB')); } else { $text .= $langs->trans('SendingFromWebInterfaceIsNotAllowed'); } } if (empty($nbemail)) { $nbemail .= ' '.img_warning($langs->trans('ToAddRecipientsChooseHere'));//.' '.$langs->trans("NoTargetYet").''; } if ($text) { // @phan-suppress-next-line PhanPluginSuspiciousParamPosition print $form->textwithpicto($nbemail, $text, 1, 'warning'); } else { print $nbemail; } } print '
'; print $langs->trans("MAIN_MAIL_SENDMODE"); print ''; if ($object->messtype != 'sms') { if (getDolGlobalString('MAIN_MAIL_SENDMODE_EMAILING') && getDolGlobalString('MAIN_MAIL_SENDMODE_EMAILING') != 'default') { $text = $listofmethods[getDolGlobalString('MAIN_MAIL_SENDMODE_EMAILING')]; } elseif (getDolGlobalString('MAIN_MAIL_SENDMODE')) { $text = $listofmethods[getDolGlobalString('MAIN_MAIL_SENDMODE')]; } else { $text = $listofmethods['mail']; } print $text; if (getDolGlobalString('MAIN_MAIL_SENDMODE_EMAILING') != 'default') { if (getDolGlobalString('MAIN_MAIL_SENDMODE_EMAILING') && getDolGlobalString('MAIN_MAIL_SENDMODE_EMAILING') != 'mail') { print ' ('.getDolGlobalString('MAIN_MAIL_SMTP_SERVER_EMAILING', getDolGlobalString('MAIN_MAIL_SMTP_SERVER')).')'; } } elseif (getDolGlobalString('MAIN_MAIL_SENDMODE') != 'mail' && getDolGlobalString('MAIN_MAIL_SMTP_SERVER')) { print ' ('.getDolGlobalString('MAIN_MAIL_SMTP_SERVER').')'; } } else { print 'SMS '; print ' ('.getDolGlobalString('MAIN_MAIL_SMTP_SERVER').')'; } print '
'; print '
'; print '
'; print '
'; print dol_get_fiche_end(); print '
'; $newcardbutton = ''; $allowaddtarget = ($object->status == $object::STATUS_DRAFT); if (GETPOST('allowaddtarget')) { $allowaddtarget = 1; } if (!$allowaddtarget) { $newcardbutton .= dolGetButtonTitle($langs->trans('New'), '', 'fa fa-plus-circle', $_SERVER["PHP_SELF"].'?id='.$object->id.'&allowaddtarget=1', '', $user->hasRight('mailing', 'creer')); } // Show email selectors if ($allowaddtarget && $user->hasRight('mailing', 'creer')) { print load_fiche_titre($langs->trans("ToAddRecipientsChooseHere"), ($user->admin ? info_admin($langs->trans("YouCanAddYourOwnPredefindedListHere"), 1) : ''), 'generic'); print '
'; print '
'; print '
'; print '
'; print '
'.$langs->trans("RecipientSelectionModules").'
'; print '
'; if ($object->messtype != 'sms') { print $langs->trans("NbOfUniqueEMails"); } else { print $langs->trans("NbOfUniquePhones"); } print '
'; print '
'.$langs->trans("Filters").'
'; if ($object->messtype != 'sms') { print '              
'.$langs->trans("EvenUnsubscribe").' '; print ajax_object_onoff($object, 'evenunsubscribe', 'evenunsubscribe', 'EvenUnsubscribe:switch_on:warning', 'EvenUnsubscribe', array(), 'small valignmiddle', '', 1); print '
'; } print '
'; print '
 
'; print '
'; // End tr clearstatcache(); foreach ($modulesdir as $dir) { $modulenames = array(); // Load modules attributes in arrays (name, numero, orders) from dir directory //print $dir."\n
"; dol_syslog("Scan directory ".$dir." for modules"); $handle = @opendir($dir); if (is_resource($handle)) { while (($file = readdir($handle)) !== false) { if (substr($file, 0, 1) != '.' && substr($file, 0, 3) != 'CVS') { $reg = array(); if (preg_match("/(.*)\.modules\.php$/i", $file, $reg)) { if ($reg[1] == 'example') { continue; } $modulenames[] = $reg[1]; } } } closedir($handle); } // Sort $modulenames sort($modulenames); $var = true; // Loop on each submodule foreach ($modulenames as $modulename) { // Loading Class $file = $dir.$modulename.".modules.php"; $classname = "mailing_".$modulename; require_once $file; $obj = new $classname($db); '@phan-var-force MailingTargets $obj'; // Check if qualified $qualified = (is_null($obj->enabled) ? 1 : (int) dol_eval($obj->enabled, 1)); // Check dependencies foreach ($obj->require_module as $key) { if (empty($conf->$key->enabled) || (empty($user->admin) && $obj->require_admin)) { $qualified = 0; //print "Les prerequis d'activation du module mailing ne sont pas respectes. Il ne sera pas actif"; break; } } // If module is qualified if ($qualified) { $var = !$var; if ($allowaddtarget) { print '
'; print ''; print ''; print ''; } else { print '
'; } print '
'; if (empty($obj->picto)) { $obj->picto = 'generic'; } print img_object($langs->trans("EmailingTargetSelector").': '.get_class($obj), $obj->picto, 'class="valignmiddle width25 size15x"'); print '
'; print '
'; // style="height: 4em" print $obj->getDesc(); print '
'; $nbofrecipient = -1; try { $obj->evenunsubscribe = $object->evenunsubscribe; // Set flag to include/exclude email that has opt-out. $nbofrecipient = $obj->getNbOfRecipients(''); } catch (Exception $e) { dol_syslog($e->getMessage(), LOG_ERR); } print '
'; if ($nbofrecipient === '' || $nbofrecipient >= 0) { print $nbofrecipient; } else { print $langs->trans("Error").' '.img_error($obj->error); } print '
'; print '
'; if ($allowaddtarget) { try { $filter = $obj->formFilter(); } catch (Exception $e) { dol_syslog($e->getMessage(), LOG_ERR); } if ($filter) { print $filter; } else { print $langs->trans("None"); } } print '
'; print '
'; if ($allowaddtarget) { print ''; } else { print ''; //print $langs->trans("MailNoChangePossible"); print " "; } print '
'; if ($allowaddtarget) { print ''; } else { print '
'; } } } } // End foreach dir $parameters = array(); $reshook = $hookmanager->executeHooks('formObjectOptions', $parameters, $object, $action); // Note that $action and $object may have been modified by hook print $hookmanager->resPrint; print '
'; // End table print '
'; print '
'; if ($sqlmessage && $user->admin) { print info_admin($langs->trans("SQLUsedForExport").':
'.$sqlmessage, 0, 0, '1', '', 'TechnicalInformation'); print '
'; } print '

'; } // List of selected targets $sql = "SELECT mc.rowid, mc.lastname, mc.firstname, mc.email, mc.other, mc.statut as status, mc.date_envoi, mc.tms,"; $sql .= " mc.source_url, mc.source_id, mc.source_type, mc.error_text,"; $sql .= " COUNT(mu.rowid) as nb"; $sql .= " FROM ".MAIN_DB_PREFIX."mailing_cibles as mc"; $sql .= " LEFT JOIN ".MAIN_DB_PREFIX."mailing_unsubscribe as mu ON mu.email = mc.email"; $sql .= " WHERE mc.fk_mailing=".((int) $object->id); $asearchcriteriahasbeenset = 0; if ($search_lastname) { $sql .= natural_search("mc.lastname", $search_lastname); $asearchcriteriahasbeenset++; } if ($search_firstname) { $sql .= natural_search("mc.firstname", $search_firstname); $asearchcriteriahasbeenset++; } if ($search_email) { $sql .= natural_search("mc.email", $search_email); $asearchcriteriahasbeenset++; } if ($search_other) { $sql .= natural_search("mc.other", $search_other); $asearchcriteriahasbeenset++; } if ($search_dest_status != '' && (int) $search_dest_status >= -1) { $sql .= " AND mc.statut = ".((int) $search_dest_status); $asearchcriteriahasbeenset++; } $sql .= ' GROUP BY mc.rowid, mc.lastname, mc.firstname, mc.email, mc.other, mc.statut, mc.date_envoi, mc.tms, mc.source_url, mc.source_id, mc.source_type, mc.error_text'; $sql .= $db->order($sortfield, $sortorder); // Count total nb of records $nbtotalofrecords = ''; if (!getDolGlobalInt('MAIN_DISABLE_FULL_SCANLIST')) { $result = $db->query($sql); $nbtotalofrecords = $db->num_rows($result); if (($page * $limit) > $nbtotalofrecords) { // if total resultset is smaller then paging size (filtering), goto and load page 0 $page = 0; $offset = 0; } // Fix/update nbemail on emailing record if it differs (may happen if user edit lines from database directly) if (empty($asearchcriteriahasbeenset)) { if ($nbtotalofrecords != $object->nbemail) { dol_syslog("We found a difference in nb of record in target table and the property ->nbemail, we fix ->nbemail"); //print "nbemail=".$object->nbemail." nbtotalofrecords=".$nbtotalofrecords; $resultrefresh = $object->refreshNbOfTargets(); if ($resultrefresh < 0) { dol_print_error($db, $object->error, $object->errors); } } } } //$nbtotalofrecords=$object->nbemail; // nbemail is a denormalized field storing nb of targets $sql .= $db->plimit($limit + 1, $offset); $resql = $db->query($sql); if ($resql) { $num = $db->num_rows($resql); $param = "&id=".$object->id; //if (!empty($contextpage) && $contextpage != $_SERVER["PHP_SELF"]) $param.='&contextpage='.urlencode($contextpage); if ($limit > 0 && $limit != $conf->liste_limit) { $param .= '&limit='.((int) $limit); } if ($search_lastname) { $param .= "&search_lastname=".urlencode($search_lastname); } if ($search_firstname) { $param .= "&search_firstname=".urlencode($search_firstname); } if ($search_email) { $param .= "&search_email=".urlencode($search_email); } if ($search_other) { $param .= "&search_other=".urlencode($search_other); } print '
'; print ''; print ''; print ''; print ''; print ''; print ''; $morehtmlcenter = ''; $arrayofmassactions = array(); if ($permissiontocreate) { $arrayofmassactions['reset_target'] = img_picto('', 'refresh', 'class="pictofixedwidth"').$langs->trans("ResetMailingTargetMassaction"); } $massactionbutton = $form->selectMassAction('', $arrayofmassactions); $morehtmlcenter .= $massactionbutton .'
'; if ($object->status == $object::STATUS_DRAFT) { $morehtmlcenter = ''.$langs->trans("ToClearAllRecipientsClickHere").' id.'" class="button reposition smallpaddingimp">'.$langs->trans("TargetsReset").''; } $morehtmlcenter .= '   id.'">'.img_picto('', 'download', 'class="pictofixedwidth"').$langs->trans("Download").''; print '
'; print "\n\n"; print '
'; print ''; print ''; print ''; print ''; print ''; print ''; print ''; // @phan-suppress-next-line PhanPluginSuspiciousParamOrder print_barre_liste($langs->trans("MailSelectedRecipients"), $page, $_SERVER["PHP_SELF"], $param, $sortfield, $sortorder, $morehtmlcenter, $num, $nbtotalofrecords, 'generic', 0, $newcardbutton, '', $limit, 0, 0, 1); if ($massaction == 'reset_target') { // Confirm reset print $form->formconfirm($_SERVER["PHP_SELF"]."?id=".$object->id, $langs->trans("ConfirmResetMailingTargetMassaction"), $langs->trans("ConfirmResetMailingTargetMassactionQuestion"), "confirm_reset_target", null, '', 0, 0, 500, 1); } $varpage = empty($contextpage) ? $_SERVER["PHP_SELF"] : $contextpage; $htmlofselectarray = $form->multiSelectArrayWithCheckbox('selectedfields', $arrayfields, $varpage, $conf->main_checkbox_left_column); // This also change content of $arrayfields with user setup $selectedfields = ($mode != 'kanban' ? $htmlofselectarray : ''); $selectedfields .= (count($arrayofmassactions) ? $form->showCheckAddButtons('checkforselect', 1) : ''); print '
'; print ''; // Ligne des champs de filtres print ''; // Action column if ($conf->main_checkbox_left_column) { print ''; } // EMail print ''; // Name print ''; // Firstname print ''; // Other print ''; // Source print ''; // Date last update print ''; // Date sending print ''; // Status print ''; // Action column if (empty($conf->main_checkbox_left_column)) { print ''; } print ''; if ($page) { $param .= "&page=".urlencode((string) ($page)); } print ''; // Action column if ($conf->main_checkbox_left_column) { print getTitleFieldOfList($selectedfields, 0, $_SERVER["PHP_SELF"], '', '', '', '', $sortfield, $sortorder, 'center maxwidthsearch ')."\n"; $totalarray['nbfield']++; } print_liste_field_titre("EMail", $_SERVER["PHP_SELF"], "mc.email", $param, "", "", $sortfield, $sortorder); print_liste_field_titre("Lastname", $_SERVER["PHP_SELF"], "mc.lastname", $param, "", "", $sortfield, $sortorder); print_liste_field_titre("Firstname", $_SERVER["PHP_SELF"], "mc.firstname", $param, "", "", $sortfield, $sortorder); print_liste_field_titre("OtherInformations", $_SERVER["PHP_SELF"], "", $param, "", "", $sortfield, $sortorder); print_liste_field_titre("Source", $_SERVER["PHP_SELF"], "", $param, "", '', $sortfield, $sortorder, 'center '); // Date last update print_liste_field_titre("DateLastModification", $_SERVER["PHP_SELF"], "mc.tms", $param, "", '', $sortfield, $sortorder, 'center '); // Date sending print_liste_field_titre("DateSending", $_SERVER["PHP_SELF"], "mc.date_envoi", $param, '', '', $sortfield, $sortorder, 'center '); print_liste_field_titre("Status", $_SERVER["PHP_SELF"], "mc.statut", $param, '', '', $sortfield, $sortorder, 'center '); // Action column if (!$conf->main_checkbox_left_column) { print getTitleFieldOfList($selectedfields, 0, $_SERVER["PHP_SELF"], '', '', '', '', $sortfield, $sortorder, 'center maxwidthsearch ')."\n"; $totalarray['nbfield']++; } print ''; $i = 0; if ($num) { include_once DOL_DOCUMENT_ROOT.'/adherents/class/adherent.class.php'; include_once DOL_DOCUMENT_ROOT.'/user/class/user.class.php'; include_once DOL_DOCUMENT_ROOT.'/societe/class/societe.class.php'; include_once DOL_DOCUMENT_ROOT.'/contact/class/contact.class.php'; include_once DOL_DOCUMENT_ROOT.'/eventorganization/class/conferenceorboothattendee.class.php'; $objectstaticmember = new Adherent($db); $objectstaticuser = new User($db); $objectstaticcompany = new Societe($db); $objectstaticcontact = new Contact($db); $objectstaticeventorganization = new ConferenceOrBoothAttendee($db); while ($i < min($num, $limit)) { $obj = $db->fetch_object($resql); print ''; // Action column if (getDolGlobalString('MAIN_CHECKBOX_LEFT_COLUMN')) { print ''; } print ''; print ''; print ''; print ''; print ''; // Date last update print ''; // Date sent print ''; // Status of recipient sending email (Warning != status of emailing) print ''; // Action column if (!getDolGlobalString('MAIN_CHECKBOX_LEFT_COLUMN')) { print ''; } print ''; $i++; } } else { if ($object->status < $object::STATUS_SENTPARTIALY) { print ''; } else { print ''; } } print "
'; $searchpicto = $form->showFilterButtons('left'); print $searchpicto; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ''; print ' '; print ''; print ' '; print ''; print ' '; print ''; print $formmailing->selectDestinariesStatus($search_dest_status, 'search_dest_status', 1, 'width100 onrightofpage'); print ''; $searchpicto = $form->showFilterButtons(); print $searchpicto; print '
'; print ''; if ($massactionbutton || $massaction) { // If we are in select mode (massactionbutton defined) or if we have already selected and sent an action ($massaction) defined $selected = 0; if (in_array($obj->rowid, $arrayofselected)) { $selected = 1; } print ''; } if ($obj->status == $object::STATUS_DRAFT) { // Not sent yet if ($user->hasRight('mailing', 'creer')) { print ''.img_delete($langs->trans("RemoveRecipient")).''; } } /*if ($obj->status == -1) // Sent with error { print ''.$langs->trans("Retry").''; }*/ print ''; print img_picto($obj->email, 'email', 'class="paddingright"'); if ($obj->nb > 0) { print img_warning($langs->trans("EmailOptedOut"), 'warning', 'pictofixedwidth'); } print dol_escape_htmltag($obj->email); print ''.dol_escape_htmltag($obj->lastname).''.dol_escape_htmltag($obj->firstname).''.dol_escape_htmltag($obj->other).''; if (empty($obj->source_id) || empty($obj->source_type)) { print empty($obj->source_url) ? '' : $obj->source_url; // For backward compatibility } else { if ($obj->source_type == 'member') { $objectstaticmember->fetch($obj->source_id); print $objectstaticmember->getNomUrl(1); } elseif ($obj->source_type == 'user') { $objectstaticuser->fetch($obj->source_id); print $objectstaticuser->getNomUrl(1); } elseif ($obj->source_type == 'thirdparty') { $objectstaticcompany->fetch($obj->source_id); print $objectstaticcompany->getNomUrl(1); } elseif ($obj->source_type == 'contact') { $objectstaticcontact->fetch($obj->source_id); print $objectstaticcontact->getNomUrl(1); } elseif ($obj->source_type == 'eventorganizationattendee') { $objectstaticeventorganization->fetch($obj->source_id); print $objectstaticeventorganization->getNomUrl(1); } else { print $obj->source_url; } } print ''; print dol_print_date($db->jdate($obj->tms), 'dayhour', 'tzuserrel'); print ''; if ($obj->status != $object::STATUS_DRAFT) { // If status of target line is not draft // Date sent print dol_print_date($db->jdate($obj->date_envoi), 'dayhour', 'tzuserrel'); // @TODO Must store date in date format } print ''; if ($obj->status == $object::STATUS_DRAFT) { // If status of target line is not draft print $object::libStatutDest((int) $obj->status, 2, ''); } else { print $object::libStatutDest((int) $obj->status, 2, $obj->error_text); } print ''; print ''; if ($obj->status == $object::STATUS_DRAFT) { // If status of target line is not sent yet if ($user->hasRight('mailing', 'creer')) { print ''.img_delete($langs->trans("RemoveRecipient")).''; } } /*if ($obj->status == -1) // Sent with error { print ''.$langs->trans("Retry").''; }*/ print '
'; print ''.$langs->trans("NoTargetYet").''; print '
'; print ''.$langs->trans("NoRecordFound").''; print '

"; print '
'; print '
'; $db->free($resql); } else { dol_print_error($db); } print "\n\n"; } // End of page llxFooter(); $db->close();