dolibarr  13.0.2
modAdherent.class.php
Go to the documentation of this file.
1 <?php
2 /* Copyright (C) 2003,2005 Rodolphe Quiedeville <rodolphe@quiedeville.org>
3  * Copyright (C) 2003 Jean-Louis Bergamo <jlb@j1b.org>
4  * Copyright (C) 2004-2012 Laurent Destailleur <eldy@users.sourceforge.net>
5  * Copyright (C) 2004 Sebastien Di Cintio <sdicintio@ressource-toi.org>
6  * Copyright (C) 2004 Benoit Mortier <benoit.mortier@opensides.be>
7  * Copyright (C) 2013 Juanjo Menent <jmenent@2byte.es>
8  * Copyright (C) 2014-2015 Raphaël Doursenaud <rdoursenaud@gpcsolutions.fr>
9  * Copyright (C) 2018 Alexandre Spangaro <aspangaro@open-dsi.fr>
10  *
11  * This program is free software; you can redistribute it and/or modify
12  * it under the terms of the GNU General Public License as published by
13  * the Free Software Foundation; either version 3 of the License, or
14  * (at your option) any later version.
15  *
16  * This program is distributed in the hope that it will be useful,
17  * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19  * GNU General Public License for more details.
20  *
21  * You should have received a copy of the GNU General Public License
22  * along with this program. If not, see <https://www.gnu.org/licenses/>.
23  */
24 
32 include_once DOL_DOCUMENT_ROOT.'/core/modules/DolibarrModules.class.php';
33 
38 {
39 
45  public function __construct($db)
46  {
47  global $conf;
48 
49  $this->db = $db;
50  $this->numero = 310;
51 
52  $this->family = "hr";
53  $this->module_position = '06';
54  // Module label (no space allowed), used if translation string 'ModuleXXXName' not found (where XXX is value of numeric property 'numero' of module)
55  $this->name = preg_replace('/^mod/i', '', get_class($this));
56  $this->description = "Management of members of a foundation or association";
57  // Possible values for version are: 'development', 'experimental', 'dolibarr' or version
58  $this->version = 'dolibarr';
59  $this->const_name = 'MAIN_MODULE_'.strtoupper($this->name);
60  $this->picto = 'member';
61 
62  // Data directories to create when module is enabled
63  $this->dirs = array(
64  "/adherent/temp",
65  "/doctemplates/members",
66  );
67 
68  // Config pages
69  $this->config_page_url = array("adherent.php@adherents");
70 
71  // Dependencies
72  $this->hidden = false; // A condition to hide module
73  $this->depends = array(); // List of module class names as string that must be enabled if this module is enabled
74  $this->requiredby = array(); // List of module ids to disable if this one is disabled
75  $this->conflictwith = array('modMailmanSpip'); // List of module class names as string this module is in conflict with
76  $this->langfiles = array("members", "companies");
77  $this->phpmin = array(5, 4); // Minimum version of PHP required by module
78 
79  // Constants
80  $this->const = array();
81  $r = 0;
82 
83  $this->const[$r][0] = "ADHERENT_ADDON_PDF";
84  $this->const[$r][1] = "chaine";
85  $this->const[$r][2] = "standard";
86  $this->const[$r][3] = 'Name of PDF model of member';
87  $this->const[$r][4] = 0;
88  $r++;
89 
90  // For emails
91  $this->const[$r][0] = "ADHERENT_MAIL_FROM";
92  $this->const[$r][1] = "chaine";
93  $this->const[$r][2] = "";
94  $this->const[$r][3] = "From des mails";
95  $this->const[$r][4] = 0;
96  $r++;
97 
98  $this->const[$r][0] = "ADHERENT_EMAIL_TEMPLATE_AUTOREGISTER";
99  $this->const[$r][1] = "emailtemplate:member";
100  $this->const[$r][2] = "(SendingEmailOnAutoSubscription)";
101  $this->const[$r][3] = "";
102  $this->const[$r][4] = 0;
103  $r++;
104 
105  $this->const[$r][0] = "ADHERENT_EMAIL_TEMPLATE_SUBSCRIPTION";
106  $this->const[$r][1] = "emailtemplate:member";
107  $this->const[$r][2] = "(SendingEmailOnNewSubscription)";
108  $this->const[$r][3] = "";
109  $this->const[$r][4] = 0;
110  $r++;
111 
112  $this->const[$r][0] = "ADHERENT_EMAIL_TEMPLATE_REMIND_EXPIRATION";
113  $this->const[$r][1] = "emailtemplate:member";
114  $this->const[$r][2] = "(SendingReminderForExpiredSubscription)";
115  $this->const[$r][3] = "";
116  $this->const[$r][4] = 0;
117  $r++;
118 
119  $this->const[$r][0] = "ADHERENT_EMAIL_TEMPLATE_CANCELATION";
120  $this->const[$r][1] = "emailtemplate:member";
121  $this->const[$r][2] = "(SendingEmailOnCancelation)";
122  $this->const[$r][3] = "";
123  $this->const[$r][4] = 0;
124  $r++;
125 
126  // For cards
127  $this->const[$r][0] = "ADHERENT_CARD_HEADER_TEXT";
128  $this->const[$r][1] = "chaine";
129  $this->const[$r][2] = "__YEAR__";
130  $this->const[$r][3] = "Texte imprimé sur le haut de la carte adhérent";
131  $this->const[$r][4] = 0;
132  $r++;
133 
134  $this->const[$r][0] = "ADHERENT_CARD_FOOTER_TEXT";
135  $this->const[$r][1] = "chaine";
136  $this->const[$r][2] = "__COMPANY__";
137  $this->const[$r][3] = "Texte imprimé sur le bas de la carte adhérent";
138  $this->const[$r][4] = 0;
139  $r++;
140 
141  $this->const[$r][0] = "ADHERENT_CARD_TEXT";
142  $this->const[$r][1] = "texte";
143  $this->const[$r][2] = "__FULLNAME__\r\nID: __ID__\r\n__EMAIL__\r\n__ADDRESS__\r\n__ZIP__ __TOWN__\r\n__COUNTRY__";
144  $this->const[$r][3] = "Text to print on member cards";
145  $this->const[$r][4] = 0;
146  $r++;
147 
148  $this->const[$r][0] = "ADHERENT_MAILMAN_ADMINPW";
149  $this->const[$r][1] = "chaine";
150  $this->const[$r][2] = "";
151  $this->const[$r][3] = "Mot de passe Admin des liste mailman";
152  $this->const[$r][4] = 0;
153  $r++;
154 
155  $this->const[$r][0] = "ADHERENT_ETIQUETTE_TYPE";
156  $this->const[$r][1] = "chaine";
157  $this->const[$r][2] = "L7163";
158  $this->const[$r][3] = "Type of address sheets";
159  $this->const[$r][4] = 0;
160  $r++;
161 
162  $this->const[$r][0] = "ADHERENT_ETIQUETTE_TEXT";
163  $this->const[$r][1] = "texte";
164  $this->const[$r][2] = "__FULLNAME__\n__ADDRESS__\n__ZIP__ __TOWN__\n__COUNTRY%";
165  $this->const[$r][3] = "Text to print on member address sheets";
166  $this->const[$r][4] = 0;
167  $r++;
168 
169  // For subscriptions
170  $this->const[$r][0] = "ADHERENT_BANK_ACCOUNT";
171  $this->const[$r][1] = "chaine";
172  $this->const[$r][2] = "";
173  $this->const[$r][3] = "ID of bank account to use";
174  $this->const[$r][4] = 0;
175  $r++;
176 
177  $this->const[$r][0] = "ADHERENT_BANK_CATEGORIE";
178  $this->const[$r][1] = "chaine";
179  $this->const[$r][2] = "";
180  $this->const[$r][3] = "ID of bank transaction category to use";
181  $this->const[$r][4] = 0;
182  $r++;
183 
184  $this->const[$r][0] = "MEMBER_ADDON_PDF_ODT_PATH";
185  $this->const[$r][1] = "chaine";
186  $this->const[$r][2] = "DOL_DATA_ROOT/doctemplates/members";
187  $this->const[$r][3] = "";
188  $this->const[$r][4] = 0;
189  $r++;
190 
191 
192  // Boxes
193  //-------
194  $this->boxes = array(
195  0=>array('file'=>'box_members.php', 'enabledbydefaulton'=>'Home'),
196  2=>array('file'=>'box_birthdays_members.php', 'enabledbydefaulton'=>'Home')
197  );
198 
199  // Permissions
200  //------------
201  $this->rights = array();
202  $this->rights_class = 'adherent';
203  $r = 0;
204 
205  // $this->rights[$r][0] Id permission (unique tous modules confondus)
206  // $this->rights[$r][1] Libelle par defaut si traduction de cle "PermissionXXX" non trouvee (XXX = Id permission)
207  // $this->rights[$r][2] Non utilise
208  // $this->rights[$r][3] 1=Permis par defaut, 0=Non permis par defaut
209  // $this->rights[$r][4] Niveau 1 pour nommer permission dans code
210  // $this->rights[$r][5] Niveau 2 pour nommer permission dans code
211 
212  $r++;
213  $this->rights[$r][0] = 71;
214  $this->rights[$r][1] = 'Read members\' card';
215  $this->rights[$r][2] = 'r';
216  $this->rights[$r][3] = 0;
217  $this->rights[$r][4] = 'lire';
218 
219  $r++;
220  $this->rights[$r][0] = 72;
221  $this->rights[$r][1] = 'Create/modify members (need also user module permissions if member linked to a user)';
222  $this->rights[$r][2] = 'w';
223  $this->rights[$r][3] = 0;
224  $this->rights[$r][4] = 'creer';
225 
226  $r++;
227  $this->rights[$r][0] = 74;
228  $this->rights[$r][1] = 'Remove members';
229  $this->rights[$r][2] = 'd';
230  $this->rights[$r][3] = 0;
231  $this->rights[$r][4] = 'supprimer';
232 
233  $r++;
234  $this->rights[$r][0] = 76;
235  $this->rights[$r][1] = 'Export members';
236  $this->rights[$r][2] = 'r';
237  $this->rights[$r][3] = 0;
238  $this->rights[$r][4] = 'export';
239 
240  $r++;
241  $this->rights[$r][0] = 75;
242  $this->rights[$r][1] = 'Setup types of membership';
243  $this->rights[$r][2] = 'w';
244  $this->rights[$r][3] = 0;
245  $this->rights[$r][4] = 'configurer';
246 
247  $r++;
248  $this->rights[$r][0] = 78;
249  $this->rights[$r][1] = 'Read subscriptions';
250  $this->rights[$r][2] = 'r';
251  $this->rights[$r][3] = 0;
252  $this->rights[$r][4] = 'cotisation';
253  $this->rights[$r][5] = 'lire';
254 
255  $r++;
256  $this->rights[$r][0] = 79;
257  $this->rights[$r][1] = 'Create/modify/remove subscriptions';
258  $this->rights[$r][2] = 'w';
259  $this->rights[$r][3] = 0;
260  $this->rights[$r][4] = 'cotisation';
261  $this->rights[$r][5] = 'creer';
262 
263 
264  // Menus
265  //-------
266  $this->menu = 1; // This module add menu entries. They are coded into menu manager.
267 
268 
269  // Exports
270  //--------
271  $r = 0;
272 
273  // $this->export_code[$r] Unique code identifying the export (all modules combined)
274  // $this->export_label[$r] Libelle by default if translation of key "ExportXXX" not found (XXX = Code)
275  // $this->export_permission[$r] List of permission codes required to export
276  // $this->export_fields_sql[$r] List of exportable fields in SQL codiffication
277  // $this->export_fields_name[$r] List of exportable fields in translation codiffication
278  // $this->export_sql[$r] SQL query that offers data for export
279 
280  $r++;
281  $this->export_code[$r] = $this->rights_class.'_'.$r;
282  $this->export_label[$r] = 'MembersAndSubscriptions';
283  $this->export_permission[$r] = array(array("adherent", "export"));
284  $this->export_fields_array[$r] = array(
285  'a.rowid'=>'Id', 'a.civility'=>"UserTitle", 'a.lastname'=>"Lastname", 'a.firstname'=>"Firstname", 'a.login'=>"Login", 'a.gender'=>"Gender", 'a.morphy'=>'Nature',
286  'a.societe'=>'Company', 'a.address'=>"Address", 'a.zip'=>"Zip", 'a.town'=>"Town", 'd.nom'=>"State", 'co.code'=>"CountryCode", 'co.label'=>"Country",
287  'a.phone'=>"PhonePro", 'a.phone_perso'=>"PhonePerso", 'a.phone_mobile'=>"PhoneMobile", 'a.email'=>"Email", 'a.birth'=>"Birthday", 'a.statut'=>"Status",
288  'a.photo'=>"Photo", 'a.note_public'=>"NotePublic", 'a.note_private'=>"NotePrivate", 'a.datec'=>'DateCreation', 'a.datevalid'=>'DateValidation',
289  'a.tms'=>'DateLastModification', 'a.datefin'=>'DateEndSubscription', 'ta.rowid'=>'MemberTypeId', 'ta.libelle'=>'MemberTypeLabel',
290  'c.rowid'=>'SubscriptionId', 'c.dateadh'=>'DateSubscription', 'c.datef'=>'DateEndSubscription', 'c.subscription'=>'Amount'
291  );
292  $this->export_TypeFields_array[$r] = array(
293  'a.civility'=>"Text", 'a.lastname'=>"Text", 'a.firstname'=>"Text", 'a.login'=>"Text", 'a.gender'=>'Text', 'a.morphy'=>'Text', 'a.societe'=>'Text', 'a.address'=>"Text",
294  'a.zip'=>"Text", 'a.town'=>"Text", 'd.nom'=>"Text", 'co.code'=>'Text', 'co.label'=>"Text", 'a.phone'=>"Text", 'a.phone_perso'=>"Text", 'a.phone_mobile'=>"Text",
295  'a.email'=>"Text", 'a.birth'=>"Date", 'a.statut'=>"Status", 'a.note_public'=>"Text", 'a.note_private'=>"Text", 'a.datec'=>'Date', 'a.datevalid'=>'Date',
296  'a.tms'=>'Date', 'a.datefin'=>'Date', 'ta.rowid'=>'List:adherent_type:libelle::member_type', 'ta.libelle'=>'Text',
297  'c.rowid'=>'Numeric', 'c.dateadh'=>'Date', 'c.datef'=>'Date', 'c.subscription'=>'Numeric'
298  );
299  $this->export_entities_array[$r] = array(
300  'a.rowid'=>'member', 'a.civility'=>"member", 'a.lastname'=>"member", 'a.firstname'=>"member", 'a.login'=>"member", 'a.gender'=>'member', 'a.morphy'=>'member',
301  'a.societe'=>'member', 'a.address'=>"member", 'a.zip'=>"member", 'a.town'=>"member", 'd.nom'=>"member", 'co.code'=>"member", 'co.label'=>"member",
302  'a.phone'=>"member", 'a.phone_perso'=>"member", 'a.phone_mobile'=>"member", 'a.email'=>"member", 'a.birth'=>"member", 'a.statut'=>"member",
303  'a.photo'=>"member", 'a.note_public'=>"member", 'a.note_private'=>"member", 'a.datec'=>'member', 'a.datevalid'=>'member', 'a.tms'=>'member',
304  'a.datefin'=>'member', 'ta.rowid'=>'member_type', 'ta.libelle'=>'member_type',
305  'c.rowid'=>'subscription', 'c.dateadh'=>'subscription', 'c.datef'=>'subscription', 'c.subscription'=>'subscription'
306  );
307  // Add extra fields
308  $keyforselect = 'adherent'; $keyforelement = 'member'; $keyforaliasextra = 'extra';
309  include DOL_DOCUMENT_ROOT.'/core/extrafieldsinexport.inc.php';
310  // End add axtra fields
311  $this->export_sql_start[$r] = 'SELECT DISTINCT ';
312  $this->export_sql_end[$r] = ' FROM ('.MAIN_DB_PREFIX.'adherent_type as ta, '.MAIN_DB_PREFIX.'adherent as a)';
313  $this->export_sql_end[$r] .= ' LEFT JOIN '.MAIN_DB_PREFIX.'adherent_extrafields as extra ON a.rowid = extra.fk_object';
314  $this->export_sql_end[$r] .= ' LEFT JOIN '.MAIN_DB_PREFIX.'subscription as c ON c.fk_adherent = a.rowid';
315  $this->export_sql_end[$r] .= ' LEFT JOIN '.MAIN_DB_PREFIX.'c_departements as d ON a.state_id = d.rowid';
316  $this->export_sql_end[$r] .= ' LEFT JOIN '.MAIN_DB_PREFIX.'c_country as co ON a.country = co.rowid';
317  $this->export_sql_end[$r] .= ' WHERE a.fk_adherent_type = ta.rowid AND ta.entity IN ('.getEntity('member_type').') ';
318  $this->export_dependencies_array[$r] = array('subscription'=>'c.rowid'); // To add unique key if we ask a field of a child to avoid the DISTINCT to discard them
319 
320  // Imports
321  //--------
322  $r = 0;
323 
324  $now = dol_now();
325  require_once DOL_DOCUMENT_ROOT.'/core/lib/date.lib.php';
326 
327  $r++;
328  $this->import_code[$r] = $this->rights_class.'_'.$r;
329  $this->import_label[$r] = "Members"; // Translation key
330  $this->import_icon[$r] = $this->picto;
331  $this->import_entities_array[$r] = array(); // We define here only fields that use another icon that the one defined into import_icon
332  $this->import_tables_array[$r] = array('a'=>MAIN_DB_PREFIX.'adherent', 'extra'=>MAIN_DB_PREFIX.'adherent_extrafields');
333  $this->import_tables_creator_array[$r] = array('a'=>'fk_user_author'); // Fields to store import user id
334  $this->import_fields_array[$r] = array(
335  'a.civility'=>"UserTitle", 'a.lastname'=>"Lastname*", 'a.firstname'=>"Firstname", 'a.gender'=>"Gender", 'a.login'=>"Login*", "a.pass"=>"Password",
336  "a.fk_adherent_type"=>"MemberType*", 'a.morphy'=>'Nature*', 'a.societe'=>'Company', 'a.address'=>"Address", 'a.zip'=>"Zip", 'a.town'=>"Town",
337  'a.state_id'=>'StateId', 'a.country'=>"CountryId", 'a.phone'=>"PhonePro", 'a.phone_perso'=>"PhonePerso", 'a.phone_mobile'=>"PhoneMobile",
338  'a.email'=>"Email", 'a.birth'=>"Birthday", 'a.statut'=>"Status*", 'a.photo'=>"Photo", 'a.note_public'=>"NotePublic", 'a.note_private'=>"NotePrivate",
339  'a.datec'=>'DateCreation', 'a.datefin'=>'DateEndSubscription'
340  );
341  // Add extra fields
342  $sql = "SELECT name, label, fieldrequired FROM ".MAIN_DB_PREFIX."extrafields WHERE elementtype = 'adherent' AND entity IN (0,".$conf->entity.")";
343  $resql = $this->db->query($sql);
344  if ($resql) // This can fail when class is used on old database (during migration for example)
345  {
346  while ($obj = $this->db->fetch_object($resql))
347  {
348  $fieldname = 'extra.'.$obj->name;
349  $fieldlabel = ucfirst($obj->label);
350  $this->import_fields_array[$r][$fieldname] = $fieldlabel.($obj->fieldrequired ? '*' : '');
351  }
352  }
353  // End add extra fields
354  $this->import_fieldshidden_array[$r] = array('extra.fk_object'=>'lastrowid-'.MAIN_DB_PREFIX.'adherent'); // aliastable.field => ('user->id' or 'lastrowid-'.tableparent)
355  $this->import_regex_array[$r] = array(
356  'a.civility'=>'code@'.MAIN_DB_PREFIX.'c_civility', 'a.fk_adherent_type'=>'rowid@'.MAIN_DB_PREFIX.'adherent_type', 'a.morphy'=>'(phy|mor)',
357  'a.statut'=>'^[0|1]', 'a.datec'=>'^[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]$', 'a.datefin'=>'^[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]$');
358  $this->import_examplevalues_array[$r] = array(
359  'a.civility'=>"MR", 'a.lastname'=>'Smith', 'a.firstname'=>'John', 'a.login'=>'jsmith', 'a.pass'=>'passofjsmith', 'a.fk_adherent_type'=>'1',
360  'a.morphy'=>'"mor" or "phy"', 'a.societe'=>'JS company', 'a.address'=>'21 jump street', 'a.zip'=>'55000', 'a.town'=>'New York', 'a.country'=>'1',
361  'a.email'=>'jsmith@example.com', 'a.birth'=>'1972-10-10', 'a.statut'=>"0 or 1", 'a.note_public'=>"This is a public comment on member",
362  'a.note_private'=>"This is private comment on member", 'a.datec'=>dol_print_date($now, '%Y-%m__%d'), 'a.datefin'=>dol_print_date(dol_time_plus_duree($now, 1, 'y'), '%Y-%m-%d')
363  );
364 
365  // Cronjobs
366  $arraydate = dol_getdate(dol_now());
367  $datestart = dol_mktime(22, 0, 0, $arraydate['mon'], $arraydate['mday'], $arraydate['year']);
368  $this->cronjobs = array(
369  0=>array(
370  'label'=>'SendReminderForExpiredSubscriptionTitle',
371  'jobtype'=>'method', 'class'=>'adherents/class/adherent.class.php',
372  'objectname'=>'Adherent',
373  'method'=>'sendReminderForExpiredSubscription',
374  'parameters'=>'10;0',
375  'comment'=>'SendReminderForExpiredSubscription',
376  'frequency'=>1,
377  'unitfrequency'=> 3600 * 24,
378  'priority'=>50,
379  'status'=>1,
380  'test'=>'$conf->adherent->enabled',
381  'datestart'=>$datestart
382  ),
383  );
384  }
385 
386 
395  public function init($options = '')
396  {
397  global $conf, $langs;
398 
399  // Permissions
400  $this->remove($options);
401 
402  //ODT template
403  /*
404  $src=DOL_DOCUMENT_ROOT.'/install/doctemplates/orders/template_order.odt';
405  $dirodt=DOL_DATA_ROOT.'/doctemplates/orders';
406  $dest=$dirodt.'/template_order.odt';
407 
408  if (file_exists($src) && ! file_exists($dest))
409  {
410  require_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';
411  dol_mkdir($dirodt);
412  $result=dol_copy($src,$dest,0,0);
413  if ($result < 0)
414  {
415  $langs->load("errors");
416  $this->error=$langs->trans('ErrorFailToCopyFile',$src,$dest);
417  return 0;
418  }
419  }*/
420 
421  $sql = array(
422  "DELETE FROM ".MAIN_DB_PREFIX."document_model WHERE nom = '".$this->db->escape($this->const[0][2])."' AND type='member' AND entity = ".$conf->entity,
423  "INSERT INTO ".MAIN_DB_PREFIX."document_model (nom, type, entity) VALUES('".$this->db->escape($this->const[0][2])."','member',".$conf->entity.")"
424  );
425 
426  return $this->_init($sql, $options);
427  }
428 }
Class DolibarrModules.
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm= 'auto', $check=1)
Return a timestamp date built from detailed informations (by default a local PHP server timestamp) Re...
</td > param sortfield sortorder printFieldListOption< tdclass="liste_titremaxwidthsearchright"></td ></tr >< trclass="liste_titre">< inputtype="checkbox"onClick="toggle(this)"/> Ref p ref Label p label Duration p duration center DesiredStock p desiredstock right StockLimitShort p seuil_stock_alerte right stock_physique right stock_real_warehouse right Ordered right StockToBuy right SupplierRef right param sortfield sortorder printFieldListTitle warehouseinternal SELECT description FROM product_lang WHERE qty< br > qty qty qty StockTooLow StockTooLow help help help< trclass="oddeven">< td >< inputtype="checkbox"class="check"name="choose'.$i.'"></td >< tdclass="nowrap"> stock</td >< td >< inputtype="hidden"name="desc'.$i.'"value="'.dol_escape_htmltag($objp-> description
Only used if Module[ID]Desc translation string is not found.
Definition: replenish.php:750
dol_now($mode= 'auto')
Return date for now.
$conf db name
Only used if Module[ID]Name translation string is not found.
Definition: repair.php:108
$conf db
API class for accounts.
Definition: inc.php:54
dol_getdate($timestamp, $fast=false, $forcetimezone= '')
Return an array with locale date info.
Class to describe and enable module Adherent.
__construct($db)
Constructor.
dol_print_date($time, $format= '', $tzoutput= 'auto', $outputlangs= '', $encodetooutput=false)
Output date in a string format according to outputlangs (or langs if not defined).
_init($array_sql, $options= '')
Enables a module.
if(!empty($conf->facture->enabled)&&$user->rights->facture->lire) if((!empty($conf->fournisseur->enabled)&&empty($conf->global->MAIN_USE_NEW_SUPPLIERMOD)||!empty($conf->supplier_invoice->enabled))&&$user->rights->fournisseur->facture->lire) if(!empty($conf->don->enabled)&&$user->rights->don->lire) if(!empty($conf->tax->enabled)&&$user->rights->tax->charges->lire) if(!empty($conf->facture->enabled)&&!empty($conf->commande->enabled)&&$user->rights->commande->lire &&empty($conf->global->WORKFLOW_DISABLE_CREATE_INVOICE_FROM_ORDER)) if(!empty($conf->facture->enabled)&&$user->rights->facture->lire) if((!empty($conf->fournisseur->enabled)&&empty($conf->global->MAIN_USE_NEW_SUPPLIERMOD)||!empty($conf->supplier_invoice->enabled))&&$user->rights->fournisseur->facture->lire) $resql
Social contributions to pay.
Definition: index.php:1232
init($options= '')
Function called when module is enabled.
dol_time_plus_duree($time, $duration_value, $duration_unit)
Add a delay to a date.
Definition: date.lib.php:114