27 require_once
'../main.inc.php';
28 require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formfile.class.php';
29 require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formother.class.php';
30 require_once DOL_DOCUMENT_ROOT.
'/imports/class/import.class.php';
31 require_once DOL_DOCUMENT_ROOT.
'/core/modules/import/modules_import.php';
32 require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
33 require_once DOL_DOCUMENT_ROOT.
'/core/lib/images.lib.php';
34 require_once DOL_DOCUMENT_ROOT.
'/core/lib/import.lib.php';
37 $langs->loadLangs(array(
'exports',
'compta',
'errors'));
43 $entitytoicon = array(
45 'invoice_line' =>
'bill',
47 'order_line' =>
'order',
49 'propal_line' =>
'propal',
50 'intervention' =>
'intervention',
51 'inter_line' =>
'intervention',
53 'member_type' =>
'group',
54 'subscription' =>
'payment',
55 'payment' =>
'payment',
57 'tax_type' =>
'generic',
59 'account' =>
'account',
60 'product' =>
'product',
61 'virtualproduct'=>
'product',
62 'subproduct' =>
'product',
63 'product_supplier_ref' =>
'product',
65 'warehouse' =>
'stock',
67 'stockbatch' =>
'stock',
68 'category' =>
'category',
69 'shipment' =>
'sending',
70 'shipment_line'=>
'sending',
71 'reception'=>
'sending',
72 'reception_line'=>
'sending',
73 'expensereport'=>
'trip',
74 'expensereport_line'=>
'trip',
75 'holiday' =>
'holiday',
76 'contract_line' =>
'contract',
77 'translation' =>
'generic',
83 $entitytolang = array(
85 'company' =>
'Company',
86 'contact' =>
'Contact',
88 'invoice_line' =>
'InvoiceLine',
90 'order_line' =>
'OrderLine',
91 'propal' =>
'Proposal',
92 'propal_line' =>
'ProposalLine',
93 'intervention' =>
'Intervention',
94 'inter_line' =>
'InterLine',
96 'member_type' =>
'MemberType',
97 'subscription' =>
'Subscription',
98 'tax' =>
'SocialContribution',
99 'tax_type' =>
'DictionarySocialContributions',
100 'account' =>
'BankTransactions',
101 'payment' =>
'Payment',
102 'product' =>
'Product',
103 'virtualproduct' =>
'AssociatedProducts',
104 'subproduct' =>
'SubProduct',
105 'product_supplier_ref' =>
'SupplierPrices',
106 'service' =>
'Service',
108 'movement' =>
'StockMovement',
110 'stockbatch' =>
'StockDetailPerBatch',
111 'warehouse' =>
'Warehouse',
112 'category' =>
'Category',
114 'trip' =>
'TripsAndExpenses',
115 'shipment' =>
'Shipments',
116 'shipment_line'=>
'ShipmentLine',
117 'project' =>
'Projects',
118 'projecttask' =>
'Tasks',
119 'task_time' =>
'TaskTimeSpent',
121 'expensereport'=>
'ExpenseReport',
122 'expensereport_line'=>
'ExpenseReportLine',
123 'holiday' =>
'TitreRequestCP',
124 'contract' =>
'Contract',
125 'contract_line'=>
'ContractLine',
126 'translation' =>
'Translation',
128 'bomline' =>
'BOMLine'
131 $datatoimport =
GETPOST(
'datatoimport');
133 $filetoimport =
GETPOST(
'filetoimport');
134 $action =
GETPOST(
'action',
'alpha');
135 $confirm =
GETPOST(
'confirm',
'alpha');
137 $import_name =
GETPOST(
'import_name');
139 $importmodelid =
GETPOST(
'importmodelid',
'int');
140 $excludefirstline = (
GETPOST(
'excludefirstline') ?
GETPOST(
'excludefirstline') : 2);
141 $endatlinenb = (
GETPOST(
'endatlinenb') ?
GETPOST(
'endatlinenb') :
'');
142 $updatekeys = (
GETPOST(
'updatekeys',
'array') ?
GETPOST(
'updatekeys',
'array') : array());
143 $separator = (
GETPOST(
'separator',
'alphanohtml') ?
GETPOST(
'separator',
'alphanohtml', 3) :
'');
144 $enclosure = (
GETPOST(
'enclosure',
'nohtml') ?
GETPOST(
'enclosure',
'nohtml') :
'"');
145 $separator_used = str_replace(
'\t',
"\t", $separator);
147 $objimport =
new Import($db);
148 $objimport->load_arrays($user, ($step == 1 ?
'' : $datatoimport));
157 if (empty($array_match_file_to_database)) {
158 $serialized_array_match_file_to_database = isset($_SESSION[
"dol_array_match_file_to_database_select"]) ? $_SESSION[
"dol_array_match_file_to_database_select"] :
'';
159 $array_match_file_to_database = array();
160 $fieldsarray = explode(
',', $serialized_array_match_file_to_database);
161 foreach ($fieldsarray as $elem) {
162 $tabelem = explode(
'=', $elem, 2);
164 $val = (isset($tabelem[1]) ? $tabelem[1] :
'');
166 $array_match_file_to_database[$key] = $val;
201 if ($action ==
'builddoc') {
203 $result = $objimport->build_file($user,
GETPOST(
'model',
'alpha'), $datatoimport, $array_match_file_to_database);
211 if ($action ==
'deleteprof') {
213 $objimport->fetch(
GETPOST(
"id",
'int'));
214 $result = $objimport->delete($user);
219 if ($action ==
'add_import_model') {
223 foreach ($array_match_file_to_database as $key => $val) {
227 $hexa .= $key.
'='.$val;
230 $objimport->model_name = $import_name;
231 $objimport->datatoimport = $datatoimport;
232 $objimport->hexa = $hexa;
233 $objimport->fk_user = (
GETPOST(
'visibility',
'aZ09') ==
'all' ? 0 : $user->id);
235 $result = $objimport->create($user);
237 setEventMessages($langs->trans(
"ImportModelSaved", $objimport->model_name),
null,
'mesgs');
240 $langs->load(
"errors");
241 if ($objimport->errno ==
'DB_ERROR_RECORD_ALREADY_EXISTS') {
242 setEventMessages($langs->trans(
"ErrorImportDuplicateProfil"),
null,
'errors');
248 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"ImportModelName")),
null,
'errors');
252 if ($step == 3 && $datatoimport) {
253 if (
GETPOST(
'sendit') && !empty($conf->global->MAIN_UPLOAD_DOC)) {
257 $fullpath = $conf->import->dir_temp.
"/".$nowyearmonth.
'-'.$_FILES[
'userfile'][
'name'];
259 dol_syslog(
"File ".$fullpath.
" was added for import");
261 $langs->load(
"errors");
267 if ($action ==
'confirm_deletefile' && $confirm ==
'yes') {
268 $langs->load(
"other");
270 $param =
'&datatoimport='.urlencode($datatoimport).
'&format='.urlencode($format);
271 if ($excludefirstline) {
272 $param .=
'&excludefirstline='.urlencode($excludefirstline);
275 $param .=
'&endatlinenb='.urlencode($endatlinenb);
278 $file = $conf->import->dir_temp.
'/'.
GETPOST(
'urlfile');
285 Header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?step='.$step.$param);
290 if ($step == 4 && $action ==
'select_model') {
292 $_SESSION[
"dol_array_match_file_to_database"] =
'';
293 $serialized_array_match_file_to_database =
'';
294 $array_match_file_to_database = array();
298 $result = $objimport->fetch($importmodelid);
300 $serialized_array_match_file_to_database = $objimport->hexa;
301 $fieldsarray = explode(
',', $serialized_array_match_file_to_database);
302 foreach ($fieldsarray as $elem) {
303 $tabelem = explode(
'=', $elem);
307 $array_match_file_to_database[$key] = $val;
310 $_SESSION[
"dol_array_match_file_to_database"] = $serialized_array_match_file_to_database;
311 $_SESSION[
'dol_array_match_file_to_database_select'] = $_SESSION[
"dol_array_match_file_to_database"];
314 if ($action ==
'saveselectorder') {
316 $serialized_array_match_file_to_database =
'';
318 $selectorder = explode(
",",
GETPOST(
'selectorder'));
319 $fieldtarget = $fieldstarget = $objimport->array_import_fields[0];
320 foreach ($selectorder as $key => $code) {
321 $serialized_array_match_file_to_database .= $key.
'='.$code;
322 $serialized_array_match_file_to_database .=
',';
324 $serialized_array_match_file_to_database = substr($serialized_array_match_file_to_database, 0, -1);
325 dol_syslog(
'dol_array_match_file_to_database_select='.$serialized_array_match_file_to_database);
326 $_SESSION[
"dol_array_match_file_to_database_select"] = $serialized_array_match_file_to_database;
338 $help_url =
'EN:Module_Imports_En|FR:Module_Imports|ES:Módulo_Importaciones';
342 if ($step == 1 || !$datatoimport) {
344 $serialized_array_match_file_to_database =
'';
345 $array_match_file_to_database = array();
346 $_SESSION[
"dol_array_match_file_to_database"] =
'';
347 $_SESSION[
"dol_array_match_file_to_database_select"] =
'';
350 if ($excludefirstline) {
351 $param .=
'&excludefirstline='.urlencode($excludefirstline);
354 $param .=
'&endatlinenb='.urlencode($endatlinenb);
357 $param .=
'&separator='.urlencode($separator);
360 $param .=
'&enclosure='.urlencode($enclosure);
369 print
'<div class="opacitymedium">'.$langs->trans(
"SelectImportDataSet").
'</div><br>';
372 print
'<div class="div-table-responsive-no-min">';
373 print
'<table class="noborder centpercent">';
374 print
'<tr class="liste_titre">';
375 print
'<td>'.$langs->trans(
"Module").
'</td>';
376 print
'<td>'.$langs->trans(
"ImportableDatas").
'</td>';
377 print
'<td> </td>';
380 if (count($objimport->array_import_module)) {
381 $sortedarrayofmodules =
dol_sort_array($objimport->array_import_module,
'position_of_profile',
'asc', 0, 0, 1);
382 foreach ($sortedarrayofmodules as $key => $value) {
384 print
'<tr class="oddeven"><td>';
385 $titleofmodule = $objimport->array_import_module[$key][
'module']->getName();
387 if (in_array($objimport->array_import_code[$key], array(
'produit_supplierprices',
'produit_multiprice',
'produit_languages'))) {
388 $titleofmodule = $langs->trans(
"ProductOrService");
390 print $titleofmodule;
392 $entity = preg_replace(
'/:.*$/',
'', $objimport->array_import_icon[$key]);
393 $entityicon = strtolower(!empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity);
394 print
img_object($objimport->array_import_module[$key][
'module']->getName(), $entityicon).
' ';
395 print $objimport->array_import_label[$key];
396 print
'</td><td style="text-align: right">';
397 if ($objimport->array_import_perms[$key]) {
398 print
'<a href="'.DOL_URL_ROOT.
'/imports/import.php?step=2&datatoimport='.$objimport->array_import_code[$key].$param.
'">'.
img_picto($langs->trans(
"NewImport"),
'next',
'class="fa-15"').
'</a>';
400 print $langs->trans(
"NotEnoughPermissions");
405 print
'<tr><td class="oddeven" colspan="3">'.$langs->trans(
"NoImportableData").
'</td></tr>';
415 if ($step == 2 && $datatoimport) {
416 $param =
'&datatoimport='.urlencode($datatoimport);
417 if ($excludefirstline) {
418 $param .=
'&excludefirstline='.urlencode($excludefirstline);
421 $param .=
'&endatlinenb='.urlencode($endatlinenb);
424 $param .=
'&separator='.urlencode($separator);
427 $param .=
'&enclosure='.urlencode($enclosure);
436 print
'<div class="underbanner clearboth"></div>';
437 print
'<div class="fichecenter">';
439 print
'<table class="border tableforfield centpercent">';
442 print
'<tr><td class="titlefieldcreate">'.$langs->trans(
"Module").
'</td>';
444 $titleofmodule = $objimport->array_import_module[0][
'module']->getName();
446 if (in_array($objimport->array_import_code[0], array(
'produit_supplierprices',
'produit_multiprice',
'produit_languages'))) {
447 $titleofmodule = $langs->trans(
"ProductOrService");
449 print $titleofmodule;
453 print
'<tr><td>'.$langs->trans(
"DatasetToImport").
'</td>';
455 $entity = preg_replace(
'/:.*$/',
'', $objimport->array_import_icon[0]);
456 $entityicon = strtolower(!empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity);
457 print
img_object($objimport->array_import_module[0][
'module']->getName(), $entityicon).
' ';
458 print $objimport->array_import_label[0];
466 print
'<form name="userfile" action="'.$_SERVER[
"PHP_SELF"].
'" enctype="multipart/form-data" METHOD="POST">';
467 print
'<input type="hidden" name="token" value="'.newToken().
'">';
471 print
'<span class="opacitymedium">';
472 $s = $langs->trans(
"ChooseFormatOfFileToImport",
'{s1}');
473 $s = str_replace(
'{s1}',
img_picto(
'',
'next'), $s);
475 print
'</span><br><br>';
479 print
'<div class="div-table-responsive-no-min">';
480 print
'<table class="noborder centpercent" cellpadding="4">';
485 print
'<tr class="liste_titre"><td colspan="5">';
486 print $langs->trans(
"FileMustHaveOneOfFollowingFormat");
488 $list = $objmodelimport->liste_modeles($db);
489 foreach ($list as $key) {
490 print
'<tr class="oddeven">';
491 print
'<td width="16">'.img_picto_common($key, $objmodelimport->getPictoForKey($key)).
'</td>';
492 $text = $objmodelimport->getDriverDescForKey($key);
493 print
'<td>'.$form->textwithpicto($objmodelimport->getDriverLabelForKey($key), $text).
'</td>';
494 print
'<td style="text-align:center">';
495 print
'<a href="'.DOL_URL_ROOT.
'/imports/emptyexample.php?format='.$key.$param.
'" target="_blank" rel="noopener noreferrer">';
496 print
img_picto(
'',
'download',
'class="paddingright opacitymedium"');
497 print $langs->trans(
"DownloadEmptyExampleShort");
499 print
$form->textwithpicto(
'', $langs->trans(
"DownloadEmptyExample").
'.<br>'.$langs->trans(
"StarAreMandatory"));
502 print
'<td style="text-align:right">';
503 print
'<a href="'.DOL_URL_ROOT.
'/imports/import.php?step=3&format='.$key.$param.
'">'.
img_picto($langs->trans(
"SelectFormat"),
'next',
'class="fa-15"').
'</a>';
516 if ($step == 3 && $datatoimport) {
517 $param =
'&datatoimport='.urlencode($datatoimport).
'&format='.urlencode($format);
518 if ($excludefirstline) {
519 $param .=
'&excludefirstline='.urlencode($excludefirstline);
522 $param .=
'&endatlinenb='.urlencode($endatlinenb);
525 $param .=
'&separator='.urlencode($separator);
528 $param .=
'&enclosure='.urlencode($enclosure);
531 $list = $objmodelimport->liste_modeles($db);
542 if ($action ==
'delete') {
543 print
$form->formconfirm($_SERVER[
"PHP_SELF"].
'?urlfile='.urlencode(
GETPOST(
'urlfile')).
'&step=3'.$param, $langs->trans(
'DeleteFile'), $langs->trans(
'ConfirmDeleteFile'),
'confirm_deletefile',
'', 0, 1);
546 print
'<div class="underbanner clearboth"></div>';
547 print
'<div class="fichecenter">';
549 print
'<table class="border tableforfield centpercent">';
552 print
'<tr><td class="titlefieldcreate">'.$langs->trans(
"Module").
'</td>';
554 $titleofmodule = $objimport->array_import_module[0][
'module']->getName();
556 if (in_array($objimport->array_import_code[0], array(
'produit_supplierprices',
'produit_multiprice',
'produit_languages'))) {
557 $titleofmodule = $langs->trans(
"ProductOrService");
559 print $titleofmodule;
563 print
'<tr><td>'.$langs->trans(
"DatasetToImport").
'</td>';
565 $entity = preg_replace(
'/:.*$/',
'', $objimport->array_import_icon[0]);
566 $entityicon = strtolower(!empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity);
567 print
img_object($objimport->array_import_module[0][
'module']->getName(), $entityicon).
' ';
568 print $objimport->array_import_label[0];
574 print
load_fiche_titre($langs->trans(
"InformationOnSourceFile"),
'',
'file-export');
576 print
'<div class="underbanner clearboth"></div>';
577 print
'<div class="fichecenter">';
578 print
'<table width="100%" class="border tableforfield">';
581 print
'<tr><td class="titlefieldcreate">'.$langs->trans(
"SourceFileFormat").
'</td>';
582 print
'<td class="nowraponall">';
583 $text = $objmodelimport->getDriverDescForKey($format);
584 print
$form->textwithpicto($objmodelimport->getDriverLabelForKey($format), $text);
585 print
'</td><td style="text-align:right" class="nowrap">';
586 print
'<a href="'.DOL_URL_ROOT.
'/imports/emptyexample.php?format='.$format.$param.
'" target="_blank" rel="noopener noreferrer">';
587 print
img_picto(
'',
'download',
'class="paddingright opacitymedium"');
588 print $langs->trans(
"DownloadEmptyExampleShort");
590 print
$form->textwithpicto(
'', $langs->trans(
"DownloadEmptyExample").
'.<br>'.$langs->trans(
"StarAreMandatory"));
599 if ($format ==
'xlsx' && !class_exists(
'XMLWriter')) {
600 $langs->load(
"install");
601 print
info_admin($langs->trans(
"ErrorPHPDoesNotSupport",
'php-xml'), 0, 0, 1,
'error');
607 print
'<form name="userfile" action="'.$_SERVER[
"PHP_SELF"].
'" enctype="multipart/form-data" method="POST">';
608 print
'<input type="hidden" name="token" value="'.newToken().
'">';
609 print
'<input type="hidden" value="'.$step.
'" name="step">';
610 print
'<input type="hidden" value="'.dol_escape_htmltag($format).
'" name="format">';
611 print
'<input type="hidden" value="'.$excludefirstline.
'" name="excludefirstline">';
612 print
'<input type="hidden" value="'.$endatlinenb.
'" name="endatlinenb">';
613 print
'<input type="hidden" value="'.dol_escape_htmltag($separator).
'" name="separator">';
614 print
'<input type="hidden" value="'.dol_escape_htmltag($enclosure).
'" name="enclosure">';
615 print
'<input type="hidden" value="'.dol_escape_htmltag($datatoimport).
'" name="datatoimport">';
617 print
'<span class="opacitymedium">';
618 $s = $langs->trans(
"ChooseFileToImport",
'{s1}');
619 $s = str_replace(
'{s1}',
img_picto(
'',
'next'), $s);
621 print
'</span><br><br>';
626 print
'<div class="marginbottomonly">';
628 $maxmin = $maxfilesizearray[
'maxmin'];
630 print
'<input type="hidden" name="MAX_FILE_SIZE" value="'.($maxmin * 1024).
'">';
632 print
'<input type="file" name="userfile" size="20" maxlength="80"> ';
633 $out = (empty($conf->global->MAIN_UPLOAD_DOC) ?
' disabled' :
'');
634 print
'<input type="submit" class="button small" value="'.$langs->trans(
"AddFile").
'"'.$out.
' name="sendit">';
636 if (!empty($conf->global->MAIN_UPLOAD_DOC)) {
637 $max = $conf->global->MAIN_UPLOAD_DOC;
638 $maxphp = @ini_get(
'upload_max_filesize');
639 if (preg_match(
'/k$/i', $maxphp)) {
640 $maxphp = (int) substr($maxphp, 0, -1) * 1;
642 if (preg_match(
'/m$/i', $maxphp)) {
643 $maxphp = (int) substr($maxphp, 0, -1) * 1024;
645 if (preg_match(
'/g$/i', $maxphp)) {
646 $maxphp = (int) substr($maxphp, 0, -1) * 1024 * 1024;
648 if (preg_match(
'/t$/i', $maxphp)) {
649 $maxphp = (int) substr($maxphp, 0, -1) * 1024 * 1024 * 1024;
651 $maxphp2 = @ini_get(
'post_max_size');
652 if (preg_match(
'/k$/i', $maxphp2)) {
653 $maxphp2 = (int) substr($maxphp2, 0, -1) * 1;
655 if (preg_match(
'/m$/i', $maxphp2)) {
656 $maxphp2 = (int) substr($maxphp2, 0, -1) * 1024;
658 if (preg_match(
'/g$/i', $maxphp2)) {
659 $maxphp2 = (int) substr($maxphp2, 0, -1) * 1024 * 1024;
661 if (preg_match(
'/t$/i', $maxphp2)) {
662 $maxphp2 = (int) substr($maxphp2, 0, -1) * 1024 * 1024 * 1024;
666 $maxphptoshow = $maxphptoshowparam =
'';
668 $maxmin = min($max, $maxphp);
669 $maxphptoshow = $maxphp;
670 $maxphptoshowparam =
'upload_max_filesize';
673 $maxmin = min($max, $maxphp2);
674 if ($maxphp2 < $maxphp) {
675 $maxphptoshow = $maxphp2;
676 $maxphptoshowparam =
'post_max_size';
680 $langs->load(
'other');
682 $out .=
info_admin($langs->trans(
"ThisLimitIsDefinedInSetup", $max, $maxphptoshow), 1);
684 $out .=
' ('.$langs->trans(
"UploadDisabled").
')';
690 $filearray =
dol_dir_list($conf->import->dir_temp,
'files', 0,
'',
'',
'name', SORT_DESC);
691 if (count($filearray) > 0) {
692 print
'<div class="div-table-responsive-no-min">';
693 print
'<table class="noborder centpercent" width="100%" cellpadding="4">';
695 $dir = $conf->import->dir_temp;
699 foreach ($filearray as $key => $val) {
700 $file = $val[
'name'];
704 $file = utf8_encode($file);
707 if (preg_match(
'/^\./', $file)) {
711 $modulepart =
'import';
712 $urlsource = $_SERVER[
"PHP_SELF"].
'?step='.$step.$param.
'&filetoimport='.urlencode($filetoimport);
713 $relativepath = $file;
715 print
'<tr class="oddeven">';
717 print
img_mime($file,
'',
'pictofixedwidth');
718 print
'<a data-ajax="false" href="'.DOL_URL_ROOT.
'/document.php?modulepart='.$modulepart.
'&file='.urlencode($relativepath).
'&step=3'.$param.
'" target="_blank" rel="noopener noreferrer">';
723 print
'<td style="text-align:right">'.dol_print_size(
dol_filesize($dir.
'/'.$file)).
'</td>';
725 print
'<td style="text-align:right">'.dol_print_date(
dol_filemtime($dir.
'/'.$file),
'dayhour').
'</td>';
727 print
'<td style="text-align:right"><a href="'.$_SERVER[
'PHP_SELF'].
'?action=delete&token='.
newToken().
'&step=3'.$param.
'&urlfile='.urlencode($relativepath);
728 print
'">'.img_delete().
'</a></td>';
730 print
'<td style="text-align:right">';
731 print
'<a href="'.$_SERVER[
'PHP_SELF'].
'?step=4'.$param.
'&filetoimport='.urlencode($relativepath).
'">'.
img_picto($langs->trans(
"NewImport"),
'next',
'class="fa-15"').
'</a>';
745 if ($step == 4 && $datatoimport) {
747 $serialized_array_match_file_to_database = isset($_SESSION[
"dol_array_match_file_to_database_select"]) ? $_SESSION[
"dol_array_match_file_to_database_select"] :
'';
748 $fieldsarray = explode(
',', $serialized_array_match_file_to_database);
749 $array_match_file_to_database = array();
750 foreach ($fieldsarray as $elem) {
751 $tabelem = explode(
'=', $elem, 2);
753 $val = (isset($tabelem[1]) ? $tabelem[1] :
'');
755 $array_match_file_to_database[$key] = $val;
764 $list = $objmodelimport->liste_modeles($db);
766 if (empty($separator)) {
767 $separator = (empty($conf->global->IMPORT_CSV_SEPARATOR_TO_USE) ?
',' : $conf->global->IMPORT_CSV_SEPARATOR_TO_USE);
771 if ($model ==
'csv' && strlen($separator) == 1 && !
GETPOSTISSET(
'separator')) {
773 $fh = fopen($conf->import->dir_temp.
'/'.$filetoimport,
'r');
775 $sline = fgets($fh, 1000000);
777 $nboccurence = substr_count($sline, $separator);
778 $nboccurencea = substr_count($sline,
',');
779 $nboccurenceb = substr_count($sline,
';');
781 if ($nboccurence == 0) {
782 if ($nboccurencea > 2) {
784 } elseif ($nboccurenceb > 2) {
792 $separator_used = str_replace(
'\t',
"\t", $separator);
795 $dir = DOL_DOCUMENT_ROOT.
"/core/modules/import/";
796 $file =
"import_".$model.
".modules.php";
797 $classname =
"Import".ucfirst($model);
798 require_once $dir.$file;
799 $obj =
new $classname($db, $datatoimport);
800 if ($model ==
'csv') {
801 $obj->separator = $separator_used;
802 $obj->enclosure = $enclosure;
804 if ($model ==
'xlsx') {
805 if (!preg_match(
'/\.xlsx$/i', $filetoimport)) {
806 $langs->load(
"errors");
807 $param =
'&datatoimport='.$datatoimport.
'&format='.$format;
808 setEventMessages($langs->trans(
"ErrorFileMustHaveFormat", $model),
null,
'errors');
809 header(
"Location: ".$_SERVER[
"PHP_SELF"].
'?step=3'.$param.
'&filetoimport='.urlencode($relativepath));
815 $array_match_file_to_database = array();
819 $fieldssource = array();
820 $result = $obj->import_open_file($conf->import->dir_temp.
'/'.$filetoimport, $langs);
823 $arrayrecord = $obj->import_read_record();
827 foreach ($arrayrecord as $key => $val) {
828 if ($val[
"type"] != -1) {
829 $fieldssource[$i][
'example1'] =
dol_trunc($val[
'val'], 128);
832 $fieldssource[$i][
'example1'] = $langs->trans(
'Empty');
836 $obj->import_close_file();
840 $fieldstarget = $objimport->array_import_fields[0];
841 $minpos = min(count($fieldssource), count($fieldstarget));
845 $initialloadofstep4 =
false;
846 if (empty($_SESSION[
'dol_array_match_file_to_database_select'])) {
847 $initialloadofstep4 =
true;
851 if (count($array_match_file_to_database) == 0) {
857 $num = count($fieldssource);
858 while ($pos <= $num) {
859 if ($num >= 1 && $pos <= $num) {
861 foreach ($fieldstarget as $key => $val) {
862 if ($posbis < $pos) {
867 $array_match_file_to_database[$pos] = $key;
874 $array_match_database_to_file = array_flip($array_match_file_to_database);
878 $fieldstarget_tmp = array();
879 $arraykeysfieldtarget = array_keys($fieldstarget);
881 foreach ($fieldstarget as $key => $label) {
882 $isrequired = preg_match(
'/\*$/', $label);
883 if (!empty($isrequired)) {
884 $newlabel = substr($label, 0, -1);
885 $fieldstarget_tmp[$key] = array(
"label"=>$newlabel,
"required"=>
true);
887 $fieldstarget_tmp[$key] = array(
"label"=>$label,
"required"=>
false);
889 if (!empty($array_match_database_to_file[$key])) {
890 $fieldstarget_tmp[$key][
"imported"] =
true;
891 $fieldstarget_tmp[$key][
"position"] = $array_match_database_to_file[$key]-1;
893 while (!empty($array_match_database_to_file[$keytoswap])) {
894 if ($position+1 > $array_match_database_to_file[$keytoswap]) {
895 $keytoswapwith = $array_match_database_to_file[$keytoswap]-1;
896 $tmp = [$keytoswap=>$fieldstarget_tmp[$keytoswap]];
897 unset($fieldstarget_tmp[$keytoswap]);
898 $fieldstarget_tmp =
arrayInsert($fieldstarget_tmp, $keytoswapwith, $tmp);
899 $keytoswapwith = $arraykeysfieldtarget[$array_match_database_to_file[$keytoswap]-1];
900 $tmp = $fieldstarget_tmp[$keytoswapwith];
901 unset($fieldstarget_tmp[$keytoswapwith]);
902 $fieldstarget_tmp[$keytoswapwith] = $tmp;
903 $keytoswap = $keytoswapwith;
909 $fieldstarget_tmp[$key][
"imported"] =
false;
913 $fieldstarget = $fieldstarget_tmp;
922 $param =
'&format='.$format.
'&datatoimport='.urlencode($datatoimport).
'&filetoimport='.urlencode($filetoimport);
923 if ($excludefirstline) {
924 $param .=
'&excludefirstline='.urlencode($excludefirstline);
927 $param .=
'&endatlinenb='.urlencode($endatlinenb);
930 $param .=
'&separator='.urlencode($separator);
933 $param .=
'&enclosure='.urlencode($enclosure);
942 print
'<div class="underbanner clearboth"></div>';
943 print
'<div class="fichecenter">';
945 print
'<table class="centpercent border tableforfield">';
948 print
'<tr><td class="titlefieldcreate">'.$langs->trans(
"Module").
'</td>';
950 $titleofmodule = $objimport->array_import_module[0][
'module']->getName();
952 if (in_array($objimport->array_import_code[0], array(
'produit_supplierprices',
'produit_multiprice',
'produit_languages'))) {
953 $titleofmodule = $langs->trans(
"ProductOrService");
955 print $titleofmodule;
959 print
'<tr><td>'.$langs->trans(
"DatasetToImport").
'</td>';
961 $entity = preg_replace(
'/:.*$/',
'', $objimport->array_import_icon[0]);
962 $entityicon = strtolower(!empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity);
963 print
img_object($objimport->array_import_module[0][
'module']->getName(), $entityicon).
' ';
964 print $objimport->array_import_label[0];
970 print
load_fiche_titre($langs->trans(
"InformationOnSourceFile"),
'',
'file-export');
972 print
'<div class="underbanner clearboth"></div>';
973 print
'<div class="fichecenter">';
974 print
'<table width="100%" class="border tableforfield">';
977 print
'<tr><td class="titlefieldcreate">'.$langs->trans(
"SourceFileFormat").
'</td>';
979 $text = $objmodelimport->getDriverDescForKey($format);
980 print
$form->textwithpicto($objmodelimport->getDriverLabelForKey($format), $text);
984 if ($model ==
'csv') {
985 print
'<tr><td>'.$langs->trans(
"CsvOptions").
'</td>';
987 print
'<form method="POST">';
988 print
'<input type="hidden" name="token" value="'.newToken().
'">';
989 print
'<input type="hidden" value="'.$step.
'" name="step">';
990 print
'<input type="hidden" value="'.$format.
'" name="format">';
991 print
'<input type="hidden" value="'.$excludefirstline.
'" name="excludefirstline">';
992 print
'<input type="hidden" value="'.$endatlinenb.
'" name="endatlinenb">';
993 print
'<input type="hidden" value="'.$datatoimport.
'" name="datatoimport">';
994 print
'<input type="hidden" value="'.$filetoimport.
'" name="filetoimport">';
995 print $langs->trans(
"Separator").
' : ';
996 print
'<input type="text" class="width25 center" name="separator" value="'.dol_escape_htmltag($separator).
'"/>';
997 print
' '.$langs->trans(
"Enclosure").
' : ';
998 print
'<input type="text" class="width25 center" name="enclosure" value="'.dol_escape_htmltag($enclosure).
'"/> ';
999 print
'<input name="update" type="submit" value="'.$langs->trans(
'Update').
'" class="button smallpaddingimp" />';
1005 print
'<tr><td>'.$langs->trans(
"FileToImport").
'</td>';
1007 $modulepart =
'import';
1008 $relativepath =
GETPOST(
'filetoimport');
1009 print
'<a data-ajax="false" href="'.DOL_URL_ROOT.
'/document.php?modulepart='.$modulepart.
'&file='.urlencode($relativepath).
'&step=4'.$param.
'" target="_blank" rel="noopener noreferrer">';
1010 print
img_mime($file,
'',
'pictofixedwidth');
1011 print $filetoimport;
1012 print
img_picto($langs->trans(
"Download"),
'download',
'class="paddingleft opacitymedium"');
1025 print
'<!-- List of source fields -->'.
"\n";
1026 print
'<form action="'.$_SERVER[
"PHP_SELF"].
'" method="POST">';
1027 print
'<input type="hidden" name="token" value="'.newToken().
'">';
1028 print
'<input type="hidden" name="action" value="select_model">';
1029 print
'<input type="hidden" name="step" value="4">';
1030 print
'<input type="hidden" name="format" value="'.$format.
'">';
1031 print
'<input type="hidden" name="datatoimport" value="'.$datatoimport.
'">';
1032 print
'<input type="hidden" name="filetoimport" value="'.$filetoimport.
'">';
1033 print
'<input type="hidden" name="excludefirstline" value="'.$excludefirstline.
'">';
1034 print
'<input type="hidden" name="endatlinenb" value="'.$endatlinenb.
'">';
1035 print
'<input type="hidden" name="separator" value="'.dol_escape_htmltag($separator).
'">';
1036 print
'<input type="hidden" name="enclosure" value="'.dol_escape_htmltag($enclosure).
'">';
1039 print
'<div class="marginbottomonly">';
1040 print
'<span class="opacitymedium">';
1041 $s = $langs->trans(
"SelectImportFieldsSource",
'{s1}');
1042 $s = str_replace(
'{s1}',
img_picto(
'',
'grip_title',
'',
false, 0, 0,
'',
'', 0), $s);
1045 $htmlother->select_import_model($importmodelid,
'importmodelid', $datatoimport, 1, $user->id);
1046 print
'<input type="submit" class="button small reposition" value="'.$langs->trans(
"Select").
'">';
1051 print
'<div class="div-table-responsive-no-min">';
1052 print
'<table class="noborder centpercent">';
1053 print
'<tr class="liste_titre">';
1054 print
'<td>'.$langs->trans(
"FieldsInSourceFile").
'</td>';
1055 print
'<td>'.$langs->trans(
"FieldsInTargetDatabase").
'</td>';
1060 print
'<tr valign="top"><td width="50%" class="nopaddingleftimp">';
1062 $fieldsplaced = array();
1063 $valforsourcefieldnb = array();
1064 $listofkeys = array();
1065 foreach ($array_match_file_to_database as $key => $val) {
1066 $listofkeys[$key] = 1;
1069 print
"\n<!-- Box left container -->\n";
1070 print
'<div id="left" class="connectedSortable">'.
"\n";
1075 foreach ($fieldssource as $key => $val) {
1076 show_elem($fieldssource, $key, $val, $var);
1077 $listofkeys[$key] = 1;
1078 $fieldsplaced[$key] = 1;
1079 $valforsourcefieldnb[$lefti] = $key;
1089 print
"<!-- End box left container -->\n";
1092 print
'</td><td width="50%" class="nopaddingrightimp">';
1095 $optionsall = array();
1096 foreach ($fieldstarget as $code => $line) {
1099 $tmparray = explode(
'|', $line[
"label"]);
1101 foreach ($tmparray as $tmpkey => $tmpval) {
1102 $labeltoshow .= ($labeltoshow ?
' '.$langs->trans(
'or').
' ' :
'').$langs->transnoentities($tmpval);
1104 $optionsall[$code] = array(
'labelkey'=>$line[
'label'],
'labelkeyarray'=>$tmparray,
'label'=>$labeltoshow,
'required'=>(empty($line[
"required"]) ? 0 : 1),
'position'=>!empty($line[
'position']) ? $line[
'position'] : 0);
1109 $optionsall[$code][
'picto'] = $picto;
1116 $mandatoryfieldshavesource =
true;
1129 $modetoautofillmapping =
'session';
1130 if ($initialloadofstep4) {
1131 $modetoautofillmapping =
'guess';
1135 print
'<table class="nobordernopadding centpercent tableimport">';
1136 foreach ($fieldssource as $code => $line) {
1140 print
'<tr style="height:'.$height.
'" class="trimport oddevenimport">';
1141 $entity = (!empty($objimport->array_import_entities[0][$code]) ? $objimport->array_import_entities[0][$code] : $objimport->array_import_icon[0]);
1143 $entityicon = !empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity;
1144 $entitylang = $entitytolang[$entity] ? $entitytolang[$entity] : $objimport->array_import_label[0];
1147 print
'<td class="nowraponall" style="font-weight: normal">=> </td>';
1148 print
'<td class="nowraponall" style="font-weight: normal">';
1153 $selectforline =
'';
1154 $selectforline .=
'<select id="selectorderimport_'.($i+1).
'" class="targetselectchange minwidth300" name="select_'.($i+1).
'">';
1155 if (!empty($line[
"imported"])) {
1156 $selectforline .=
'<option value="-1"> </option>';
1158 $selectforline .=
'<option selected="" value="-1"> </option>';
1162 $codeselectedarray = array();
1163 foreach ($optionsall as $tmpcode => $tmpval) {
1165 if (!empty($tmpval[
'picto'])) {
1166 $label .=
img_picto(
'', $tmpval[
'picto'],
'class="pictofixedwidth"');
1168 $label .= $tmpval[
'required'] ?
'<strong>' :
'';
1169 $label .= $tmpval[
'label'];
1170 $label .= $tmpval[
'required'] ?
'*</strong>' :
'';
1172 $tablealias = preg_replace(
'/(\..*)$/i',
'', $tmpcode);
1173 $tablename = !empty($objimport->array_import_tables[0][$tablealias]) ? $objimport->array_import_tables[0][$tablealias] :
"";
1177 $filecolumn = ($i + 1);
1179 if (empty($objimport->array_import_convertvalue[0][$tmpcode])) {
1182 if ($objimport->array_import_convertvalue[0][$tmpcode][
'rule'] ==
'fetchidfromref') {
1183 $htmltext .= $langs->trans(
"DataComeFromIdFoundFromRef", $langs->transnoentitiesnoconv($entitylang)).
'<br>';
1185 if ($objimport->array_import_convertvalue[0][$tmpcode][
'rule'] ==
'fetchidfromcodeid') {
1186 $htmltext .= $langs->trans(
"DataComeFromIdFoundFromCodeId", $langs->transnoentitiesnoconv($objimport->array_import_convertvalue[0][$tmpcode][
'dict'])).
'<br>';
1190 $example = !empty($objimport->array_import_examplevalues[0][$tmpcode])?$objimport->array_import_examplevalues[0][$tmpcode]:
"";
1192 if (empty($objimport->array_import_convertvalue[0][$tmpcode])) {
1194 $htmltext .= $langs->trans(
"SourceExample").
': <b>'.str_replace(
'"',
'', $example).
'</b><br>';
1197 if ($objimport->array_import_convertvalue[0][$tmpcode][
'rule'] ==
'fetchidfromref') {
1198 $htmltext .= $langs->trans(
"SourceExample").
': <b>'.$langs->transnoentitiesnoconv(
"ExampleAnyRefFoundIntoElement", $entitylang).($example ?
' ('.$langs->transnoentitiesnoconv(
"Example").
': '.str_replace(
'"',
'', $example).
')' :
'').
'</b><br>';
1199 } elseif ($objimport->array_import_convertvalue[0][$tmpcode][
'rule'] ==
'fetchidfromcodeid') {
1200 $htmltext .= $langs->trans(
"SourceExample").
': <b>'.$langs->trans(
"ExampleAnyCodeOrIdFoundIntoDictionary", $langs->transnoentitiesnoconv($objimport->array_import_convertvalue[0][$tmpcode][
'dict'])).($example ?
' ('.$langs->transnoentitiesnoconv(
"Example").
': '.str_replace(
'"',
'', $example).
')' :
'').
'</b><br>';
1201 } elseif ($example) {
1202 $htmltext .= $langs->trans(
"SourceExample").
': <b>'.str_replace(
'"',
'', $example).
'</b><br>';
1206 if (!empty($objimport->array_import_regex[0][$tmpcode])) {
1207 $htmltext .= $langs->trans(
"FormatControlRule").
': <b>'.str_replace(
'"',
'', $objimport->array_import_regex[0][$tmpcode]).
'</b><br>';
1211 $htmltext .= $langs->trans(
"InformationOnTargetTables").
': <b>'.$tablename.
"->".preg_replace(
'/^.*\./',
'', $tmpcode).
"</b>";
1213 $labelhtml = $label.
' '.
$form->textwithpicto(
'', $htmltext, 1,
'help',
'', 1);
1215 $selectforline .=
'<option value="'.$tmpcode.
'"';
1216 if ($modetoautofillmapping ==
'orderoftargets') {
1219 $selectforline .=
' selected';
1221 } elseif ($modetoautofillmapping ==
'guess') {
1225 if (preg_match(
'/^(.+)\((.+\..+)\)$/', $line[
'example1'], $regs)) {
1226 $tmpstring1 = $regs[1];
1227 $tmpstring2 = $regs[2];
1229 $tmpstring1 = $line[
'example1'];
1232 $tmpstring1 = strtolower(str_replace(
'*',
'', trim($tmpstring1)));
1233 $tmpstring2 = strtolower(str_replace(
'*',
'', trim($tmpstring2)));
1236 foreach ($tmpval[
'labelkeyarray'] as $tmpval2) {
1237 $labeltarget = $langs->transnoentities($tmpval2);
1239 if ($tmpstring1 && ($tmpstring1 == $tmpcode || $tmpstring1 == strtolower($labeltarget)
1240 || $tmpstring1 == strtolower(
dol_string_unaccent($labeltarget)) || $tmpstring1 == strtolower($tmpval2))) {
1241 if (empty($codeselectedarray[$code])) {
1242 $selectforline .=
' selected';
1243 $codeselectedarray[$code] = 1;
1246 } elseif ($tmpstring2 && ($tmpstring2 == $tmpcode || $tmpstring2 == strtolower($labeltarget)
1247 || $tmpstring2 == strtolower(
dol_string_unaccent($labeltarget)) || $tmpstring2 == strtolower($tmpval2))) {
1248 if (empty($codeselectedarray[$code])) {
1249 $selectforline .=
' selected';
1250 $codeselectedarray[$code] = 1;
1255 } elseif ($modetoautofillmapping ==
'session' && !empty($_SESSION[
'dol_array_match_file_to_database_select'])) {
1256 $tmpselectioninsession =
dolExplodeIntoArray($_SESSION[
'dol_array_match_file_to_database_select'],
',',
'=');
1258 if (!empty($tmpselectioninsession[($i+1)]) && $tmpselectioninsession[($i+1)] == $tmpcode) {
1259 $selectforline .=
' selected';
1261 $selectforline .=
' data-debug="'.$tmpcode.
'-'.$code.
'-'.$j.
'-'.(!empty($tmpselectioninsession[($i+1)]) ? $tmpselectioninsession[($i+1)] :
"").
'"';
1263 $selectforline .=
' data-html="'.dol_escape_htmltag($labelhtml).
'"';
1264 $selectforline .=
'>';
1265 $selectforline .= $label;
1266 $selectforline .=
'</options>';
1269 $selectforline .=
'</select>';
1270 $selectforline .=
ajax_combobox(
'selectorderimport_'.($i+1));
1272 print $selectforline;
1277 print
'<td class="nowraponall" style="font-weight:normal; text-align:right">';
1280 $htmltext =
'<b><u>'.$langs->trans(
"FieldSource").
'</u></b><br>';
1282 $htmltext .= $langs->trans(
"DataComeFromFileFieldNb", $filecolumntoshow).
'<br>';
1284 print
$form->textwithpicto(
'', $htmltext);
1295 print
'<tr class="liste_titre"><td colspan="2">'.$langs->trans(
"Note").
'</td></tr>';
1296 print
'<tr><td colspan="2"><div id="div-mandatory-target-fields-not-mapped"></div></td></tr>';
1302 if (!empty($conf->use_javascript_ajax)) {
1303 print
'<script type="text/javascript">'.
"\n";
1304 print
'var previousselectedvalueimport = "0";'.
"\n";
1305 print
'var previousselectedlabelimport = "0";'.
"\n";
1306 print
'var arrayofselectedvalues = [];'.
"\n";
1307 print
'var arrayoftargetfields = [];'.
"\n";
1308 print
'var arrayoftargetmandatoryfields = [];'.
"\n";
1312 foreach ($fieldstarget as $key => $val) {
1313 print
"arrayoftargetfields[".$tmpi.
"] = '".
dol_escape_js($langs->trans($val[
'label'])).
"'; ";
1314 if ($val[
'required']) {
1315 print
"arrayoftargetmandatoryfields[".$tmpi.
"] = '".
dol_escape_js($key).
"'; ";
1321 print
'$(document).ready(function () {'.
"\n";
1323 print
'setOptionsToDisabled();'.
"\n";
1324 print
'saveSelection();'.
"\n";
1326 print
'$(".targetselectchange").focus(function(){'.
"\n";
1327 print
' previousselectedvalueimport = $(this).val();'.
"\n";
1328 print
' previousselectedlabelimport = $(this).children("option:selected").text();'.
"\n";
1329 print
' console.log("previousselectedvalueimport="+previousselectedvalueimport)'.
"\n";
1336 print
'function setOptionsToDisabled() {'.
"\n";
1337 print
' console.log("Remove the disabled flag everywhere");'.
"\n";
1338 print
' $("select.targetselectchange").not($( this )).find(\'option\').prop("disabled", false);'.
"\n";
1339 print
' arrayofselectedvalues = [];'.
"\n";
1341 print
' $("select.targetselectchange").each(function(){'.
"\n";
1342 print
' id = $(this).attr(\'id\')'.
"\n";
1343 print
' value = $(this).val()'.
"\n";
1344 print
' console.log("a selected value has been found for component "+id+" = "+value);'.
"\n";
1345 print
' arrayofselectedvalues.push(value);'.
"\n";
1348 print
' console.log("List of all selected values arrayofselectedvalues");'.
"\n";
1349 print
' console.log(arrayofselectedvalues);'.
"\n";
1350 print
' console.log("Set the option to disabled for every entry that is currently selected somewhere else (so into arrayofselectedvalues)");'.
"\n";
1352 print
' $.each(arrayofselectedvalues, function(key, value) {'.
"\n";
1353 print
' if (value != -1) {'.
"\n";
1354 print
' console.log("Process key="+key+" value="+value+" to disable.");'.
"\n";
1355 print
' $("select.targetselectchange").find(\'option[value="\'+value+\'"]:not(:selected)\').prop("disabled", true);'.
"\n";
1361 print
'function saveSelection() {'.
"\n";
1363 print
' arrayselectedfields = [];'.
"\n";
1364 print
' arrayselectedfields.push(0);'.
"\n";
1366 print
' $.each( arrayofselectedvalues, function( key, value ) {'.
"\n";
1367 print
' if (value != -1) {'.
"\n";
1368 print
' arrayselectedfields.push(value);'.
"\n";
1369 print
' } else {'.
"\n";
1370 print
' arrayselectedfields.push(0);'.
"\n";
1374 print
" $.ajax({\n";
1375 print
" type: 'POST',\n";
1376 print
" dataType: 'json',\n";
1377 print
" url: '".dol_escape_js($_SERVER[
"PHP_SELF"]).
"?action=saveselectorder&token=".
newToken().
"',\n";
1378 print
" data: 'selectorder='+arrayselectedfields.toString(),\n";
1379 print
" success: function(){\n";
1380 print
" console.log('The selected fields have been saved into '+arrayselectedfields.toString());\n";
1385 print
' console.log("arrayselectedfields");';
1386 print
' console.log(arrayselectedfields);';
1387 print
' console.log("arrayoftargetmandatoryfields");';
1388 print
' console.log(arrayoftargetmandatoryfields);';
1389 print
" listtoshow = '';";
1390 print
" nbelement = arrayoftargetmandatoryfields.length
1391 for (let i = 0; i < nbelement; i++) {
1392 if (arrayoftargetmandatoryfields[i] && ! arrayselectedfields.includes(arrayoftargetmandatoryfields[i])) {
1393 console.log(arrayoftargetmandatoryfields[i]+' not mapped');
1394 listtoshow = listtoshow + (listtoshow ? ', ' : '') + '<b>' + arrayoftargetfields[i] + '*</b>';
1397 console.log(listtoshow);
1399 listtoshow = '".dol_escape_js(
img_warning($langs->trans(
"MandatoryTargetFieldsNotMapped")).
' '.$langs->trans(
"MandatoryTargetFieldsNotMapped")).
": ' + listtoshow;
1400 $('#div-mandatory-target-fields-not-mapped').html(listtoshow);
1402 $('#div-mandatory-target-fields-not-mapped').html('<span class=\"opacitymedium\">".
dol_escape_js($langs->trans(
"AllTargetMandatoryFieldsAreMapped")).
"</span>');
1409 print
'$(".targetselectchange").change(function(){'.
"\n";
1410 print
' setOptionsToDisabled();'.
"\n";
1412 print
' if(previousselectedlabelimport != "" && previousselectedvalueimport != -1) {'.
"\n";
1413 print
' let valuetochange = $(this).val(); '.
"\n";
1414 print
' $(".boxtdunused").each(function(){'.
"\n";
1415 print
' if ($(this).text().includes(valuetochange)){'.
"\n";
1416 print
' arraychild = $(this)[0].childNodes'.
"\n";
1417 print
' arraytexttomodify = arraychild[0].textContent.split(" ")'.
"\n";
1418 print
' arraytexttomodify[1] = previousselectedvalueimport '.
"\n";
1419 print
' textmodified = arraytexttomodify.join(" ") '.
"\n";
1420 print
' arraychild[0].textContent = textmodified'.
"\n";
1421 print
' arraychild[1].innerHTML = previousselectedlabelimport'.
"\n";
1425 print
' $(this).blur()'.
"\n";
1427 print
' saveSelection()'.
"\n";
1431 print
'</script>'.
"\n";
1437 print
'<div class="tabsAction">';
1439 if (count($array_match_file_to_database)) {
1440 if ($mandatoryfieldshavesource) {
1441 print
'<a class="butAction saveorderselect" href="import.php?step=5'.$param.
'&filetoimport='.urlencode($filetoimport).
'">'.$langs->trans(
"NextStep").
'</a>';
1443 print
'<a class="butActionRefused classfortooltip" href="#" title="'.dol_escape_htmltag($langs->transnoentitiesnoconv(
"SomeMandatoryFieldHaveNoSource")).
'">'.$langs->trans(
"NextStep").
'</a>';
1451 if (count($array_match_file_to_database)) {
1453 print
'<!-- Area to add new import profile -->'.
"\n";
1454 print
'<div class="marginbottomonly"><span class="opacitymedium">'.$langs->trans(
"SaveImportModel").
'</span></div>';
1456 print
'<form class="nocellnopadd" action="'.$_SERVER[
"PHP_SELF"].
'" method="post">';
1457 print
'<input type="hidden" name="token" value="'.newToken().
'">';
1458 print
'<input type="hidden" name="action" value="add_import_model">';
1459 print
'<input type="hidden" name="step" value="'.$step.
'">';
1460 print
'<input type="hidden" name="format" value="'.$format.
'">';
1461 print
'<input type="hidden" name="datatoimport" value="'.$datatoimport.
'">';
1462 print
'<input type="hidden" name="filetoimport" value="'.$filetoimport.
'">';
1463 print
'<input type="hidden" name="hexa" value="'.$hexa.
'">';
1464 print
'<input type="hidden" name="excludefirstline" value="'.$excludefirstline.
'">';
1465 print
'<input type="hidden" name="endatlinenb" value="'.$endatlinenb.
'">';
1466 print
'<input type="hidden" name="page_y" value="">';
1467 print
'<input type="hidden" value="'.dol_escape_htmltag($separator).
'" name="separator">';
1468 print
'<input type="hidden" value="'.dol_escape_htmltag($enclosure).
'" name="enclosure">';
1470 print
'<div class="div-table-responsive-no-min">';
1471 print
'<table summary="selectofimportprofil" class="noborder centpercent">';
1472 print
'<tr class="liste_titre">';
1473 print
'<td>'.$langs->trans(
"ImportModelName").
'</td>';
1474 print
'<td>'.$langs->trans(
"Visibility").
'</td>';
1478 $nameofimportprofile = str_replace(
' ',
'-', $langs->trans(
"ImportProfile").
' '.$titleofmodule.
' '.
dol_print_date(
dol_now(
'gmt'),
'dayxcard'));
1480 $nameofimportprofile = $import_name;
1483 print
'<tr class="oddeven">';
1484 print
'<td><input name="import_name" class="minwidth300" value="'.$nameofimportprofile.
'"></td>';
1486 $arrayvisibility = array(
'private'=>$langs->trans(
"Private"),
'all'=>$langs->trans(
"Everybody"));
1487 print
$form->selectarray(
'visibility', $arrayvisibility,
'private');
1489 print
'<td class="right">';
1490 print
'<input type="submit" class="button smallpaddingimp reposition" value="'.$langs->trans(
"SaveImportProfile").
'">';
1494 $sql =
"SELECT rowid, label, fk_user, entity";
1495 $sql .=
" FROM ".MAIN_DB_PREFIX.
"import_model";
1496 $sql .=
" WHERE type = '".$db->escape($datatoimport).
"'";
1497 if (empty($conf->global->EXPORTS_SHARE_MODELS)) {
1498 $sql .=
" AND fk_user IN (0, ".((int) $user->id).
")";
1500 $sql .=
" ORDER BY rowid";
1502 $resql = $db->query($sql);
1504 $num = $db->num_rows(
$resql);
1506 $tmpuser =
new user($db);
1510 $obj = $db->fetch_object(
$resql);
1512 print
'<tr class="oddeven"><td>';
1516 if (empty($obj->fk_user)) {
1517 print $langs->trans(
"Everybody");
1519 $tmpuser->fetch($obj->fk_user);
1520 print $tmpuser->getNomUrl(-1);
1523 print
'<td class="right">';
1524 print
'<a class="reposition" href="'.$_SERVER[
"PHP_SELF"].
'?step='.$step.$param.
'&action=deleteprof&token='.
newToken().
'&id='.$obj->rowid.
'&filetoimport='.urlencode($filetoimport).
'">';
1542 if ($step == 5 && $datatoimport) {
1543 $max_execution_time_for_importexport = (empty($conf->global->IMPORT_MAX_EXECUTION_TIME) ? 300 : $conf->global->IMPORT_MAX_EXECUTION_TIME);
1544 $max_time = @ini_get(
"max_execution_time");
1545 if ($max_time && $max_time < $max_execution_time_for_importexport) {
1546 dol_syslog(
"max_execution_time=".$max_time.
" is lower than max_execution_time_for_importexport=".$max_execution_time_for_importexport.
". We try to increase it dynamically.");
1547 @ini_set(
"max_execution_time", $max_execution_time_for_importexport);
1551 $list = $objmodelimport->liste_modeles($db);
1554 $dir = DOL_DOCUMENT_ROOT.
"/core/modules/import/";
1555 $file =
"import_".$model.
".modules.php";
1556 $classname =
"Import".ucfirst($model);
1557 require_once $dir.$file;
1558 $obj =
new $classname($db, $datatoimport);
1559 if ($model ==
'csv') {
1560 $obj->separator = $separator_used;
1561 $obj->enclosure = $enclosure;
1565 $fieldssource = array();
1566 $result = $obj->import_open_file($conf->import->dir_temp.
'/'.$filetoimport, $langs);
1570 $arrayrecord = $obj->import_read_record();
1573 foreach ($arrayrecord as $key => $val) {
1574 $fieldssource[$i][
'example1'] =
dol_trunc($val[
'val'], 24);
1577 $obj->import_close_file();
1580 $nboflines = $obj->import_get_nb_of_lines($conf->import->dir_temp.
'/'.$filetoimport);
1582 $param =
'&leftmenu=import&format='.urlencode($format).
'&datatoimport='.urlencode($datatoimport).
'&filetoimport='.urlencode($filetoimport).
'&nboflines='.urlencode($nboflines).
'&separator='.urlencode($separator).
'&enclosure='.urlencode($enclosure);
1584 if ($excludefirstline) {
1585 $param .=
'&excludefirstline='.urlencode($excludefirstline);
1588 $param .=
'&endatlinenb='.urlencode($endatlinenb);
1590 if (!empty($updatekeys)) {
1591 $param .=
'&updatekeys[]='.implode(
'&updatekeys[]=', $updatekeys);
1594 llxHeader(
'', $langs->trans(
"NewImport"),
'EN:Module_Imports_En|FR:Module_Imports|ES:Módulo_Importaciones');
1599 print
'<form action="'.$_SERVER[
"PHP_SELF"].
'?'.$param2.
'" method="POST">';
1600 print
'<input type="hidden" name="token" value="'.newToken().
'">';
1601 print
'<input type="hidden" name="step" value="5">';
1602 print
'<input type="hidden" name="action" value="launchsimu">';
1606 print
'<div class="underbanner clearboth"></div>';
1607 print
'<div class="fichecenter">';
1609 print
'<table width="100%" class="border tableforfield">';
1612 print
'<tr><td class="titlefieldcreate">'.$langs->trans(
"Module").
'</td>';
1614 $titleofmodule = $objimport->array_import_module[0][
'module']->getName();
1616 if (in_array($objimport->array_import_code[0], array(
'produit_supplierprices',
'produit_multiprice',
'produit_languages'))) {
1617 $titleofmodule = $langs->trans(
"ProductOrService");
1619 print $titleofmodule;
1623 print
'<tr><td>'.$langs->trans(
"DatasetToImport").
'</td>';
1625 $entity = preg_replace(
'/:.*$/',
'', $objimport->array_import_icon[0]);
1626 $entityicon = strtolower(!empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity);
1627 print
img_object($objimport->array_import_module[0][
'module']->getName(), $entityicon).
' ';
1628 print $objimport->array_import_label[0];
1634 print
load_fiche_titre($langs->trans(
"InformationOnSourceFile"),
'',
'file-export');
1636 print
'<div class="underbanner clearboth"></div>';
1637 print
'<div class="fichecenter">';
1638 print
'<table width="100%" class="border tableforfield">';
1641 print
'<tr><td class="titlefieldcreate">'.$langs->trans(
"SourceFileFormat").
'</td>';
1643 $text = $objmodelimport->getDriverDescForKey($format);
1644 print
$form->textwithpicto($objmodelimport->getDriverLabelForKey($format), $text);
1648 if ($model ==
'csv') {
1649 print
'<tr><td>'.$langs->trans(
"CsvOptions").
'</td>';
1652 print
' '.$langs->trans(
"Enclosure").
' : '.
dol_escape_htmltag($enclosure);
1657 print
'<tr><td>'.$langs->trans(
"FileToImport").
'</td>';
1659 $modulepart =
'import';
1660 $relativepath =
GETPOST(
'filetoimport');
1661 print
'<a data-ajax="false" href="'.DOL_URL_ROOT.
'/document.php?modulepart='.$modulepart.
'&file='.urlencode($relativepath).
'&step=4'.$param.
'" target="_blank" rel="noopener noreferrer">';
1662 print
img_mime($file,
'',
'pictofixedwidth');
1663 print $filetoimport;
1664 print
img_picto($langs->trans(
"Download"),
'download',
'class="paddingleft opacitymedium"');
1670 print $langs->trans(
"NbOfSourceLines");
1677 print $langs->trans(
"ImportFromToLine");
1679 if ($action ==
'launchsimu') {
1680 print
'<input type="number" class="maxwidth50 right" name="excludefirstlinebis" disabled="disabled" value="'.$excludefirstline.
'">';
1681 print
'<input type="hidden" name="excludefirstline" value="'.$excludefirstline.
'">';
1683 print
'<input type="number" class="maxwidth50 right" name="excludefirstline" value="'.$excludefirstline.
'">';
1684 print
$form->textwithpicto(
"", $langs->trans(
"SetThisValueTo2ToExcludeFirstLine"));
1687 if ($action ==
'launchsimu') {
1688 print
'<input type="text" class="maxwidth50" name="endatlinenbbis" disabled="disabled" value="'.$endatlinenb.
'">';
1689 print
'<input type="hidden" name="endatlinenb" value="'.$endatlinenb.
'">';
1691 print
'<input type="text" class="maxwidth50" name="endatlinenb" value="'.$endatlinenb.
'">';
1692 print
$form->textwithpicto(
"", $langs->trans(
"KeepEmptyToGoToEndOfFile"));
1694 if ($action ==
'launchsimu') {
1695 print
' <a href="'.$_SERVER[
"PHP_SELF"].
'?step=5'.$param.
'">'.$langs->trans(
"Modify").
'</a>';
1697 if ($excludefirstline == 2) {
1698 print
$form->textwithpicto(
"", $langs->trans(
"WarningFirstImportedLine", $excludefirstline), 1,
'warning',
"warningexcludefirstline");
1700 $( document ).ready(function() {
1701 $("input[name=\'excludefirstline\']").on("change",function(){
1702 if($(this).val() <= 1){
1703 $(".warningexcludefirstline").hide();
1705 $(".warningexcludefirstline").show();
1715 print
$form->textwithpicto($langs->trans(
"KeysToUseForUpdates"), $langs->trans(
"SelectPrimaryColumnsForUpdateAttempt"));
1717 if ($action ==
'launchsimu') {
1718 if (count($updatekeys)) {
1719 print
$form->multiselectarray(
'updatekeysbis', $objimport->array_import_updatekeys[0], $updatekeys, 0, 0,
'', 1,
'80%',
'disabled');
1721 print
'<span class="opacitymedium">'.$langs->trans(
"NoUpdateAttempt").
'</span> -';
1723 foreach ($updatekeys as $val) {
1724 print
'<input type="hidden" name="updatekeys[]" value="'.$val.
'">';
1726 print
' <a href="'.$_SERVER[
"PHP_SELF"].
'?step=5'.$param.
'">'.$langs->trans(
"Modify").
'</a>';
1728 if (is_array($objimport->array_import_updatekeys[0]) && count($objimport->array_import_updatekeys[0])) {
1729 print
$form->multiselectarray(
'updatekeys', $objimport->array_import_updatekeys[0], $updatekeys, 0, 0,
'', 1,
'80%');
1732 print
'<span class="opacitymedium">'.$langs->trans(
"UpdateNotYetSupportedForThisImport").
'</span>';
1744 print
load_fiche_titre($langs->trans(
"InformationOnTargetTables"),
'',
'file-import');
1746 print
'<div class="underbanner clearboth"></div>';
1747 print
'<div class="fichecenter">';
1749 print
'<table width="100%" class="border tableforfield">';
1752 print
'<tr><td class="titlefieldcreate">';
1753 print $langs->trans(
"TablesTarget");
1755 $listtables = array();
1756 $sort_array_match_file_to_database = $array_match_file_to_database;
1757 foreach ($array_match_file_to_database as $code => $label) {
1759 if ($code > count($fieldssource)) {
1763 $alias = preg_replace(
'/(\..*)$/i',
'', $label);
1764 $listtables[$alias] = $objimport->array_import_tables[0][$alias];
1766 if (count($listtables)) {
1769 foreach ($listtables as $val) {
1788 print $langs->trans(
"Error");
1794 print $langs->trans(
"FieldsTarget").
'</td><td>';
1795 $listfields = array();
1798 $sort_array_match_file_to_database = $array_match_file_to_database;
1799 ksort($sort_array_match_file_to_database);
1801 foreach ($sort_array_match_file_to_database as $code => $label) {
1804 if ($code > count($fieldssource)) {
1808 $alias = preg_replace(
'/(\..*)$/i',
'', $label);
1809 $listfields[$i] =
'<span class="nowrap">'.$langs->trans(
"Column").
' '.
num2Alpha($code - 1).
' -> '.$label.
'</span>';
1811 print count($listfields) ? (join(
', ', $listfields)) : $langs->trans(
"Error");
1820 if ($action !=
'launchsimu') {
1822 print
'<br><span class="opacitymedium">';
1823 print $langs->trans(
"NowClickToTestTheImport", $langs->transnoentitiesnoconv(
"RunSimulateImportFile")).
'</span><br>';
1827 print
'<div class="center">';
1828 if ($user->rights->import->run) {
1829 print
'<input type="submit" class="butAction" value="'.$langs->trans(
"RunSimulateImportFile").
'">';
1831 print
'<a class="butActionRefused classfortooltip" href="#" title="'.dol_escape_htmltag($langs->transnoentitiesnoconv(
"NotEnoughPermissions")).
'">'.$langs->trans(
"RunSimulateImportFile").
'</a>';
1836 $arrayoferrors = array();
1837 $arrayofwarnings = array();
1838 $maxnboferrors = empty($conf->global->IMPORT_MAX_NB_OF_ERRORS) ? 50 : $conf->global->IMPORT_MAX_NB_OF_ERRORS;
1839 $maxnbofwarnings = empty($conf->global->IMPORT_MAX_NB_OF_WARNINGS) ? 50 : $conf->global->IMPORT_MAX_NB_OF_WARNINGS;
1851 $pathfile = $conf->import->dir_temp.
'/'.$filetoimport;
1852 $result = $obj->import_open_file($pathfile, $langs);
1854 global $tablewithentity_cache;
1855 $tablewithentity_cache = array();
1856 $sourcelinenb = 0; $endoffile = 0;
1859 while (($sourcelinenb < $nboflines) && !$endoffile) {
1863 $arrayrecord = $obj->import_read_record();
1864 if ($arrayrecord ===
false) {
1865 $arrayofwarnings[$sourcelinenb][0] = array(
'lib'=>
'File has '.$nboflines.
' lines. However we reach end of file after record '.$sourcelinenb.
'. This may occurs when some records are split onto several lines. Ensure the complete string is delimited correctly when there is a separator character in the text string.',
'type'=>
'EOF_RECORD_ON_SEVERAL_LINES');
1869 if ($excludefirstline && ($sourcelinenb < $excludefirstline)) {
1872 if ($endatlinenb && ($sourcelinenb > $endatlinenb)) {
1877 $result = $obj->import_insert($arrayrecord, $array_match_file_to_database, $objimport, count($fieldssource), $importid, $updatekeys);
1879 if (count($obj->errors)) {
1880 $arrayoferrors[$sourcelinenb] = $obj->errors;
1882 if (count($obj->warnings)) {
1883 $arrayofwarnings[$sourcelinenb] = $obj->warnings;
1885 if (!count($obj->errors) && !count($obj->warnings)) {
1890 $obj->import_close_file();
1892 print $langs->trans(
"ErrorFailedToOpenFile", $pathfile);
1899 if (!empty($objimport->array_import_run_sql_after[0]) && is_array($objimport->array_import_run_sql_after[0])) {
1901 foreach ($objimport->array_import_run_sql_after[0] as $sqlafterimport) {
1903 $resqlafterimport = $db->query($sqlafterimport);
1904 if (!$resqlafterimport) {
1905 $arrayoferrors[
'none'][] = array(
'lib'=>$langs->trans(
"Error running final request: ".$sqlafterimport));
1914 if (!count($arrayoferrors) && !count($arrayofwarnings)) {
1916 print
'<div class="info">';
1917 print
'<div class=""><b>'.$langs->trans(
"ResultOfSimulationNoError").
'</b></div>';
1918 print $langs->trans(
"NbInsert", empty($obj->nbinsert) ? 0 : $obj->nbinsert).
'<br>';
1919 print $langs->trans(
"NbUpdate", empty($obj->nbupdate) ? 0 : $obj->nbupdate).
'<br>';
1924 print
'<div class="warning">';
1925 print $langs->trans(
"NbOfLinesOK", $nbok).
'...<br>';
1932 if (count($arrayoferrors)) {
1933 print
img_error().
' <b>'.$langs->trans(
"ErrorsOnXLines", count($arrayoferrors)).
'</b><br>';
1934 print
'<table width="100%" class="border"><tr><td>';
1935 foreach ($arrayoferrors as $key => $val) {
1937 if ($nboferrors > $maxnboferrors) {
1938 print $langs->trans(
"TooMuchErrors", (count($arrayoferrors) - $nboferrors)).
"<br>";
1942 foreach ($val as $i => $err) {
1943 print
' > '.dol_escape_htmltag($err[
'lib']).
'<br>';
1946 print
'</td></tr></table>';
1952 if (count($arrayofwarnings)) {
1953 print
img_warning().
' <b>'.$langs->trans(
"WarningsOnXLines", count($arrayofwarnings)).
'</b><br>';
1954 print
'<table width="100%" class="border"><tr><td>';
1955 foreach ($arrayofwarnings as $key => $val) {
1957 if ($nbofwarnings > $maxnbofwarnings) {
1958 print $langs->trans(
"TooMuchWarnings", (count($arrayofwarnings) - $nbofwarnings)).
"<br>";
1962 foreach ($val as $i => $err) {
1963 print
' > '.dol_escape_htmltag($err[
'lib']).
'<br>';
1966 print
'</td></tr></table>';
1973 print
'<div class="center">';
1974 print
'<span class="opacitymedium">'.$langs->trans(
"NowClickToRunTheImport", $langs->transnoentitiesnoconv(
"RunImportFile")).
'</span><br>';
1983 print
'<div class="center">';
1984 if ($user->rights->import->run) {
1985 if (empty($nboferrors)) {
1986 print
'<a class="butAction" href="'.DOL_URL_ROOT.
'/imports/import.php?leftmenu=import&step=6&importid='.$importid.$param.
'">'.$langs->trans(
"RunImportFile").
'</a>';
1990 print
'<a class="butActionRefused classfortooltip" href="#" title="'.dol_escape_htmltag($langs->transnoentitiesnoconv(
"CorrectErrorBeforeRunningImport")).
'">'.$langs->trans(
"RunImportFile").
'</a>';
1993 print
'<a class="butActionRefused classfortooltip" href="#" title="'.dol_escape_htmltag($langs->transnoentitiesnoconv(
"NotEnoughPermissions")).
'">'.$langs->trans(
"RunSimulateImportFile").
'</a>';
1995 print
'<a class="butActionRefused classfortooltip" href="#" title="'.dol_escape_htmltag($langs->transnoentitiesnoconv(
"NotEnoughPermissions")).
'">'.$langs->trans(
"RunImportFile").
'</a>';
2005 if ($step == 6 && $datatoimport) {
2006 $max_execution_time_for_importexport = (empty($conf->global->IMPORT_MAX_EXECUTION_TIME) ? 300 : $conf->global->IMPORT_MAX_EXECUTION_TIME);
2007 $max_time = @ini_get(
"max_execution_time");
2008 if ($max_time && $max_time < $max_execution_time_for_importexport) {
2009 dol_syslog(
"max_execution_time=".$max_time.
" is lower than max_execution_time_for_importexport=".$max_execution_time_for_importexport.
". We try to increase it dynamically.");
2010 @ini_set(
"max_execution_time", $max_execution_time_for_importexport);
2014 $list = $objmodelimport->liste_modeles($db);
2015 $importid =
GETPOST(
"importid",
'alphanohtml');
2019 $dir = DOL_DOCUMENT_ROOT.
"/core/modules/import/";
2020 $file =
"import_".$model.
".modules.php";
2021 $classname =
"Import".ucfirst($model);
2022 require_once $dir.$file;
2023 $obj =
new $classname($db, $datatoimport);
2024 if ($model ==
'csv') {
2025 $obj->separator = $separator_used;
2026 $obj->enclosure = $enclosure;
2030 $fieldssource = array();
2031 $result = $obj->import_open_file($conf->import->dir_temp.
'/'.$filetoimport, $langs);
2034 $arrayrecord = $obj->import_read_record();
2037 foreach ($arrayrecord as $key => $val) {
2038 $fieldssource[$i][
'example1'] =
dol_trunc($val[
'val'], 24);
2041 $obj->import_close_file();
2044 $nboflines = (!empty($_GET[
"nboflines"]) ? $_GET[
"nboflines"] :
dol_count_nb_of_line($conf->import->dir_temp.
'/'.$filetoimport));
2046 $param =
'&format='.$format.
'&datatoimport='.urlencode($datatoimport).
'&filetoimport='.urlencode($filetoimport).
'&nboflines='.urlencode($nboflines);
2047 if ($excludefirstline) {
2048 $param .=
'&excludefirstline='.urlencode($excludefirstline);
2051 $param .=
'&endatlinenb='.urlencode($endatlinenb);
2054 $param .=
'&separator='.urlencode($separator);
2057 $param .=
'&enclosure='.urlencode($enclosure);
2060 llxHeader(
'', $langs->trans(
"NewImport"),
'EN:Module_Imports_En|FR:Module_Imports|ES:Módulo_Importaciones');
2066 print
'<div class="underbanner clearboth"></div>';
2067 print
'<div class="fichecenter">';
2069 print
'<table width="100%" class="border">';
2072 print
'<tr><td class="titlefieldcreate">'.$langs->trans(
"Module").
'</td>';
2074 $titleofmodule = $objimport->array_import_module[0][
'module']->getName();
2076 if (in_array($objimport->array_import_code[0], array(
'produit_supplierprices',
'produit_multiprice',
'produit_languages'))) {
2077 $titleofmodule = $langs->trans(
"ProductOrService");
2079 print $titleofmodule;
2083 print
'<tr><td>'.$langs->trans(
"DatasetToImport").
'</td>';
2085 $entity = preg_replace(
'/:.*$/',
'', $objimport->array_import_icon[0]);
2086 $entityicon = strtolower(!empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity);
2087 print
img_object($objimport->array_import_module[0][
'module']->getName(), $entityicon).
' ';
2088 print $objimport->array_import_label[0];
2094 print
load_fiche_titre($langs->trans(
"InformationOnSourceFile"),
'',
'file-export');
2096 print
'<div class="underbanner clearboth"></div>';
2097 print
'<div class="fichecenter">';
2098 print
'<table width="100%" class="border">';
2101 print
'<tr><td class="titlefieldcreate">'.$langs->trans(
"SourceFileFormat").
'</td>';
2103 $text = $objmodelimport->getDriverDescForKey($format);
2104 print
$form->textwithpicto($objmodelimport->getDriverLabelForKey($format), $text);
2108 if ($model ==
'csv') {
2109 print
'<tr><td>'.$langs->trans(
"CsvOptions").
'</td>';
2111 print $langs->trans(
"Separator").
' : ';
2112 print htmlentities($separator);
2113 print
' '.$langs->trans(
"Enclosure").
' : ';
2114 print htmlentities($enclosure);
2119 print
'<tr><td>'.$langs->trans(
"FileToImport").
'</td>';
2121 $modulepart =
'import';
2122 $relativepath =
GETPOST(
'filetoimport');
2123 print
'<a data-ajax="false" href="'.DOL_URL_ROOT.
'/document.php?modulepart='.$modulepart.
'&file='.urlencode($relativepath).
'&step=4'.$param.
'" target="_blank" rel="noopener noreferrer">';
2124 print
img_mime($file,
'',
'pictofixedwidth');
2125 print $filetoimport;
2131 print $langs->trans(
"NbOfSourceLines");
2138 print $langs->trans(
"ImportFromLine");
2140 print
'<input type="text" size="4" name="excludefirstline" disabled="disabled" value="'.$excludefirstline.
'">';
2145 print $langs->trans(
"EndAtLineNb");
2147 print
'<input type="text" size="4" name="endatlinenb" disabled="disabled" value="'.$endatlinenb.
'">';
2155 print
'<b>'.$langs->trans(
"InformationOnTargetTables").
'</b>';
2156 print
'<div class="underbanner clearboth"></div>';
2157 print
'<div class="fichecenter">';
2158 print
'<table class="border centpercent">';
2161 print
'<tr><td width="25%">';
2162 print $langs->trans(
"TablesTarget");
2164 $listtables = array();
2165 foreach ($array_match_file_to_database as $code => $label) {
2167 if ($code > count($fieldssource)) {
2171 $alias = preg_replace(
'/(\..*)$/i',
'', $label);
2172 $listtables[$alias] = $objimport->array_import_tables[0][$alias];
2174 if (count($listtables)) {
2176 foreach ($listtables as $val) {
2195 print $langs->trans(
"Error");
2201 print $langs->trans(
"FieldsTarget").
'</td><td>';
2202 $listfields = array();
2204 $sort_array_match_file_to_database = $array_match_file_to_database;
2205 ksort($sort_array_match_file_to_database);
2207 foreach ($sort_array_match_file_to_database as $code => $label) {
2210 if ($code > count($fieldssource)) {
2214 $alias = preg_replace(
'/(\..*)$/i',
'', $label);
2215 $listfields[$i] = $langs->trans(
"Field").
' '.$code.
'->'.$label;
2217 print count($listfields) ? (join(
', ', $listfields)) : $langs->trans(
"Error");
2224 $arrayoferrors = array();
2225 $arrayofwarnings = array();
2226 $maxnboferrors = empty($conf->global->IMPORT_MAX_NB_OF_ERRORS) ? 50 : $conf->global->IMPORT_MAX_NB_OF_ERRORS;
2227 $maxnbofwarnings = empty($conf->global->IMPORT_MAX_NB_OF_WARNINGS) ? 50 : $conf->global->IMPORT_MAX_NB_OF_WARNINGS;
2239 $pathfile = $conf->import->dir_temp.
'/'.$filetoimport;
2240 $result = $obj->import_open_file($pathfile, $langs);
2242 global $tablewithentity_cache;
2243 $tablewithentity_cache = array();
2244 $sourcelinenb = 0; $endoffile = 0;
2246 while ($sourcelinenb < $nboflines && !$endoffile) {
2248 $arrayrecord = $obj->import_read_record();
2249 if ($arrayrecord ===
false) {
2250 $arrayofwarnings[$sourcelinenb][0] = array(
'lib'=>
'File has '.$nboflines.
' lines. However we reach end of file after record '.$sourcelinenb.
'. This may occurs when some records are split onto several lines.',
'type'=>
'EOF_RECORD_ON_SEVERAL_LINES');
2254 if ($excludefirstline && ($sourcelinenb < $excludefirstline)) {
2257 if ($endatlinenb && ($sourcelinenb > $endatlinenb)) {
2262 $result = $obj->import_insert($arrayrecord, $array_match_file_to_database, $objimport, count($fieldssource), $importid, $updatekeys);
2264 if (count($obj->errors)) {
2265 $arrayoferrors[$sourcelinenb] = $obj->errors;
2267 if (count($obj->warnings)) {
2268 $arrayofwarnings[$sourcelinenb] = $obj->warnings;
2270 if (!count($obj->errors) && !count($obj->warnings)) {
2275 $obj->import_close_file();
2277 print $langs->trans(
"ErrorFailedToOpenFile", $pathfile);
2280 if (count($arrayoferrors) > 0) {
2287 if (!empty($objimport->array_import_run_sql_after[0]) && is_array($objimport->array_import_run_sql_after[0])) {
2289 foreach ($objimport->array_import_run_sql_after[0] as $sqlafterimport) {
2291 $resqlafterimport = $db->query($sqlafterimport);
2292 if (!$resqlafterimport) {
2293 $arrayoferrors[
'none'][] = array(
'lib'=>$langs->trans(
"Error running final request: ".$sqlafterimport));
2311 print
'<div class="info">';
2312 print $langs->trans(
"NbOfLinesImported", $nbok).
'</b><br>';
2313 print $langs->trans(
"NbInsert", empty($obj->nbinsert) ? 0 : $obj->nbinsert).
'<br>';
2314 print $langs->trans(
"NbUpdate", empty($obj->nbupdate) ? 0 : $obj->nbupdate).
'<br>';
2316 print
'<div class="center">';
2317 print $langs->trans(
"FileWasImported", $importid).
'<br>';
2318 print
'<span class="opacitymedium">'.$langs->trans(
"YouCanUseImportIdToFindRecord", $importid).
'</span><br>';
2341 function show_elem($fieldssource, $pos, $key, $var, $nostyle =
'')
2347 if ($key ==
'none') {
2349 print
"\n\n<!-- Box_no-key start-->\n";
2350 print
'<div class="box boximport" style="padding:0;">'.
"\n";
2351 print
'<table summary="boxtable_no-key" class="centpercent nobordernopadding">'.
"\n";
2353 print
"\n\n<!-- Box ".$pos.
" start -->\n";
2354 print
'<div class="box boximport" style="padding: 0;" id="boxto_'.$pos.
'">'.
"\n";
2356 print
'<table summary="boxtable'.$pos.
'" class="nobordernopadding centpercent tableimport">'.
"\n";
2359 if (($pos && $pos > count($fieldssource)) && (!isset($fieldssource[$pos][
"imported"]))) {
2369 } elseif ($key ==
'none') {
2370 print
'<tr style="height:'.$height.
'" class="trimport oddevenimport">';
2371 print
'<td class="nocellnopadding" width="16" style="font-weight: normal">';
2374 print
'<td style="font-weight: normal">';
2380 print
'<tr style="height:'.$height.
'" class="trimport oddevenimport">';
2381 print
'<td class="nocellnopadding" width="16" style="font-weight: normal">';
2384 print
img_picto($langs->trans(
"Column").
' '.
num2Alpha($pos - 1),
'file',
'class="pictofixedwith"');
2386 if (isset($fieldssource[$pos][
'imported']) && $fieldssource[$pos][
'imported'] ==
false) {
2387 print
'<td class="nowraponall boxtdunused" style="font-weight: normal">';
2389 print
'<td class="nowraponall" style="font-weight: normal">';
2391 print $langs->trans(
"Column").
' '.
num2Alpha($pos - 1).
' (#'.$pos.
')';
2392 if (empty($fieldssource[$pos][
'example1'])) {
2393 $example = $fieldssource[$pos][
'label'];
2395 $example = $fieldssource[$pos][
'example1'];
2399 $example = utf8_encode($example);
2403 print
'<i class="opacitymedium">'.$example.
'</i>';
2412 print
"<!-- Box end -->\n\n";
2425 $i = count($fieldssource) + 1;
2428 foreach ($listofkey as $key => $val) {
2429 $maxkey = max($maxkey, $key);
2432 while ($i <= $maxkey) {
2433 if (empty($listofkey[$i])) {
2455 if ($position == count($array)) {
2456 $ret = $array + $insertArray;
2459 foreach ($array as $key => $value) {
2460 if ($position == $i++) {
2461 $ret += $insertArray;
2464 $ret[$key] = $value;