26 include_once DOL_DOCUMENT_ROOT.
'/core/modules/DolibarrModules.class.php';
48 $this->module_position =
'43';
50 $this->
name = preg_replace(
'/^mod/i',
'', get_class($this));
51 $this->
description =
"Gestion des notes de frais et deplacements";
54 $this->version =
'dolibarr_deprecated';
56 $this->const_name =
'MAIN_MODULE_'.strtoupper($this->
name);
57 $this->picto =
"trip";
60 $this->dirs = array();
63 $this->config_page_url = array();
64 $this->langfiles = array(
"companies",
"trips");
67 $this->depends = array();
68 $this->requiredby = array();
71 $this->
const = array();
74 $this->boxes = array();
77 $this->rights = array();
78 $this->rights_class =
'deplacement';
80 $this->rights[1][0] = 171;
81 $this->rights[1][1] =
'Lire ses notes de frais et deplacements et celles de sa hierarchy';
82 $this->rights[1][2] =
'r';
83 $this->rights[1][3] = 1;
84 $this->rights[1][4] =
'lire';
86 $this->rights[2][0] = 172;
87 $this->rights[2][1] =
'Creer/modifier une note de frais et deplacements';
88 $this->rights[2][2] =
'w';
89 $this->rights[2][3] = 0;
90 $this->rights[2][4] =
'creer';
92 $this->rights[3][0] = 173;
93 $this->rights[3][1] =
'Supprimer les notes de frais et deplacements';
94 $this->rights[3][2] =
'd';
95 $this->rights[3][3] = 0;
96 $this->rights[3][4] =
'supprimer';
98 $this->rights[4][0] = 174;
99 $this->rights[4][1] =
'Lire toutes les notes de frais';
100 $this->rights[4][2] =
'd';
101 $this->rights[4][3] = 0;
102 $this->rights[4][4] =
'readall';
104 $this->rights[5][0] = 178;
105 $this->rights[5][1] =
'Exporter les notes de frais et deplacements';
106 $this->rights[5][2] =
'd';
107 $this->rights[5][3] = 0;
108 $this->rights[5][4] =
'export';
120 $this->export_code[$r] =
'trips_'.$r;
121 $this->export_label[$r] =
'ListTripsAndExpenses';
122 $this->export_permission[$r] = array(array(
"deplacement",
"export"));
123 $this->export_fields_array[$r] = array(
'u.login'=>
'Login',
'u.lastname'=>
'Lastname',
'u.firstname'=>
'Firstname',
'd.rowid'=>
"TripId",
'd.type'=>
"Type",
'd.km'=>
"FeesKilometersOrAmout",
'd.dated'=>
"Date",
'd.note_private'=>
'NotePrivate',
'd.note_public'=>
'NotePublic',
's.nom'=>
'ThirdParty');
124 $this->export_TypeFields_array[$r] = array(
'u.rowid'=>
'List:user:name',
'u.login'=>
'Text',
'u.lastname'=>
'Text',
'u.firstname'=>
'Text',
'd.type'=>
"Text",
'd.km'=>
"Numeric",
'd.dated'=>
"Date",
'd.note_private'=>
'Text',
'd.note_public'=>
'Text',
's.rowid'=>
"Numeric",
's.nom'=>
'Text');
125 $this->export_entities_array[$r] = array(
'u.login'=>
'user',
'u.lastname'=>
'user',
'u.firstname'=>
'user',
'd.rowid'=>
"trip",
'd.type'=>
"trip",
'd.km'=>
"trip",
'd.dated'=>
"trip",
'd.note_private'=>
'trip',
'd.note_public'=>
'trip',
's.nom'=>
'company');
126 $this->export_dependencies_array[$r] = array(
'trip'=>
'd.rowid');
128 $this->export_sql_start[$r] =
'SELECT DISTINCT ';
129 $this->export_sql_end[$r] =
' FROM '.MAIN_DB_PREFIX.
'user as u';
130 $this->export_sql_end[$r] .=
', '.MAIN_DB_PREFIX.
'deplacement as d';
131 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'societe as s ON d.fk_soc = s.rowid';
132 if (empty($user->rights->societe->client->voir)) {
133 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'societe_commerciaux as sc ON sc.fk_soc = s.rowid';
135 $this->export_sql_end[$r] .=
' WHERE d.fk_user = u.rowid';
136 $this->export_sql_end[$r] .=
' AND d.entity IN ('.getEntity(
'deplacement').
')';
137 if (empty($user->rights->societe->client->voir)) {
138 $this->export_sql_end[$r] .=
' AND (sc.fk_user = '.(empty($user) ? 0 : $user->id).
' OR d.fk_soc IS NULL)';
142 $childids = $user->getAllChildIds();
143 $childids[] = $user->id;
145 if (empty($user->rights->deplacement->readall) && empty($user->rights->deplacement->lire_tous)) {
146 $this->export_sql_end[$r] .=
' AND d.fk_user IN ('.$this->db->sanitize(join(
',', $childids)).
')';
160 public function init($options =
'')
162 $result = $this->
_load_tables(
'/install/mysql/',
'deplacement');
168 $this->
remove($options);
172 return $this->
_init($sql, $options);
_init($array_sql, $options='')
Enables a module.
_load_tables($reldir, $onlywithsuffix='')
Create tables and keys required by module:
Class to describe and enable module Deplacement.
init($options='')
Function called when module is enabled.
__construct($db)
Constructor.
print *****$script_file(".$version.") pid cd cd cd description as description
Only used if Module[ID]Desc translation string is not found.
$conf db name
Only used if Module[ID]Name translation string is not found.
$conf db
API class for accounts.