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(
'p.rowid' =>
"Id",
'p.ref' =>
"Ref",
'p.label' =>
"Label",
363 'pr.price_base_type' =>
"PriceBase",
'pr.price_level' =>
"PriceLevel",
364 'pr.price' =>
"PriceLevelUnitPriceHT",
'pr.price_ttc' =>
"PriceLevelUnitPriceTTC",
365 'pr.price_min' =>
"MinPriceLevelUnitPriceHT",
'pr.price_min_ttc' =>
"MinPriceLevelUnitPriceTTC",
366 'pr.tva_tx' =>
'PriceLevelVATRate',
367 'pr.date_price' =>
'DateCreation');
368 if (is_object(
$mysoc) && $usenpr) {
369 $this->export_fields_array[$r][
'pr.recuperableonly'] =
'NPR';
377 $this->export_entities_array[$r] = array(
'p.rowid' =>
"product",
'p.ref' =>
"product",
'p.label' =>
"Label",
378 'pr.price_base_type' =>
"product",
'pr.price_level' =>
"product",
'pr.price' =>
"product",
379 'pr.price_ttc' =>
"product",
380 'pr.price_min' =>
"product",
'pr.price_min_ttc' =>
"product",
381 'pr.tva_tx' =>
'product',
382 'pr.recuperableonly' =>
'product',
383 'pr.date_price' =>
"product");
384 $this->export_sql_start[$r] =
'SELECT DISTINCT ';
385 $this->export_sql_end[$r] =
' FROM '.MAIN_DB_PREFIX.
'product as p';
386 $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;
387 $this->export_sql_end[$r] .=
' WHERE p.entity IN ('.getEntity(
'product').
')';
388 $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').
'))';
389 $this->export_sql_end[$r] .=
' ORDER BY p.ref, pr.price_level';
395 $this->export_code[$r] = $this->rights_class.
'_'.$r;
396 $this->export_label[$r] =
"ProductsPricePerCustomer";
397 $this->export_permission[$r] = array(array(
"produit",
"export"));
398 $this->export_fields_array[$r] = array(
'p.rowid' =>
"Id",
'p.ref' =>
"Ref",
'p.label' =>
"Label",
399 's.nom' =>
'ThirdParty',
400 's.code_client' =>
'CodeClient',
401 'pr.date_begin' =>
"AppliedPricesFrom",
402 'pr.date_end' =>
"AppliedPricesTo",
403 'pr.price_base_type' =>
"PriceBase",
404 'pr.price' =>
"PriceUnitPriceHT",
'pr.price_ttc' =>
"PriceUnitPriceTTC",
405 'pr.price_min' =>
"MinPriceUnitPriceHT",
'pr.price_min_ttc' =>
"MinPriceUnitPriceTTC",
406 'pr.tva_tx' =>
'PriceVATRate',
407 'pr.default_vat_code' =>
'PriceVATCode',
408 'pr.discount_percent' =>
'Discount',
409 'pr.datec' =>
'DateCreation');
410 if (is_object(
$mysoc) && $usenpr) {
411 $this->export_fields_array[$r][
'pr.recuperableonly'] =
'NPR';
413 $this->export_entities_array[$r] = array(
'p.rowid' =>
"product",
'p.ref' =>
"product",
'p.label' =>
"Label",
414 's.nom' =>
'company',
415 's.code_client' =>
'company',
416 'pr.date_begin' =>
"product",
417 'pr.date_end' =>
"product",
418 'pr.price_base_type' =>
"product",
'pr.price' =>
"product",
419 'pr.price_ttc' =>
"product",
420 'pr.price_min' =>
"product",
'pr.price_min_ttc' =>
"product",
421 'pr.tva_tx' =>
'product',
422 'pr.default_vat_code' =>
'product',
423 'pr.discount_percent' =>
'product',
424 'pr.recuperableonly' =>
'product',
425 'pr.datec' =>
"product");
426 $this->export_sql_start[$r] =
'SELECT DISTINCT ';
427 $this->export_sql_end[$r] =
' FROM '.MAIN_DB_PREFIX.
'product as p';
428 $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;
429 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'societe as s ON pr.fk_soc = s.rowid';
430 $this->export_sql_end[$r] .=
' WHERE p.entity IN ('.getEntity(
'product').
')';
436 $this->export_code[$r] = $this->rights_class.
'_'.$r;
437 $this->export_label[$r] =
"AssociatedProducts";
438 $this->export_permission[$r] = array(array(
"produit",
"export"));
439 $this->export_fields_array[$r] = array(
440 'p.rowid' =>
"Id",
'p.ref' =>
"Ref",
'p.label' =>
"Label",
'p.description' =>
"Description",
'p.url' =>
"PublicUrl",
441 $alias_product_perentity .
'.accountancy_code_sell' =>
"ProductAccountancySellCode", $alias_product_perentity .
'.accountancy_code_sell_intra' =>
"ProductAccountancySellIntraCode",
442 $alias_product_perentity .
'.accountancy_code_sell_export' =>
"ProductAccountancySellExportCode", $alias_product_perentity .
'.accountancy_code_buy' =>
"ProductAccountancyBuyCode",
443 $alias_product_perentity .
'.accountancy_code_buy_intra' =>
"ProductAccountancyBuyIntraCode", $alias_product_perentity .
'.accountancy_code_buy_export' =>
"ProductAccountancyBuyExportCode",
444 'p.note' =>
"NotePrivate",
'p.note_public' =>
'NotePublic',
445 'p.weight' =>
"Weight",
'p.length' =>
"Length",
'p.surface' =>
"Surface",
'p.volume' =>
"Volume",
'p.customcode' =>
'CustomsCode',
446 'p.price_base_type' =>
"PriceBase",
'p.price' =>
"UnitPriceHT",
'p.price_ttc' =>
"UnitPriceTTC",
'p.tva_tx' =>
'VATRate',
'p.tosell' =>
"OnSell",
447 'p.tobuy' =>
"OnBuy",
'p.datec' =>
'DateCreation',
'p.tms' =>
'DateModification'
450 $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'));
453 $this->export_fields_array[$r] = array_merge($this->export_fields_array[$r], array(
'p.barcode' =>
'BarCode'));
455 $this->export_fields_array[$r] = array_merge($this->export_fields_array[$r], array(
'pa.qty' =>
'Qty',
'pa.incdec' =>
'ComposedProductIncDecStock'));
456 $this->export_TypeFields_array[$r] = array(
457 'p.ref' =>
"Text",
'p.label' =>
"Text",
'p.description' =>
"Text",
'p.url' =>
"Text",
458 $alias_product_perentity .
'.accountancy_code_sell' =>
"Text", $alias_product_perentity .
'.accountancy_code_sell_intra' =>
"Text", $alias_product_perentity .
'.accountancy_code_sell_export' =>
"Text",
459 $alias_product_perentity .
'.accountancy_code_buy' =>
"Text", $alias_product_perentity .
'.accountancy_code_buy_intra' =>
"Text", $alias_product_perentity .
'.accountancy_code_buy_export' =>
"Text",
460 'p.note' =>
"Text",
'p.note_public' =>
"Text",
461 'p.weight' =>
"Numeric",
'p.length' =>
"Numeric",
'p.surface' =>
"Numeric",
'p.volume' =>
"Numeric",
'p.customcode' =>
'Text',
462 'p.price_base_type' =>
"Text",
'p.price' =>
"Numeric",
'p.price_ttc' =>
"Numeric",
'p.tva_tx' =>
'Numeric',
'p.tosell' =>
"Boolean",
'p.tobuy' =>
"Boolean",
463 'p.datec' =>
'Date',
'p.tms' =>
'Date'
466 $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'));
469 $this->export_TypeFields_array[$r] = array_merge($this->export_TypeFields_array[$r], array(
'p.barcode' =>
'Text'));
471 $this->export_TypeFields_array[$r] = array_merge($this->export_TypeFields_array[$r], array(
'pa.qty' =>
'Numeric'));
472 $this->export_entities_array[$r] = array(
473 'p.rowid' =>
"virtualproduct",
'p.ref' =>
"virtualproduct",
'p.label' =>
"virtualproduct",
'p.description' =>
"virtualproduct",
'p.url' =>
"virtualproduct",
474 $alias_product_perentity .
'.accountancy_code_sell' =>
'virtualproduct', $alias_product_perentity .
'.accountancy_code_sell_intra' =>
'virtualproduct', $alias_product_perentity .
'.accountancy_code_sell_export' =>
'virtualproduct',
475 $alias_product_perentity .
'.accountancy_code_buy' =>
'virtualproduct', $alias_product_perentity .
'.accountancy_code_buy_intra' =>
'virtualproduct', $alias_product_perentity .
'.accountancy_code_buy_export' =>
'virtualproduct',
476 'p.note' =>
"virtualproduct",
'p.length' =>
"virtualproduct",
477 'p.surface' =>
"virtualproduct",
'p.volume' =>
"virtualproduct",
'p.weight' =>
"virtualproduct",
'p.customcode' =>
'virtualproduct',
478 'p.price_base_type' =>
"virtualproduct",
'p.price' =>
"virtualproduct",
'p.price_ttc' =>
"virtualproduct",
'p.tva_tx' =>
"virtualproduct",
479 'p.tosell' =>
"virtualproduct",
'p.tobuy' =>
"virtualproduct",
'p.datec' =>
"virtualproduct",
'p.tms' =>
"virtualproduct"
482 $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'));
485 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
'p.barcode' =>
'virtualproduct'));
487 $this->export_entities_array[$r] = array_merge($this->export_entities_array[$r], array(
'pa.qty' =>
"subproduct",
'pa.incdec' =>
'subproduct'));
488 $keyforselect =
'product';
489 $keyforelement =
'product';
490 $keyforaliasextra =
'extra';
491 include DOL_DOCUMENT_ROOT.
'/core/extrafieldsinexport.inc.php';
492 $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"));
493 $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"));
494 $this->export_sql_start[$r] =
'SELECT DISTINCT ';
495 $this->export_sql_end[$r] =
' FROM '.MAIN_DB_PREFIX.
'product as p';
497 $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);
499 $this->export_sql_end[$r] .=
' LEFT JOIN '.MAIN_DB_PREFIX.
'product_extrafields as extra ON p.rowid = extra.fk_object,';
500 $this->export_sql_end[$r] .=
' '.MAIN_DB_PREFIX.
'product_association as pa, '.MAIN_DB_PREFIX.
'product as p2';
501 $this->export_sql_end[$r] .=
' WHERE p.entity IN ('.getEntity(
'product').
')';
502 $this->export_sql_end[$r] .=
' AND p.rowid = pa.fk_product_pere AND p2.rowid = pa.fk_product_fils';
512 $this->import_code[$r] = $this->rights_class.
'_'.$r;
513 $this->import_label[$r] =
"Products";
514 $this->import_icon[$r] = $this->picto;
515 $this->import_entities_array[$r] = array();
516 $this->import_tables_array[$r] = array(
'p' => MAIN_DB_PREFIX.
'product',
'extra' => MAIN_DB_PREFIX.
'product_extrafields');
517 $this->import_tables_creator_array[$r] = array(
'p' =>
'fk_user_author');
518 $this->import_fields_array[$r] = array(
520 'p.label' =>
"Label*",
521 'p.fk_product_type' =>
"Type*",
522 'p.tosell' =>
"OnSell*",
523 'p.tobuy' =>
"OnBuy*",
524 'p.description' =>
"Description",
525 'p.url' =>
"PublicUrl",
526 'p.customcode' =>
'CustomsCode',
527 'p.fk_country' =>
'CountryCode',
528 'p.accountancy_code_sell' =>
"ProductAccountancySellCode",
529 'p.accountancy_code_sell_intra' =>
"ProductAccountancySellIntraCode",
530 'p.accountancy_code_sell_export' =>
"ProductAccountancySellExportCode",
531 'p.accountancy_code_buy' =>
"ProductAccountancyBuyCode",
532 'p.accountancy_code_buy_intra' =>
"ProductAccountancyBuyIntraCode",
533 'p.accountancy_code_buy_export' =>
"ProductAccountancyBuyExportCode",
534 'p.note_public' =>
"NotePublic",
535 'p.note' =>
"NotePrivate",
536 'p.weight' =>
"Weight",
537 'p.weight_units' =>
"WeightUnits",
538 'p.length' =>
"Length",
539 'p.length_units' =>
"LengthUnits",
540 'p.width' =>
"Width",
541 'p.width_units' =>
"WidthUnits",
542 'p.height' =>
"Height",
543 'p.height_units' =>
"HeightUnits",
544 'p.surface' =>
"Surface",
545 'p.surface_units' =>
"SurfaceUnits",
546 'p.volume' =>
"Volume",
547 'p.volume_units' =>
"VolumeUnits",
548 'p.duration' =>
"Duration",
549 'p.finished' =>
'Nature',
550 'p.price' =>
"SellingPriceHT",
551 'p.price_min' =>
"MinPrice",
552 'p.price_ttc' =>
"SellingPriceTTC",
553 'p.price_min_ttc' =>
"SellingMinPriceTTC",
554 'p.price_base_type' =>
"PriceBaseType",
555 'p.tva_tx' =>
'VATRate',
556 'p.default_vat_code' =>
'VATCode',
557 'p.datec' =>
'DateCreation',
558 'p.cost_price' =>
"CostPrice"
561 $this->import_convertvalue_array[$r] = array(
562 'p.weight_units' => array(
563 'rule' =>
'fetchscalefromcodeunits',
564 'classfile' =>
'/core/class/cunits.class.php',
568 'dict' =>
'DictionaryMeasuringUnits'
570 'p.length_units' => array(
571 'rule' =>
'fetchscalefromcodeunits',
572 'classfile' =>
'/core/class/cunits.class.php',
576 'dict' =>
'DictionaryMeasuringUnits'
578 'p.width_units' => array(
579 'rule' =>
'fetchscalefromcodeunits',
580 'classfile' =>
'/core/class/cunits.class.php',
584 'dict' =>
'DictionaryMeasuringUnits'
586 'p.height_units' => array(
587 'rule' =>
'fetchscalefromcodeunits',
588 'classfile' =>
'/core/class/cunits.class.php',
592 'dict' =>
'DictionaryMeasuringUnits'
594 'p.surface_units' => array(
595 'rule' =>
'fetchscalefromcodeunits',
596 'classfile' =>
'/core/class/cunits.class.php',
599 'units' =>
'surface',
600 'dict' =>
'DictionaryMeasuringUnits'
602 'p.volume_units' => array(
603 'rule' =>
'fetchscalefromcodeunits',
604 'classfile' =>
'/core/class/cunits.class.php',
608 'dict' =>
'DictionaryMeasuringUnits'
610 'p.fk_country' => array(
611 'rule' =>
'fetchidfromcodeid',
612 'classfile' =>
'/core/class/ccountry.class.php',
613 'class' =>
'Ccountry',
615 'dict' =>
'DictionaryCountry'
617 'p.finished' => array(
618 'rule' =>
'fetchidfromcodeorlabel',
619 'classfile' =>
'/core/class/cproductnature.class.php',
620 'class' =>
'CProductNature',
622 'dict' =>
'DictionaryProductNature'
624 'p.accountancy_code_sell' => array(
'rule' =>
'accountingaccount'),
625 'p.accountancy_code_sell_intra' => array(
'rule' =>
'accountingaccount'),
626 'p.accountancy_code_sell_export' => array(
'rule' =>
'accountingaccount'),
627 'p.accountancy_code_buy' => array(
'rule' =>
'accountingaccount'),
628 'p.accountancy_code_buy_intra' => array(
'rule' =>
'accountingaccount'),
629 'p.accountancy_code_buy_export' => array(
'rule' =>
'accountingaccount'),
632 $this->import_regex_array[$r] = array(
634 'p.price_base_type' =>
'\AHT\z|\ATTC\z',
635 'p.tosell' =>
'^[0|1]$',
636 'p.tobuy' =>
'^[0|1]$',
637 'p.fk_product_type' =>
'^[0|1]$',
638 'p.datec' =>
'^[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]$',
639 'p.recuperableonly' =>
'^[0|1]$',
644 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
645 'p.fk_default_warehouse' =>
'DefaultWarehouse',
646 'p.tobatch' =>
'ManageLotSerial',
647 'p.sell_or_eat_by_mandatory' =>
'SellOrEatByMandatory',
648 'p.seuil_stock_alerte' =>
'StockLimit',
649 'p.pmp' =>
'PMPValue',
650 'p.desiredstock' =>
'DesiredStock'
653 $this->import_regex_array[$r] = array_merge($this->import_regex_array[$r], array(
654 'p.tobatch' =>
'^[0|1|2]$',
655 'p.sell_or_eat_by_mandatory' =>
'^[0-3]$'
658 $this->import_convertvalue_array[$r] = array_merge($this->import_convertvalue_array[$r], array(
659 'p.fk_default_warehouse' => array(
660 'rule' =>
'fetchidfromref',
661 'classfile' =>
'/product/stock/class/entrepot.class.php',
662 'class' =>
'Entrepot',
664 'element' =>
'Warehouse'
670 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
671 'p.packaging' =>
'PackagingForThisProductSell',
676 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'p.cost_price' =>
'CostPrice'));
678 if (is_object(
$mysoc) && $usenpr) {
679 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'p.recuperableonly' =>
'NPR'));
682 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'p.localtax1_tx' =>
'LT1',
'p.localtax1_type' =>
'LT1Type'));
685 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'p.localtax2_tx' =>
'LT2',
'p.localtax2_type' =>
'LT2Type'));
688 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'p.barcode' =>
'BarCode'));
691 $this->import_fields_array[$r][
'p.fk_unit'] =
'Unit';
695 $import_extrafield_sample = array();
696 $sql =
"SELECT name, label, fieldrequired FROM ".MAIN_DB_PREFIX.
"extrafields WHERE type <> 'separate' AND elementtype = 'product' AND entity IN (0, ".$conf->entity.
")";
697 $resql = $this->db->query($sql);
699 while ($obj = $this->db->fetch_object($resql)) {
700 $fieldname =
'extra.'.$obj->name;
701 $fieldlabel = ucfirst($obj->label);
702 $this->import_fields_array[$r][$fieldname] = $fieldlabel.($obj->fieldrequired ?
'*' :
'');
703 $import_extrafield_sample[$fieldname] = $fieldlabel;
707 $this->import_fieldshidden_array[$r] = array(
'extra.fk_object' =>
'lastrowid-'.MAIN_DB_PREFIX.
'product');
710 $import_sample = array(
711 'p.ref' =>
"ref:PREF123456",
713 'p.label' =>
"Product name in default language",
714 'p.description' =>
"Product description in default language",
715 'p.note_public' =>
"a public note (free text)",
716 'p.note' =>
"a private note (free text)",
717 'p.customcode' =>
'customs code',
718 'p.fk_country' =>
'FR',
720 'p.price_min' =>
"100",
721 'p.price_ttc' =>
"110",
722 'p.price_min_ttc' =>
"110",
723 'p.price_base_type' =>
"HT (show/use price excl. tax) / TTC (show/use price incl. tax)",
725 'p.default_vat_code' =>
'',
726 'p.tosell' =>
"0 (not for sale to customer, eg. raw material) / 1 (for sale)",
727 'p.tobuy' =>
"0 (not for purchase from supplier, eg. virtual product) / 1 (for purchase)",
728 'p.fk_product_type' =>
"0 (product) / 1 (service)",
729 'p.duration' =>
"eg. 365d/12m/1y",
730 'p.url' =>
'link to product (no https)',
731 'p.accountancy_code_sell' =>
"",
732 'p.accountancy_code_sell_intra' =>
"",
733 'p.accountancy_code_sell_export' =>
"",
734 'p.accountancy_code_buy' =>
"",
735 'p.accountancy_code_buy_intra' =>
"",
736 'p.accountancy_code_buy_export' =>
"",
738 'p.weight_units' =>
'kg',
740 'p.length_units' =>
'm',
742 'p.width_units' =>
'm',
744 'p.height_units' =>
'm',
746 'p.surface_units' =>
'm2',
748 'p.volume_units' =>
'm3',
749 'p.finished' =>
'0 (raw material) / 1 (finished goods), matches field "code" in dictionary table "'.MAIN_DB_PREFIX.
'c_product_nature"'
753 $import_sample = array_merge($import_sample, array(
754 'p.tobatch' =>
"0 (don't use) / 1 (use batch) / 2 (use serial number)",
755 'p.sell_or_eat_by_mandatory' =>
"0 (none) / 1 (sell-by) / 2 (eat-by) / 3 (sell+eat)",
756 'p.seuil_stock_alerte' =>
'',
758 'p.desiredstock' =>
''
762 $import_sample = array_merge($import_sample, array(
'p.cost_price' =>
'90'));
764 if (is_object(
$mysoc) && $usenpr) {
765 $import_sample = array_merge($import_sample, array(
'p.recuperableonly' =>
'0'));
768 $import_sample = array_merge($import_sample, array(
'p.localtax1_tx' =>
'',
'p.localtax1_type' =>
''));
771 $import_sample = array_merge($import_sample, array(
'p.localtax2_tx' =>
'',
'p.localtax2_type' =>
''));
774 $import_sample = array_merge($import_sample, array(
'p.barcode' =>
''));
777 $import_sample = array_merge(
780 '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"'
784 if (!is_array($this->import_convertvalue_array[$r])) {
785 $this->import_convertvalue_array[$r] = array();
787 $this->import_convertvalue_array[$r] = array_merge($this->import_convertvalue_array[$r], array(
788 'p.fk_unit' => array(
789 'rule' =>
'fetchidfromcodeorlabel',
790 'classfile' =>
'/core/class/cunits.class.php',
793 'dict' =>
'DictionaryUnits'
799 $import_sample = array_merge($import_sample, array(
800 'p.packaging' =>
"2",
804 $this->import_examplevalues_array[$r] = array_merge($import_sample, $import_extrafield_sample);
805 $this->import_updatekeys_array[$r] = array(
'p.ref' =>
'Ref');
807 $this->import_updatekeys_array[$r] = array_merge($this->import_updatekeys_array[$r], array(
'p.barcode' =>
'BarCode'));
813 $this->import_code[$r] = $this->rights_class.
'_stock_by_warehouse';
814 $this->import_label[$r] =
"ProductStockWarehouse";
815 $this->import_icon[$r] = $this->picto;
816 $this->import_entities_array[$r] = array();
817 $this->import_tables_array[$r] = array(
'pwp' => MAIN_DB_PREFIX.
'product_warehouse_properties');
818 $this->import_fields_array[$r] = array(
'pwp.fk_product' =>
"Product*",
819 'pwp.fk_entrepot' =>
"Warehouse*",
'pwp.seuil_stock_alerte' =>
"StockLimit",
820 'pwp.desiredstock' =>
"DesiredStock");
821 $this->import_regex_array[$r] = array(
822 'pwp.fk_product' =>
'rowid@'.MAIN_DB_PREFIX.
'product',
823 'pwp.fk_entrepot' =>
'rowid@'.MAIN_DB_PREFIX.
'entrepot',
825 $this->import_convertvalue_array[$r] = array(
826 'pwp.fk_product' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/class/product.class.php',
'class' =>
'Product',
'method' =>
'fetch',
'element' =>
'Product')
827 ,
'pwp.fk_entrepot' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/stock/class/entrepot.class.php',
'class' =>
'Entrepot',
'method' =>
'fetch',
'element' =>
'Entrepot')
829 $this->import_examplevalues_array[$r] = array(
'pwp.fk_product' =>
"ref:PRODUCT_REF or id:123456",
830 'pwp.fk_entrepot' =>
"ref:WAREHOUSE_REF or id:123456",
831 'pwp.seuil_stock_alerte' =>
"100",
832 'pwp.desiredstock' =>
"110"
834 $this->import_updatekeys_array[$r] = array(
'pwp.fk_product' =>
'Product',
'pwp.fk_entrepot' =>
'Warehouse');
840 $this->import_code[$r] = $this->rights_class.
'_supplierprices';
841 $this->import_label[$r] =
"SuppliersPricesOfProductsOrServices";
842 $this->import_icon[$r] = $this->picto;
843 $this->import_entities_array[$r] = array();
844 $this->import_tables_array[$r] = array(
'sp' => MAIN_DB_PREFIX.
'product_fournisseur_price',
'extra' => MAIN_DB_PREFIX.
'product_fournisseur_price_extrafields');
845 $this->import_tables_creator_array[$r] = array(
'sp' =>
'fk_user');
846 $this->import_fields_array[$r] = array(
847 'sp.fk_product' =>
"ProductOrService*",
848 'sp.fk_soc' =>
"Supplier*",
849 'sp.ref_fourn' =>
'SupplierRef*',
850 'sp.quantity' =>
"QtyMin*",
851 'sp.tva_tx' =>
'VATRate',
852 'sp.default_vat_code' =>
'VATCode',
853 'sp.delivery_time_days' =>
'NbDaysToDelivery',
854 'sp.supplier_reputation' =>
'SupplierReputation',
855 'sp.status' =>
'Status',
856 'sp.datec' =>
'DateCreation'
858 if (is_object(
$mysoc) && $usenpr) {
859 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'sp.recuperableonly' =>
'VATNPR'));
862 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'sp.localtax1_tx' =>
'LT1',
'sp.localtax1_type' =>
'LT1Type'));
865 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'sp.localtax2_tx' =>
'LT2',
'sp.localtax2_type' =>
'LT2Type'));
867 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
868 'sp.price' =>
"PriceQtyMinHT*",
869 'sp.unitprice' =>
'UnitPriceHT*',
870 'sp.remise_percent' =>
'DiscountQtyMin'
874 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
875 'sp.fk_multicurrency' =>
'CurrencyCodeId',
876 'sp.multicurrency_code' =>
'CurrencyCode',
877 'sp.multicurrency_tx' =>
'CurrencyRate',
878 'sp.multicurrency_unitprice' =>
'CurrencyUnitPrice',
879 'sp.multicurrency_price' =>
'CurrencyPrice',
884 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'sp.packaging' =>
'PackagingForThisProduct'));
888 $import_extrafield_sample = array();
889 $sql =
"SELECT name, label, fieldrequired FROM ".MAIN_DB_PREFIX.
"extrafields WHERE type <> 'separate' AND elementtype = 'product_fournisseur_price' AND entity IN (0, ".$conf->entity.
")";
890 $resql = $this->db->query($sql);
892 while ($obj = $this->db->fetch_object($resql)) {
893 $fieldname =
'extra.'.$obj->name;
894 $fieldlabel = ucfirst($obj->label);
895 $this->import_fields_array[$r][$fieldname] = $fieldlabel.($obj->fieldrequired ?
'*' :
'');
896 $import_extrafield_sample[$fieldname] = $fieldlabel;
902 $this->import_fieldshidden_array[$r] = array(
904 'extra.fk_object' =>
'lastrowid-'.MAIN_DB_PREFIX.
'product_fournisseur_price'
907 $this->import_convertvalue_array[$r] = array(
908 'sp.fk_soc' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/societe/class/societe.class.php',
'class' =>
'Societe',
'method' =>
'fetch',
'element' =>
'ThirdParty'),
909 'sp.fk_product' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/class/product.class.php',
'class' =>
'Product',
'method' =>
'fetch',
'element' =>
'Product')
912 $this->import_regex_array[$r] = array(
913 '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]$'
916 $this->import_examplevalues_array[$r] = array(
917 'sp.fk_product' =>
"ref:PRODUCT_REF or id:123456",
918 'sp.fk_soc' =>
"My Supplier",
919 'sp.ref_fourn' =>
"XYZ-F123456",
920 'sp.quantity' =>
"5",
922 'sp.default_vat_code' =>
'',
924 'sp.unitprice' =>
'50',
925 'sp.remise_percent' =>
'0',
926 'sp.delivery_time_days' =>
'5',
927 'sp.supplier_reputation' =>
'FAVORITE / NOTTHGOOD / DONOTORDER',
931 if (is_object(
$mysoc) && $usenpr) {
932 $this->import_examplevalues_array[$r] = array_merge($this->import_examplevalues_array[$r], array(
'sp.recuperableonly' =>
''));
935 $this->import_examplevalues_array[$r] = array_merge($this->import_examplevalues_array[$r], array(
'sp.localtax1_tx' =>
'LT1',
'sp.localtax1_type' =>
'LT1Type'));
938 $this->import_examplevalues_array[$r] = array_merge($this->import_examplevalues_array[$r], array(
'sp.localtax2_tx' =>
'LT2',
'sp.localtax2_type' =>
'LT2Type'));
940 $this->import_examplevalues_array[$r] = array_merge($this->import_examplevalues_array[$r], array(
941 'sp.price' =>
"50.00",
942 'sp.unitprice' =>
'10',
944 'sp.remise_percent' =>
'20'
947 $this->import_examplevalues_array[$r] = array_merge($this->import_examplevalues_array[$r], array(
948 'sp.fk_multicurrency' =>
'eg: 2 = the rowid for code of multicurrency currency',
949 'sp.multicurrency_code' =>
'GBP',
950 'sp.multicurrency_tx' =>
'1.12345',
951 'sp.multicurrency_unitprice' =>
'',
953 'sp.multicurrency_price' =>
''
957 $this->import_examplevalues_array[$r] = array_merge($this->import_examplevalues_array[$r], array(
958 'sp.packaging' =>
'10',
962 $this->import_updatekeys_array[$r] = array(
'sp.fk_product' =>
'ProductOrService',
'sp.ref_fourn' =>
'SupplierRef',
'sp.fk_soc' =>
'Supplier',
'sp.quantity' =>
"QtyMin");
968 $this->import_code[$r] = $this->rights_class.
'_multiprice';
969 $this->import_label[$r] =
"ProductsOrServiceMultiPrice";
970 $this->import_icon[$r] = $this->picto;
971 $this->import_entities_array[$r] = array();
972 $this->import_tables_array[$r] = array(
'pr' => MAIN_DB_PREFIX.
'product_price',
'extra' => MAIN_DB_PREFIX.
'product_price_extrafields');
973 $this->import_tables_creator_array[$r] = array(
'pr' =>
'fk_user_author');
974 $this->import_fields_array[$r] = array(
'pr.fk_product' =>
"ProductOrService*",
975 'pr.price_base_type' =>
"PriceBase",
'pr.price_level' =>
"PriceLevel",
976 'pr.price' =>
"PriceLevelUnitPriceHT",
'pr.price_ttc' =>
"PriceLevelUnitPriceTTC",
977 'pr.price_min' =>
"MinPriceLevelUnitPriceHT",
'pr.price_min_ttc' =>
"MinPriceLevelUnitPriceTTC",
978 'pr.date_price' =>
'DateCreation*');
980 $this->import_fields_array[$r][
'pr.tva_tx'] =
'VATRate';
982 if (is_object(
$mysoc) && $usenpr) {
983 $this->import_fields_array[$r] = array_merge($this->import_fields_array[$r], array(
'pr.recuperableonly' =>
'NPR'));
987 $import_extrafield_sample = array();
988 $sql =
"SELECT name, label, fieldrequired FROM ".MAIN_DB_PREFIX.
"extrafields WHERE type <> 'separate' AND elementtype = 'product_price' AND entity IN (0, ".$conf->entity.
")";
989 $resql = $this->db->query($sql);
991 while ($obj = $this->db->fetch_object($resql)) {
992 $fieldname =
'extra.'.$obj->name;
993 $fieldlabel = ucfirst($obj->label);
994 $this->import_fields_array[$r][$fieldname] = $fieldlabel.($obj->fieldrequired ?
'*' :
'');
995 $import_extrafield_sample[$fieldname] = $fieldlabel;
999 $this->import_fieldshidden_array[$r] = array(
'extra.fk_object' =>
'lastrowid-'.MAIN_DB_PREFIX.
'product_price');
1001 $this->import_regex_array[$r] = array(
1002 'pr.datec' =>
'^[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]$',
1003 'pr.recuperableonly' =>
'^[0|1]$'
1006 $this->import_convertvalue_array[$r] = array(
1007 'pr.fk_product' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/class/product.class.php',
'class' =>
'Product',
'method' =>
'fetch',
'element' =>
'Product')
1009 $this->import_examplevalues_array[$r] = array(
'pr.fk_product' =>
"ref:PRODUCT_REF or id:123456",
1010 'pr.price_base_type' =>
"HT (for excl tax) or TTC (for inc tax)",
'pr.price_level' =>
"1",
1011 'pr.price' =>
"100",
'pr.price_ttc' =>
"110",
1012 'pr.price_min' =>
"100",
'pr.price_min_ttc' =>
"110",
1013 'pr.tva_tx' =>
'20',
1014 'pr.recuperableonly' =>
'0',
1015 'pr.date_price' =>
'2020-12-31');
1021 $this->import_code[$r] = $this->rights_class.
'_productcustomerprice';
1022 $this->import_label[$r] =
"ProductsPricePerCustomer";
1023 $this->import_icon[$r] = $this->picto;
1024 $this->import_entities_array[$r] = array();
1025 $this->import_tables_array[$r] = array(
'sp' => $this->db->prefix().
'product_customer_price',
'extra' => $this->db->prefix().
'product_customer_price_extrafields');
1026 $this->import_tables_creator_array[$r] = array(
'sp' =>
'fk_user');
1027 $this->import_fields_array[$r] = array(
1028 'sp.fk_product' =>
"Products*",
1029 'sp.fk_soc' =>
"Customer*",
1030 'sp.ref_customer' =>
"RefCustomer",
1031 'sp.date_begin' =>
"AppliedPricesFrom*",
1032 'sp.date_end' =>
"AppliedPricesTo",
1033 'sp.tva_tx' =>
"VATRate*",
1034 'sp.default_vat_code' =>
'VATCode',
1035 'sp.discount_percent' =>
'Discount',
1036 'sp.price_base_type' =>
"PriceBase*",
1037 'sp.price' =>
"SellingUnitPriceHT*",
1038 'sp.price_min' =>
"SellingUnitMinPriceHT",
1039 'sp.price_ttc' =>
"SellingUnitPriceTTC",
1040 'sp.price_min_ttc' =>
"SellingUnitMinPriceTTC",
1041 'sp.datec' =>
"DateCreation");
1043 $this->import_convertvalue_array[$r] = array(
1044 'sp.fk_soc' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/societe/class/societe.class.php',
'class' =>
'Societe',
'method' =>
'fetch',
'element' =>
'ThirdParty'),
1045 'sp.fk_product' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/class/product.class.php',
'class' =>
'Product',
'method' =>
'fetch',
'element' =>
'Product')
1048 $this->import_examplevalues_array[$r] = array_merge($import_sample, $import_extrafield_sample);
1049 $this->import_examplevalues_array[$r] = array(
1050 'sp.fk_product' =>
"ref:PRODUCT_REF or id:123456",
1051 'sp.fk_soc' =>
"My Supplier",
1052 'sp.ref_customer' =>
"XYZ-F123456",
1053 'sp.date_begin' =>
"2025-06-30",
1054 'sp.date_end' =>
"2027-06-30",
1055 'sp.tva_tx' =>
'20',
1056 'sp.default_vat_code' =>
'5',
1057 'sp.discount_percent' =>
'30',
1058 'sp.price_base_type'=>
'HT (for excl tax) or TTC (for inc tax)',
1059 'sp.price' =>
"100",
1060 'sp.price_min' =>
"80",
1061 'sp.price_ttc' =>
"120",
1062 'sp.price_min_ttc' =>
"96",
1063 'sp.datec' =>
"2025-09-30"
1070 $this->import_code[$r] = $this->rights_class.
'_languages';
1071 $this->import_label[$r] =
"ProductsOrServicesTranslations";
1072 $this->import_icon[$r] = $this->picto;
1073 $this->import_entities_array[$r] = array();
1074 $this->import_tables_array[$r] = array(
'l' => MAIN_DB_PREFIX.
'product_lang');
1076 $this->import_fields_array[$r] = array(
'l.fk_product' =>
'ProductOrService*',
'l.lang' =>
'Language*',
'l.label' =>
'TranslatedLabel',
'l.description' =>
'TranslatedDescription');
1078 $this->import_convertvalue_array[$r] = array(
1079 'l.fk_product' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/class/product.class.php',
'class' =>
'Product',
'method' =>
'fetch',
'element' =>
'Product')
1081 $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');
1082 $this->import_updatekeys_array[$r] = array(
'l.fk_product' =>
'ProductOrService',
'l.lang' =>
'Language');
1088 $this->import_code[$r] = $this->rights_class .
'_' . $r;
1089 $this->import_label[$r] =
"AssociatedProducts";
1090 $this->import_icon[$r] = $this->picto;
1091 $this->import_entities_array[$r] = array();
1092 $this->import_tables_array[$r] = array(
'pa' => MAIN_DB_PREFIX .
'product_association');
1093 $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');
1095 $this->import_convertvalue_array[$r] = array(
1096 'pa.fk_product_pere' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/class/product.class.php',
'class' =>
'Product',
'method' =>
'fetch',
'element' =>
'Product'),
1097 'pa.fk_product_fils' => array(
'rule' =>
'fetchidfromref',
'classfile' =>
'/product/class/product.class.php',
'class' =>
'Product',
'method' =>
'fetch',
'element' =>
'Product')
1099 $this->import_examplevalues_array[$r] = array(
1100 'pa.fk_product_pere' =>
"ref:PREF123456",
1101 'pa.fk_product_fils' =>
"ref:PREF123456",
1105 $this->import_regex_array[$r] = array(
'pa.fk_product_pere' =>
'rowid@'.MAIN_DB_PREFIX.
'product',
'pa.fk_product_fils' =>
'rowid@'.MAIN_DB_PREFIX.
'product');
1106 $this->import_updatekeys_array[$r] = array(
'pa.fk_product_pere' =>
'ref parent',
'pa.fk_product_fils' =>
"ref enfant");