56 $this->family =
"products";
57 $this->module_position =
'26';
59 $this->
name = preg_replace(
'/^mod/i',
'', get_class($this));
63 $this->version =
'dolibarr';
65 $this->const_name =
'MAIN_MODULE_'.strtoupper($this->
name);
66 $this->picto =
'product';
69 $this->dirs = array(
"/product/temp");
72 $this->hidden =
false;
73 $this->depends = array();
74 $this->requiredby = array(
"modStock",
"modBarcode",
"modProductBatch",
"modVariants",
"modBom");
75 $this->conflictwith = array();
76 $this->phpmin = array(7, 0);
79 $this->config_page_url = array(
"product.php@product");
80 $this->langfiles = array(
"products",
"companies",
"stocks",
"bills");
85 "PRODUCT_CODEPRODUCT_ADDON",
87 "mod_codeproduct_leopard",
88 'Module to control product codes',
96 'pricing rule by default',
109 $this->boxes = array(
110 0 => array(
'file' =>
'box_produits.php',
'enabledbydefaulton' =>
'Home'),
111 1 => array(
'file' =>
'box_produits_alerte_stock.php',
'enabledbydefaulton' =>
'Home'),
112 2 => array(
'file' =>
'box_graph_product_distribution.php',
'enabledbydefaulton' =>
'Home')
116 $this->rights = array();
117 $this->rights_class =
'produit';
120 $this->rights[$r][0] = 31;
121 $this->rights[$r][1] =
'Read products';
122 $this->rights[$r][2] =
'r';
123 $this->rights[$r][3] = 0;
124 $this->rights[$r][4] =
'lire';
127 $this->rights[$r][0] = 32;
128 $this->rights[$r][1] =
'Create/modify products';
129 $this->rights[$r][2] =
'w';
130 $this->rights[$r][3] = 0;
131 $this->rights[$r][4] =
'creer';
134 $this->rights[$r][0] = 33;
135 $this->rights[$r][1] =
'Read prices products';
136 $this->rights[$r][2] =
'w';
137 $this->rights[$r][3] = 0;
138 $this->rights[$r][4] =
'product_advance';
139 $this->rights[$r][5] =
'read_prices';
142 $this->rights[$r][0] = 35;
143 $this->rights[$r][1] =
'Read supplier prices';
144 $this->rights[$r][2] =
'w';
145 $this->rights[$r][3] = 0;
146 $this->rights[$r][4] =
'product_advance';
147 $this->rights[$r][5] =
'read_supplier_prices';
151 $this->rights[$r][0] = 36;
152 $this->rights[$r][1] =
'Write supplier prices';
153 $this->rights[$r][2] =
'w';
154 $this->rights[$r][3] = 0;
155 $this->rights[$r][4] =
'product_advance';
156 $this->rights[$r][5] =
'write_supplier_prices';
159 $this->rights[$r][0] = 34;
160 $this->rights[$r][1] =
'Delete products';
161 $this->rights[$r][2] =
'd';
162 $this->rights[$r][3] = 0;
163 $this->rights[$r][4] =
'supprimer';
166 $this->rights[$r][0] = 38;
167 $this->rights[$r][1] =
'Export products';
168 $this->rights[$r][2] =
'r';
169 $this->rights[$r][3] = 0;
170 $this->rights[$r][4] =
'export';
173 $this->rights[$r][0] = 39;
174 $this->rights[$r][1] =
'Ignore minimum price';
175 $this->rights[$r][2] =
'r';
176 $this->rights[$r][3] = 0;
177 $this->rights[$r][4] =
'ignore_price_min_advance';
209 $usenpr =
$mysoc->useNPR();
216 $alias_product_perentity = !
getDolGlobalString(
'MAIN_PRODUCT_PERENTITY_SHARED') ?
"p" :
"ppe";
219 $this->export_code[$r] = $this->rights_class.
'_'.$r;
220 $this->export_label[$r] =
"Products";
221 $this->export_permission[$r] = array(array(
"produit",
"export"));
222 $this->export_fields_array[$r] = array(
223 'p.rowid' =>
"Id",
'p.ref' =>
"Ref",
'p.label' =>
"Label",
224 'p.fk_product_type' =>
'Type',
'p.tosell' =>
"OnSell",
'p.tobuy' =>
"OnBuy",
225 'p.description' =>
"Description",
'p.url' =>
"PublicUrl",
226 'p.customcode' =>
'CustomsCode',
'p.fk_country' =>
'IDCountry',
227 $alias_product_perentity .
'.accountancy_code_sell' =>
"ProductAccountancySellCode", $alias_product_perentity .
'.accountancy_code_sell_intra' =>
"ProductAccountancySellIntraCode",
228 $alias_product_perentity .
'.accountancy_code_sell_export' =>
"ProductAccountancySellExportCode", $alias_product_perentity .
'.accountancy_code_buy' =>
"ProductAccountancyBuyCode",
229 $alias_product_perentity .
'.accountancy_code_buy_intra' =>
"ProductAccountancyBuyIntraCode", $alias_product_perentity .
'.accountancy_code_buy_export' =>
"ProductAccountancyBuyExportCode",
230 'p.note' =>
"NotePrivate",
'p.note_public' =>
'NotePublic',
231 'p.weight' =>
"Weight",
'p.weight_units' =>
"WeightUnits",
'p.length' =>
"Length",
'p.length_units' =>
"LengthUnits",
'p.width' =>
"Width",
'p.width_units' =>
"WidthUnits",
'p.height' =>
"Height",
'p.height_units' =>
"HeightUnits",
232 'p.surface' =>
"Surface",
'p.surface_units' =>
"SurfaceUnits",
'p.volume' =>
"Volume",
'p.volume_units' =>
"VolumeUnits",
233 'p.duration' =>
"Duration",
234 'p.finished' =>
'Nature',
235 'p.price_base_type' =>
"PriceBase",
'p.price' =>
"UnitPriceHT",
'p.price_ttc' =>
"UnitPriceTTC",
236 'p.price_min' =>
"MinPriceHT",
'p.price_min_ttc' =>
"MinPriceTTC",
237 'p.tva_tx' =>
'VATRate',
238 'p.datec' =>
'DateCreation',
'p.tms' =>
'DateModification'
240 if (is_object(
$mysoc) && $usenpr) {
241 $this->export_fields_array[$r][
'p.recuperableonly'] =
'NPR';
244 $this->export_fields_array[$r] = array_merge($this->export_fields_array[$r], array(
'p.cost_price' =>
'CostPrice'));
247 $this->export_fields_array[$r] = array_merge($this->export_fields_array[$r], array(
'e.ref' =>
'DefaultWarehouse',
'p.tobatch' =>
'ManageLotSerial',
'p.stock' =>
'Stock',
'p.seuil_stock_alerte' =>
'StockLimit',
'p.desiredstock' =>
'DesiredStock',
'p.pmp' =>
'PMPValue'));
250 $this->export_fields_array[$r] = array_merge($this->export_fields_array[$r], array(
'p.barcode' =>
'BarCode'));
252 $keyforselect =
'product';
253 $keyforelement =
'product';
254 $keyforaliasextra =
'extra';
255 include DOL_DOCUMENT_ROOT.
'/core/extrafieldsinexport.inc.php';
257 $this->export_fields_array[$r] = array_merge($this->export_fields_array[$r], array(
's.nom' =>
'Supplier',
'pf.ref_fourn' =>
'SupplierRef',
'pf.quantity' =>
'QtyMin',
'pf.remise_percent' =>
'DiscountQtyMin',
'pf.unitprice' =>
'BuyingPrice',
'pf.delivery_time_days' =>
'NbDaysToDelivery'));
260 $this->export_fields_array[$r] = array_merge($this->export_fields_array[$r], array(
'group_concat(cat.label)' =>
'Categories'));
263 $this->export_fields_array[$r] = array_merge($this->export_fields_array[$r], array(
'l.lang' =>
'Language',
'l.label' =>
'TranslatedLabel',
'l.description' =>
'TranslatedDescription',
'l.note' =>
'TranslatedNote'));
266 $this->export_fields_array[$r][
'p.fk_unit'] =
'Unit';
268 $this->export_TypeFields_array[$r] = array(
269 'p.ref' =>
"Text",
'p.label' =>
"Text",
270 'p.fk_product_type' =>
'Numeric',
'p.tosell' =>
"Boolean",
'p.tobuy' =>
"Boolean",
271 'p.description' =>
"Text",
'p.url' =>
"Text",
272 $alias_product_perentity .
'.accountancy_code_sell' =>
"Text", $alias_product_perentity .
'.accountancy_code_sell_intra' =>
"Text", $alias_product_perentity .
'.accountancy_code_sell_export' =>
"Text",
273 $alias_product_perentity .
'.accountancy_code_buy' =>
"Text", $alias_product_perentity .
'.accountancy_code_buy_intra' =>
"Text", $alias_product_perentity .
'.accountancy_code_buy_export' =>
"Text",
274 'p.note' =>
"Text",
'p.note_public' =>
"Text",
275 'p.weight' =>
"Numeric",
'p.length' =>
"Numeric",
'p.width' =>
"Numeric",
'p.height' =>
"Numeric",
'p.surface' =>
"Numeric",
'p.volume' =>
"Numeric",
276 'p.customcode' =>
'Text',
277 'p.duration' =>
"Text",
278 'p.finished' =>
'Numeric',
279 'p.price_base_type' =>
"Text",
'p.price' =>
"Numeric",
'p.price_ttc' =>
"Numeric",
280 'p.price_min' =>
"Numeric",
'p.price_min_ttc' =>
"Numeric",
281 'p.tva_tx' =>
'Numeric',
282 'p.datec' =>
'Date',
'p.tms' =>
'Date'
285 $this->export_TypeFields_array[$r] = array_merge($this->export_TypeFields_array[$r], array(
'e.ref' =>
'Text',
'p.tobatch' =>
'Numeric',
'p.stock' =>
'Numeric',
'p.seuil_stock_alerte' =>
'Numeric',
'p.desiredstock' =>
'Numeric',
'p.pmp' =>
'Numeric',
'p.cost_price' =>
'Numeric'));
288 $this->export_TypeFields_array[$r] = array_merge($this->export_TypeFields_array[$r], array(
'p.barcode' =>
'Text'));
291 $this->export_TypeFields_array[$r] = array_merge($this->export_TypeFields_array[$r], array(
's.nom' =>
'Text',
'pf.ref_fourn' =>
'Text',
'pf.unitprice' =>
'Numeric',
'pf.quantity' =>
'Numeric',
'pf.remise_percent' =>
'Numeric',
'pf.delivery_time_days' =>
'Numeric'));
294 $this->export_TypeFields_array[$r] = array_merge($this->export_TypeFields_array[$r], array(
'l.lang' =>
'Text',
'l.label' =>
'Text',
'l.description' =>
'Text',
'l.note' =>
'Text'));
297 $this->export_TypeFields_array[$r] = array_merge($this->export_TypeFields_array[$r], array(
"group_concat(cat.label)" =>
'Text'));
299 $this->export_entities_array[$r] = array();
301 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
"group_concat(cat.label)" =>
'category'));
304 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
'p.stock' =>
'product',
'p.pmp' =>
'product'));
307 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
'p.barcode' =>
'product'));
310 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
's.nom' =>
'product_supplier_ref',
'pf.ref_fourn' =>
'product_supplier_ref',
'pf.unitprice' =>
'product_supplier_ref',
'pf.quantity' =>
'product_supplier_ref',
'pf.remise_percent' =>
'product_supplier_ref',
'pf.delivery_time_days' =>
'product_supplier_ref'));
313 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
'l.lang' =>
'translation',
'l.label' =>
'translation',
'l.description' =>
'translation',
'l.note' =>
'translation'));
316 $this->export_dependencies_array[$r] = array(
'category' =>
'p.rowid');
319 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
'p.stock' =>
'product',
'p.pmp' =>
'product'));
322 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
'p.barcode' =>
'product'));
325 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
's.nom' =>
'product_supplier_ref',
'pf.ref_fourn' =>
'product_supplier_ref',
'pf.unitprice' =>
'product_supplier_ref',
'pf.quantity' =>
'product_supplier_ref',
'pf.remise_percent' =>
'product_supplier_ref',
'pf.delivery_time_days' =>
'product_supplier_ref'));
328 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
'l.lang' =>
'translation',
'l.label' =>
'translation',
'l.description' =>
'translation',
'l.note' =>
'translation'));
331 $this->export_dependencies_array[$r] = array(
'category' =>
'p.rowid');
333 $this->export_sql_start[$r] =
'SELECT DISTINCT ';
334 $this->export_sql_end[$r] =
' FROM '.MAIN_DB_PREFIX.
'product as p';
336 $this->export_sql_end[$r] .=
" LEFT JOIN " . MAIN_DB_PREFIX .
"product_perentity as ppe ON ppe.fk_product = p.rowid AND ppe.entity = " . ((int)
$conf->entity);
339 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'categorie_product as cp ON cp.fk_product = p.rowid LEFT JOIN '.MAIN_DB_PREFIX.
'categorie as cat ON cp.fk_categorie = cat.rowid';
342 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'product_lang as l ON l.fk_product = p.rowid';
344 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'product_extrafields as extra ON p.rowid = extra.fk_object';
346 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'product_fournisseur_price as pf ON pf.fk_product = p.rowid LEFT JOIN '.MAIN_DB_PREFIX.
'societe s ON s.rowid = pf.fk_soc';
349 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'entrepot as e ON e.rowid = p.fk_default_warehouse';
351 $this->export_sql_end[$r] .=
' WHERE p.fk_product_type = 0 AND p.entity IN ('.getEntity(
'product').
')';
353 $this->export_sql_order[$r] =
' GROUP BY p.rowid';
359 $this->export_code[$r] = $this->rights_class.
'_'.$r;
360 $this->export_label[$r] =
"ProductsMultiPrice";
361 $this->export_permission[$r] = array(array(
"produit",
"export"));
362 $this->export_fields_array[$r] = array(
363 'p.rowid' =>
"Id",
'p.ref' =>
"Ref",
'p.label' =>
"Label",
364 'pr.price_base_type' =>
"PriceBase",
'pr.price_level' =>
"PriceLevel",
365 'pr.price' =>
"PriceLevelUnitPriceHT",
'pr.price_ttc' =>
"PriceLevelUnitPriceTTC",
366 'pr.price_min' =>
"MinPriceLevelUnitPriceHT",
'pr.price_min_ttc' =>
"MinPriceLevelUnitPriceTTC",
367 'pr.tva_tx' =>
'PriceLevelVATRate',
368 'pr.date_price' =>
'DateCreation'
370 if (is_object(
$mysoc) && $usenpr) {
371 $this->export_fields_array[$r][
'pr.recuperableonly'] =
'NPR';
379 $this->export_entities_array[$r] = array(
380 'p.rowid' =>
"product",
'p.ref' =>
"product",
'p.label' =>
"Label",
381 'pr.price_base_type' =>
"product",
'pr.price_level' =>
"product",
'pr.price' =>
"product",
382 'pr.price_ttc' =>
"product",
383 'pr.price_min' =>
"product",
'pr.price_min_ttc' =>
"product",
384 'pr.tva_tx' =>
'product',
385 'pr.recuperableonly' =>
'product',
386 'pr.date_price' =>
"product"
388 $this->export_sql_start[$r] =
'SELECT DISTINCT ';
389 $this->export_sql_end[$r] =
' FROM '.MAIN_DB_PREFIX.
'product as p';
390 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'product_price as pr ON p.rowid = pr.fk_product AND pr.entity = '.
$conf->entity;
391 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'product_price_extrafields as extra ON pr.rowid = extra.fk_object';
392 $this->export_sql_end[$r] .=
' WHERE p.entity IN ('.getEntity(
'product').
')';
393 $this->export_sql_end[$r] .=
' AND pr.date_price = (SELECT MAX(pr2.date_price) FROM '.MAIN_DB_PREFIX.
'product_price as pr2 WHERE pr2.fk_product = pr.fk_product AND pr2.price_level = pr.price_level AND pr2.entity IN ('.
getEntity(
'product').
'))';
395 global $keyforselect, $keyforelement, $keyforaliasextra;
396 $keyforselect =
'product_price';
397 $keyforelement =
'product';
398 $keyforaliasextra =
'extra';
399 include DOL_DOCUMENT_ROOT.
'/core/extrafieldsinexport.inc.php';
405 $this->export_code[$r] = $this->rights_class.
'_'.$r;
406 $this->export_label[$r] =
"ProductsPricePerCustomer";
407 $this->export_permission[$r] = array(array(
"produit",
"export"));
408 $this->export_fields_array[$r] = array(
'p.rowid' =>
"Id",
'p.ref' =>
"Ref",
'p.label' =>
"Label",
409 's.nom' =>
'ThirdParty',
410 's.code_client' =>
'CodeClient',
411 'pr.date_begin' =>
"AppliedPricesFrom",
412 'pr.date_end' =>
"AppliedPricesTo",
413 'pr.price_base_type' =>
"PriceBase",
414 'pr.price' =>
"PriceUnitPriceHT",
'pr.price_ttc' =>
"PriceUnitPriceTTC",
415 'pr.price_min' =>
"MinPriceUnitPriceHT",
'pr.price_min_ttc' =>
"MinPriceUnitPriceTTC",
416 'pr.tva_tx' =>
'PriceVATRate',
417 'pr.default_vat_code' =>
'PriceVATCode',
418 'pr.discount_percent' =>
'Discount',
419 'pr.datec' =>
'DateCreation');
420 if (is_object(
$mysoc) && $usenpr) {
421 $this->export_fields_array[$r][
'pr.recuperableonly'] =
'NPR';
423 $this->export_entities_array[$r] = array(
'p.rowid' =>
"product",
'p.ref' =>
"product",
'p.label' =>
"Label",
424 's.nom' =>
'company',
425 's.code_client' =>
'company',
426 'pr.date_begin' =>
"product",
427 'pr.date_end' =>
"product",
428 'pr.price_base_type' =>
"product",
'pr.price' =>
"product",
429 'pr.price_ttc' =>
"product",
430 'pr.price_min' =>
"product",
'pr.price_min_ttc' =>
"product",
431 'pr.tva_tx' =>
'product',
432 'pr.default_vat_code' =>
'product',
433 'pr.discount_percent' =>
'product',
434 'pr.recuperableonly' =>
'product',
435 'pr.datec' =>
"product");
436 $this->export_sql_start[$r] =
'SELECT DISTINCT ';
437 $this->export_sql_end[$r] =
' FROM '.MAIN_DB_PREFIX.
'product as p';
438 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'product_customer_price as pr ON p.rowid = pr.fk_product AND pr.entity = '.
$conf->entity;
439 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'societe as s ON pr.fk_soc = s.rowid';
440 $this->export_sql_end[$r] .=
' WHERE p.entity IN ('.getEntity(
'product').
')';
446 $this->export_code[$r] = $this->rights_class.
'_'.$r;
447 $this->export_label[$r] =
"AssociatedProducts";
448 $this->export_permission[$r] = array(array(
"produit",
"export"));
449 $this->export_fields_array[$r] = array(
450 'p.rowid' =>
"Id",
'p.ref' =>
"Ref",
'p.label' =>
"Label",
'p.description' =>
"Description",
'p.url' =>
"PublicUrl",
451 $alias_product_perentity .
'.accountancy_code_sell' =>
"ProductAccountancySellCode", $alias_product_perentity .
'.accountancy_code_sell_intra' =>
"ProductAccountancySellIntraCode",
452 $alias_product_perentity .
'.accountancy_code_sell_export' =>
"ProductAccountancySellExportCode", $alias_product_perentity .
'.accountancy_code_buy' =>
"ProductAccountancyBuyCode",
453 $alias_product_perentity .
'.accountancy_code_buy_intra' =>
"ProductAccountancyBuyIntraCode", $alias_product_perentity .
'.accountancy_code_buy_export' =>
"ProductAccountancyBuyExportCode",
454 'p.note' =>
"NotePrivate",
'p.note_public' =>
'NotePublic',
455 'p.weight' =>
"Weight",
'p.length' =>
"Length",
'p.surface' =>
"Surface",
'p.volume' =>
"Volume",
'p.customcode' =>
'CustomsCode',
456 'p.price_base_type' =>
"PriceBase",
'p.price' =>
"UnitPriceHT",
'p.price_ttc' =>
"UnitPriceTTC",
'p.tva_tx' =>
'VATRate',
'p.tosell' =>
"OnSell",
457 'p.tobuy' =>
"OnBuy",
'p.datec' =>
'DateCreation',
'p.tms' =>
'DateModification'
460 $this->export_fields_array[$r] = array_merge($this->export_fields_array[$r], array(
'p.stock' =>
'Stock',
'p.seuil_stock_alerte' =>
'StockLimit',
'p.desiredstock' =>
'DesiredStock',
'p.pmp' =>
'PMPValue'));
463 $this->export_fields_array[$r] = array_merge($this->export_fields_array[$r], array(
'p.barcode' =>
'BarCode'));
465 $this->export_fields_array[$r] = array_merge($this->export_fields_array[$r], array(
'pa.qty' =>
'Qty',
'pa.incdec' =>
'ComposedProductIncDecStock'));
466 $this->export_TypeFields_array[$r] = array(
467 'p.ref' =>
"Text",
'p.label' =>
"Text",
'p.description' =>
"Text",
'p.url' =>
"Text",
468 $alias_product_perentity .
'.accountancy_code_sell' =>
"Text", $alias_product_perentity .
'.accountancy_code_sell_intra' =>
"Text", $alias_product_perentity .
'.accountancy_code_sell_export' =>
"Text",
469 $alias_product_perentity .
'.accountancy_code_buy' =>
"Text", $alias_product_perentity .
'.accountancy_code_buy_intra' =>
"Text", $alias_product_perentity .
'.accountancy_code_buy_export' =>
"Text",
470 'p.note' =>
"Text",
'p.note_public' =>
"Text",
471 'p.weight' =>
"Numeric",
'p.length' =>
"Numeric",
'p.surface' =>
"Numeric",
'p.volume' =>
"Numeric",
'p.customcode' =>
'Text',
472 'p.price_base_type' =>
"Text",
'p.price' =>
"Numeric",
'p.price_ttc' =>
"Numeric",
'p.tva_tx' =>
'Numeric',
'p.tosell' =>
"Boolean",
'p.tobuy' =>
"Boolean",
473 'p.datec' =>
'Date',
'p.tms' =>
'Date'
476 $this->export_TypeFields_array[$r] = array_merge($this->export_TypeFields_array[$r], array(
'p.stock' =>
'Numeric',
'p.seuil_stock_alerte' =>
'Numeric',
'p.desiredstock' =>
'Numeric',
'p.pmp' =>
'Numeric',
'p.cost_price' =>
'Numeric'));
479 $this->export_TypeFields_array[$r] = array_merge($this->export_TypeFields_array[$r], array(
'p.barcode' =>
'Text'));
481 $this->export_TypeFields_array[$r] = array_merge($this->export_TypeFields_array[$r], array(
'pa.qty' =>
'Numeric'));
482 $this->export_entities_array[$r] = array(
483 'p.rowid' =>
"virtualproduct",
'p.ref' =>
"virtualproduct",
'p.label' =>
"virtualproduct",
'p.description' =>
"virtualproduct",
'p.url' =>
"virtualproduct",
484 $alias_product_perentity .
'.accountancy_code_sell' =>
'virtualproduct', $alias_product_perentity .
'.accountancy_code_sell_intra' =>
'virtualproduct', $alias_product_perentity .
'.accountancy_code_sell_export' =>
'virtualproduct',
485 $alias_product_perentity .
'.accountancy_code_buy' =>
'virtualproduct', $alias_product_perentity .
'.accountancy_code_buy_intra' =>
'virtualproduct', $alias_product_perentity .
'.accountancy_code_buy_export' =>
'virtualproduct',
486 'p.note' =>
"virtualproduct",
'p.length' =>
"virtualproduct",
487 'p.surface' =>
"virtualproduct",
'p.volume' =>
"virtualproduct",
'p.weight' =>
"virtualproduct",
'p.customcode' =>
'virtualproduct',
488 'p.price_base_type' =>
"virtualproduct",
'p.price' =>
"virtualproduct",
'p.price_ttc' =>
"virtualproduct",
'p.tva_tx' =>
"virtualproduct",
489 'p.tosell' =>
"virtualproduct",
'p.tobuy' =>
"virtualproduct",
'p.datec' =>
"virtualproduct",
'p.tms' =>
"virtualproduct"
492 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
'p.stock' =>
'virtualproduct',
'p.seuil_stock_alerte' =>
'virtualproduct',
'p.desiredstock' =>
'virtualproduct',
'p.pmp' =>
'virtualproduct'));
495 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
'p.barcode' =>
'virtualproduct'));
497 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
'pa.qty' =>
"subproduct",
'pa.incdec' =>
'subproduct'));
498 $keyforselect =
'product';
499 $keyforelement =
'product';
500 $keyforaliasextra =
'extra';
501 include DOL_DOCUMENT_ROOT.
'/core/extrafieldsinexport.inc.php';
502 $this->export_fields_array[$r] = array_merge($this->export_fields_array[$r], array(
'p2.rowid' =>
"Id",
'p2.ref' =>
"Ref",
'p2.label' =>
"Label",
'p2.description' =>
"Description"));
503 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
'p2.rowid' =>
"subproduct",
'p2.ref' =>
"subproduct",
'p2.label' =>
"subproduct",
'p2.description' =>
"subproduct"));
504 $this->export_sql_start[$r] =
'SELECT DISTINCT ';
505 $this->export_sql_end[$r] =
' FROM '.MAIN_DB_PREFIX.
'product as p';
507 $this->export_sql_end[$r] .=
" LEFT JOIN " . MAIN_DB_PREFIX .
"product_perentity as ppe ON ppe.fk_product = p.rowid AND ppe.entity = " . ((int)
$conf->entity);
509 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'product_extrafields as extra ON p.rowid = extra.fk_object,';
510 $this->export_sql_end[$r] .=
' '.MAIN_DB_PREFIX.
'product_association as pa, '.MAIN_DB_PREFIX.
'product as p2';
511 $this->export_sql_end[$r] .=
' WHERE p.entity IN ('.getEntity(
'product').
')';
512 $this->export_sql_end[$r] .=
' AND p.rowid = pa.fk_product_pere AND p2.rowid = pa.fk_product_fils';
522 $this->import_code[$r] = $this->rights_class.
'_'.$r;
523 $this->import_label[$r] =
"Products";
524 $this->import_icon[$r] = $this->picto;
525 $this->import_entities_array[$r] = array();
526 $this->import_tables_array[$r] = array(
'p' => MAIN_DB_PREFIX.
'product',
'extra' => MAIN_DB_PREFIX.
'product_extrafields');
527 $this->import_tables_creator_array[$r] = array(
'p' =>
'fk_user_author');
528 $this->import_fields_array[$r] = array(
530 'p.label' =>
"Label*",
531 'p.fk_product_type' =>
"Type*",
532 'p.tosell' =>
"OnSell*",
533 'p.tobuy' =>
"OnBuy*",
534 'p.description' =>
"Description",
535 'p.url' =>
"PublicUrl",
536 'p.customcode' =>
'CustomsCode',
537 'p.fk_country' =>
'CountryCode',
538 'p.accountancy_code_sell' =>
"ProductAccountancySellCode",
539 'p.accountancy_code_sell_intra' =>
"ProductAccountancySellIntraCode",
540 'p.accountancy_code_sell_export' =>
"ProductAccountancySellExportCode",
541 'p.accountancy_code_buy' =>
"ProductAccountancyBuyCode",
542 'p.accountancy_code_buy_intra' =>
"ProductAccountancyBuyIntraCode",
543 'p.accountancy_code_buy_export' =>
"ProductAccountancyBuyExportCode",
544 'p.note_public' =>
"NotePublic",
545 'p.note' =>
"NotePrivate",
546 'p.weight' =>
"Weight",
547 'p.weight_units' =>
"WeightUnits",
548 'p.length' =>
"Length",
549 'p.length_units' =>
"LengthUnits",
550 'p.width' =>
"Width",
551 'p.width_units' =>
"WidthUnits",
552 'p.height' =>
"Height",
553 'p.height_units' =>
"HeightUnits",
554 'p.surface' =>
"Surface",
555 'p.surface_units' =>
"SurfaceUnits",
556 'p.volume' =>
"Volume",
557 'p.volume_units' =>
"VolumeUnits",
558 'p.duration' =>
"Duration",
559 'p.finished' =>
'Nature',
560 'p.price' =>
"SellingPriceHT",
561 'p.price_min' =>
"MinPrice",
562 'p.price_ttc' =>
"SellingPriceTTC",
563 'p.price_min_ttc' =>
"SellingMinPriceTTC",
564 'p.price_base_type' =>
"PriceBaseType",
565 'p.tva_tx' =>
'VATRate',
566 'p.default_vat_code' =>
'VATCode',
567 'p.datec' =>
'DateCreation',
568 'p.cost_price' =>
"CostPrice"
571 $this->import_convertvalue_array[$r] = array(
572 'p.weight_units' => array(
573 'rule' =>
'fetchscalefromcodeunits',
574 'classfile' =>
'/core/class/cunits.class.php',
578 'dict' =>
'DictionaryMeasuringUnits'
580 'p.length_units' => array(
581 'rule' =>
'fetchscalefromcodeunits',
582 'classfile' =>
'/core/class/cunits.class.php',
586 'dict' =>
'DictionaryMeasuringUnits'
588 'p.width_units' => array(
589 'rule' =>
'fetchscalefromcodeunits',
590 'classfile' =>
'/core/class/cunits.class.php',
594 'dict' =>
'DictionaryMeasuringUnits'
596 'p.height_units' => array(
597 'rule' =>
'fetchscalefromcodeunits',
598 'classfile' =>
'/core/class/cunits.class.php',
602 'dict' =>
'DictionaryMeasuringUnits'
604 'p.surface_units' => array(
605 'rule' =>
'fetchscalefromcodeunits',
606 'classfile' =>
'/core/class/cunits.class.php',
609 'units' =>
'surface',
610 'dict' =>
'DictionaryMeasuringUnits'
612 'p.volume_units' => array(
613 'rule' =>
'fetchscalefromcodeunits',
614 'classfile' =>
'/core/class/cunits.class.php',
618 'dict' =>
'DictionaryMeasuringUnits'
620 'p.fk_country' => array(
621 'rule' =>
'fetchidfromcodeid',
622 'classfile' =>
'/core/class/ccountry.class.php',
623 'class' =>
'Ccountry',
625 'dict' =>
'DictionaryCountry'
627 'p.finished' => array(
628 'rule' =>
'fetchidfromcodeorlabel',
629 'classfile' =>
'/core/class/cproductnature.class.php',
630 'class' =>
'CProductNature',
632 'dict' =>
'DictionaryProductNature'
634 'p.accountancy_code_sell' => array(
'rule' =>
'accountingaccount'),
635 'p.accountancy_code_sell_intra' => array(
'rule' =>
'accountingaccount'),
636 'p.accountancy_code_sell_export' => array(
'rule' =>
'accountingaccount'),
637 'p.accountancy_code_buy' => array(
'rule' =>
'accountingaccount'),
638 'p.accountancy_code_buy_intra' => array(
'rule' =>
'accountingaccount'),
639 'p.accountancy_code_buy_export' => array(
'rule' =>
'accountingaccount'),
642 $this->import_regex_array[$r] = array(
644 'p.price_base_type' =>
'\AHT\z|\ATTC\z',
645 'p.tosell' =>
'^[0|1]$',
646 'p.tobuy' =>
'^[0|1]$',
647 'p.fk_product_type' =>
'^[0|1]$',
648 'p.datec' =>
'^[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]$',
649 'p.recuperableonly' =>
'^[0|1]$',
654 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
655 'p.fk_default_warehouse' =>
'DefaultWarehouse',
656 'p.tobatch' =>
'ManageLotSerial',
657 'p.sell_or_eat_by_mandatory' =>
'SellOrEatByMandatory',
658 'p.seuil_stock_alerte' =>
'StockLimit',
659 'p.pmp' =>
'PMPValue',
660 'p.desiredstock' =>
'DesiredStock'
663 $this->import_regex_array[$r] = array_merge($this->import_regex_array[$r], array(
664 'p.tobatch' =>
'^[0|1|2]$',
665 'p.sell_or_eat_by_mandatory' =>
'^[0-3]$'
668 $this->import_convertvalue_array[$r] = array_merge($this->import_convertvalue_array[$r], array(
669 'p.fk_default_warehouse' => array(
670 'rule' =>
'fetchidfromref',
671 'classfile' =>
'/product/stock/class/entrepot.class.php',
672 'class' =>
'Entrepot',
674 'element' =>
'Warehouse'
680 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
681 'p.packaging' =>
'PackagingForThisProductSell',
686 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'p.cost_price' =>
'CostPrice'));
688 if (is_object(
$mysoc) && $usenpr) {
689 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'p.recuperableonly' =>
'NPR'));
692 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'p.localtax1_tx' =>
'LT1',
'p.localtax1_type' =>
'LT1Type'));
695 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'p.localtax2_tx' =>
'LT2',
'p.localtax2_type' =>
'LT2Type'));
698 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'p.barcode' =>
'BarCode'));
701 $this->import_fields_array[$r][
'p.fk_unit'] =
'Unit';
705 $import_extrafield_sample = array();
706 $sql =
"SELECT name, label, fieldrequired FROM ".MAIN_DB_PREFIX.
"extrafields WHERE type <> 'separate' AND elementtype = 'product' AND entity IN (0, ".
$conf->entity.
")";
707 $resql = $this->db->query($sql);
709 while ($obj = $this->db->fetch_object($resql)) {
710 $fieldname =
'extra.'.$obj->name;
711 $fieldlabel = ucfirst($obj->label);
712 $this->import_fields_array[$r][$fieldname] = $fieldlabel.($obj->fieldrequired ?
'*' :
'');
713 $import_extrafield_sample[$fieldname] = $fieldlabel;
717 $this->import_fieldshidden_array[$r] = array(
'extra.fk_object' =>
'lastrowid-'.MAIN_DB_PREFIX.
'product');
720 $import_sample = array(
721 'p.ref' =>
"ref:PREF123456",
723 'p.label' =>
"Product name in default language",
724 'p.description' =>
"Product description in default language",
725 'p.note_public' =>
"a public note (free text)",
726 'p.note' =>
"a private note (free text)",
727 'p.customcode' =>
'customs code',
728 'p.fk_country' =>
'FR',
730 'p.price_min' =>
"100",
731 'p.price_ttc' =>
"110",
732 'p.price_min_ttc' =>
"110",
733 'p.price_base_type' =>
"HT (show/use price excl. tax) / TTC (show/use price incl. tax)",
735 'p.default_vat_code' =>
'',
736 'p.tosell' =>
"0 (not for sale to customer, eg. raw material) / 1 (for sale)",
737 'p.tobuy' =>
"0 (not for purchase from supplier, eg. virtual product) / 1 (for purchase)",
738 'p.fk_product_type' =>
"0 (product) / 1 (service)",
739 'p.duration' =>
"eg. 365d/12m/1y",
740 'p.url' =>
'link to product (no https)',
741 'p.accountancy_code_sell' =>
"",
742 'p.accountancy_code_sell_intra' =>
"",
743 'p.accountancy_code_sell_export' =>
"",
744 'p.accountancy_code_buy' =>
"",
745 'p.accountancy_code_buy_intra' =>
"",
746 'p.accountancy_code_buy_export' =>
"",
748 'p.weight_units' =>
'kg',
750 'p.length_units' =>
'm',
752 'p.width_units' =>
'm',
754 'p.height_units' =>
'm',
756 'p.surface_units' =>
'm2',
758 'p.volume_units' =>
'm3',
759 'p.finished' =>
'0 (raw material) / 1 (finished goods), matches field "code" in dictionary table "'.MAIN_DB_PREFIX.
'c_product_nature"'
763 $import_sample = array_merge($import_sample, array(
764 'p.tobatch' =>
"0 (don't use) / 1 (use batch) / 2 (use serial number)",
765 'p.sell_or_eat_by_mandatory' =>
"0 (none) / 1 (sell-by) / 2 (eat-by) / 3 (sell+eat)",
766 'p.seuil_stock_alerte' =>
'',
768 'p.desiredstock' =>
''
772 $import_sample = array_merge($import_sample, array(
'p.cost_price' =>
'90'));
774 if (is_object(
$mysoc) && $usenpr) {
775 $import_sample = array_merge($import_sample, array(
'p.recuperableonly' =>
'0'));
778 $import_sample = array_merge($import_sample, array(
'p.localtax1_tx' =>
'',
'p.localtax1_type' =>
''));
781 $import_sample = array_merge($import_sample, array(
'p.localtax2_tx' =>
'',
'p.localtax2_type' =>
''));
784 $import_sample = array_merge($import_sample, array(
'p.barcode' =>
''));
787 $import_sample = array_merge(
790 'p.fk_unit' =>
'use a unit of measure from the dictionary. G/KG/M2/M3 etc....matches field "code" in table "'.MAIN_DB_PREFIX.
'c_units"'
794 if (!is_array($this->import_convertvalue_array[$r])) {
795 $this->import_convertvalue_array[$r] = array();
797 $this->import_convertvalue_array[$r] = array_merge($this->import_convertvalue_array[$r], array(
798 'p.fk_unit' => array(
799 'rule' =>
'fetchidfromcodeorlabel',
800 'classfile' =>
'/core/class/cunits.class.php',
803 'dict' =>
'DictionaryUnits'
809 $import_sample = array_merge($import_sample, array(
810 'p.packaging' =>
"2",
814 $this->import_examplevalues_array[$r] = array_merge($import_sample, $import_extrafield_sample);
815 $this->import_updatekeys_array[$r] = array(
'p.ref' =>
'Ref');
817 $this->import_updatekeys_array[$r] = array_merge($this->import_updatekeys_array[$r], array(
'p.barcode' =>
'BarCode'));
823 $this->import_code[$r] = $this->rights_class.
'_stock_by_warehouse';
824 $this->import_label[$r] =
"ProductStockWarehouse";
825 $this->import_icon[$r] = $this->picto;
826 $this->import_entities_array[$r] = array();
827 $this->import_tables_array[$r] = array(
'pwp' => MAIN_DB_PREFIX.
'product_warehouse_properties');
828 $this->import_fields_array[$r] = array(
'pwp.fk_product' =>
"Product*",
829 'pwp.fk_entrepot' =>
"Warehouse*",
'pwp.seuil_stock_alerte' =>
"StockLimit",
830 'pwp.desiredstock' =>
"DesiredStock");
831 $this->import_regex_array[$r] = array(
832 'pwp.fk_product' =>
'rowid@'.MAIN_DB_PREFIX.
'product',
833 'pwp.fk_entrepot' =>
'rowid@'.MAIN_DB_PREFIX.
'entrepot',
835 $this->import_convertvalue_array[$r] = array(
836 'pwp.fk_product' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/class/product.class.php',
'class' =>
'Product',
'method' =>
'fetch',
'element' =>
'Product')
837 ,
'pwp.fk_entrepot' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/stock/class/entrepot.class.php',
'class' =>
'Entrepot',
'method' =>
'fetch',
'element' =>
'Entrepot')
839 $this->import_examplevalues_array[$r] = array(
'pwp.fk_product' =>
"ref:PRODUCT_REF or id:123456",
840 'pwp.fk_entrepot' =>
"ref:WAREHOUSE_REF or id:123456",
841 'pwp.seuil_stock_alerte' =>
"100",
842 'pwp.desiredstock' =>
"110"
844 $this->import_updatekeys_array[$r] = array(
'pwp.fk_product' =>
'Product',
'pwp.fk_entrepot' =>
'Warehouse');
850 $this->import_code[$r] = $this->rights_class.
'_supplierprices';
851 $this->import_label[$r] =
"SuppliersPricesOfProductsOrServices";
852 $this->import_icon[$r] = $this->picto;
853 $this->import_entities_array[$r] = array();
854 $this->import_tables_array[$r] = array(
'sp' => MAIN_DB_PREFIX.
'product_fournisseur_price',
'extra' => MAIN_DB_PREFIX.
'product_fournisseur_price_extrafields');
855 $this->import_tables_creator_array[$r] = array(
'sp' =>
'fk_user');
856 $this->import_fields_array[$r] = array(
857 'sp.fk_product' =>
"ProductOrService*",
858 'sp.fk_soc' =>
"Supplier*",
859 'sp.ref_fourn' =>
'SupplierRef*',
860 'sp.quantity' =>
"QtyMin*",
861 'sp.tva_tx' =>
'VATRate',
862 'sp.default_vat_code' =>
'VATCode',
863 'sp.delivery_time_days' =>
'NbDaysToDelivery',
864 'sp.supplier_reputation' =>
'SupplierReputation',
865 'sp.status' =>
'Status',
866 'sp.datec' =>
'DateCreation'
868 if (is_object(
$mysoc) && $usenpr) {
869 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'sp.recuperableonly' =>
'VATNPR'));
872 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'sp.localtax1_tx' =>
'LT1',
'sp.localtax1_type' =>
'LT1Type'));
875 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'sp.localtax2_tx' =>
'LT2',
'sp.localtax2_type' =>
'LT2Type'));
877 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
878 'sp.price' =>
"PriceQtyMinHT*",
879 'sp.unitprice' =>
'UnitPriceHT*',
880 'sp.remise_percent' =>
'DiscountQtyMin'
884 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
885 'sp.fk_multicurrency' =>
'CurrencyCodeId',
886 'sp.multicurrency_code' =>
'CurrencyCode',
887 'sp.multicurrency_tx' =>
'CurrencyRate',
888 'sp.multicurrency_unitprice' =>
'CurrencyUnitPrice',
889 'sp.multicurrency_price' =>
'CurrencyPrice',
894 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'sp.packaging' =>
'PackagingForThisProduct'));
898 $import_extrafield_sample = array();
899 $sql =
"SELECT name, label, fieldrequired FROM ".MAIN_DB_PREFIX.
"extrafields WHERE type <> 'separate' AND elementtype = 'product_fournisseur_price' AND entity IN (0, ".
$conf->entity.
")";
900 $resql = $this->db->query($sql);
902 while ($obj = $this->db->fetch_object($resql)) {
903 $fieldname =
'extra.'.$obj->name;
904 $fieldlabel = ucfirst($obj->label);
905 $this->import_fields_array[$r][$fieldname] = $fieldlabel.($obj->fieldrequired ?
'*' :
'');
906 $import_extrafield_sample[$fieldname] = $fieldlabel;
912 $this->import_fieldshidden_array[$r] = array(
914 'extra.fk_object' =>
'lastrowid-'.MAIN_DB_PREFIX.
'product_fournisseur_price'
917 $this->import_convertvalue_array[$r] = array(
918 'sp.fk_soc' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/societe/class/societe.class.php',
'class' =>
'Societe',
'method' =>
'fetch',
'element' =>
'ThirdParty'),
919 'sp.fk_product' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/class/product.class.php',
'class' =>
'Product',
'method' =>
'fetch',
'element' =>
'Product')
922 $this->import_regex_array[$r] = array(
923 'sp.datec' =>
'^[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9] [0-9][0-9]:[0-9][0-9]:[0-9][0-9]$'
926 $this->import_examplevalues_array[$r] = array(
927 'sp.fk_product' =>
"ref:PRODUCT_REF or id:123456",
928 'sp.fk_soc' =>
"My Supplier",
929 'sp.ref_fourn' =>
"XYZ-F123456",
930 'sp.quantity' =>
"5",
932 'sp.default_vat_code' =>
'',
934 'sp.unitprice' =>
'50',
935 'sp.remise_percent' =>
'0',
936 'sp.delivery_time_days' =>
'5',
937 'sp.supplier_reputation' =>
'FAVORITE / NOTTHGOOD / DONOTORDER',
941 if (is_object(
$mysoc) && $usenpr) {
942 $this->import_examplevalues_array[$r] = array_merge($this->import_examplevalues_array[$r], array(
'sp.recuperableonly' =>
''));
945 $this->import_examplevalues_array[$r] = array_merge($this->import_examplevalues_array[$r], array(
'sp.localtax1_tx' =>
'LT1',
'sp.localtax1_type' =>
'LT1Type'));
948 $this->import_examplevalues_array[$r] = array_merge($this->import_examplevalues_array[$r], array(
'sp.localtax2_tx' =>
'LT2',
'sp.localtax2_type' =>
'LT2Type'));
950 $this->import_examplevalues_array[$r] = array_merge($this->import_examplevalues_array[$r], array(
951 'sp.price' =>
"50.00",
952 'sp.unitprice' =>
'10',
954 'sp.remise_percent' =>
'20'
957 $this->import_examplevalues_array[$r] = array_merge($this->import_examplevalues_array[$r], array(
958 'sp.fk_multicurrency' =>
'eg: 2 = the rowid for code of multicurrency currency',
959 'sp.multicurrency_code' =>
'GBP',
960 'sp.multicurrency_tx' =>
'1.12345',
961 'sp.multicurrency_unitprice' =>
'',
963 'sp.multicurrency_price' =>
''
967 $this->import_examplevalues_array[$r] = array_merge($this->import_examplevalues_array[$r], array(
968 'sp.packaging' =>
'10',
972 $this->import_updatekeys_array[$r] = array(
'sp.fk_product' =>
'ProductOrService',
'sp.ref_fourn' =>
'SupplierRef',
'sp.fk_soc' =>
'Supplier',
'sp.quantity' =>
"QtyMin");
978 $this->import_code[$r] = $this->rights_class.
'_multiprice';
979 $this->import_label[$r] =
"ProductsOrServiceMultiPrice";
980 $this->import_icon[$r] = $this->picto;
981 $this->import_entities_array[$r] = array();
982 $this->import_tables_array[$r] = array(
'pr' => MAIN_DB_PREFIX.
'product_price',
'extra' => MAIN_DB_PREFIX.
'product_price_extrafields');
983 $this->import_tables_creator_array[$r] = array(
'pr' =>
'fk_user_author');
984 $this->import_fields_array[$r] = array(
'pr.fk_product' =>
"ProductOrService*",
985 'pr.price_base_type' =>
"PriceBase",
'pr.price_level' =>
"PriceLevel",
986 'pr.price' =>
"PriceLevelUnitPriceHT",
'pr.price_ttc' =>
"PriceLevelUnitPriceTTC",
987 'pr.price_min' =>
"MinPriceLevelUnitPriceHT",
'pr.price_min_ttc' =>
"MinPriceLevelUnitPriceTTC",
988 'pr.date_price' =>
'DateCreation*');
990 $this->import_fields_array[$r][
'pr.tva_tx'] =
'VATRate';
992 if (is_object(
$mysoc) && $usenpr) {
993 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'pr.recuperableonly' =>
'NPR'));
997 $import_extrafield_sample = array();
998 $sql =
"SELECT name, label, fieldrequired FROM ".MAIN_DB_PREFIX.
"extrafields WHERE type <> 'separate' AND elementtype = 'product_price' AND entity IN (0, ".
$conf->entity.
")";
999 $resql = $this->db->query($sql);
1001 while ($obj = $this->db->fetch_object($resql)) {
1002 $fieldname =
'extra.'.$obj->name;
1003 $fieldlabel = ucfirst($obj->label);
1004 $this->import_fields_array[$r][$fieldname] = $fieldlabel.($obj->fieldrequired ?
'*' :
'');
1005 $import_extrafield_sample[$fieldname] = $fieldlabel;
1009 $this->import_fieldshidden_array[$r] = array(
'extra.fk_object' =>
'lastrowid-'.MAIN_DB_PREFIX.
'product_price');
1011 $this->import_regex_array[$r] = array(
1012 'pr.datec' =>
'^[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]$',
1013 'pr.recuperableonly' =>
'^[0|1]$'
1016 $this->import_convertvalue_array[$r] = array(
1017 'pr.fk_product' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/class/product.class.php',
'class' =>
'Product',
'method' =>
'fetch',
'element' =>
'Product')
1019 $this->import_examplevalues_array[$r] = array(
'pr.fk_product' =>
"ref:PRODUCT_REF or id:123456",
1020 'pr.price_base_type' =>
"HT (for excl tax) or TTC (for inc tax)",
'pr.price_level' =>
"1",
1021 'pr.price' =>
"100",
'pr.price_ttc' =>
"110",
1022 'pr.price_min' =>
"100",
'pr.price_min_ttc' =>
"110",
1023 'pr.tva_tx' =>
'20',
1024 'pr.recuperableonly' =>
'0',
1025 'pr.date_price' =>
'2020-12-31');
1031 $this->import_code[$r] = $this->rights_class.
'_productcustomerprice';
1032 $this->import_label[$r] =
"ProductsPricePerCustomer";
1033 $this->import_icon[$r] = $this->picto;
1034 $this->import_entities_array[$r] = array();
1035 $this->import_tables_array[$r] = array(
'sp' => $this->db->prefix().
'product_customer_price',
'extra' => $this->db->prefix().
'product_customer_price_extrafields');
1036 $this->import_tables_creator_array[$r] = array(
'sp' =>
'fk_user');
1037 $this->import_fields_array[$r] = array(
1038 'sp.fk_product' =>
"Products*",
1039 'sp.fk_soc' =>
"Customer*",
1040 'sp.ref_customer' =>
"RefCustomer",
1041 'sp.date_begin' =>
"AppliedPricesFrom*",
1042 'sp.date_end' =>
"AppliedPricesTo",
1043 'sp.tva_tx' =>
"VATRate*",
1044 'sp.default_vat_code' =>
'VATCode',
1045 'sp.discount_percent' =>
'Discount',
1046 'sp.price_base_type' =>
"PriceBase*",
1047 'sp.price' =>
"SellingUnitPriceHT*",
1048 'sp.price_min' =>
"SellingUnitMinPriceHT",
1049 'sp.price_ttc' =>
"SellingUnitPriceTTC",
1050 'sp.price_min_ttc' =>
"SellingUnitMinPriceTTC",
1051 'sp.datec' =>
"DateCreation");
1053 $this->import_convertvalue_array[$r] = array(
1054 'sp.fk_soc' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/societe/class/societe.class.php',
'class' =>
'Societe',
'method' =>
'fetch',
'element' =>
'ThirdParty'),
1055 'sp.fk_product' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/class/product.class.php',
'class' =>
'Product',
'method' =>
'fetch',
'element' =>
'Product')
1058 $this->import_examplevalues_array[$r] = array_merge($import_sample, $import_extrafield_sample);
1059 $this->import_examplevalues_array[$r] = array(
1060 'sp.fk_product' =>
"ref:PRODUCT_REF or id:123456",
1061 'sp.fk_soc' =>
"My Supplier",
1062 'sp.ref_customer' =>
"XYZ-F123456",
1063 'sp.date_begin' =>
"2025-06-30",
1064 'sp.date_end' =>
"2027-06-30",
1065 'sp.tva_tx' =>
'20',
1066 'sp.default_vat_code' =>
'5',
1067 'sp.discount_percent' =>
'30',
1068 'sp.price_base_type'=>
'HT (for excl tax) or TTC (for inc tax)',
1069 'sp.price' =>
"100",
1070 'sp.price_min' =>
"80",
1071 'sp.price_ttc' =>
"120",
1072 'sp.price_min_ttc' =>
"96",
1073 'sp.datec' =>
"2025-09-30"
1080 $this->import_code[$r] = $this->rights_class.
'_languages';
1081 $this->import_label[$r] =
"ProductsOrServicesTranslations";
1082 $this->import_icon[$r] = $this->picto;
1083 $this->import_entities_array[$r] = array();
1084 $this->import_tables_array[$r] = array(
'l' => MAIN_DB_PREFIX.
'product_lang');
1086 $this->import_fields_array[$r] = array(
'l.fk_product' =>
'ProductOrService*',
'l.lang' =>
'Language*',
'l.label' =>
'TranslatedLabel',
'l.description' =>
'TranslatedDescription');
1088 $this->import_convertvalue_array[$r] = array(
1089 'l.fk_product' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/class/product.class.php',
'class' =>
'Product',
'method' =>
'fetch',
'element' =>
'Product')
1091 $this->import_examplevalues_array[$r] = array(
'l.fk_product' =>
'ref:PRODUCT_REF or id:123456',
'l.lang' =>
'en_US',
'l.label' =>
'Label in en_US',
'l.description' =>
'Desc in en_US');
1092 $this->import_updatekeys_array[$r] = array(
'l.fk_product' =>
'ProductOrService',
'l.lang' =>
'Language');
1098 $this->import_code[$r] = $this->rights_class .
'_' . $r;
1099 $this->import_label[$r] =
"AssociatedProducts";
1100 $this->import_icon[$r] = $this->picto;
1101 $this->import_entities_array[$r] = array();
1102 $this->import_tables_array[$r] = array(
'pa' => MAIN_DB_PREFIX .
'product_association');
1103 $this->import_fields_array[$r] = array(
'pa.fk_product_pere' =>
'ParentProducts',
'pa.fk_product_fils' =>
'ComposedProduct',
'pa.qty' =>
'Qty',
'pa.incdec' =>
'ComposedProductIncDecStock',
'pa.rang' =>
'rang');
1105 $this->import_convertvalue_array[$r] = array(
1106 'pa.fk_product_pere' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/class/product.class.php',
'class' =>
'Product',
'method' =>
'fetch',
'element' =>
'Product'),
1107 'pa.fk_product_fils' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/class/product.class.php',
'class' =>
'Product',
'method' =>
'fetch',
'element' =>
'Product')
1109 $this->import_examplevalues_array[$r] = array(
1110 'pa.fk_product_pere' =>
"ref:PREF123456",
1111 'pa.fk_product_fils' =>
"ref:PREF123456",
1115 $this->import_regex_array[$r] = array(
'pa.fk_product_pere' =>
'rowid@'.MAIN_DB_PREFIX.
'product',
'pa.fk_product_fils' =>
'rowid@'.MAIN_DB_PREFIX.
'product');
1116 $this->import_updatekeys_array[$r] = array(
'pa.fk_product_pere' =>
'ref parent',
'pa.fk_product_fils' =>
"ref enfant");