47 global $conf, $user, $mysoc, $langs;
52 $this->family =
"crm";
53 $this->module_position =
'09';
55 $this->
name = preg_replace(
'/^mod/i',
'', get_class($this));
56 $this->
description =
"Gestion des sociétés et contacts";
59 $this->version =
'dolibarr';
61 $this->const_name =
'MAIN_MODULE_'.strtoupper($this->
name);
62 $this->config_page_url = array(
"societe.php@societe");
64 $this->picto =
'company';
67 $this->dirs = array(
"/societe/temp");
70 $this->hidden =
false;
71 $this->depends = array();
72 $this->requiredby = array(
"modExpedition",
"modFacture",
"modFournisseur",
"modFicheinter",
"modPropale",
"modContrat",
"modCommande");
73 $this->conflictwith = array();
74 $this->phpmin = array(7, 0);
75 $this->langfiles = array(
"companies",
'bills',
"compta",
"admin",
"banks");
78 $this->
const = array();
81 $this->
const[$r][0] =
"SOCIETE_CODECLIENT_ADDON";
82 $this->
const[$r][1] =
"chaine";
83 $this->
const[$r][2] =
"mod_codeclient_monkey";
84 $this->
const[$r][3] =
'Module to control third parties codes';
85 $this->
const[$r][4] = 0;
88 $this->
const[$r][0] =
"SOCIETE_CODECOMPTA_ADDON";
89 $this->
const[$r][1] =
"chaine";
90 $this->
const[$r][2] =
"mod_codecompta_panicum";
91 $this->
const[$r][3] =
'Module to control third parties codes';
92 $this->
const[$r][4] = 0;
95 $this->
const[$r][0] =
"SOCIETE_FISCAL_MONTH_START";
96 $this->
const[$r][1] =
"chaine";
97 $this->
const[$r][2] =
"0";
98 $this->
const[$r][3] =
"Enter the month number of the first month of the fiscal year, e. g. 9 for September";
99 $this->
const[$r][4] = 0;
102 $this->
const[$r][0] =
"COMPANY_ADDON_PDF_ODT_PATH";
103 $this->
const[$r][1] =
"chaine";
104 $this->
const[$r][2] =
"DOL_DATA_ROOT/doctemplates/thirdparties";
105 $this->
const[$r][3] =
"";
106 $this->
const[$r][4] = 0;
118 $this->
const[$r][0] =
"SOCIETE_ADD_REF_IN_LIST";
119 $this->
const[$r][1] =
"yesno";
120 $this->
const[$r][2] =
"0";
121 $this->
const[$r][3] =
"Display customer ref into select list";
122 $this->
const[$r][4] = 0;
126 $this->boxes = array(
127 0=>array(
'file'=>
'box_clients.php',
'enabledbydefaulton'=>
'Home'),
128 1=>array(
'file'=>
'box_prospect.php',
'enabledbydefaulton'=>
'Home'),
129 2=>array(
'file'=>
'box_contacts.php',
'enabledbydefaulton'=>
'Home'),
130 3=>array(
'file'=>
'box_activity.php',
'enabledbydefaulton'=>
'Home',
'note'=>
'(WarningUsingThisBoxSlowDown)'),
131 4=>array(
'file'=>
'box_goodcustomers.php',
'enabledbydefaulton'=>
'Home',
'note'=>
'(WarningUsingThisBoxSlowDown)'),
135 $this->rights = array();
136 $this->rights_class =
'societe';
140 $this->rights[$r][0] = 121;
141 $this->rights[$r][1] =
'Read third parties';
142 $this->rights[$r][2] =
'r';
143 $this->rights[$r][3] = 0;
144 $this->rights[$r][4] =
'lire';
164 $this->rights[$r][0] = 122;
165 $this->rights[$r][1] =
'Create and update third parties';
166 $this->rights[$r][2] =
'w';
167 $this->rights[$r][3] = 0;
168 $this->rights[$r][4] =
'creer';
188 $this->rights[$r][0] = 125;
189 $this->rights[$r][1] =
'Delete third parties';
190 $this->rights[$r][2] =
'd';
191 $this->rights[$r][3] = 0;
192 $this->rights[$r][4] =
'supprimer';
195 $this->rights[$r][0] = 126;
196 $this->rights[$r][1] =
'Export third parties';
197 $this->rights[$r][2] =
'r';
198 $this->rights[$r][3] = 0;
199 $this->rights[$r][4] =
'export';
202 $this->rights[$r][0] = 130;
203 $this->rights[$r][1] =
'Modify thirdparty information payment';
204 $this->rights[$r][3] = 0;
205 $this->rights[$r][4] =
'thirdparty_paymentinformation_advance';
206 $this->rights[$r][5] =
'write';
210 $this->rights[$r][0] = 262;
211 $this->rights[$r][1] =
'Read all third parties (and their objects) by internal users (otherwise only if commercial contact). Not effective for external users (limited to themselves).';
212 $this->rights[$r][2] =
'r';
213 $this->rights[$r][3] = 0;
214 $this->rights[$r][4] =
'client';
215 $this->rights[$r][5] =
'voir';
228 $this->rights[$r][0] = 281;
229 $this->rights[$r][1] =
'Read contacts';
230 $this->rights[$r][2] =
'r';
231 $this->rights[$r][3] = 0;
232 $this->rights[$r][4] =
'contact';
233 $this->rights[$r][5] =
'lire';
236 $this->rights[$r][0] = 282;
237 $this->rights[$r][1] =
'Create and update contact';
238 $this->rights[$r][2] =
'w';
239 $this->rights[$r][3] = 0;
240 $this->rights[$r][4] =
'contact';
241 $this->rights[$r][5] =
'creer';
244 $this->rights[$r][0] = 283;
245 $this->rights[$r][1] =
'Delete contacts';
246 $this->rights[$r][2] =
'd';
247 $this->rights[$r][3] = 0;
248 $this->rights[$r][4] =
'contact';
249 $this->rights[$r][5] =
'supprimer';
252 $this->rights[$r][0] = 286;
253 $this->rights[$r][1] =
'Export contacts';
254 $this->rights[$r][2] =
'd';
255 $this->rights[$r][3] = 0;
256 $this->rights[$r][4] =
'contact';
257 $this->rights[$r][5] =
'export';
271 $this->export_code[$r] = $this->rights_class.
'_'.$r;
272 $this->export_label[$r] =
'ExportDataset_company_1';
273 $this->export_icon[$r] =
'company';
274 $this->export_permission[$r] = array(array(
"societe",
"export"));
275 $this->export_fields_array[$r] = array(
276 's.rowid'=>
"Id",
's.nom'=>
"Name",
's.name_alias'=>
"AliasNameShort",
'ps.nom'=>
"ParentCompany",
277 's.status'=>
"Status",
's.client'=>
"Customer",
's.fournisseur'=>
"Supplier",
's.datec'=>
"DateCreation",
's.tms'=>
"DateLastModification",
278 's.code_client'=>
"CustomerCode",
's.code_fournisseur'=>
"SupplierCode",
's.code_compta'=>
"AccountancyCode",
's.code_compta_fournisseur'=>
"SupplierAccountancyCode",
279 's.address'=>
"Address",
's.zip'=>
"Zip",
's.town'=>
"Town",
'd.nom'=>
'State',
'r.nom'=>
'Region',
'c.label'=>
"Country",
'c.code'=>
"CountryCode",
's.phone'=>
"Phone",
's.fax'=>
"Fax",
280 's.url'=>
"Url",
's.email'=>
"Email",
's.default_lang'=>
"DefaultLang",
's.canvas' =>
"Canvas",
's.siren'=>
"ProfId1",
's.siret'=>
"ProfId2",
's.ape'=>
"ProfId3",
's.idprof4'=>
"ProfId4",
281 's.idprof5'=>
"ProfId5",
's.idprof6'=>
"ProfId6",
's.tva_intra'=>
"VATIntraShort",
's.capital'=>
"Capital",
's.note_private'=>
"NotePrivate",
's.note_public'=>
"NotePublic",
282 't.code'=>
"ThirdPartyType",
'ce.code'=>
"DictionaryStaff",
"cfj.libelle"=>
"JuridicalStatus",
's.fk_prospectlevel'=>
'ProspectLevel',
283 'st.code'=>
'ProspectStatus',
'payterm.libelle'=>
'PaymentConditions',
'paymode.libelle'=>
'PaymentMode',
284 's.outstanding_limit'=>
'OutstandingBill',
'pbacc.ref'=>
'PaymentBankAccount',
'incoterm.code'=>
'IncotermLabel'
286 if (!empty($conf->global->SOCIETE_USEPREFIX)) {
287 $this->export_fields_array[$r][
's.prefix'] =
'Prefix';
289 if (!empty($conf->global->PRODUIT_MULTIPRICES)) {
290 $this->export_fields_array[$r][
's.price_level'] =
'PriceLevel';
292 if (!empty($conf->global->ACCOUNTANCY_USE_PRODUCT_ACCOUNT_ON_THIRDPARTY)) {
293 $this->export_fields_array[$r] += array(
's.accountancy_code_sell'=>
'ProductAccountancySellCode',
's.accountancy_code_buy'=>
'ProductAccountancyBuyCode');
296 if (!empty($conf->global->MULTICOMPANY_ENTITY_IN_EXPORT_IF_SHARED)) {
297 $nbofallowedentities = count(explode(
',',
getEntity(
'societe')));
298 if (isModEnabled(
'multicompany') && $nbofallowedentities > 1) {
299 $this->export_fields_array[$r] += array(
's.entity'=>
'Entity');
302 $keyforselect =
'societe';
303 $keyforelement =
'company';
304 $keyforaliasextra =
'extra';
305 include DOL_DOCUMENT_ROOT.
'/core/extrafieldsinexport.inc.php';
306 $this->export_fields_array[$r] += array(
'u.login'=>
'SaleRepresentativeLogin',
'u.firstname'=>
'SaleRepresentativeFirstname',
'u.lastname'=>
'SaleRepresentativeLastname');
308 $this->export_TypeFields_array[$r] = array(
309 's.rowid'=>
"Numeric",
's.nom'=>
"Text",
's.name_alias'=>
"Text",
'ps.nom'=>
"Text",
310 's.status'=>
"Numeric",
's.client'=>
"Numeric",
's.fournisseur'=>
"Boolean",
's.datec'=>
"Date",
's.tms'=>
"Date",
311 's.code_client'=>
"Text",
's.code_fournisseur'=>
"Text",
's.code_compta'=>
"Text",
's.code_compta_fournisseur'=>
"Text",
312 's.address'=>
"Text",
's.zip'=>
"Text",
's.town'=>
"Text",
313 'd.nom'=>
'Text',
'r.nom'=>
'Text',
'c.label'=>
'List:c_country:label:label',
'c.code'=>
'Text',
314 's.phone'=>
"Text",
's.fax'=>
"Text",
315 's.url'=>
"Text",
's.email'=>
"Text",
's.default_lang'=>
"Text",
's.canvas' =>
"Text",
316 's.siret'=>
"Text",
's.siren'=>
"Text",
's.ape'=>
"Text",
's.idprof4'=>
"Text",
's.idprof5'=>
"Text",
's.idprof6'=>
"Text",
317 's.tva_intra'=>
"Text",
's.capital'=>
"Numeric",
318 's.note_private'=>
"Text",
's.note_public'=>
"Text",
319 't.code'=>
"List:c_typent:libelle:code",
320 'ce.code'=>
"List:c_effectif:libelle:code",
321 "cfj.libelle"=>
"Text",
322 's.fk_prospectlevel'=>
'List:c_prospectlevel:label:code',
323 'st.code'=>
'List:c_stcomm:libelle:code',
324 'payterm.libelle'=>
'Text',
'paymode.libelle'=>
'Text',
325 's.outstanding_limit'=>
'Numeric',
'pbacc.ref'=>
'Text',
'incoterm.code'=>
'Text',
326 'u.login'=>
'Text',
'u.firstname'=>
'Text',
'u.lastname'=>
'Text',
327 's.entity'=>
'List:entity:label:rowid',
's.price_level'=>
'Numeric',
328 's.accountancy_code_sell'=>
'Text',
's.accountancy_code_buy'=>
'Text'
331 $this->export_entities_array[$r] = array(
333 'u.firstname'=>
'user',
334 'u.lastname'=>
'user');
335 $this->export_examplevalues_array[$r] = array(
's.client'=>
'0 (no customer no prospect)/1 (customer)/2 (prospect)/3 (customer and prospect)',
's.fournisseur'=>
'0 (not a supplier) or 1 (supplier)');
336 $this->export_sql_start[$r] =
'SELECT DISTINCT ';
337 $this->export_sql_end[$r] =
' FROM '.MAIN_DB_PREFIX.
'societe as s';
338 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'societe_extrafields as extra ON s.rowid = extra.fk_object';
339 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'societe as ps ON s.parent = ps.rowid';
340 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_typent as t ON s.fk_typent = t.id';
341 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_country as c ON s.fk_pays = c.rowid';
342 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_effectif as ce ON s.fk_effectif = ce.id';
343 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_forme_juridique as cfj ON s.fk_forme_juridique = cfj.code';
344 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_departements as d ON s.fk_departement = d.rowid';
345 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_regions as r ON r.code_region = d.fk_region AND r.fk_pays = s.fk_pays';
346 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_stcomm as st ON s.fk_stcomm = st.id';
347 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'societe_commerciaux as sc ON sc.fk_soc = s.rowid LEFT JOIN '.MAIN_DB_PREFIX.
'user as u ON sc.fk_user = u.rowid';
348 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_payment_term as payterm ON s.cond_reglement = payterm.rowid';
349 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_paiement as paymode ON s.mode_reglement = paymode.id';
350 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'bank_account as pbacc ON s.fk_account = pbacc.rowid';
351 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_incoterms as incoterm ON s.fk_incoterms = incoterm.rowid';
352 $this->export_sql_end[$r] .=
' WHERE s.entity IN ('.getEntity(
'societe').
')';
353 if (is_object($user) && empty($user->rights->societe->client->voir)) {
354 $this->export_sql_end[$r] .=
' AND (sc.fk_user = '.((int) $user->id).
' ';
355 if (!empty($conf->global->SOCIETE_EXPORT_SUBORDINATES_CHILDS)) {
356 $subordinatesids = $user->getAllChildIds();
357 $this->export_sql_end[$r] .= count($subordinatesids) > 0 ?
' OR (sc.fk_user IN ('.$this->db->sanitize(implode(
',', $subordinatesids)).
')' :
'';
359 $this->export_sql_end[$r] .=
')';
364 $this->export_code[$r] = $this->rights_class.
'_'.$r;
365 $this->export_label[$r] =
'ExportDataset_company_2';
366 $this->export_icon[$r] =
'contact';
367 $this->export_permission[$r] = array(array(
"societe",
"contact",
"export"));
368 $this->export_fields_array[$r] = array(
369 'c.rowid'=>
"IdContact",
'c.civility'=>
"CivilityCode",
'c.lastname'=>
'Lastname',
'c.firstname'=>
'Firstname',
'c.poste'=>
'PostOrFunction',
370 'c.datec'=>
"DateCreation",
'c.tms'=>
"DateLastModification",
'c.priv'=>
"ContactPrivate",
'c.address'=>
"Address",
'c.zip'=>
"Zip",
'c.town'=>
"Town",
371 'd.nom'=>
'State',
'r.nom'=>
'Region',
'co.label'=>
"Country",
'co.code'=>
"CountryCode",
'c.phone'=>
"Phone",
'c.fax'=>
"Fax",
'c.phone_mobile'=>
"Mobile",
'c.email'=>
"EMail",
372 'c.note_private'=>
'NotePrivate',
'c.note_public'=>
"NotePublic",
373 'c.statut'=>
"Status",
374 's.rowid'=>
"IdCompany",
's.nom'=>
"CompanyName",
's.status'=>
"Status",
's.code_client'=>
"CustomerCode",
's.code_fournisseur'=>
"SupplierCode",
375 's.code_compta'=>
"AccountancyCode",
's.code_compta_fournisseur'=>
"SupplierAccountancyCode",
376 's.client'=>
'Customer',
's.fournisseur'=>
'Supplier',
377 's.address'=>
'Address',
's.zip'=>
"Zip",
's.town'=>
"Town",
's.phone'=>
'Phone',
's.email'=>
"Email",
378 's.note_private'=>
'NotePrivate',
's.note_public'=>
"NotePublic",
379 't.code'=>
"ThirdPartyType"
382 if (!empty($conf->global->MULTICOMPANY_ENTITY_IN_EXPORT_IF_SHARED)) {
383 if (isModEnabled(
'multicompany')) {
384 $nbofallowedentities = count(explode(
',',
getEntity(
'contact')));
385 if ($nbofallowedentities > 1) {
386 $this->export_fields_array[$r][
'c.entity'] =
'Entity';
389 $nbofallowedentities = count(explode(
',',
getEntity(
'societe')));
390 if ($nbofallowedentities > 1) {
391 $this->export_fields_array[$r][
's.entity'] =
'Entity';
395 $this->export_examplevalues_array[$r] = array(
's.client'=>
'0 (no customer no prospect)/1 (customer)/2 (prospect)/3 (customer and prospect)',
's.fournisseur'=>
'0 (not a supplier) or 1 (supplier)');
396 $this->export_TypeFields_array[$r] = array(
397 'c.civility'=>
"List:c_civility:label:code",
'c.lastname'=>
'Text',
'c.firstname'=>
'Text',
'c.poste'=>
'Text',
'c.datec'=>
"Date",
'c.priv'=>
"Boolean",
398 'c.address'=>
"Text",
'c.zip'=>
"Text",
'c.town'=>
"Text",
'd.nom'=>
'Text',
'r.nom'=>
'Text',
'co.label'=>
"List:c_country:label:rowid",
'co.code'=>
"Text",
'c.phone'=>
"Text",
399 'c.fax'=>
"Text",
'c.email'=>
"Text",
400 'c.statut'=>
"Status",
401 's.rowid'=>
"Numeric",
's.nom'=>
"Text",
's.status'=>
"Status",
's.code_client'=>
"Text",
's.code_fournisseur'=>
"Text",
402 's.code_compta'=>
"Text",
's.code_compta_fournisseur'=>
"Text",
403 's.client'=>
"Numeric",
's.fournisseur'=>
"Numeric",
404 's.address'=>
"Text",
's.zip'=>
"Text",
's.town'=>
"Text",
's.phone'=>
"Text",
's.email'=>
"Text",
405 't.code'=>
"List:c_stcomm:libelle:code",
406 'c.entity'=>
'List:entity:label:rowid',
407 's.entity'=>
'List:entity:label:rowid',
409 $this->export_entities_array[$r] = array(
410 's.rowid'=>
"company",
's.nom'=>
"company",
's.status'=>
'company',
's.code_client'=>
"company",
's.code_fournisseur'=>
"company",
411 's.code_compta'=>
"company",
's.code_compta_fournisseur'=>
"company",
412 's.client'=>
"company",
's.fournisseur'=>
"company",
413 's.address'=>
"company",
's.zip'=>
"company",
's.town'=>
"company",
's.phone'=>
"company",
's.email'=>
"company",
415 's.entity'=>
'company',
417 if (!isModEnabled(
"supplier_order") && !isModEnabled(
"supplier_invoice")) {
418 unset($this->export_fields_array[$r][
's.code_fournisseur']);
419 unset($this->export_entities_array[$r][
's.code_fournisseur']);
421 $keyforselect =
'socpeople';
422 $keyforelement =
'contact';
423 $keyforaliasextra =
'extra';
424 include DOL_DOCUMENT_ROOT.
'/core/extrafieldsinexport.inc.php';
425 $keyforselect =
'societe';
426 $keyforelement =
'company';
427 $keyforaliasextra =
'extrasoc';
428 include DOL_DOCUMENT_ROOT.
'/core/extrafieldsinexport.inc.php';
429 $this->export_sql_start[$r] =
'SELECT DISTINCT ';
430 $this->export_sql_end[$r] =
' FROM '.MAIN_DB_PREFIX.
'socpeople as c';
431 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'societe as s ON c.fk_soc = s.rowid';
432 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'societe_extrafields as extrasoc ON s.rowid = extrasoc.fk_object';
433 if (is_object($user) && empty($user->rights->societe->client->voir)) {
434 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'societe_commerciaux as sc ON sc.fk_soc = s.rowid';
436 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_departements as d ON c.fk_departement = d.rowid';
437 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_regions as r ON r.code_region = d.fk_region AND r.fk_pays = c.fk_pays';
438 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_country as co ON c.fk_pays = co.rowid';
439 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'socpeople_extrafields as extra ON extra.fk_object = c.rowid';
440 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'c_typent as t ON s.fk_typent = t.id';
441 $this->export_sql_end[$r] .=
' WHERE c.entity IN ('.getEntity(
'contact').
')';
442 if (is_object($user) && empty($user->rights->societe->client->voir)) {
443 $this->export_sql_end[$r] .=
' AND (sc.fk_user = '.((int) $user->id).
' ';
444 if (!empty($conf->global->SOCIETE_EXPORT_SUBORDINATES_CHILDS)) {
445 $subordinatesids = $user->getAllChildIds();
446 $this->export_sql_end[$r] .= count($subordinatesids) > 0 ?
' OR (sc.fk_user IN ('.$this->db->sanitize(implode(
',', $subordinatesids)).
')' :
'';
448 $this->export_sql_end[$r] .=
')';
459 $this->import_code[$r] = $this->rights_class.
'_'.$r;
460 $this->import_label[$r] =
'ImportDataset_company_1';
461 $this->import_icon[$r] =
'company';
462 $this->import_entities_array[$r] = array();
463 $this->import_tables_array[$r] = array(
464 's' => MAIN_DB_PREFIX.
'societe',
465 'extra' => MAIN_DB_PREFIX.
'societe_extrafields'
467 $this->import_fields_array[$r] = array(
468 's.nom' =>
"ThirdPartyName*",
469 's.name_alias' =>
"AliasNameShort",
470 's.parent' =>
"ParentCompany",
471 's.status' =>
"Status*",
472 's.code_client' =>
"CustomerCode",
473 's.code_fournisseur' =>
"SupplierCode",
474 's.code_compta' =>
"CustomerAccountancyCode",
475 's.code_compta_fournisseur' =>
"SupplierAccountancyCode",
476 's.address' =>
"Address",
479 's.fk_departement' =>
"StateCode",
480 's.fk_pays' =>
"CountryCode",
481 's.phone' =>
"Phone",
484 's.email' =>
"Email",
485 's.fk_effectif' =>
"Staff",
486 's.fk_typent' =>
"ThirdPartyType",
487 "s.fk_forme_juridique" =>
"JuridicalStatus",
488 's.siren' =>
"ProfId1",
489 's.siret' =>
"ProfId2",
490 's.ape' =>
"ProfId3",
491 's.idprof4' =>
"ProfId4",
492 's.idprof5' =>
"ProfId5",
493 's.idprof6' =>
"ProfId6",
494 's.tva_intra' =>
"VATIntraShort",
495 's.capital' =>
"Capital",
496 's.fk_stcomm' =>
'ProspectStatus',
497 's.note_private' =>
"NotePrivate",
498 's.note_public' =>
"NotePublic",
499 's.client' =>
"Customer*",
500 's.fournisseur' =>
"Supplier*",
501 's.fk_prospectlevel' =>
'ProspectLevel',
502 's.mode_reglement' =>
'PaymentTypeCustomer',
503 's.cond_reglement' =>
"PaymentTermsCustomer",
504 's.mode_reglement_supplier' =>
'PaymentTypeSupplier',
505 's.cond_reglement_supplier' =>
"PaymentTermsSupplier",
506 's.outstanding_limit'=>
'OutstandingBill',
507 's.fk_account'=>
'PaymentBankAccount',
508 's.fk_incoterms'=>
'IncotermLabel',
509 's.tva_assuj' =>
'VATIsUsed',
510 's.barcode' =>
'BarCode',
511 's.default_lang' =>
'DefaultLanguage',
512 's.canvas' =>
"Canvas",
513 's.datec' =>
"DateCreation",
514 's.fk_multicurrency' =>
'MulticurrencyUsed',
515 's.multicurrency_code' =>
'MulticurrencyCurrency'
517 if (!empty($conf->global->PRODUIT_MULTIPRICES)) {
518 $this->import_fields_array[$r][
's.price_level'] =
'PriceLevel';
520 if (!empty($conf->global->ACCOUNTANCY_USE_PRODUCT_ACCOUNT_ON_THIRDPARTY)) {
521 $this->import_fields_array[$r] += array(
's.accountancy_code_sell'=>
'ProductAccountancySellCode',
's.accountancy_code_buy'=>
'ProductAccountancyBuyCode');
524 if (isModEnabled(
'socialnetworks')) {
525 $sql =
"SELECT code, label FROM ".MAIN_DB_PREFIX.
"c_socialnetworks WHERE active = 1";
526 $resql = $this->db->query($sql);
527 while ($obj = $this->db->fetch_object($resql)) {
528 $fieldname =
's.socialnetworks_'.$obj->code;
529 $fieldlabel = ucfirst($obj->label);
530 $this->import_fields_array[$r][$fieldname] = $fieldlabel;
534 $sql =
"SELECT name, label, fieldrequired FROM ".MAIN_DB_PREFIX.
"extrafields WHERE type <> 'separate' AND elementtype = 'societe' AND entity IN (0, ".$conf->entity.
")";
535 $resql = $this->db->query($sql);
537 while ($obj = $this->db->fetch_object($resql)) {
538 $fieldname =
'extra.'.$obj->name;
539 $fieldlabel = ucfirst($obj->label);
540 $this->import_fields_array[$r][$fieldname] = $fieldlabel.($obj->fieldrequired ?
'*' :
'');
544 $this->import_fieldshidden_array[$r] = array(
545 's.fk_user_creat' =>
'user->id',
546 'extra.fk_object' =>
'lastrowid-'.MAIN_DB_PREFIX.
'societe'
548 $this->import_convertvalue_array[$r] = array(
549 's.code_client' => array(
'rule' =>
'getcustomercodeifauto'),
550 's.code_fournisseur' => array(
'rule' =>
'getsuppliercodeifauto'),
551 's.code_compta' => array(
'rule' =>
'getcustomeraccountancycodeifauto'),
552 's.code_compta_fournisseur' => array(
'rule' =>
'getsupplieraccountancycodeifauto'),
553 's.fk_departement' => array(
554 'rule' =>
'fetchidfromcodeid',
555 'classfile' =>
'/core/class/cstate.class.php',
558 'dict' =>
'DictionaryStateCode'
560 's.fk_pays' => array(
561 'rule' =>
'fetchidfromcodeid',
562 'classfile' =>
'/core/class/ccountry.class.php',
563 'class' =>
'Ccountry',
565 'dict' =>
'DictionaryCountry'
567 's.fk_typent' => array(
568 'rule' =>
'fetchidfromcodeorlabel',
569 'classfile' =>
'/core/class/ctypent.class.php',
570 'class' =>
'Ctypent',
572 'dict' =>
'DictionaryCompanyType'
574 's.capital' => array(
'rule' =>
'numeric'),
576 'rule' =>
'fetchidfromref',
577 'file' =>
'/societe/class/societe.class.php',
578 'class' =>
'Societe',
580 'element' =>
'ThirdParty'
582 's.outstanding_limit' => array(
'rule' =>
'numeric'),
583 's.fk_account' => array(
584 'rule' =>
'fetchidfromcodeid',
585 'classfile' =>
'/compta/bank/class/account.class.php',
586 'class' =>
'Account',
588 'element' =>
'BankAccount'
590 's.fk_stcomm' => array(
591 'rule' =>
'fetchidfromcodeid',
592 'classfile' =>
'/core/class/cgenericdic.class.php',
593 'class' =>
'CGenericDic',
595 'dict' =>
'DictionaryProspectStatus',
596 'element' =>
'c_stcomm',
597 'table_element' =>
'c_stcomm'
619 $this->import_regex_array[$r] = array(
620 's.status' =>
'^[0|1]',
621 's.fk_typent' =>
'id@'.MAIN_DB_PREFIX.
'c_typent',
622 's.client' =>
'^[0|1|2|3]',
623 's.fournisseur' =>
'^[0|1]',
624 's.mode_reglement' =>
'id@'.MAIN_DB_PREFIX.
'c_paiement',
625 's.cond_reglement' =>
'rowid@'.MAIN_DB_PREFIX.
'c_payment_term',
626 's.mode_reglement_supplier' =>
'id@'.MAIN_DB_PREFIX.
'c_paiement',
627 's.cond_reglement_supplier' =>
'rowid@'.MAIN_DB_PREFIX.
'c_payment_term',
628 's.fk_incoterms' =>
'rowid@'.MAIN_DB_PREFIX.
'c_incoterms',
629 's.tva_assuj' =>
'^[0|1]',
630 's.fk_multicurrency' =>
'^[0|1]',
631 's.datec' =>
'^[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]( [0-9][0-9]:[0-9][0-9]:[0-9][0-9])?$',
632 's.multicurrency_code' =>
'code_iso@'.MAIN_DB_PREFIX.
'c_currencies'
635 $this->import_examplevalues_array[$r] = array(
636 's.nom' =>
"TPBigCompany",
637 's.name_alias' =>
"Alias for TPBigCompany",
638 's.parent' =>
"TPMotherCompany",
639 's.status' =>
"0 (closed) / 1 (active)",
640 's.code_client' =>
'eg. CU01-0001 / empty / "auto"',
641 's.code_fournisseur' =>
'eg. SU01-0001 / empty / "auto"',
642 's.code_compta' =>
"Code or empty to be auto-created",
643 's.code_compta_fournisseur' =>
"Code or empty to be auto-created",
644 's.address' =>
"61 Jump Street",
646 's.town' =>
"Bigtown",
647 's.fk_departement' =>
'matches field "code_departement" in table "'.MAIN_DB_PREFIX.
'c_departements"',
648 's.fk_pays' =>
'US/FR/DE etc. matches field "code" in table "'.MAIN_DB_PREFIX.
'c_country"',
649 's.phone' =>
"eg: +34123456789",
650 's.fax' =>
"eg. +34987654321",
651 's.url' =>
"e.g. https://www.mybigcompany.com",
652 's.email' =>
"e.g. test@mybigcompany.com",
653 's.fk_effectif' =>
"1/2/3/5: represents one of the five ranges of employees",
654 's.fk_typent' =>
'matches field "id" (1-9 etc.) OR "code" (TE_SMALL etc.) in table "'.MAIN_DB_PREFIX.
'c_typent"',
655 's.fk_forme_juridique' =>
'1/2/3 etc...matches field "code" in table "'.MAIN_DB_PREFIX.
'c_forme_juridique"',
662 's.tva_intra' =>
'VAT number e.g."FR0123456789"',
663 's.capital' =>
"10000",
664 's.fk_stcomm' =>
'-1/0/1/2 etc... matches field "id" in table "'.MAIN_DB_PREFIX.
'c_stcomm"',
665 's.note_private' =>
"Example of a PRIVATE note.",
666 's.note_public' =>
"Example of a PUBLIC note.",
667 's.client' =>
'0 (no customer no prospect) / 1 (customer) / 2 (prospect)/ 3 (customer and prospect)',
668 's.fournisseur' =>
'0 (not supplier) / 1 (supplier)',
669 's.fk_prospectlevel' =>
'eg. "PL_MEDIUM" matches field "code" in table "'.MAIN_DB_PREFIX.
'c_prospectlevel"',
670 's.mode_reglement' =>
'1/2/3...matches field "id" in table "'.MAIN_DB_PREFIX.
'c_paiement"',
671 's.cond_reglement' =>
'1/2/3...matches field "rowid" in table "'.MAIN_DB_PREFIX.
'c_payment_term"',
672 's.mode_reglement_supplier' =>
'1/2/3...matches field "id" in table "'.MAIN_DB_PREFIX.
'c_paiement"',
673 's.cond_reglement_supplier' =>
'1/2/3...matches field "rowid" in table "'.MAIN_DB_PREFIX.
'c_payment_term"',
674 's.outstanding_limit' =>
"5000",
675 's.fk_account' =>
"rowid or ref",
676 's.fk_incoterms' =>
'1/2/3...matches field "rowid" in table "'.MAIN_DB_PREFIX.
'c_incoterms"',
677 's.tva_assuj' =>
'0 (VAT not used) / 1 (VAT used)',
678 's.barcode' =>
'123456789',
679 's.default_lang' =>
'en_US / es_ES etc...matches a language directory in htdocs/langs/',
680 's.canvas' =>
"empty / a custom canvas form layout url e.g. mycanvas@mymodule",
681 's.datec' =>
'formatted as '.dol_print_date(
dol_now(),
'%Y-%m-%d'),
682 's.fk_multicurrency' =>
'0 (use system default currency) / 1 (use local currency)',
683 's.multicurrency_code' =>
'GBP/USD etc... matches field "code_iso" in table "'.MAIN_DB_PREFIX.
'c_currencies"',
684 's.accountancy_code_sell' =>
'707',
685 's.accountancy_code_buy' =>
'607',
687 $this->import_updatekeys_array[$r] = array(
688 's.nom' =>
'ThirdPartyName',
690 's.email' =>
'Email',
691 's.code_client' =>
'CustomerCode',
692 's.code_fournisseur' =>
'SupplierCode',
693 's.code_compta' =>
'CustomerAccountancyCode',
694 's.code_compta_fournisseur' =>
'SupplierAccountancyCode'
696 if (isModEnabled(
'socialnetworks')) {
697 $sql =
"SELECT code, label FROM ".MAIN_DB_PREFIX.
"c_socialnetworks WHERE active = 1";
698 $resql = $this->db->query($sql);
699 while ($obj = $this->db->fetch_object($resql)) {
700 $fieldname =
's.socialnetworks_'.$obj->code;
701 $fieldlabel = ucfirst($obj->label);
702 $this->import_updatekeys_array[$r][$fieldname] = $fieldlabel;
706 $langs->load(
"companies");
710 $this->import_updatekeys_array[$r][
's.siren'] =
'ProfId1'.(empty($mysoc->country_code) ?
'' : $mysoc->country_code);
713 $this->import_updatekeys_array[$r][
's.siret'] =
'ProfId2'.(empty($mysoc->country_code) ?
'' : $mysoc->country_code);
716 $this->import_updatekeys_array[$r][
's.ape'] =
'ProfId3'.(empty($mysoc->country_code) ?
'' : $mysoc->country_code);
720 if ($langs->trans(
'ProfId'.$i.(empty($mysoc->country_code) ?
'' : $mysoc->country_code)) !=
'-') {
721 $this->import_updatekeys_array[$r][
's.idprof'.$i] =
'ProfId'.$i.(empty($mysoc->country_code) ?
'' : $mysoc->country_code);
729 $this->import_code[$r] = $this->rights_class.
'_'.$r;
730 $this->import_label[$r] =
'ImportDataset_company_2';
731 $this->import_icon[$r] =
'contact';
732 $this->import_entities_array[$r] = array(
's.fk_soc' =>
'company');
733 $this->import_tables_array[$r] = array(
734 's' => MAIN_DB_PREFIX.
'socpeople',
735 'extra' => MAIN_DB_PREFIX.
'socpeople_extrafields'
737 $this->import_fields_array[$r] = array(
739 's.datec' =>
"DateCreation",
740 's.fk_soc' =>
'ThirdPartyName',
741 's.civility' =>
'UserTitle',
742 's.lastname' =>
"Lastname*",
743 's.firstname' =>
"Firstname",
744 's.address' =>
"Address",
747 's.fk_departement' =>
"StateCode",
748 's.fk_pays' =>
"CountryCode",
749 's.birthday' =>
"DateOfBirth",
750 's.poste' =>
"PostOrFunction",
751 's.phone' =>
"Phone",
752 's.phone_perso' =>
"PhonePerso",
753 's.phone_mobile' =>
"PhoneMobile",
755 's.email' =>
"Email",
756 's.note_private' =>
"NotePrivate",
757 's.note_public' =>
"NotePublic"
760 if (isModEnabled(
'socialnetworks')) {
761 $sql =
"SELECT code, label FROM ".MAIN_DB_PREFIX.
"c_socialnetworks WHERE active = 1";
762 $resql = $this->db->query($sql);
763 while ($obj = $this->db->fetch_object($resql)) {
764 $fieldname =
's.socialnetworks_'.$obj->code;
765 $fieldlabel = ucfirst($obj->label);
766 $this->import_fields_array[$r][$fieldname] = $fieldlabel;
770 $sql =
"SELECT name, label, fieldrequired FROM ".MAIN_DB_PREFIX.
"extrafields WHERE type <> 'separate' AND elementtype = 'socpeople' AND entity IN (0, ".$conf->entity.
")";
771 $resql = $this->db->query($sql);
773 while ($obj = $this->db->fetch_object($resql)) {
774 $fieldname =
'extra.'.$obj->name;
775 $fieldlabel = ucfirst($obj->label);
776 $this->import_fields_array[$r][$fieldname] = $fieldlabel.($obj->fieldrequired ?
'*' :
'');
780 $this->import_fieldshidden_array[$r] = array(
781 's.fk_user_creat' =>
'user->id',
782 'extra.fk_object' =>
'lastrowid-'.MAIN_DB_PREFIX.
'socpeople'
784 $this->import_convertvalue_array[$r] = array(
786 'rule' =>
'fetchidfromref',
787 'file' =>
'/societe/class/societe.class.php',
788 'class' =>
'Societe',
790 'element' =>
'ThirdParty'
792 's.fk_departement' => array(
793 'rule' =>
'fetchidfromcodeid',
794 'classfile' =>
'/core/class/cstate.class.php',
797 'dict' =>
'DictionaryCanton'
799 's.fk_pays' => array(
800 'rule' =>
'fetchidfromcodeid',
801 'classfile' =>
'/core/class/ccountry.class.php',
802 'class' =>
'Ccountry',
804 'dict' =>
'DictionaryCountry'
808 $this->import_regex_array[$r] = array(
809 's.birthday' =>
'^[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]$',
810 's.datec' =>
'^[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]( [0-9][0-9]:[0-9][0-9]:[0-9][0-9])?$'
812 $this->import_examplevalues_array[$r] = array(
815 's.fk_soc' =>
'Third Party name eg. TPBigCompany',
816 's.civility' =>
'Title of civility eg: MR...matches field "code" in table "'.MAIN_DB_PREFIX.
'c_civility"',
817 's.lastname' =>
"lastname or label",
818 's.firstname' =>
'John',
819 's.address' =>
'61 Jump street',
821 's.town' =>
'Bigtown',
822 's.fk_departement' =>
'matches field "code_departement" in table "'.MAIN_DB_PREFIX.
'c_departements"',
823 's.fk_pays' =>
'US/FR/DE etc. matches field "code" in table "'.MAIN_DB_PREFIX.
'c_country"',
824 's.birthday' =>
'formatted as '.dol_print_date(
dol_now(),
'%Y-%m-%d'),
825 's.poste' =>
"Director",
826 's.phone' =>
"5551122",
827 's.phone_perso' =>
"5551133",
828 's.phone_mobile' =>
"5551144",
829 's.fax' =>
"5551155",
830 's.email' =>
"johnsmith@email.com",
831 's.note_private' =>
"My private note",
832 's.note_public' =>
"My public note"
834 $this->import_updatekeys_array[$r] = array(
836 's.lastname' =>
"Lastname",
838 if (isModEnabled(
'socialnetworks')) {
839 $sql =
"SELECT code, label FROM ".MAIN_DB_PREFIX.
"c_socialnetworks WHERE active = 1";
840 $resql = $this->db->query($sql);
841 while ($obj = $this->db->fetch_object($resql)) {
842 $fieldname =
's.socialnetworks_'.$obj->code;
843 $fieldlabel = ucfirst($obj->label);
844 $this->import_updatekeys_array[$r][$fieldname] = $fieldlabel;
850 $this->import_code[$r] = $this->rights_class.
'_'.$r;
851 $this->import_label[$r] =
"ImportDataset_company_3";
852 $this->import_icon[$r] =
'company';
853 $this->import_entities_array[$r] = array();
854 $this->import_tables_array[$r] = array(
'sr' => MAIN_DB_PREFIX.
'societe_rib');
855 $this->import_fields_array[$r] = array(
856 'sr.label' =>
"Label*",
857 'sr.fk_soc' =>
"ThirdPartyName*",
858 'sr.datec' =>
"DateCreation*",
860 'sr.code_banque' =>
"BankCode",
861 'sr.code_guichet' =>
"DeskCode",
862 'sr.number' =>
"BankAccountNumber",
863 'sr.cle_rib' =>
"BankAccountNumberKey",
865 'sr.iban_prefix' =>
"IBAN",
866 'sr.domiciliation' =>
"BankAccountDomiciliation",
867 'sr.proprio' =>
"BankAccountOwner",
868 'sr.owner_address' =>
"BankAccountOwnerAddress",
869 'sr.default_rib' =>
'Default',
871 'sr.frstrecur' =>
"WithdrawMode",
872 'sr.type' =>
"Type ban is defaut",
875 $this->import_convertvalue_array[$r] = array(
876 'sr.fk_soc' => array(
877 'rule' =>
'fetchidfromref',
878 'classfile' =>
'/societe/class/societe.class.php',
879 'class' =>
'Societe',
881 'element' =>
'ThirdParty'
884 $this->import_examplevalues_array[$r] = array(
885 'sr.label' =>
'eg. "account1"',
886 'sr.fk_soc' =>
'eg. "TPBigCompany"',
887 'sr.datec' =>
'date used for creating direct debit UMR formatted as '.
dol_print_date(
891 'sr.bank' =>
'bank name eg: "ING-Direct"',
892 'sr.code_banque' =>
'account sort code (GB)/Routing number (US) eg. "8456"',
893 'sr.code_guichet' =>
"bank code for office/branch",
894 'sr.number' =>
'account number eg. "3333333333"',
895 'sr.cle_rib' =>
'account checksum/control digits (if used) eg. "22"',
896 'sr.bic' =>
'bank identifier eg. "USHINGMMXXX"',
897 'sr.iban_prefix' =>
'complete account IBAN eg. "GB78CPBK08925068637123"',
898 'sr.domiciliation' =>
'bank branch address eg. "PARIS"',
899 'sr.proprio' =>
'name on the bank account',
900 'sr.owner_address' =>
'address of account holder',
901 'sr.default_rib' =>
'1 (default account) / 0 (not default)',
902 'sr.rum' =>
'RUM code',
903 'sr.frstrecur' =>
'FRST',
909 $this->import_code[$r] = $this->rights_class.
'_'.$r;
910 $this->import_label[$r] =
"ImportDataset_company_4";
911 $this->import_icon[$r] =
'company';
912 $this->import_entities_array[$r] = array(
'sr.fk_user'=>
'user');
913 $this->import_tables_array[$r] = array(
'sr'=>MAIN_DB_PREFIX.
'societe_commerciaux');
914 $this->import_fields_array[$r] = array(
'sr.fk_soc'=>
"ThirdPartyName*",
'sr.fk_user'=>
"User*");
916 $this->import_convertvalue_array[$r] = array(
917 'sr.fk_soc'=>array(
'rule'=>
'fetchidfromref',
'classfile'=>
'/societe/class/societe.class.php',
'class'=>
'Societe',
'method'=>
'fetch',
'element'=>
'ThirdParty'),
918 'sr.fk_user'=>array(
'rule'=>
'fetchidfromref',
'classfile'=>
'/user/class/user.class.php',
'class'=>
'User',
'method'=>
'fetch',
'element'=>
'User')
920 $this->import_examplevalues_array[$r] = array(
'sr.fk_soc'=>
"MyBigCompany",
'sr.fk_user'=>
"login");