30require_once
'../main.inc.php';
38require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formfile.class.php';
39require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formother.class.php';
40require_once DOL_DOCUMENT_ROOT.
'/exports/class/export.class.php';
41require_once DOL_DOCUMENT_ROOT.
'/core/modules/export/modules_export.php';
42require_once DOL_DOCUMENT_ROOT.
'/core/lib/files.lib.php';
45$langs->loadlangs(array(
'admin',
'exports',
'other',
'users',
'companies',
'projects',
'suppliers',
'products',
'bank',
'bills'));
54 'invoice_line' =>
'bill',
56 'order_line' =>
'order',
58 'propal_line' =>
'propal',
59 'intervention' =>
'intervention',
60 'inter_line' =>
'intervention',
62 'member_type' =>
'group',
63 'subscription' =>
'payment',
64 'payment' =>
'payment',
66 'tax_type' =>
'generic',
68 'account' =>
'account',
69 'product' =>
'product',
70 'virtualproduct' =>
'product',
71 'subproduct' =>
'product',
72 'product_supplier_ref' =>
'product',
74 'warehouse' =>
'stock',
76 'stockbatch' =>
'stock',
77 'category' =>
'category',
78 'securityevent' =>
'generic',
79 'shipment' =>
'sending',
80 'shipment_line' =>
'sending',
81 'reception' =>
'sending',
82 'reception_line' =>
'sending',
83 'expensereport' =>
'trip',
84 'expensereport_line' =>
'trip',
85 'holiday' =>
'holiday',
86 'contract_line' =>
'contract',
87 'translation' =>
'generic',
90 'conferenceorboothattendee' =>
'contact',
91 'inventory_line' =>
'inventory',
93 'task_time' =>
'clock',
99 'company' =>
'Company',
100 'contact' =>
'Contact',
102 'invoice_line' =>
'InvoiceLine',
104 'order_line' =>
'OrderLine',
105 'propal' =>
'Proposal',
106 'propal_line' =>
'ProposalLine',
107 'intervention' =>
'Intervention',
108 'inter_line' =>
'InterLine',
109 'member' =>
'Member',
110 'member_type' =>
'MemberType',
111 'subscription' =>
'Subscription',
112 'tax' =>
'SocialContribution',
113 'tax_type' =>
'DictionarySocialContributions',
114 'account' =>
'BankTransactions',
115 'payment' =>
'Payment',
116 'product' =>
'Product',
117 'virtualproduct' =>
'AssociatedProducts',
118 'subproduct' =>
'SubProduct',
119 'product_supplier_ref' =>
'SupplierPrices',
120 'service' =>
'Service',
122 'movement' =>
'StockMovement',
124 'stockbatch' =>
'StockDetailPerBatch',
125 'warehouse' =>
'Warehouse',
126 'category' =>
'Category',
128 'trip' =>
'TripsAndExpenses',
129 'securityevent' =>
'SecurityEvent',
130 'shipment' =>
'Shipments',
131 'shipment_line' =>
'ShipmentLine',
132 'project' =>
'Projects',
133 'projecttask' =>
'Tasks',
134 'resource' =>
'Resource',
135 'task_time' =>
'TaskTimeSpent',
137 'expensereport' =>
'ExpenseReport',
138 'expensereport_line' =>
'ExpenseReportLine',
139 'holiday' =>
'TitreRequestCP',
140 'contract' =>
'Contract',
141 'contract_line' =>
'ContractLine',
142 'translation' =>
'Translation',
144 'bomline' =>
'BOMLine',
145 'mrp' =>
'ManufacturingOrder',
146 'mrp_line' =>
'ManufacturingOrderLine',
147 'conferenceorbooth' =>
'ConferenceOrBooth',
148 'conferenceorboothattendee' =>
'Attendee',
149 'inventory' =>
'Inventory',
150 'inventory_line' =>
'InventoryLine'
154$array_selected = isset($_SESSION[
"export_selected_fields"]) ? $_SESSION[
"export_selected_fields"] : array();
155$array_filtervalue = isset($_SESSION[
"export_filtered_fields"]) ? $_SESSION[
"export_filtered_fields"] : array();
156$datatoexport =
GETPOST(
"datatoexport",
"aZ09");
157$action =
GETPOST(
'action',
'aZ09');
158$confirm =
GETPOST(
'confirm',
'alpha');
160$export_name =
GETPOST(
"export_name",
"alphanohtml");
161$hexa =
GETPOST(
"hexa",
"alpha");
166$objexport->load_arrays($user, $datatoexport);
173$sqlusedforexport =
'';
176$upload_dir =
$conf->export->dir_temp.
'/'.$user->id;
188if ($action ==
'selectfield' && $user->hasRight(
'export',
'creer')) {
189 $fieldsarray = $objexport->array_export_fields[0];
190 $fieldsentitiesarray = $objexport->array_export_entities[0];
191 $fieldsdependenciesarray = $objexport->array_export_dependencies[0];
193 if ($field ==
'all') {
194 foreach ($fieldsarray as $key => $val) {
195 if (!empty($array_selected[$key])) {
198 $array_selected[$key] = count($array_selected) + 1;
200 $_SESSION[
"export_selected_fields"] = $array_selected;
205 $array_selected[$field] = count($array_selected) + 1;
210 $listofdependencies = array();
211 if (!empty($fieldsentitiesarray[$field]) && !empty($fieldsdependenciesarray[$fieldsentitiesarray[$field]])) {
213 $tmp = $fieldsdependenciesarray[$fieldsentitiesarray[$field]];
214 if (is_array($tmp)) {
215 $listofdependencies = $tmp;
217 $listofdependencies = array($tmp);
219 } elseif (!empty($field) && !empty($fieldsdependenciesarray[$field])) {
221 $tmp = $fieldsdependenciesarray[$field];
222 if (is_array($tmp)) {
223 $listofdependencies = $tmp;
225 $listofdependencies = array($tmp);
229 if (count($listofdependencies)) {
230 foreach ($listofdependencies as $fieldid) {
231 if (empty($array_selected[$fieldid])) {
232 $array_selected[$fieldid] = count($array_selected) + 1;
233 $warnings[] = $langs->trans(
"ExportFieldAutomaticallyAdded", $langs->transnoentitiesnoconv($fieldsarray[$fieldid]));
238 $_SESSION[
"export_selected_fields"] = $array_selected;
243if ($action ==
'unselectfield' && $user->hasRight(
'export',
'creer')) {
244 if (
GETPOST(
"field") ==
'all') {
245 $array_selected = array();
246 $_SESSION[
"export_selected_fields"] = $array_selected;
248 unset($array_selected[
GETPOST(
"field")]);
250 asort($array_selected);
252 $array_selected_save = $array_selected;
253 foreach ($array_selected as $code => $value) {
255 $array_selected[$code] = $i;
258 $_SESSION[
"export_selected_fields"] = $array_selected;
263if (($action ==
'downfield' || $action ==
'upfield') && $user->hasRight(
'export',
'creer')) {
264 $pos = $array_selected[
GETPOST(
"field")];
265 if ($action ==
'downfield') {
268 if ($action ==
'upfield') {
273 foreach ($array_selected as $code => $value) {
274 if ($value == $newpos) {
281 $array_selected[
GETPOST(
"field")] = $newpos;
282 $array_selected[$newcode] = $pos;
283 $_SESSION[
"export_selected_fields"] = $array_selected;
287if ($step == 1 || $action ==
'cleanselect') {
288 $_SESSION[
"export_selected_fields"] = array();
289 $_SESSION[
"export_filtered_fields"] = array();
290 $array_selected = array();
291 $array_filtervalue = array();
294if ($action ==
'builddoc' && $user->hasRight(
'export',
'lire')) {
296 if (empty($objexport->array_export_perms[0])) {
300 $separator =
GETPOST(
'delimiter',
'alpha');
301 $max_execution_time_for_importexport =
getDolGlobalInt(
'EXPORT_MAX_EXECUTION_TIME', 300);
302 $max_time = @ini_get(
"max_execution_time");
303 if ($max_time && $max_time < $max_execution_time_for_importexport) {
304 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.");
305 @ini_set(
"max_execution_time", $max_execution_time_for_importexport);
309 $result = $objexport->build_file($user,
GETPOST(
'model',
'alpha'), $datatoexport, $array_selected, $array_filtervalue,
'', $separator);
312 $sqlusedforexport = $objexport->sqlusedforexport;
315 $sqlusedforexport = $objexport->sqlusedforexport;
320if ($step == 5 && $action ==
'confirm_deletefile' && $confirm ==
'yes' && $user->hasRight(
'export',
'lire')) {
322 if (empty($objexport->array_export_perms[0])) {
326 $file = $upload_dir.
"/".
GETPOST(
'file');
334 header(
'Location: '.$_SERVER[
"PHP_SELF"].
'?step='.$step.
'&datatoexport='.$datatoexport);
338if ($action ==
'deleteprof' && $user->hasRight(
'export',
'lire')) {
340 if (empty($objexport->array_export_perms[0])) {
346 $result = $objexport->delete($user);
351if ($action ==
'add_export_model' && $user->hasRight(
'export',
'lire')) {
353 if (empty($objexport->array_export_perms[0])) {
358 asort($array_selected);
362 foreach ($array_selected as $key => $val) {
369 $hexafiltervalue =
'';
370 if (!empty($array_filtervalue) && is_array($array_filtervalue)) {
371 foreach ($array_filtervalue as $key => $val) {
372 if ($hexafiltervalue) {
373 $hexafiltervalue .=
',';
375 $hexafiltervalue .= $key.
'='.$val;
379 $objexport->model_name = $export_name;
380 $objexport->datatoexport = $datatoexport;
381 $objexport->hexa = $hexa;
382 $objexport->hexafiltervalue = $hexafiltervalue;
383 $objexport->fk_user = (
GETPOST(
'visibility',
'aZ09') ==
'all' ? 0 : $user->id);
385 $result = $objexport->create($user);
387 setEventMessages($langs->trans(
"ExportModelSaved", $objexport->model_name),
null,
'mesgs');
389 $langs->load(
"errors");
390 if ($objexport->errno ==
'DB_ERROR_RECORD_ALREADY_EXISTS') {
391 setEventMessages($langs->trans(
"ErrorExportDuplicateProfil"),
null,
'errors');
397 setEventMessages($langs->trans(
"ErrorFieldRequired", $langs->transnoentities(
"ExportModelName")),
null,
'errors');
402if ($step == 2 && $action ==
'select_model' && $user->hasRight(
'export',
'lire')) {
403 $_SESSION[
"export_selected_fields"] = array();
404 $_SESSION[
"export_filtered_fields"] = array();
406 $array_selected = array();
407 $array_filtervalue = array();
409 $result = $objexport->fetch($exportmodelid);
411 $fieldsarray = preg_split(
"/,(?! [^(]*\))/", $objexport->hexa);
413 foreach ($fieldsarray as $val) {
414 $array_selected[$val] = $i;
417 $_SESSION[
"export_selected_fields"] = $array_selected;
419 $fieldsarrayvalue = explode(
',', $objexport->hexafiltervalue);
421 foreach ($fieldsarrayvalue as $val) {
422 $tmp = explode(
'=', $val);
423 $array_filtervalue[$tmp[0]] = $tmp[1];
426 $_SESSION[
"export_filtered_fields"] = $array_filtervalue;
431if ($step == 4 && $action ==
'submitFormField' && $user->hasRight(
'export',
'lire')) {
433 if (empty($objexport->array_export_perms[0])) {
438 if (is_array($objexport->array_export_TypeFields[0])) {
439 $_SESSION[
"export_filtered_fields"] = array();
440 foreach ($objexport->array_export_TypeFields[0] as $code => $type) {
441 $newcode = (
string) preg_replace(
'/\./',
'_', $code);
443 $check =
'alphanohtml';
444 $filterqualified = 1;
445 if (!GETPOSTISSET($newcode) ||
GETPOST($newcode, $check) ==
'') {
446 $filterqualified = 0;
447 } elseif (preg_match(
'/^List/', $type) && (is_numeric(
GETPOST($newcode, $check)) &&
GETPOST($newcode, $check) <= 0)) {
448 $filterqualified = 0;
450 if ($filterqualified) {
451 $objexport->array_export_FilterValue[0][$code] =
GETPOST($newcode, $check);
454 $array_filtervalue = (!empty($objexport->array_export_FilterValue[0]) ? $objexport->array_export_FilterValue[0] :
'');
455 $_SESSION[
"export_filtered_fields"] = $array_filtervalue;
464if ($step == 1 || !$datatoexport) {
465 llxHeader(
'', $langs->trans(
"NewExport"),
'EN:Module_Exports_En|FR:Module_Exports|ES:Módulo_Exportaciones',
'', 0, 0,
'',
'',
'',
'mod-exports page-export action-step1');
469 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=1';
470 $head[$h][1] = $langs->trans(
"Step").
" 1";
476 print
'<div class="opacitymedium">'.$langs->trans(
"SelectExportDataSet").
'</div>';
480 $nbmodulesnotautoenabled = count(
$conf->modules);
481 $listofmodulesautoenabled = array(
'user',
'agenda',
'fckeditor',
'export',
'import');
482 foreach ($listofmodulesautoenabled as $moduleautoenable) {
483 if (in_array($moduleautoenable,
$conf->modules)) {
484 $nbmodulesnotautoenabled--;
488 if ($user->admin && $nbmodulesnotautoenabled <
getDolGlobalInt(
'MAIN_MIN_NB_ENABLED_MODULE_FOR_WARNING', 1)) {
489 print
info_admin($langs->trans(
"WarningOnlyProfilesOfActivatedModules").
' '.$langs->trans(
"YouCanEnableModulesFrom"));
495 print
'<div class="div-table-responsive-no-min">';
496 print
'<table class="noborder centpercent nomarginbottom">';
497 print
'<tr class="liste_titre">';
498 print
'<td>'.$langs->trans(
"Module").
'</td>';
499 print
'<td>'.$langs->trans(
"ExportableDatas").
'</td>';
500 print
'<td> </td>';
503 if (count($objexport->array_export_module)) {
504 asort($objexport->array_export_code_for_sort);
507 foreach ($objexport->array_export_code_for_sort as $key => $value) {
508 $titleofmodule = $objexport->array_export_module[$key]->getName();
509 print
'<tr class="oddeven"><td class="tdoverflowmax200" title="'.dolPrintHTML($titleofmodule).
'">';
512 $entity = preg_replace(
'/:.*$/',
'', $objexport->array_export_icon[$key]);
513 $entityicon = strtolower(!empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity);
514 $label = $objexport->array_export_label[$key];
515 print
'<div class="twolinesmax-normallineheight minwidth200onall">';
516 print
img_object($objexport->array_export_module[$key]->getName(), $entityicon,
'class="pictofixedwidth"');
519 print
'</td><td class="right">';
520 if ($objexport->array_export_perms[$key]) {
521 print
'<a href="'.DOL_URL_ROOT.
'/exports/export.php?step=2&module_position='.$objexport->array_export_module[$key]->module_position.
'&datatoexport='.$objexport->array_export_code[$key].
'">'.
img_picto($langs->trans(
"NewExport"),
'next',
'class="fa-15"').
'</a>';
523 print
'<span class="opacitymedium">'.$langs->trans(
"NotEnoughPermissions").
'</span>';
528 print
'<tr><td class="oddeven" colspan="3">'.$langs->trans(
"NoExportableData").
'</td></tr>';
536if ($step == 2 && $datatoexport) {
538 if (empty($objexport->array_export_perms[0])) {
542 llxHeader(
'', $langs->trans(
"NewExport"),
'EN:Module_Exports_En|FR:Module_Exports|ES:Módulo_Exportaciones',
'', 0, 0,
'',
'',
'',
'mod-exports page-export action-step2');
546 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=1';
547 $head[$h][1] = $langs->trans(
"Step").
" 1";
550 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=2&datatoexport='.$datatoexport;
551 $head[$h][1] = $langs->trans(
"Step").
" 2";
558 print
'<div class="fichecenter">';
559 print
'<div class="underbanner clearboth"></div>';
561 print
'<table class="border tableforfield centpercent">';
564 print
'<tr><td class="titlefield">'.$langs->trans(
"Module").
'</td>';
566 print $objexport->array_export_module[0]->getName();
570 print
'<tr><td>'.$langs->trans(
"DatasetToExport").
'</td>';
572 $entity = preg_replace(
'/:.*$/',
'', $objexport->array_export_icon[0]);
573 $entityicon = strtolower(!empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity);
574 print
img_object($objexport->array_export_module[0]->getName(), $entityicon).
' ';
575 print $objexport->array_export_label[0];
586 print
'<form action="'.$_SERVER[
"PHP_SELF"].
'" method="post">';
587 print
'<input type="hidden" name="token" value="'.newToken().
'">';
588 print
'<input type="hidden" name="action" value="select_model">';
589 print
'<input type="hidden" name="step" value="2">';
590 print
'<input type="hidden" name="datatoexport" value="'.$datatoexport.
'">';
591 print
'<div class="valignmiddle marginbottomonly">';
592 print
'<span class="opacitymedium">'.$langs->trans(
"SelectExportFields").
'</span> ';
593 $htmlother->select_export_model((
string) $exportmodelid,
'exportmodelid', $datatoexport, 1, $user->id);
595 print
'<input type="submit" name="applyprofile" id="applyprofile" class="button smallpaddingimp hidden" value="'.$langs->trans(
"Apply").
'">';
597 if (!empty(
$conf->use_javascript_ajax)) {
599 $(document).ready(function() {
601 $("#applyprofile").hide();
603 // follow change on list
604 $("#exportmodelid").change(function() {
605 console.log("We select a new profile");
606 if ($(this).val() && $(this).val() != "-1") {
607 $("#applyprofile").show();
609 $("#applyprofile").hide();
622 print
'<div class="div-table-responsive-no-min">';
623 print
'<table class="noborder centpercent">';
624 print
'<tr class="liste_titre">';
625 print
'<td>'.$langs->trans(
"Object").
'</td>';
626 print
'<td>'.$langs->trans(
"ExportableFields").
'</td>';
627 print
'<td width="100" class="center">';
630 if (!$user->hasRight(
'export',
'creer')) {
631 $morecss =
' disabled';
632 $moretitle = $langs->trans(
"NotAllowed");
634 print
'<a class="liste_titre button small nopaddingimp '.$morecss;
635 print
'" title="'.$langs->trans(
"All").($moretitle ?
' - '.$moretitle :
'').
'" href="'.$_SERVER[
"PHP_SELF"].
'?step=2&datatoexport='.urlencode($datatoexport).
'&action=selectfield&field=all&token='.newToken().
'">'.$langs->trans(
"All");
636 print
' '.img_right($moretitle, 0,
'style="max-width: 20px"');
639 print
'<a class="liste_titre button small nopaddingimp'.$morecss;
640 print
'" title="'.$langs->trans(
"None").($moretitle ?
' - '.$moretitle :
'').
'" href="'.$_SERVER[
"PHP_SELF"].
'?step=2&datatoexport='.urlencode($datatoexport).
'&action=unselectfield&field=all&token='.newToken().
'">';
641 print
img_left($moretitle, 0,
'style="max-width: 20px"').
' ';
642 print $langs->trans(
"None").
"</a>";
644 print
'<td width="44%">'.$langs->trans(
"ExportedFields").
'</td>';
648 $fieldsarray = $objexport->array_export_fields[0];
650 $sqlmaxforexport = $objexport->build_sql(0, array(), array());
662 foreach ($fieldsarray as $code => $label) {
663 print
'<tr class="oddeven">';
667 $entity = (!empty($objexport->array_export_entities[0][$code]) ? $objexport->array_export_entities[0][$code] : $objexport->array_export_icon[0]);
668 $entityicon = strtolower(!empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity);
669 $entitylang = (!empty($entitytolang[$entity]) ? $entitytolang[$entity] : $entity);
671 print
'<td class="nowraponall">';
675 $tmparray = explode(
':', $entityicon);
676 if (count($tmparray) >= 2) {
677 $entityicon = $tmparray[0];
678 $entitylang = $tmparray[1];
680 print
img_object(
'', $entityicon).
' '.$langs->trans((
string) $entitylang);
683 $text = (empty($objexport->array_export_special[0][$code]) ?
'' :
'<i>');
684 $tmplabelarray = explode(
':', $label);
685 if (!empty($tmplabelarray[1])) {
686 $text .= $langs->trans($tmplabelarray[0]).
' - '.$langs->trans($tmplabelarray[1]);
688 $text .= $langs->trans($label);
690 $text .= (empty($objexport->array_export_special[0][$code]) ?
'' :
'</i>');
693 $htmltext =
'<b>'.$langs->trans(
"Name").
":</b> ".$text.
'<br>';
694 if (!empty($objexport->array_export_special[0][$code])) {
695 $htmltext .=
'<b>'.$langs->trans(
"ComputedField").
" -> ".$langs->trans(
"Method").
" :</b> ".$objexport->array_export_special[0][$code].
"<br>";
697 $htmltext .=
'<b>'.$langs->trans(
"Table").
" -> ".$langs->trans(
"Field").
":</b> ".$tablename.
" -> ".preg_replace(
'/^.*\./',
'', $code).
"<br>";
699 if (!empty($objexport->array_export_examplevalues[0][$code])) {
700 $htmltext .=
'<b>'.$langs->trans(
"SourceExample").
':</b> '.$objexport->array_export_examplevalues[0][$code].
'<br>';
702 if (!empty($objexport->array_export_TypeFields[0][$code])) {
703 $htmltext .=
'<b>'.$langs->trans(
"Type").
':</b> '.$objexport->array_export_TypeFields[0][$code].
'<br>';
705 if (!empty($objexport->array_export_help[0][$code])) {
706 $htmltext .=
'<b>'.$langs->trans(
"Help").
':</b> '.$langs->trans($objexport->array_export_help[0][$code]).
'<br>';
709 if (isset($array_selected[$code]) && $array_selected[$code]) {
711 print
'<td> </td>';
712 print
'<td class="center"><a class="reposition'.$morecss.
'" href="'.$_SERVER[
"PHP_SELF"].
'?step=2&datatoexport='.urlencode($datatoexport).
'&action=unselectfield&token='.newToken().
'&field='.urlencode($code).
'">'.
img_left($moretitle, 0,
'style="max-width: 20px"').
'</a></td>';
715 print $form->textwithpicto($text, $htmltext);
722 print $form->textwithpicto($text, $htmltext);
725 print
'<td class="center"><a class="reposition'.$morecss.
'" href="'.$_SERVER[
"PHP_SELF"].
'?step=2&datatoexport='.urlencode($datatoexport).
'&action=selectfield&token='.newToken().
'&field='.urlencode($code).
'">'.
img_right($moretitle, 0,
'style="max-width: 20px"').
'</a></td>';
726 print
'<td> </td>';
738 print
'<div class="tabsAction tabsActionNoBottom">';
740 if (count($array_selected)) {
742 if ($usefilters && isset($objexport->array_export_TypeFields[0]) && is_array($objexport->array_export_TypeFields[0])) {
743 print
'<a class="butAction" href="export.php?step=3&datatoexport='.$datatoexport.
'">'.$langs->trans(
"NextStep").
'</a>';
745 print
'<a class="butAction" href="export.php?step=4&datatoexport='.$datatoexport.
'">'.$langs->trans(
"NextStep").
'</a>';
748 print
'<a class="butActionRefused classfortooltip" href="#" title="'.dol_escape_htmltag($langs->trans(
"SelectAtLeastOneField")).
'">'.$langs->trans(
"NextStep").
'</a>';
754if ($step == 3 && $datatoexport) {
755 if (count($array_selected) < 1) {
757 header(
"Location: ".DOL_URL_ROOT.
'/exports/export.php?step=2&datatoexport='.$datatoexport);
762 if (empty($objexport->array_export_perms[0])) {
766 llxHeader(
'', $langs->trans(
"NewExport"),
'EN:Module_Exports_En|FR:Module_Exports|ES:Módulo_Exportaciones',
'', 0, 0,
'',
'',
'',
'mod-exports page-export action-step3');
770 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=1';
771 $head[$h][1] = $langs->trans(
"Step").
" 1";
774 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=2&datatoexport='.$datatoexport;
775 $head[$h][1] = $langs->trans(
"Step").
" 2";
778 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=3&datatoexport='.$datatoexport;
779 $head[$h][1] = $langs->trans(
"Step").
" 3";
785 print
'<div class="fichecenter">';
786 print
'<div class="underbanner clearboth"></div>';
787 print
'<table class="border tableforfield centpercent">';
790 print
'<tr><td class="titlefield">'.$langs->trans(
"Module").
'</td>';
793 print $objexport->array_export_module[0]->getName();
797 print
'<tr><td>'.$langs->trans(
"DatasetToExport").
'</td>';
799 $entity = preg_replace(
'/:.*$/',
'', $objexport->array_export_icon[0]);
800 $entityicon = strtolower(!empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity);
801 print
img_object($objexport->array_export_module[0]->getName(), $entityicon).
' ';
802 print $objexport->array_export_label[0];
806 print
'<tr><td>'.$langs->trans(
"ExportedFields").
'</td>';
808 foreach ($array_selected as $code => $value) {
809 if (isset($objexport->array_export_fields[0][$code])) {
810 $list .= (!empty($list) ?
', ' :
'');
812 $tmplabelarray = explode(
':', $objexport->array_export_fields[0][$code]);
813 if (!empty($tmplabelarray[1])) {
814 $list .= $langs->trans($tmplabelarray[0]).
' - '.$langs->trans($tmplabelarray[1]);
816 $list .= $langs->trans($objexport->array_export_fields[0][$code]);
820 print
'<td><span class="small">'.$list.
'</span></td>';
829 print
'<span class="opacitymedium">'.$langs->trans(
"SelectFilterFields").
'...</span><br><br>';
833 print
'<form action="'.$_SERVER[
"PHP_SELF"].
'?step=4&action=submitFormField&datatoexport='.$datatoexport.
'" name="FilterField" method="post">';
834 print
'<input type="hidden" name="token" value="'.newToken().
'">';
836 print
'<div class="div-table-responsive-no-min">';
838 print
'<table class="noborder centpercent">';
839 print
'<tr class="liste_titre">';
840 print
'<td>'.$langs->trans(
"Entities").
'</td>';
841 print
'<td>'.$langs->trans(
"ExportableFields").
'</td>';
842 print
'<td width="25%">'.$langs->trans(
"FilteredFieldsValues").
'</td>';
846 $fieldsarray = $objexport->array_export_fields[0];
848 $Typefieldsarray = $objexport->array_export_TypeFields[0];
850 $ValueFiltersarray = (!empty($objexport->array_export_FilterValue[0]) ? $objexport->array_export_FilterValue[0] :
'');
852 $sqlmaxforexport = $objexport->build_sql(0, array(), array());
856 foreach ($fieldsarray as $code => $label) {
857 print
'<tr class="oddeven">';
860 $entity = (!empty($objexport->array_export_entities[0][$code]) ? $objexport->array_export_entities[0][$code] : $objexport->array_export_icon[0]);
861 $entityicon = strtolower(!empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity);
862 $entitylang = (!empty($entitytolang[$entity]) ? $entitytolang[$entity] : $entity);
864 print
'<td class="nowrap">';
866 $tmparray = explode(
':', $entityicon);
867 if (count($tmparray) >= 2) {
868 $entityicon = $tmparray[0];
869 $entitylang = $tmparray[1];
871 print
img_object(
'', $entityicon).
' '.$langs->trans((
string) $entitylang);
875 $labelName = (!empty($fieldsarray[$code]) ? $fieldsarray[$code] :
'');
876 $ValueFilter = (!empty($array_filtervalue[$code]) ? $array_filtervalue[$code] :
'');
878 $text = (empty($objexport->array_export_special[0][$code]) ?
'' :
'<i>');
879 $tmplabelarray = explode(
':', $label);
880 if (!empty($tmplabelarray[1])) {
881 $text .= $langs->trans($tmplabelarray[0]).
' - '.$langs->trans($tmplabelarray[1]);
883 $text .= $langs->trans($label);
885 $text .= (empty($objexport->array_export_special[0][$code]) ?
'' :
'</i>');
888 $htmltext =
'<b>'.$langs->trans(
"Name").
':</b> '.$text.
'<br>';
889 if (!empty($objexport->array_export_special[0][$code])) {
890 $htmltext .=
'<b>'.$langs->trans(
"ComputedField").
" -> ".$langs->trans(
"Method").
" :</b> ".$objexport->array_export_special[0][$code].
"<br>";
892 $htmltext .=
'<b>'.$langs->trans(
"Table").
" -> ".$langs->trans(
"Field").
":</b> ".$tablename.
" -> ".preg_replace(
'/^.*\./',
'', $code).
"<br>";
894 if (!empty($objexport->array_export_examplevalues[0][$code])) {
895 $htmltext .=
'<b>'.$langs->trans(
"SourceExample").
':</b> '.$objexport->array_export_examplevalues[0][$code].
'<br>';
897 if (!empty($objexport->array_export_TypeFields[0][$code])) {
898 $htmltext .=
'<b>'.$langs->trans(
"Type").
':</b> '.$objexport->array_export_TypeFields[0][$code].
'<br>';
900 if (!empty($objexport->array_export_help[0][$code])) {
901 $htmltext .=
'<b>'.$langs->trans(
"Help").
':</b> '.$langs->trans($objexport->array_export_help[0][$code]).
'<br>';
905 print $form->textwithpicto($text, $htmltext);
910 if (!empty($Typefieldsarray[$code])) {
911 $szInfoFiltre = $objexport->genDocFilter($Typefieldsarray[$code]);
913 $tmp = $objexport->build_filterField($Typefieldsarray[$code], $code, $ValueFilter);
914 print $form->textwithpicto($tmp, $szInfoFiltre);
916 print $objexport->build_filterField($Typefieldsarray[$code], $code, $ValueFilter);
932 print
'<div class="tabsAction tabsActionNoBottom">';
934 print
'<a class="butAction" href="javascript:FilterField.submit();">'.$langs->trans(
"NextStep").
'</a>';
938if ($step == 4 && $datatoexport) {
939 if (count($array_selected) < 1) {
941 header(
"Location: ".DOL_URL_ROOT.
'/exports/export.php?step=2&datatoexport='.$datatoexport);
946 if (empty($objexport->array_export_perms[0])) {
950 asort($array_selected);
952 llxHeader(
'', $langs->trans(
"NewExport"),
'EN:Module_Exports_En|FR:Module_Exports|ES:Módulo_Exportaciones',
'', 0, 0,
'',
'',
'',
'mod-exports page-export action-step4');
957 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=1';
958 $head[$h][1] = $langs->trans(
"Step").
" 1";
961 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=2&datatoexport='.$datatoexport;
962 $head[$h][1] = $langs->trans(
"Step").
" 2";
966 if ($usefilters && isset($objexport->array_export_TypeFields[0]) && is_array($objexport->array_export_TypeFields[0])) {
967 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=3&datatoexport='.$datatoexport;
968 $head[$h][1] = $langs->trans(
"Step").
" 3";
973 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=4&datatoexport='.$datatoexport;
974 $head[$h][1] = $langs->trans(
"Step").
" ".(3 + $stepoffset);
978 $titleofmodule = $objexport->array_export_module[0]->getName();
982 print
'<div class="fichecenter">';
983 print
'<div class="underbanner clearboth"></div>';
984 print
'<table width="100%" class="border tableforfield">';
987 print
'<tr><td class="titlefield tableforfield">'.$langs->trans(
"Module").
'</td>';
993 print
'<tr><td>'.$langs->trans(
"DatasetToExport").
'</td>';
995 $entity = preg_replace(
'/:.*$/',
'', $objexport->array_export_icon[0]);
996 $entityicon = strtolower(!empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity);
997 print
img_object($objexport->array_export_module[0]->getName(), $entityicon).
' ';
998 print $objexport->array_export_label[0];
1002 print
'<tr><td>'.$langs->trans(
"ExportedFields").
'</td>';
1004 foreach ($array_selected as $code => $value) {
1005 if (isset($objexport->array_export_fields[0][$code])) {
1006 $list .= (!empty($list) ?
', ' :
'');
1008 $tmplabelarray = explode(
':', $objexport->array_export_fields[0][$code]);
1009 if (!empty($tmplabelarray[1])) {
1010 $list .= $langs->trans($tmplabelarray[0]).
' - '.$langs->trans($tmplabelarray[1]);
1012 $list .= $langs->trans($objexport->array_export_fields[0][$code]);
1016 print
'<td><span class="small">'.$list.
'</span></td>';
1020 if (isset($objexport->array_export_TypeFields[0]) && is_array($objexport->array_export_TypeFields[0])) {
1021 print
'<tr><td>'.$langs->trans(
"FilteredFields").
'</td>';
1023 if (!empty($array_filtervalue)) {
1024 foreach ($array_filtervalue as $code => $value) {
1025 if (preg_match(
'/^FormSelect:/', $objexport->array_export_TypeFields[0][$code])) {
1031 if (isset($objexport->array_export_fields[0][$code])) {
1032 $list .= ($list ?
', ' :
'');
1033 if (isset($array_filtervalue[$code]) && preg_match(
'/^\s*[<>]/', $array_filtervalue[$code])) {
1034 $list .=
'<span class="opacitymedium">'.$langs->trans($objexport->array_export_fields[0][$code]).
'</span>'.(isset($array_filtervalue[$code]) ? $array_filtervalue[$code] :
'');
1036 $list .=
'<span class="opacitymedium">'.$langs->trans($objexport->array_export_fields[0][$code]).
"</span>='".(isset($array_filtervalue[$code]) ? $array_filtervalue[$code] :
'').
"'";
1041 print
'<td>'.(!empty($list) ? $list :
'<span class="opacitymedium">'.$langs->trans(
"None").
'</span>').
'</td>';
1051 $sqlmaxforexport = $objexport->build_sql(0, array(), array());
1054 print
'<div class="marginbottomonly"><span class="opacitymedium">'.$langs->trans(
"ChooseFieldsOrdersAndTitle").
'</span></div>';
1056 print
'<div class="div-table-responsive-no-min">';
1057 print
'<table class="noborder centpercent">';
1058 print
'<tr class="liste_titre">';
1059 print
'<td>'.$langs->trans(
"Entities").
'</td>';
1060 print
'<td>'.$langs->trans(
"ExportedFields").
'</td>';
1061 print
'<td class="right" colspan="2">'.$langs->trans(
"Position").
'</td>';
1066 foreach ($array_selected as $code => $value) {
1067 if (!isset($objexport->array_export_fields[0][$code])) {
1071 print
'<tr class="oddeven">';
1073 $entity = (!empty($objexport->array_export_entities[0][$code]) ? $objexport->array_export_entities[0][$code] : $objexport->array_export_icon[0]);
1074 $entityicon = strtolower(!empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity);
1075 $entitylang = (!empty($entitytolang[$entity]) ? $entitytolang[$entity] : $entity);
1077 print
'<td class="nowrap">';
1079 $tmparray = explode(
':', $entityicon);
1080 if (count($tmparray) >= 2) {
1081 $entityicon = $tmparray[0];
1082 $entitylang = $tmparray[1];
1084 print
img_object(
'', $entityicon).
' '.$langs->trans((
string) $entitylang);
1087 $labelName = $objexport->array_export_fields[0][$code];
1089 $text = (empty($objexport->array_export_special[0][$code]) ?
'' :
'<i>');
1090 $tmplabelarray = explode(
':', $labelName);
1091 if (!empty($tmplabelarray[1])) {
1092 $text .= $langs->trans($tmplabelarray[0]).
' - '.$langs->trans($tmplabelarray[1]);
1094 $text .= $langs->trans($labelName);
1096 $text .= (empty($objexport->array_export_special[0][$code]) ?
'' :
'</i>');
1099 $htmltext =
'<b>'.$langs->trans(
"Name").
':</b> '.$text.
'<br>';
1100 if (!empty($objexport->array_export_special[0][$code])) {
1101 $htmltext .=
'<b>'.$langs->trans(
"ComputedField").
" -> ".$langs->trans(
"Method").
" :</b> ".$objexport->array_export_special[0][$code].
"<br>";
1103 $htmltext .=
'<b>'.$langs->trans(
"Table").
" -> ".$langs->trans(
"Field").
":</b> ".$tablename.
" -> ".preg_replace(
'/^.*\./',
'', $code).
"<br>";
1105 if (!empty($objexport->array_export_examplevalues[0][$code])) {
1106 $htmltext .=
'<b>'.$langs->trans(
"SourceExample").
':</b> '.$objexport->array_export_examplevalues[0][$code].
'<br>';
1108 if (!empty($objexport->array_export_TypeFields[0][$code])) {
1109 $htmltext .=
'<b>'.$langs->trans(
"Type").
':</b> '.$objexport->array_export_TypeFields[0][$code].
'<br>';
1111 if (!empty($objexport->array_export_help[0][$code])) {
1112 $htmltext .=
'<b>'.$langs->trans(
"Help").
':</b> '.$langs->trans($objexport->array_export_help[0][$code]).
'<br>';
1116 print $form->textwithpicto($text, $htmltext);
1120 print
'<td class="right" width="100">';
1122 print
'</td><td class="center nowraponall" width="40">';
1123 if ($value < count($array_selected)) {
1124 print
'<a href="'.$_SERVER[
"PHP_SELF"].
'?step='.$step.
'&datatoexport='.$datatoexport.
'&action=downfield&field='.$code.
'" class="paddingleft paddingright">'.
img_down().
'</a>';
1127 print
'<a href="'.$_SERVER[
"PHP_SELF"].
'?step='.$step.
'&datatoexport='.$datatoexport.
'&action=upfield&field='.$code.
'" class="paddingleft paddingright">'.
img_up().
'</a>';
1145 print
'<div class="tabsAction">';
1147 if (count($array_selected)) {
1148 print
'<a class="butAction" href="export.php?step='.($step + 1).
'&datatoexport='.$datatoexport.
'">'.$langs->trans(
"NextStep").
'</a>';
1155 if (count($array_selected)) {
1158 print
'<div class="marginbottomonly">';
1159 print
'<span class="opacitymedium">'.$langs->trans(
"SaveExportModel").
'</span>';
1162 print
'<form class="nocellnopadd" action="export.php" method="post">';
1163 print
'<input type="hidden" name="token" value="'.newToken().
'">';
1164 print
'<input type="hidden" name="action" value="add_export_model">';
1165 print
'<input type="hidden" name="step" value="'.$step.
'">';
1166 print
'<input type="hidden" name="datatoexport" value="'.$datatoexport.
'">';
1167 print
'<input type="hidden" name="hexa" value="'.$hexa.
'">';
1168 print
'<input type="hidden" name="page_y" value="">';
1170 print
'<div class="div-table-responsive-no-min">';
1171 print
'<table class="noborder centpercent">';
1172 print
'<tr class="liste_titre">';
1173 print
'<td>'.$langs->trans(
"ExportModelName").
'</td>';
1174 print
'<td>'.$langs->trans(
"Visibility").
'</td>';
1178 $nameofexportprofile = str_replace(
' ',
'-', $langs->trans(
"ExportProfile").
' '.$titleofmodule.
' '.
dol_print_date(
dol_now(
'gmt'),
'dayxcard'));
1180 $nameofexportprofile = $export_name;
1184 print
'<tr class="oddeven">';
1185 print
'<td><input name="export_name" class="minwidth300" value="'.$nameofexportprofile.
'"></td>';
1187 $arrayvisibility = array(
'private' => $langs->trans(
"Private"),
'all' => $langs->trans(
"Everybody"));
1188 print $form->selectarray(
'visibility', $arrayvisibility,
'private');
1190 print
'<td class="right">';
1191 print
'<input type="submit" class="button reposition button-save smallpaddingimp" value="'.$langs->trans(
"Save").
'">';
1197 $sql =
"SELECT rowid, label, fk_user, entity";
1198 $sql .=
" FROM ".MAIN_DB_PREFIX.
"export_model";
1199 $sql .=
" WHERE type = '".$db->escape($datatoexport).
"'";
1201 $sql .=
" AND fk_user IN (0, ".((int) $user->id).
")";
1203 $sql .=
" ORDER BY rowid";
1204 $resql =
$db->query($sql);
1206 $num =
$db->num_rows($resql);
1209 $obj =
$db->fetch_object($resql);
1211 print
'<tr class="oddeven"><td>';
1215 if (empty($obj->fk_user)) {
1216 print $langs->trans(
"Everybody");
1218 $tmpuser->fetch($obj->fk_user);
1219 print $tmpuser->getNomUrl(-1);
1222 print
'<td class="right">';
1223 print
'<a class="reposition" href="'.$_SERVER[
"PHP_SELF"].
'?step='.$step.
'&datatoexport='.$datatoexport.
'&action=deleteprof&token='.newToken().
'&id='.$obj->rowid.
'">';
1240if ($step == 5 && $datatoexport) {
1241 if (count($array_selected) < 1) {
1243 header(
"Location: ".DOL_URL_ROOT.
'/exports/export.php?step=2&datatoexport='.$datatoexport);
1248 if (empty($objexport->array_export_perms[0])) {
1252 asort($array_selected);
1254 llxHeader(
'', $langs->trans(
"NewExport"),
'EN:Module_Exports_En|FR:Module_Exports|ES:Módulo_Exportaciones',
'', 0, 0,
'',
'',
'',
'mod-exports page-export action-step5');
1259 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=1';
1260 $head[$h][1] = $langs->trans(
"Step").
" 1";
1263 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=2&datatoexport='.$datatoexport;
1264 $head[$h][1] = $langs->trans(
"Step").
" 2";
1268 if ($usefilters && isset($objexport->array_export_TypeFields[0]) && is_array($objexport->array_export_TypeFields[0])) {
1269 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=3&datatoexport='.$datatoexport;
1270 $head[$h][1] = $langs->trans(
"Step").
" 3";
1275 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=4&datatoexport='.$datatoexport;
1276 $head[$h][1] = $langs->trans(
"Step").
" ".(3 + $stepoffset);
1279 $head[$h][0] = DOL_URL_ROOT.
'/exports/export.php?step=5&datatoexport='.$datatoexport;
1280 $head[$h][1] = $langs->trans(
"Step").
" ".(4 + $stepoffset);
1281 $hselected = (
string) $h;
1289 if ($action ==
'remove_file') {
1290 print $form->formconfirm($_SERVER[
"PHP_SELF"].
'?step=5&datatoexport='.$datatoexport.
'&file='.urlencode(
GETPOST(
"file")), $langs->trans(
'DeleteFile'), $langs->trans(
'ConfirmDeleteFile'),
'confirm_deletefile',
'', 0, 1);
1293 print
'<div class="fichecenter">';
1294 print
'<div class="underbanner clearboth"></div>';
1296 print
'<table class="border tableforfield centpercent">';
1299 print
'<tr><td class="titlefield">'.$langs->trans(
"Module").
'</td>';
1302 print $objexport->array_export_module[0]->getName();
1306 print
'<tr><td>'.$langs->trans(
"DatasetToExport").
'</td>';
1308 $entity = preg_replace(
'/:.*$/',
'', $objexport->array_export_icon[0]);
1309 $entityicon = strtolower(!empty($entitytoicon[$entity]) ? $entitytoicon[$entity] : $entity);
1310 print
img_object($objexport->array_export_module[0]->getName(), $entityicon).
' ';
1311 print $objexport->array_export_label[0];
1315 print
'<tr><td>'.$langs->trans(
"ExportedFields").
'</td>';
1317 foreach ($array_selected as $code => $value) {
1318 if (isset($objexport->array_export_fields[0][$code])) {
1319 $list .= (!empty($list) ?
', ' :
'');
1321 $tmplabelarray = explode(
':', $objexport->array_export_fields[0][$code]);
1322 if (!empty($tmplabelarray[1])) {
1323 $list .= $langs->trans($tmplabelarray[0]).
' - '.$langs->trans($tmplabelarray[1]);
1325 $list .= $langs->trans($objexport->array_export_fields[0][$code]);
1329 print
'<td><span class="small">'.$list.
'</span></td>';
1333 if (isset($objexport->array_export_TypeFields[0]) && is_array($objexport->array_export_TypeFields[0])) {
1334 print
'<tr><td>'.$langs->trans(
"FilteredFields").
'</td>';
1336 if (!empty($array_filtervalue)) {
1337 foreach ($array_filtervalue as $code => $value) {
1338 if (preg_match(
'/^FormSelect:/', $objexport->array_export_TypeFields[0][$code])) {
1344 if (isset($objexport->array_export_fields[0][$code])) {
1345 $list .= ($list ?
', ' :
'');
1346 if (isset($array_filtervalue[$code]) && preg_match(
'/^\s*[<>]/', $array_filtervalue[$code])) {
1347 $list .=
'<span class="opacitymedium">'.$langs->trans($objexport->array_export_fields[0][$code]).
'</span>'.(isset($array_filtervalue[$code]) ? $array_filtervalue[$code] :
'');
1349 $list .=
'<span class="opacitymedium">'.$langs->trans($objexport->array_export_fields[0][$code]).
"</span>='".(isset($array_filtervalue[$code]) ? $array_filtervalue[$code] :
'').
"'";
1354 print
'<td>'.(!empty($list) ? $list :
'<span class="opacitymedium">'.$langs->trans(
"None").
'</span>').
'</td>';
1364 $htmltabloflibs =
'<!-- Table with available export formats --><br>';
1365 $htmltabloflibs .=
'<table class="noborder centpercent nomarginbottom">';
1366 $htmltabloflibs .=
'<tr class="liste_titre">';
1367 $htmltabloflibs .=
'<td>'.$langs->trans(
"AvailableFormats").
'</td>';
1368 $htmltabloflibs .=
'<td>'.$langs->trans(
"LibraryUsed").
'</td>';
1369 $htmltabloflibs .=
'<td class="right">'.$langs->trans(
"LibraryVersion").
'</td>';
1370 $htmltabloflibs .=
'</tr>'.
"\n";
1372 $liste = $objmodelexport->listOfAvailableExportFormat(
$db);
1374 foreach ($listeall as $key => $val) {
1375 if (preg_match(
'/__\(Disabled\)__/', $listeall[$key])) {
1376 $listeall[$key] = preg_replace(
'/__\(Disabled\)__/',
'('.$langs->transnoentitiesnoconv(
"Disabled").
')', $listeall[$key]);
1377 unset($liste[$key]);
1380 $htmltabloflibs .=
'<tr class="oddeven">';
1381 $htmltabloflibs .=
'<td>'.img_picto_common($key, $objmodelexport->getPictoForKey($key)).
' ';
1382 $text = $objmodelexport->getDriverDescForKey($key);
1383 $label = $listeall[$key];
1385 $htmltabloflibs .= $form->textwithpicto($label, $text).
'</td>';
1386 $htmltabloflibs .=
'<td>'.$objmodelexport->getLibLabelForKey($key).
'</td>';
1387 $htmltabloflibs .=
'<td class="right">'.$objmodelexport->getLibVersionForKey($key).
'</td>';
1388 $htmltabloflibs .=
'</tr>'.
"\n";
1390 $htmltabloflibs .=
'</table><br>';
1393 print
'<span class="opacitymedium">'.$form->textwithpicto($langs->trans(
"NowClickToGenerateToBuildExportFile"), $htmltabloflibs, 1,
'help',
'', 0, 2,
'helphonformat').
'</span>';
1399 if ($sqlusedforexport && $user->admin) {
1400 print
info_admin($langs->trans(
"SQLUsedForExport").
':<br> '.$sqlusedforexport, 0, 0,
'1',
'',
'TechnicalInformation').
'<br>';
1405 if (!is_dir(
$conf->export->dir_temp)) {
1411 print $formfile->showdocuments(
'export',
'', $upload_dir, $_SERVER[
"PHP_SELF"].
'?step=5&datatoexport='.$datatoexport, $liste, 1, (
GETPOST(
'model') ?
GETPOST(
'model') :
'csv'), 1, 1, 0, 0, 0,
'',
'none',
'',
'',
'');
1430 $alias = preg_replace(
'/\.(.*)$/i',
'', $code);
1431 $regexstring =
'/([a-zA-Z_]+) as '.preg_quote($alias).
'[, \)]/i';
1433 $newsql = $sqlmaxforexport;
1434 $newsql = preg_replace(
'/^(.*) FROM /i',
'', $newsql);
1435 $newsql = preg_replace(
'/WHERE (.*)$/i',
'', $newsql);
1438 if (preg_match($regexstring, $newsql, $reg)) {
llxFooter($comment='', $zone='private', $disabledoutputofmessages=0)
Empty footer.
if(!defined('NOREQUIRESOC')) if(!defined( 'NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined( 'NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined( 'NOREQUIREAJAX')) llxHeader($head='', $title='', $help_url='', $target='', $disablejs=0, $disablehead=0, $arrayofjs='', $arrayofcss='', $morequerystring='', $morecssonbody='', $replacemainareaby='', $disablenofollow=0, $disablenoindex=0)
Empty header.
Parent class for export modules.
Class to manage Dolibarr users.
getablenamefromfield($code, $sqlmaxforexport)
Return table name of an alias.
dol_delete_file($file, $disableglob=0, $nophperrors=0, $nohook=0, $object=null, $allowdotdot=false, $indexdatabase=1, $nolog=0)
Remove a file or several files with a mask.
dol_now($mode='gmt')
Return date for now.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
img_right($titlealt='default', $selected=0, $moreatt='')
Show right arrow logo.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2, $allowothertags=array())
Show picto whatever it's its name (generic function)
img_left($titlealt='default', $selected=0, $moreatt='')
Show left arrow logo.
info_admin($text, $infoonimgalt=0, $nodiv=0, $admin='1', $morecss='hideonsmartphone', $textfordropdown='', $picto='', $textonpictotooltip='')
Show information in HTML for admin users or standard users.
img_delete($titlealt='default', $other='class="pictodelete"', $morecss='')
Show delete logo.
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dolPrintHTML($s, $allowiframe=0, $moreallowedtags=array())
Return a string (that can be on several lines) ready to be output on a HTML page.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='', $dragdropfile=0, $morecssdiv='')
Show tabs of a record.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
img_object($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $allowothertags=array())
Show a picto called object_picto (generic function)
img_down($titlealt='default', $selected=0, $moreclass='')
Show down arrow logo.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false, $decorate=0)
Output date in a string format according to outputlangs (or langs if not defined).
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
img_up($titlealt='default', $selected=0, $moreclass='')
Show top arrow logo.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
dol_mkdir($dir, $dataroot='', $newmask='')
Creation of a directory (this can create recursive subdir)
print $langs trans("Show") . '< td style="' . $timeColor . '" align="center"> s</td > badge status0 badge status4 badge status3 Error badge status8< td align="center">< span class="badge ' . $badge . '"></span ></td >< td align="center">< a href="#" class="button button-small" onclick="openLogModal(this)" data-req="' . dol_escape_htmltag($reqSafe) . '" data-res="' . dol_escape_htmltag($resSafe) . '" data-err="' . dol_escape_htmltag($errSafe) . '">< span class="fa fa-search-plus"></span ></a ></td ></tr >< tr >< td colspan="' . $colspan . '" class="opacitymedium"></td ></tr ></table ></div ></form > logModal none logModal none s a JSON string
buildzip.php
restrictedArea(User $user, $features, $object=0, $tableandshare='', $feature2='', $dbt_keyfield='fk_soc', $dbt_select='rowid', $isdraft=0, $mode=0)
Check permissions of a user to show a page and an object.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.