27include_once DOL_DOCUMENT_ROOT.
'/core/modules/mailings/modules_mailings.php';
38 public $name =
'DolibarrUsers';
43 public $desc =
'Dolibarr users with emails';
48 public $require_module = array();
53 public $require_admin = 1;
58 public $picto =
'user';
84 $langs->load(
"users");
87 $sql =
"SELECT '".$this->db->escape($langs->trans(
"DolibarrUsers")).
"' as label,";
88 $sql .=
" count(distinct(u.email)) as nb";
89 $sql .=
" FROM ".MAIN_DB_PREFIX.
"user as u";
90 $sql .=
" WHERE u.email != ''";
91 $sql .=
" AND u.entity IN (0,".$conf->entity.
")";
111 $sql =
"SELECT count(distinct(u.email)) as nb";
112 $sql .=
" FROM ".MAIN_DB_PREFIX.
"user as u";
113 $sql .=
" WHERE u.email != ''";
114 $sql .=
" AND u.entity IN (0,".$conf->entity.
")";
115 if (empty($this->evenunsubscribe)) {
116 $sql .=
" AND NOT EXISTS (SELECT rowid FROM ".MAIN_DB_PREFIX.
"mailing_unsubscribe as mu WHERE mu.email = u.email and mu.entity = ".((int)
$conf->entity).
")";
120 return parent::getNbOfRecipients($sql);
133 $langs->load(
"users");
136 $s .=
'<select id="filter_pomme"" name="filter" class="flat minwidth100">';
137 $s .=
'<option value="-1">'.$langs->trans(
"Status").
'</option>';
138 $s .=
'<option value="1">'.$langs->trans(
"Enabled").
'</option>';
139 $s .=
'<option value="0">'.$langs->trans(
"Disabled").
'</option>';
144 $s .=
'<select id="filteremployee_pomme" name="filteremployee" class="flat minwidth100">';
145 $s .=
'<option value="-1">'.$langs->trans(
"Employee").
'</option>';
146 $s .=
'<option value="1">'.$langs->trans(
"Yes").
'</option>';
147 $s .=
'<option value="0">'.$langs->trans(
"No").
'</option>';
163 return '<a href="'.DOL_URL_ROOT.
'/user/card.php?id='.
$id.
'">'.
img_object(
'',
"user").
'</a>';
177 global
$conf, $langs;
178 $langs->load(
"companies");
183 $sql =
"SELECT u.rowid as id, u.email as email, null as fk_contact,";
184 $sql .=
" u.lastname, u.firstname as firstname, u.civility as civility_id, u.login, u.office_phone";
185 $sql .=
" FROM ".MAIN_DB_PREFIX.
"user as u";
186 $sql .=
" WHERE u.email <> ''";
187 $sql .=
" AND u.entity IN (0,".$conf->entity.
")";
188 $sql .=
" AND u.email NOT IN (SELECT email FROM ".MAIN_DB_PREFIX.
"mailing_cibles WHERE fk_mailing=".((int) $mailing_id).
")";
189 if (GETPOSTISSET(
"filter") &&
GETPOST(
"filter") ==
'1') {
190 $sql .=
" AND u.statut=1";
192 if (GETPOSTISSET(
"filter") &&
GETPOST(
"filter") ==
'0') {
193 $sql .=
" AND u.statut=0";
195 if (GETPOSTISSET(
"filteremployee") &&
GETPOST(
"filteremployee") ==
'1') {
196 $sql .=
" AND u.employee=1";
198 if (GETPOSTISSET(
"filteremployee") &&
GETPOST(
"filteremployee") ==
'0') {
199 $sql .=
" AND u.employee=0";
201 if (empty($this->evenunsubscribe)) {
202 $sql .=
" AND NOT EXISTS (SELECT rowid FROM ".MAIN_DB_PREFIX.
"mailing_unsubscribe as mu WHERE mu.email = u.email and mu.entity = ".((int)
$conf->entity).
")";
204 $sql .=
" ORDER BY u.email";
207 $result = $this->db->query($sql);
209 $num = $this->db->num_rows($result);
213 dol_syslog(get_class($this).
"::add_to_target mailing ".$num.
" targets found");
217 $obj = $this->db->fetch_object($result);
218 if ($old != $obj->email) {
220 'email' => $obj->email,
221 'fk_contact' => (
int) $obj->fk_contact,
222 'lastname' => $obj->lastname,
223 'firstname' => $obj->firstname,
225 ($langs->transnoentities(
"Login").
'='.$obj->login).
';'.
226 ($langs->transnoentities(
"UserTitle").
'='.$obj->civility_id).
';'.
227 ($langs->transnoentities(
"PhonePro").
'='.$obj->office_phone),
228 'source_url' => $this->url($obj->id),
229 'source_id' => (
int) $obj->id,
230 'source_type' =>
'user'
240 $this->error = $this->db->error();
244 return parent::addTargetsToDatabase($mailing_id, $cibles);
ajax_combobox($htmlname, $events=array(), $minLengthToAutocomplete=0, $forcefocus=0, $widthTypeOfAutocomplete='resolve', $idforemptyvalue='-1', $morecss='')
Convert a html select field into an ajax combobox.
Parent class of emailing target selectors modules.
Class to offer a selector of emailing targets with Rule 'Pomme'.
formFilter()
Affiche formulaire de filtre qui apparait dans page de selection des destinataires de mailings.
getNbOfRecipients($sql='')
Return here number of distinct emails returned by your selector.
__construct($db)
Constructor.
url($id)
Provide the URL to the car of the source information of the recipient for the mailing.
add_to_target($mailing_id)
Ajoute destinataires dans table des cibles.
getSqlArrayForStats()
On the main mailing area, there is a box with statistics.
img_object($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0)
Show a picto called object_picto (generic function)
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
global $conf
The following vars must be defined: $type2label $form $conf, $lang, The following vars may also be de...