25 include_once DOL_DOCUMENT_ROOT.
'/core/modules/mailings/modules_mailings.php';
33 public $name =
'DolibarrUsers';
35 public $desc =
'Dolibarr users with emails';
36 public $require_module = array();
37 public $require_admin = 1;
42 public $picto =
'user';
73 $langs->load(
"users");
76 $sql =
"SELECT '".$this->db->escape($langs->trans(
"DolibarrUsers")).
"' as label,";
77 $sql .=
" count(distinct(u.email)) as nb";
78 $sql .=
" FROM ".MAIN_DB_PREFIX.
"user as u";
79 $sql .=
" WHERE u.email != ''";
80 $sql .=
" AND u.entity IN (0,".$conf->entity.
")";
99 $sql =
"SELECT count(distinct(u.email)) as nb";
100 $sql .=
" FROM ".MAIN_DB_PREFIX.
"user as u";
101 $sql .=
" WHERE u.email != ''";
102 $sql .=
" AND u.entity IN (0,".$conf->entity.
")";
106 return parent::getNbOfRecipients($sql);
119 $langs->load(
"users");
122 $s .= $langs->trans(
"Status").
': ';
123 $s .=
'<select name="filter" class="flat">';
124 $s .=
'<option value="-1"> </option>';
125 $s .=
'<option value="1">'.$langs->trans(
"Enabled").
'</option>';
126 $s .=
'<option value="0">'.$langs->trans(
"Disabled").
'</option>';
130 $s .= $langs->trans(
"Employee").
': ';
131 $s .=
'<select name="filteremployee" class="flat">';
132 $s .=
'<option value="-1"> </option>';
133 $s .=
'<option value="1">'.$langs->trans(
"Yes").
'</option>';
134 $s .=
'<option value="0">'.$langs->trans(
"No").
'</option>';
149 return '<a href="'.DOL_URL_ROOT.
'/user/card.php?id='.$id.
'">'.
img_object(
'',
"user").
'</a>';
163 global $conf, $langs;
164 $langs->load(
"companies");
169 $sql =
"SELECT u.rowid as id, u.email as email, null as fk_contact,";
170 $sql .=
" u.lastname, u.firstname as firstname, u.civility as civility_id, u.login, u.office_phone";
171 $sql .=
" FROM ".MAIN_DB_PREFIX.
"user as u";
172 $sql .=
" WHERE u.email <> ''";
173 $sql .=
" AND u.entity IN (0,".$conf->entity.
")";
174 $sql .=
" AND u.email NOT IN (SELECT email FROM ".MAIN_DB_PREFIX.
"mailing_cibles WHERE fk_mailing=".$mailing_id.
")";
177 if (
GETPOSTISSET(
"filteremployee") && GETPOSt(
"filteremployee") ==
'1') $sql .=
" AND u.employee=1";
178 if (
GETPOSTISSET(
"filteremployee") &&
GETPOST(
"filteremployee") ==
'0') $sql .=
" AND u.employee=0";
179 $sql .=
" ORDER BY u.email";
182 $result = $this->
db->query($sql);
185 $num = $this->
db->num_rows($result);
189 dol_syslog(get_class($this).
"::add_to_target mailing ".$num.
" targets found");
194 $obj = $this->
db->fetch_object($result);
195 if ($old <> $obj->email)
198 'email' => $obj->email,
199 'fk_contact' => $obj->fk_contact,
200 'lastname' => $obj->lastname,
201 'firstname' => $obj->firstname,
203 ($langs->transnoentities(
"Login").
'='.$obj->login).
';'.
204 ($langs->transnoentities(
"UserTitle").
'='.$obj->civility_id).
';'.
205 ($langs->transnoentities(
"PhonePro").
'='.$obj->office_phone),
206 'source_url' => $this->
url($obj->id),
207 'source_id' => $obj->id,
208 'source_type' =>
'user'
218 $this->error = $this->
db->error();
222 return parent::addTargetsToDatabase($mailing_id, $cibles);
add_to_target($mailing_id)
Ajoute destinataires dans table des cibles.
GETPOST($paramname, $check= 'alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
Class to offer a selector of emailing targets with Rule 'Peche'.
formFilter()
Affiche formulaire de filtre qui apparait dans page de selection des destinataires de mailings...
$conf db
API class for accounts.
GETPOSTISSET($paramname)
Return true if we are in a context of submitting the parameter $paramname.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename= '', $restricttologhandler= '', $logcontext=null)
Write log message into outputs.
img_object($titlealt, $picto, $moreatt= '', $pictoisfullpath=false, $srconly=0, $notitle=0)
Show a picto called object_picto (generic function)
getNbOfRecipients($sql= '')
Return here number of distinct emails returned by your selector.
getSqlArrayForStats()
On the main mailing area, there is a box with statistics.
url($id)
Renvoie url lien vers fiche de la source du destinataire du mailing.
__construct($db)
Constructor.
Parent class of emailing target selectors modules.