dolibarr 19.0.4
cibles.php
Go to the documentation of this file.
1<?php
2/* Copyright (C) 2004 Rodolphe Quiedeville <rodolphe@quiedeville.org>
3 * Copyright (C) 2005-2023 Laurent Destailleur <eldy@uers.sourceforge.net>
4 * Copyright (C) 2005-2010 Regis Houssin <regis.houssin@inodbox.com>
5 * Copyright (C) 2014 Florian Henry <florian.henry@open-concept.pro>
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program. If not, see <https://www.gnu.org/licenses/>.
19 */
20
27// Load Dolibarr environment
28require '../../main.inc.php';
29require_once DOL_DOCUMENT_ROOT.'/core/modules/mailings/modules_mailings.php';
30require_once DOL_DOCUMENT_ROOT.'/comm/mailing/class/mailing.class.php';
31require_once DOL_DOCUMENT_ROOT.'/core/class/html.formmailing.class.php';
32require_once DOL_DOCUMENT_ROOT.'/core/lib/emailing.lib.php';
33require_once DOL_DOCUMENT_ROOT.'/core/class/CMailFile.class.php';
34require_once DOL_DOCUMENT_ROOT.'/core/lib/functions2.lib.php';
35require_once DOL_DOCUMENT_ROOT.'/core/lib/ajax.lib.php';
36
37// Load translation files required by the page
38$langs->loadLangs(array("mails", "admin"));
39
40// Load variable for pagination
41$limit = GETPOST('limit', 'int') ? GETPOST('limit', 'int') : $conf->liste_limit;
42$sortfield = GETPOST('sortfield', 'aZ09comma');
43$sortorder = GETPOST('sortorder', 'aZ09comma');
44$page = GETPOSTISSET('pageplusone') ? (GETPOST('pageplusone') - 1) : GETPOST("page", 'int');
45if (empty($page) || $page == -1) {
46 $page = 0;
47} // If $page is not defined, or '' or -1
48$offset = $limit * $page;
49$pageprev = $page - 1;
50$pagenext = $page + 1;
51if (!$sortfield) {
52 $sortfield = "mc.statut,email";
53}
54if (!$sortorder) {
55 $sortorder = "DESC,ASC";
56}
57
58$id = GETPOST('id', 'int');
59$rowid = GETPOST('rowid', 'int');
60$action = GETPOST('action', 'aZ09');
61$search_lastname = GETPOST("search_lastname", 'alphanohtml');
62$search_firstname = GETPOST("search_firstname", 'alphanohtml');
63$search_email = GETPOST("search_email", 'alphanohtml');
64$search_other = GETPOST("search_other", 'alphanohtml');
65$search_dest_status = GETPOST('search_dest_status', 'int');
66
67// Search modules dirs
68$modulesdir = dolGetModulesDirs('/mailings');
69
70$object = new Mailing($db);
71$result = $object->fetch($id);
72
73// Initialize technical object to manage hooks of page. Note that conf->hooks_modules contains array of hook context
74$hookmanager->initHooks(array('ciblescard', 'globalcard'));
75
76$sqlmessage = '';
77
78// List of sending methods
79$listofmethods = array();
80//$listofmethods['default'] = $langs->trans('DefaultOutgoingEmailSetup');
81$listofmethods['mail'] = 'PHP mail function';
82//$listofmethods['simplemail']='Simplemail class';
83$listofmethods['smtps'] = 'SMTP/SMTPS socket library';
84if (version_compare(phpversion(), '7.0', '>=')) {
85 $listofmethods['swiftmailer'] = 'Swift Mailer socket library';
86}
87
88// Security check
89if (!$user->hasRight('mailing', 'lire') || (!getDolGlobalString('EXTERNAL_USERS_ARE_AUTHORIZED') && $user->socid > 0)) {
91}
92//$result = restrictedArea($user, 'mailing');
93
94
95/*
96 * Actions
97 */
98
99if ($action == 'add' && $user->hasRight('mailing', 'creer')) { // Add recipients
100 $module = GETPOST("module", 'alpha');
101 $result = -1;
102
103 foreach ($modulesdir as $dir) {
104 // Load modules attributes in arrays (name, numero, orders) from dir directory
105 //print $dir."\n<br>";
106 dol_syslog("Scan directory ".$dir." for modules");
107
108 // Loading Class
109 $file = $dir."/".$module.".modules.php";
110 $classname = "mailing_".$module;
111
112 if (file_exists($file)) {
113 include_once $file;
114
115 // Add targets into database
116 dol_syslog("Call add_to_target() on class ".$classname." evenunsubscribe=".$object->evenunsubscribe);
117
118 if (class_exists($classname)) {
119 $obj = new $classname($db);
120 $obj->evenunsubscribe = $object->evenunsubscribe;
121
122 $result = $obj->add_to_target($id);
123
124 $sqlmessage = $obj->sql;
125 } else {
126 $result = -1;
127 break;
128 }
129 }
130 }
131 if ($result > 0) {
132 setEventMessages($langs->trans("XTargetsAdded", $result), null, 'mesgs');
133 $action = '';
134 }
135 if ($result == 0) {
136 setEventMessages($langs->trans("WarningNoEMailsAdded"), null, 'warnings');
137 }
138 if ($result < 0) {
139 setEventMessages($langs->trans("Error").($obj->error ? ' '.$obj->error : ''), null, 'errors');
140 }
141}
142
143if (GETPOST('clearlist', 'int') && $user->hasRight('mailing', 'creer')) {
144 // Loading Class
145 $obj = new MailingTargets($db);
146 $obj->clear_target($id);
147 /* Avoid this to allow reposition
148 header("Location: ".$_SERVER['PHP_SELF']."?id=".$id);
149 exit;
150 */
151}
152
153if (GETPOST('exportcsv', 'int') && $user->hasRight('mailing', 'lire')) {
154 $completefilename = 'targets_emailing'.$object->id.'_'.dol_print_date(dol_now(), 'dayhourlog').'.csv';
155 header('Content-Type: text/csv');
156 header('Content-Disposition: attachment;filename='.$completefilename);
157
158 // List of selected targets
159 $sql = "SELECT mc.rowid, mc.lastname, mc.firstname, mc.email, mc.other, mc.statut as status, mc.date_envoi, mc.tms,";
160 $sql .= " mc.source_id, mc.source_type, mc.error_text";
161 $sql .= " FROM ".MAIN_DB_PREFIX."mailing_cibles as mc";
162 $sql .= " WHERE mc.fk_mailing = ".((int) $object->id);
163 $sql .= $db->order($sortfield, $sortorder);
164
165 $resql = $db->query($sql);
166 if ($resql) {
167 $num = $db->num_rows($resql);
168 $sep = ',';
169
170 while ($obj = $db->fetch_object($resql)) {
171 print $obj->rowid.$sep;
172 print '"'.$obj->lastname.'"'.$sep;
173 print '"'.$obj->firstname.'"'.$sep;
174 print $obj->email.$sep;
175 print $obj->other.$sep;
176 print $obj->tms.$sep;
177 print $obj->source_type.$sep;
178 print $obj->source_id.$sep;
179 print $obj->date_envoi.$sep;
180 print $obj->status.$sep;
181 print '"'.$obj->error_text.'"'.$sep;
182 print "\n";
183 }
184
185 exit;
186 } else {
187 dol_print_error($db);
188 }
189 exit;
190}
191
192if ($action == 'delete' && $user->hasRight('mailing', 'creer')) {
193 // Ici, rowid indique le destinataire et id le mailing
194 $sql = "DELETE FROM ".MAIN_DB_PREFIX."mailing_cibles WHERE rowid = ".((int) $rowid);
195 $resql = $db->query($sql);
196 if ($resql) {
197 if (!empty($id)) {
198 $obj = new MailingTargets($db);
199 $obj->update_nb($id);
200
201 setEventMessages($langs->trans("RecordDeleted"), null, 'mesgs');
202 } else {
203 header("Location: list.php");
204 exit;
205 }
206 } else {
207 dol_print_error($db);
208 }
209}
210
211// Purge search criteria
212if (GETPOST('button_removefilter_x', 'alpha') || GETPOST('button_removefilter.x', 'alpha') || GETPOST('button_removefilter', 'alpha')) { // All tests are required to be compatible with all browsers
213 $search_lastname = '';
214 $search_firstname = '';
215 $search_email = '';
216 $search_other = '';
217 $search_dest_status = '';
218}
219
220// Action update description of emailing
221if ($action == 'settitle' || $action == 'setemail_from' || $action == 'setreplyto' || $action == 'setemail_errorsto' || $action == 'setevenunsubscribe') {
222 $upload_dir = $conf->mailing->dir_output."/".get_exdir($object->id, 2, 0, 1, $object, 'mailing');
223
224 if ($action == 'settitle') {
225 $object->title = trim(GETPOST('title', 'alpha'));
226 } elseif ($action == 'setemail_from') {
227 $object->email_from = trim(GETPOST('email_from', 'alphawithlgt')); // Must allow 'name <email>'
228 } elseif ($action == 'setemail_replyto') {
229 $object->email_replyto = trim(GETPOST('email_replyto', 'alphawithlgt')); // Must allow 'name <email>'
230 } elseif ($action == 'setemail_errorsto') {
231 $object->email_errorsto = trim(GETPOST('email_errorsto', 'alphawithlgt')); // Must allow 'name <email>'
232 } elseif ($action == 'settitle' && empty($object->title)) {
233 $mesg = $langs->trans("ErrorFieldRequired", $langs->transnoentities("MailTitle"));
234 } elseif ($action == 'setfrom' && empty($object->email_from)) {
235 $mesg = $langs->trans("ErrorFieldRequired", $langs->transnoentities("MailFrom"));
236 } elseif ($action == 'setevenunsubscribe') {
237 $object->evenunsubscribe = (GETPOST('evenunsubscribe') ? 1 : 0);
238 }
239
240 if (!$mesg) {
241 $result = $object->update($user);
242 if ($result >= 0) {
243 header("Location: ".$_SERVER['PHP_SELF']."?id=".$object->id);
244 exit;
245 }
246 $mesg = $object->error;
247 }
248
249 setEventMessages($mesg, null, 'errors');
250 $action = "";
251}
252
253
254/*
255 * View
256 */
257
258llxHeader('', $langs->trans("Mailing"), 'EN:Module_EMailing|FR:Module_Mailing|ES:M&oacute;dulo_Mailing');
259
260$form = new Form($db);
261$formmailing = new FormMailing($db);
262
263if ($object->fetch($id) >= 0) {
264 $head = emailing_prepare_head($object);
265
266 print dol_get_fiche_head($head, 'targets', $langs->trans("Mailing"), -1, 'email');
267
268 $linkback = '<a href="'.DOL_URL_ROOT.'/comm/mailing/list.php?restore_lastsearch_values=1">'.$langs->trans("BackToList").'</a>';
269
270 $morehtmlref = '<div class="refidno">';
271 // Ref customer
272 $morehtmlref .= $form->editfieldkey("", 'title', $object->title, $object, 0, 'string', '', 0, 1);
273 $morehtmlref .= $form->editfieldval("", 'title', $object->title, $object, 0, 'string', '', null, null, '', 1);
274 $morehtmlref .= '</div>';
275
276 $morehtmlright = '';
277 $nbtry = $nbok = 0;
278 if ($object->statut == $object::STATUS_SENTPARTIALY || $object->statut == $object::STATUS_SENTCOMPLETELY) {
279 $nbtry = $object->countNbOfTargets('alreadysent');
280 $nbko = $object->countNbOfTargets('alreadysentko');
281 $nbok = ($nbtry - $nbko);
282
283 $morehtmlright .= ' ('.$nbtry.'/'.$object->nbemail;
284 if ($nbko) {
285 $morehtmlright .= ' - '.$nbko.' '.$langs->trans("Error");
286 }
287 $morehtmlright .= ') &nbsp; ';
288 }
289
290 dol_banner_tab($object, 'id', $linkback, 1, 'rowid', 'ref', $morehtmlref, '', 0, '', $morehtmlright);
291
292 print '<div class="fichecenter">';
293 print '<div class="fichehalfleft">';
294 print '<div class="underbanner clearboth"></div>';
295
296 print '<table class="border centpercent tableforfield">';
297
298 print '<tr><td class="titlefield">'.$langs->trans("MailFrom").'</td><td>';
299 $emailarray = CMailFile::getArrayAddress($object->email_from);
300 foreach ($emailarray as $email => $name) {
301 if ($name && $name != $email) {
302 print dol_escape_htmltag($name).' &lt;'.$email;
303 print '&gt;';
304 if (!isValidEmail($email)) {
305 $langs->load("errors");
306 print img_warning($langs->trans("ErrorBadEMail", $email));
307 }
308 } else {
309 print dol_print_email($object->email_from, 0, 0, 0, 0, 1);
310 }
311 }
312 //print dol_print_email($object->email_from, 0, 0, 0, 0, 1);
313 //var_dump($object->email_from);
314 print '</td></tr>';
315
316 // Errors to
317 print '<tr><td>'.$langs->trans("MailErrorsTo").'</td><td>';
318 $emailarray = CMailFile::getArrayAddress($object->email_errorsto);
319 foreach ($emailarray as $email => $name) {
320 if ($name != $email) {
321 print dol_escape_htmltag($name).' &lt;'.$email;
322 print '&gt;';
323 if (!isValidEmail($email)) {
324 $langs->load("errors");
325 print img_warning($langs->trans("ErrorBadEMail", $email));
326 }
327 } else {
328 print dol_print_email($object->email_errorsto, 0, 0, 0, 0, 1);
329 }
330 }
331 print '</td></tr>';
332
333 print '</table>';
334 print '</div>';
335
336
337 print '<div class="fichehalfright">';
338 print '<div class="underbanner clearboth"></div>';
339
340 print '<table class="border centpercent tableforfield">';
341
342 // Number of distinct emails
343 print '<tr><td class="titlefield">';
344 print $langs->trans("TotalNbOfDistinctRecipients");
345 print '</td><td>';
346 $nbemail = ($object->nbemail ? $object->nbemail : 0);
347 if (is_numeric($nbemail)) {
348 $text = '';
349 if ((getDolGlobalString('MAILING_LIMIT_SENDBYWEB') && $conf->global->MAILING_LIMIT_SENDBYWEB < $nbemail) && ($object->statut == 1 || ($object->statut == 2 && $nbtry < $nbemail))) {
350 if (getDolGlobalInt('MAILING_LIMIT_SENDBYWEB') > 0) {
351 $text .= $langs->trans('LimitSendingEmailing', $conf->global->MAILING_LIMIT_SENDBYWEB);
352 } else {
353 $text .= $langs->trans('SendingFromWebInterfaceIsNotAllowed');
354 }
355 }
356 if (empty($nbemail)) {
357 $nbemail .= ' '.img_warning($langs->trans('ToAddRecipientsChooseHere'));//.' <span class="warning">'.$langs->trans("NoTargetYet").'</span>';
358 }
359 if ($text) {
360 print $form->textwithpicto($nbemail, $text, 1, 'warning');
361 } else {
362 print $nbemail;
363 }
364 }
365 print '</td></tr>';
366
367 print '<tr><td>';
368 print $langs->trans("MAIN_MAIL_SENDMODE");
369 print '</td><td>';
370 if (getDolGlobalString('MAIN_MAIL_SENDMODE_EMAILING') && getDolGlobalString('MAIN_MAIL_SENDMODE_EMAILING') != 'default') {
371 $text = $listofmethods[getDolGlobalString('MAIN_MAIL_SENDMODE_EMAILING')];
372 } elseif (getDolGlobalString('MAIN_MAIL_SENDMODE')) {
373 $text = $listofmethods[getDolGlobalString('MAIN_MAIL_SENDMODE')];
374 } else {
375 $text = $listofmethods['mail'];
376 }
377 print $text;
378 if (getDolGlobalString('MAIN_MAIL_SENDMODE_EMAILING') != 'default') {
379 if (getDolGlobalString('MAIN_MAIL_SENDMODE_EMAILING') != 'mail') {
380 print ' <span class="opacitymedium">('.getDolGlobalString('MAIN_MAIL_SMTP_SERVER_EMAILING').')</span>';
381 }
382 } elseif (getDolGlobalString('MAIN_MAIL_SENDMODE') != 'mail' && getDolGlobalString('MAIN_MAIL_SMTP_SERVER')) {
383 print ' <span class="opacitymedium">('.getDolGlobalString('MAIN_MAIL_SMTP_SERVER').')</span>';
384 }
385 print '</td></tr>';
386
387 // Other attributes. Fields from hook formObjectOptions and Extrafields.
388 include DOL_DOCUMENT_ROOT.'/core/tpl/extrafields_view.tpl.php';
389
390 print '</table>';
391 print '</div>';
392 print '</div>';
393
394 print '<div class="clearboth"></div>';
395
396 print dol_get_fiche_end();
397
398 print '<br>';
399
400
401 $allowaddtarget = ($object->statut == $object::STATUS_DRAFT);
402
403 // Show email selectors
404 if ($allowaddtarget && $user->hasRight('mailing', 'creer')) {
405 print load_fiche_titre($langs->trans("ToAddRecipientsChooseHere"), ($user->admin ? info_admin($langs->trans("YouCanAddYourOwnPredefindedListHere"), 1) : ''), 'generic');
406
407 print '<div class="div-table-responsive">';
408 print '<div class="tagtable centpercentwithout1imp liste_titre_bydiv borderbottom" id="tablelines">';
409
410 print '<div class="tagtr liste_titre">';
411 print '<div class="tagtd"></div>';
412 print '<div class="tagtd">'.$langs->trans("RecipientSelectionModules").'</div>';
413 print '<div class="tagtd center maxwidth150">'.$langs->trans("NbOfUniqueEMails").'</div>';
414 print '<div class="tagtd left"><div class="inline-block">'.$langs->trans("Filters").'</div>';
415 print ' &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <div class=" inline-block">'.$langs->trans("EvenUnsubscribe").' ';
416 print ajax_object_onoff($object, 'evenunsubscribe', 'evenunsubscribe', 'EvenUnsubscribe:switch_on:warning', 'EvenUnsubscribe', array(), 'small valignmiddle', '', 1);
417 print '</div>';
418 print '</div>';
419 print '<div class="tagtd">&nbsp;</div>';
420 print '</div>'; // End tr
421
422 clearstatcache();
423
424 foreach ($modulesdir as $dir) {
425 $modulenames = array();
426
427 // Load modules attributes in arrays (name, numero, orders) from dir directory
428 //print $dir."\n<br>";
429 dol_syslog("Scan directory ".$dir." for modules");
430 $handle = @opendir($dir);
431 if (is_resource($handle)) {
432 while (($file = readdir($handle)) !== false) {
433 if (substr($file, 0, 1) != '.' && substr($file, 0, 3) != 'CVS') {
434 $reg = array();
435 if (preg_match("/(.*)\.modules\.php$/i", $file, $reg)) {
436 if ($reg[1] == 'example') {
437 continue;
438 }
439 $modulenames[] = $reg[1];
440 }
441 }
442 }
443 closedir($handle);
444 }
445
446 // Sort $modulenames
447 sort($modulenames);
448
449 $var = true;
450
451 // Loop on each submodule
452 foreach ($modulenames as $modulename) {
453 // Loading Class
454 $file = $dir.$modulename.".modules.php";
455 $classname = "mailing_".$modulename;
456 require_once $file;
457
458 $obj = new $classname($db);
459
460 // Check if qualified
461 $qualified = (is_null($obj->enabled) ? 1 : dol_eval($obj->enabled, 1));
462
463 // Check dependencies
464 foreach ($obj->require_module as $key) {
465 if (empty($conf->$key->enabled) || (empty($user->admin) && $obj->require_admin)) {
466 $qualified = 0;
467 //print "Les prerequis d'activation du module mailing ne sont pas respectes. Il ne sera pas actif";
468 break;
469 }
470 }
471
472 // If module is qualified
473 if ($qualified) {
474 $var = !$var;
475
476 if ($allowaddtarget) {
477 print '<form '.$bctag[$var].' name="'.$modulename.'" action="'.$_SERVER['PHP_SELF'].'?id='.$object->id.'&module='.$modulename.'" method="POST" enctype="multipart/form-data">';
478 print '<input type="hidden" name="token" value="'.newToken().'">';
479 print '<input type="hidden" name="action" value="add">';
480 print '<input type="hidden" name="page_y" value="'.newToken().'">';
481 } else {
482 print '<div '.$bctag[$var].'>';
483 }
484
485 print '<div class="tagtd paddingleftimp marginleftonly paddingrightimp marginrightonly valignmiddle center">';
486 if (empty($obj->picto)) {
487 $obj->picto = 'generic';
488 }
489 print img_object($langs->trans("EmailingTargetSelector").': '.get_class($obj), $obj->picto, 'class="valignmiddle width25 size15x"');
490 print '</div>';
491 print '<div class="tagtd valignmiddle">'; // style="height: 4em"
492 print $obj->getDesc();
493 print '</div>';
494
495 try {
496 $obj->evenunsubscribe = $object->evenunsubscribe; // Set flag to include/exclude email that has opt-out.
497
498 $nbofrecipient = $obj->getNbOfRecipients('');
499 } catch (Exception $e) {
500 dol_syslog($e->getMessage(), LOG_ERR);
501 }
502
503 print '<div class="tagtd center valignmiddle">';
504 if ($nbofrecipient === '' || $nbofrecipient >= 0) {
505 print $nbofrecipient;
506 } else {
507 print $langs->trans("Error").' '.img_error($obj->error);
508 }
509 print '</div>';
510
511 print '<div class="tagtd left valignmiddle">';
512 if ($allowaddtarget) {
513 try {
514 $filter = $obj->formFilter();
515 } catch (Exception $e) {
516 dol_syslog($e->getMessage(), LOG_ERR);
517 }
518 if ($filter) {
519 print $filter;
520 } else {
521 print $langs->trans("None");
522 }
523 }
524 print '</div>';
525
526 print '<div class="tagtd right valignmiddle">';
527 if ($allowaddtarget) {
528 print '<input type="submit" class="button button-add small reposition" name="button_'.$modulename.'" value="'.$langs->trans("Add").'">';
529 } else {
530 print '<input type="submit" class="button small disabled" disabled="disabled" name="button_'.$modulename.'" value="'.$langs->trans("Add").'">';
531 //print $langs->trans("MailNoChangePossible");
532 print "&nbsp;";
533 }
534 print '</div>';
535
536 if ($allowaddtarget) {
537 print '</form>';
538 } else {
539 print '</div>';
540 }
541 }
542 }
543 } // End foreach dir
544
545 $parameters = array();
546 $reshook = $hookmanager->executeHooks('formObjectOptions', $parameters, $object, $action); // Note that $action and $object may have been modified by hook
547 print $hookmanager->resPrint;
548
549 print '</div>'; // End table
550 print '</div>';
551
552 print '<br>';
553
554 if ($sqlmessage && $user->admin) {
555 print info_admin($langs->trans("SQLUsedForExport").':<br> '.$sqlmessage, 0, 0, 1, '', 'TechnicalInformation');
556 print '<br>';
557 }
558
559 print '<br>';
560 }
561
562 // List of selected targets
563 $sql = "SELECT mc.rowid, mc.lastname, mc.firstname, mc.email, mc.other, mc.statut, mc.date_envoi, mc.tms,";
564 $sql .= " mc.source_url, mc.source_id, mc.source_type, mc.error_text,";
565 $sql .= " COUNT(mu.rowid) as nb";
566 $sql .= " FROM ".MAIN_DB_PREFIX."mailing_cibles as mc";
567 $sql .= " LEFT JOIN ".MAIN_DB_PREFIX."mailing_unsubscribe as mu ON mu.email = mc.email";
568 $sql .= " WHERE mc.fk_mailing=".((int) $object->id);
569 $asearchcriteriahasbeenset = 0;
570 if ($search_lastname) {
571 $sql .= natural_search("mc.lastname", $search_lastname);
572 $asearchcriteriahasbeenset++;
573 }
574 if ($search_firstname) {
575 $sql .= natural_search("mc.firstname", $search_firstname);
576 $asearchcriteriahasbeenset++;
577 }
578 if ($search_email) {
579 $sql .= natural_search("mc.email", $search_email);
580 $asearchcriteriahasbeenset++;
581 }
582 if ($search_other) {
583 $sql .= natural_search("mc.other", $search_other);
584 $asearchcriteriahasbeenset++;
585 }
586 if ($search_dest_status != '' && $search_dest_status >= -1) {
587 $sql .= " AND mc.statut = ".((int) $search_dest_status);
588 $asearchcriteriahasbeenset++;
589 }
590 $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';
591 $sql .= $db->order($sortfield, $sortorder);
592
593
594 // Count total nb of records
595 $nbtotalofrecords = '';
596 if (!getDolGlobalInt('MAIN_DISABLE_FULL_SCANLIST')) {
597 $result = $db->query($sql);
598 $nbtotalofrecords = $db->num_rows($result);
599 if (($page * $limit) > $nbtotalofrecords) { // if total resultset is smaller then paging size (filtering), goto and load page 0
600 $page = 0;
601 $offset = 0;
602 }
603
604 // Fix/update nbemail on emailing record if it differs (may happen if user edit lines from database directly)
605 if (empty($asearchcriteriahasbeenset)) {
606 if ($nbtotalofrecords != $object->nbemail) {
607 dol_syslog("We found a difference in nb of record in target table and the property ->nbemail, we fix ->nbemail");
608 //print "nbemail=".$object->nbemail." nbtotalofrecords=".$nbtotalofrecords;
609 $resultrefresh = $object->refreshNbOfTargets();
610 if ($resultrefresh < 0) {
611 dol_print_error($db, $object->error, $object->errors);
612 }
613 }
614 }
615 }
616
617 //$nbtotalofrecords=$object->nbemail; // nbemail is a denormalized field storing nb of targets
618 $sql .= $db->plimit($limit + 1, $offset);
619
620 $resql = $db->query($sql);
621 if ($resql) {
622 $num = $db->num_rows($resql);
623
624 $param = "&id=".$object->id;
625 //if (!empty($contextpage) && $contextpage != $_SERVER["PHP_SELF"]) $param.='&contextpage='.urlencode($contextpage);
626 if ($limit > 0 && $limit != $conf->liste_limit) {
627 $param .= '&limit='.((int) $limit);
628 }
629 if ($search_lastname) {
630 $param .= "&search_lastname=".urlencode($search_lastname);
631 }
632 if ($search_firstname) {
633 $param .= "&search_firstname=".urlencode($search_firstname);
634 }
635 if ($search_email) {
636 $param .= "&search_email=".urlencode($search_email);
637 }
638 if ($search_other) {
639 $param .= "&search_other=".urlencode($search_other);
640 }
641
642 print '<form method="POST" action="'.$_SERVER["PHP_SELF"].'">';
643 print '<input type="hidden" name="token" value="'.newToken().'">';
644 print '<input type="hidden" name="sortfield" value="'.$sortfield.'">';
645 print '<input type="hidden" name="sortorder" value="'.$sortorder.'">';
646 print '<input type="hidden" name="page" value="'.$page.'">';
647 print '<input type="hidden" name="id" value="'.$object->id.'">';
648 print '<input type="hidden" name="page_y" value="">';
649
650 $morehtmlcenter = '';
651 if ($allowaddtarget) {
652 $morehtmlcenter = '<span class="opacitymedium hideonsmartphone">'.$langs->trans("ToClearAllRecipientsClickHere").'</span> <a href="'.$_SERVER["PHP_SELF"].'?clearlist=1&id='.$object->id.'" class="button reposition smallpaddingimp">'.$langs->trans("TargetsReset").'</a>';
653 }
654 $morehtmlcenter .= ' &nbsp; <a class="reposition" href="'.$_SERVER["PHP_SELF"].'?action=exportcsv&token='.newToken().'&exportcsv=1&id='.$object->id.'">'.img_picto('', 'download', 'class="pictofixedwidth"').$langs->trans("Download").'</a>';
655
656 $massactionbutton = '';
657
658 print_barre_liste($langs->trans("MailSelectedRecipients"), $page, $_SERVER["PHP_SELF"], $param, $sortfield, $sortorder, $morehtmlcenter, $num, $nbtotalofrecords, 'generic', 0, '', '', $limit, 0, 0, 1);
659
660 print '</form>';
661
662 print "\n<!-- Liste destinataires selectionnes -->\n";
663 print '<form method="POST" action="'.$_SERVER["PHP_SELF"].'">';
664 print '<input type="hidden" name="token" value="'.newToken().'">';
665 print '<input type="hidden" name="sortfield" value="'.$sortfield.'">';
666 print '<input type="hidden" name="sortorder" value="'.$sortorder.'">';
667 print '<input type="hidden" name="page" value="'.$page.'">';
668 print '<input type="hidden" name="id" value="'.$object->id.'">';
669 print '<input type="hidden" name="limit" value="'.$limit.'">';
670 print '<input type="hidden" name="page_y" value="">';
671
672 print '<div class="div-table-responsive">';
673 print '<table class="noborder centpercent">';
674
675 // Ligne des champs de filtres
676 print '<tr class="liste_titre_filter">';
677
678 // Action column
679 if (getDolGlobalString('MAIN_CHECKBOX_LEFT_COLUMN')) {
680 print '<td class="liste_titre maxwidthsearch">';
681 $searchpicto = $form->showFilterAndCheckAddButtons($massactionbutton ? 1 : 0, 'checkforselect', 1);
682 print $searchpicto;
683 print '</td>';
684 }
685 // EMail
686 print '<td class="liste_titre">';
687 print '<input class="flat maxwidth75" type="text" name="search_email" value="'.dol_escape_htmltag($search_email).'">';
688 print '</td>';
689 // Name
690 print '<td class="liste_titre">';
691 print '<input class="flat maxwidth50" type="text" name="search_lastname" value="'.dol_escape_htmltag($search_lastname).'">';
692 print '</td>';
693 // Firstname
694 print '<td class="liste_titre">';
695 print '<input class="flat maxwidth50" type="text" name="search_firstname" value="'.dol_escape_htmltag($search_firstname).'">';
696 print '</td>';
697 // Other
698 print '<td class="liste_titre">';
699 print '<input class="flat maxwidth100" type="text" name="search_other" value="'.dol_escape_htmltag($search_other).'">';
700 print '</td>';
701 // Source
702 print '<td class="liste_titre">';
703 print '&nbsp;';
704 print '</td>';
705
706 // Date last update
707 print '<td class="liste_titre">';
708 print '&nbsp;';
709 print '</td>';
710
711 // Date sending
712 print '<td class="liste_titre">';
713 print '&nbsp;';
714 print '</td>';
715
716 // Status
717 print '<td class="liste_titre center parentonrightofpage">';
718 print $formmailing->selectDestinariesStatus($search_dest_status, 'search_dest_status', 1, 'width100 onrightofpage');
719 print '</td>';
720
721 // Action column
722 if (!getDolGlobalString('MAIN_CHECKBOX_LEFT_COLUMN')) {
723 print '<td class="liste_titre maxwidthsearch">';
724 $searchpicto = $form->showFilterAndCheckAddButtons($massactionbutton ? 1 : 0, 'checkforselect', 1);
725 print $searchpicto;
726 print '</td>';
727 }
728
729 print '</tr>';
730
731 if ($page) {
732 $param .= "&page=".urlencode($page);
733 }
734
735 print '<tr class="liste_titre">';
736 // Action column
737 if (getDolGlobalString('MAIN_CHECKBOX_LEFT_COLUMN')) {
738 print_liste_field_titre('', $_SERVER["PHP_SELF"], "", '', '', '', $sortfield, $sortorder, 'maxwidthsearch ');
739 }
740 print_liste_field_titre("EMail", $_SERVER["PHP_SELF"], "mc.email", $param, "", "", $sortfield, $sortorder);
741 print_liste_field_titre("Lastname", $_SERVER["PHP_SELF"], "mc.lastname", $param, "", "", $sortfield, $sortorder);
742 print_liste_field_titre("Firstname", $_SERVER["PHP_SELF"], "mc.firstname", $param, "", "", $sortfield, $sortorder);
743 print_liste_field_titre("OtherInformations", $_SERVER["PHP_SELF"], "", $param, "", "", $sortfield, $sortorder);
744 print_liste_field_titre("Source", $_SERVER["PHP_SELF"], "", $param, "", '', $sortfield, $sortorder, 'center ');
745 // Date last update
746 print_liste_field_titre("DateLastModification", $_SERVER["PHP_SELF"], "mc.tms", $param, "", '', $sortfield, $sortorder, 'center ');
747 // Date sending
748 print_liste_field_titre("DateSending", $_SERVER["PHP_SELF"], "mc.date_envoi", $param, '', '', $sortfield, $sortorder, 'center ');
749 print_liste_field_titre("Status", $_SERVER["PHP_SELF"], "mc.statut", $param, '', '', $sortfield, $sortorder, 'center ');
750 // Action column
751 if (!getDolGlobalString('MAIN_CHECKBOX_LEFT_COLUMN')) {
752 print_liste_field_titre('', $_SERVER["PHP_SELF"], "", '', '', '', $sortfield, $sortorder, 'maxwidthsearch ');
753 }
754 print '</tr>';
755
756 $i = 0;
757
758 if ($num) {
759 include_once DOL_DOCUMENT_ROOT.'/adherents/class/adherent.class.php';
760 include_once DOL_DOCUMENT_ROOT.'/user/class/user.class.php';
761 include_once DOL_DOCUMENT_ROOT.'/societe/class/societe.class.php';
762 include_once DOL_DOCUMENT_ROOT.'/contact/class/contact.class.php';
763 include_once DOL_DOCUMENT_ROOT.'/eventorganization/class/conferenceorboothattendee.class.php';
764 $objectstaticmember = new Adherent($db);
765 $objectstaticuser = new User($db);
766 $objectstaticcompany = new Societe($db);
767 $objectstaticcontact = new Contact($db);
768 $objectstaticeventorganization = new ConferenceOrBoothAttendee($db);
769
770 while ($i < min($num, $limit)) {
771 $obj = $db->fetch_object($resql);
772
773 print '<tr class="oddeven">';
774
775 // Action column
776 if (getDolGlobalString('MAIN_CHECKBOX_LEFT_COLUMN')) {
777 print '<td class="center">';
778 print '<!-- ID mailing_cibles = '.$obj->rowid.' -->';
779 if ($obj->statut == $object::STATUS_DRAFT) { // Not sent yet
780 if ($user->hasRight('mailing', 'creer')) {
781 print '<a class="reposition" href="'.$_SERVER['PHP_SELF'].'?action=delete&token='.newToken().'&rowid='.((int) $obj->rowid).$param.'">'.img_delete($langs->trans("RemoveRecipient")).'</a>';
782 }
783 }
784 /*if ($obj->statut == -1) // Sent with error
785 {
786 print '<a href="'.$_SERVER['PHP_SELF'].'?action=retry&rowid='.$obj->rowid.$param.'">'.$langs->trans("Retry").'</a>';
787 }*/
788 print '</td>';
789 }
790
791 print '<td class="tdoverflowmax150">';
792 print img_picto($obj->email, 'email', 'class="paddingright"');
793 if ($obj->nb > 0) {
794 print img_warning($langs->trans("EmailOptedOut"), 'warning', 'pictofixedwidth');
795 }
796 print dol_escape_htmltag($obj->email);
797 print '</td>';
798
799 print '<td class="tdoverflowmax150" title="'.dol_escape_htmltag($obj->lastname).'">'.dol_escape_htmltag($obj->lastname).'</td>';
800
801 print '<td class="tdoverflowmax150" title="'.dol_escape_htmltag($obj->firstname).'">'.dol_escape_htmltag($obj->firstname).'</td>';
802
803 print '<td><span class="small">'.dol_escape_htmltag($obj->other).'</small></td>';
804
805 print '<td class="center tdoverflowmax150">';
806 if (empty($obj->source_id) || empty($obj->source_type)) {
807 print empty($obj->source_url) ? '' : $obj->source_url; // For backward compatibility
808 } else {
809 if ($obj->source_type == 'member') {
810 $objectstaticmember->fetch($obj->source_id);
811 print $objectstaticmember->getNomUrl(1);
812 } elseif ($obj->source_type == 'user') {
813 $objectstaticuser->fetch($obj->source_id);
814 print $objectstaticuser->getNomUrl(1);
815 } elseif ($obj->source_type == 'thirdparty') {
816 $objectstaticcompany->fetch($obj->source_id);
817 print $objectstaticcompany->getNomUrl(1);
818 } elseif ($obj->source_type == 'contact') {
819 $objectstaticcontact->fetch($obj->source_id);
820 print $objectstaticcontact->getNomUrl(1);
821 } elseif ($obj->source_type == 'eventorganizationattendee') {
822 $objectstaticeventorganization->fetch($obj->source_id);
823 print $objectstaticeventorganization->getNomUrl(1);
824 } else {
825 print $obj->source_url;
826 }
827 }
828 print '</td>';
829
830 // Date last update
831 print '<td class="center nowraponall">';
832 print dol_print_date(dol_stringtotime($obj->tms), 'dayhour');
833 print '</td>';
834
835 // Date sent
836 print '<td class="center nowraponall">';
837 if ($obj->statut != $object::STATUS_DRAFT) {
838 // Date sent
839 print $obj->date_envoi;
840 }
841 print '</td>';
842
843 // Status of recipient sending email (Warning != status of emailing)
844 print '<td class="nowrap center">';
845 if ($obj->statut == $object::STATUS_DRAFT) {
846 print $object::libStatutDest($obj->statut, 2, '');
847 } else {
848 print $object::libStatutDest($obj->statut, 2, $obj->error_text);
849 }
850 print '</td>';
851
852 // Action column
853 if (!getDolGlobalString('MAIN_CHECKBOX_LEFT_COLUMN')) {
854 print '<td class="center">';
855 print '<!-- ID mailing_cibles = '.$obj->rowid.' -->';
856 if ($obj->statut == $object::STATUS_DRAFT) { // Not sent yet
857 if ($user->hasRight('mailing', 'creer')) {
858 print '<a class="reposition" href="'.$_SERVER['PHP_SELF'].'?action=delete&token='.newToken().'&rowid='.((int) $obj->rowid).$param.'">'.img_delete($langs->trans("RemoveRecipient")).'</a>';
859 }
860 }
861 /*if ($obj->statut == -1) // Sent with error
862 {
863 print '<a href="'.$_SERVER['PHP_SELF'].'?action=retry&rowid='.$obj->rowid.$param.'">'.$langs->trans("Retry").'</a>';
864 }*/
865 print '</td>';
866 }
867 print '</tr>';
868
869 $i++;
870 }
871 } else {
872 if ($object->statut < $object::STATUS_SENTPARTIALY) {
873 print '<tr><td colspan="9">';
874 print '<span class="opacitymedium">'.$langs->trans("NoTargetYet").'</span>';
875 print '</td></tr>';
876 } else {
877 print '<tr><td colspan="9">';
878 print '<span class="opacitymedium">'.$langs->trans("NoRecordFound").'</span>';
879 print '</td></tr>';
880 }
881 }
882 print "</table><br>";
883 print '</div>';
884
885 print '</form>';
886
887 $db->free($resql);
888 } else {
889 dol_print_error($db);
890 }
891
892 print "\n<!-- Fin liste destinataires selectionnes -->\n";
893}
894
895// End of page
896llxFooter();
897$db->close();
ajax_object_onoff($object, $code, $field, $text_on, $text_off, $input=array(), $morecss='', $htmlname='', $forcenojs=0)
On/off button to change a property status of an object This uses the ajax service objectonoff....
Definition ajax.lib.php:717
if(!defined('NOREQUIRESOC')) if(!defined( 'NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined( 'NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined( 'NOREQUIREAJAX')) llxHeader()
Empty header.
Definition wrapper.php:55
llxFooter()
Empty footer.
Definition wrapper.php:69
Class to manage members of a foundation.
static getArrayAddress($address)
Return a formatted array of address string for SMTP protocol.
Class for ConferenceOrBoothAttendee.
Class to manage generation of HTML components Only common components must be here.
Class to offer components to list and upload files.
Class to manage emailings module.
Parent class of emailing target selectors modules.
Class to manage third parties objects (customers, suppliers, prospects...)
Class to manage Dolibarr users.
dol_stringtotime($string, $gm=1)
Convert a string date into a GM Timestamps date Warning: YYYY-MM-DDTHH:MM:SS+02:00 (RFC3339) is not s...
Definition date.lib.php:426
emailing_prepare_head(Mailing $object)
Prepare array with list of tabs.
dolGetModulesDirs($subdir='')
Return list of modules directories.
dol_banner_tab($object, $paramid, $morehtml='', $shownav=1, $fieldid='rowid', $fieldref='ref', $morehtmlref='', $moreparam='', $nodbprefix=0, $morehtmlleft='', $morehtmlstatus='', $onlybanner=0, $morehtmlright='')
Show tab footer of a card.
load_fiche_titre($titre, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='')
Load a title with picto.
img_warning($titlealt='default', $moreatt='', $morecss='pictowarning')
Show warning logo.
img_delete($titlealt='default', $other='class="pictodelete"', $morecss='')
Show delete logo.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='', $dragdropfile=0)
Show tabs of a record.
dol_print_error($db='', $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
img_object($titlealt, $picto, $moreatt='', $pictoisfullpath=false, $srconly=0, $notitle=0)
Show a picto called object_picto (generic function)
dol_get_fiche_end($notab=0)
Return tab footer of a card.
natural_search($fields, $value, $mode=0, $nofirstand=0)
Generate natural SQL search string for a criteria (this criteria can be tested on one or several fiel...
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs='', $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
dol_print_email($email, $cid=0, $socid=0, $addlink=0, $max=64, $showinvalid=1, $withpicto=0)
Show EMail link formatted for HTML output.
dol_now($mode='auto')
Return date for now.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=false, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
dol_eval($s, $returnvalue=0, $hideerrors=1, $onlysimplestring='1')
Replace eval function to add more security.
print_liste_field_titre($name, $file="", $field="", $begin="", $moreparam="", $moreattrib="", $sortfield="", $sortorder="", $prefix="", $tooltip="", $forcenowrapcolumntitle=0)
Show title line of an array.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
info_admin($text, $infoonimgalt=0, $nodiv=0, $admin='1', $morecss='hideonsmartphone', $textfordropdown='')
Show information for admin users or standard users.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0)
Set event messages in dol_events session object.
print_barre_liste($titre, $page, $file, $options='', $sortfield='', $sortorder='', $morehtmlcenter='', $num=-1, $totalnboflines='', $picto='generic', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limit=-1, $hideselectlimit=0, $hidenavigation=0, $pagenavastextinput=0, $morehtmlrightbeforearrow='')
Print a title with navigation controls for pagination.
img_error($titlealt='default')
Show error logo.
isValidEmail($address, $acceptsupervisorkey=0, $acceptuserkey=0)
Return true if email syntax is ok.
getDolGlobalString($key, $default='')
Return dolibarr global constant string value.
get_exdir($num, $level, $alpha, $withoutslash, $object, $modulepart='')
Return a path to have a the directory according to object where files are stored.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
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...
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.
Contact()
Old copy.
Definition index.php:572