2004-10-20 00:24:10 +02:00
< ? php
2012-08-25 15:21:34 +02:00
/* Copyright ( C ) 2003 - 2005 Rodolphe Quiedeville < rodolphe @ quiedeville . org >
2013-06-30 23:01:28 +02:00
* Copyright ( C ) 2004 - 2013 Laurent Destailleur < eldy @ users . sourceforge . net >
2012-08-25 15:21:34 +02:00
* Copyright ( C ) 2004 Sebastien Di Cintio < sdicintio @ ressource - toi . org >
* Copyright ( C ) 2004 Benoit Mortier < benoit . mortier @ opensides . be >
* Copyright ( C ) 2004 Eric Seigne < eric . seigne @ ryxeo . com >
2018-10-27 14:43:12 +02:00
* Copyright ( C ) 2005 - 2012 Regis Houssin < regis . houssin @ inodbox . com >
2012-08-25 15:21:34 +02:00
* Copyright ( C ) 2012 Juanjo Menent < jmenent @ 2 byte . es >
2020-10-05 12:39:26 +02:00
* Copyright ( C ) 2020 Ahmad Jamaly Rabub < rabib @ metroworks . co . jp >
2003-09-10 18:06:35 +02:00
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
2013-01-16 15:36:08 +01:00
* the Free Software Foundation ; either version 3 of the License , or
2003-09-10 18:06:35 +02:00
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
2019-09-23 21:55:30 +02:00
* along with this program . If not , see < https :// www . gnu . org / licenses />.
2003-09-10 18:06:35 +02:00
*/
2011-01-30 11:00:10 +01:00
/**
* \defgroup commande Module orders
2009-07-30 00:52:08 +02:00
* \brief Module pour gerer le suivi des commandes
2011-10-24 14:11:49 +02:00
* \file htdocs / core / modules / modCommande . class . php
2009-07-30 00:52:08 +02:00
* \ingroup commande
2021-03-20 13:55:43 +01:00
* \brief Description and activation file for the module command
2008-08-07 22:29:46 +02:00
*/
2004-08-14 14:21:24 +02:00
2020-04-10 10:59:32 +02:00
include_once DOL_DOCUMENT_ROOT . '/core/modules/DolibarrModules.class.php' ;
2003-09-10 18:06:35 +02:00
2004-08-15 14:40:18 +02:00
2011-01-30 11:00:10 +01:00
/**
2012-07-23 10:55:29 +02:00
* Class to describe module customer orders
2008-08-07 22:29:46 +02:00
*/
2003-11-13 16:07:42 +01:00
class modCommande extends DolibarrModules
2003-09-10 18:06:35 +02:00
{
2008-08-07 22:29:46 +02:00
/**
2011-09-26 16:22:35 +02:00
* Constructor . Define names , constants , directories , boxes , permissions
*
2012-01-04 21:23:50 +01:00
* @ param DoliDB $db Database handler
2008-08-07 22:29:46 +02:00
*/
2019-02-25 20:35:59 +01:00
public function __construct ( $db )
2008-08-07 22:29:46 +02:00
{
2016-06-06 17:51:39 +02:00
global $conf , $user ;
2009-05-04 13:40:00 +02:00
2012-01-04 21:23:50 +01:00
$this -> db = $db ;
$this -> numero = 25 ;
2008-08-07 22:29:46 +02:00
$this -> family = " crm " ;
2020-05-02 00:41:27 +02:00
$this -> module_position = '11' ;
2008-10-01 21:10:17 +02:00
// Module label (no space allowed), used if translation string 'ModuleXXXName' not found (where XXX is value of numeric property 'numero' of module)
2019-01-27 11:55:16 +01:00
$this -> name = preg_replace ( '/^mod/i' , '' , get_class ( $this ));
2008-08-07 22:29:46 +02:00
$this -> description = " Gestion des commandes clients " ;
2008-12-15 23:25:59 +01:00
// Possible values for version are: 'development', 'experimental', 'dolibarr' or version
$this -> version = 'dolibarr' ;
2009-05-04 13:40:00 +02:00
2008-10-06 09:39:52 +02:00
$this -> const_name = 'MAIN_MODULE_' . strtoupper ( $this -> name );
2020-04-10 10:59:32 +02:00
$this -> picto = 'order' ;
2008-08-07 22:29:46 +02:00
2009-04-28 15:52:08 +02:00
// Data directories to create when module is enabled
2009-05-04 13:40:00 +02:00
$this -> dirs = array ( " /commande/temp " );
2008-08-07 22:29:46 +02:00
// Config pages
$this -> config_page_url = array ( " commande.php " );
2009-03-20 18:10:02 +01:00
// Dependancies
2009-12-03 23:11:13 +01:00
$this -> depends = array ( " modSociete " );
2008-11-27 22:53:08 +01:00
$this -> requiredby = array ( " modExpedition " );
2008-08-07 22:29:46 +02:00
$this -> conflictwith = array ();
2020-04-10 10:59:32 +02:00
$this -> langfiles = array ( 'orders' , 'bills' , 'companies' , 'products' , 'deliveries' , 'sendings' );
2008-08-07 22:29:46 +02:00
2015-09-07 15:40:55 +02:00
// Constants
2008-08-07 22:29:46 +02:00
$this -> const = array ();
2020-04-10 10:59:32 +02:00
$r = 0 ;
2009-05-04 13:40:00 +02:00
2009-04-28 20:14:50 +02:00
$this -> const [ $r ][ 0 ] = " COMMANDE_ADDON_PDF " ;
$this -> const [ $r ][ 1 ] = " chaine " ;
$this -> const [ $r ][ 2 ] = " einstein " ;
2013-03-03 21:23:18 +01:00
$this -> const [ $r ][ 3 ] = 'Name of PDF model of order' ;
2009-04-28 20:14:50 +02:00
$this -> const [ $r ][ 4 ] = 0 ;
2009-05-04 13:40:00 +02:00
2009-04-28 20:14:50 +02:00
$r ++ ;
$this -> const [ $r ][ 0 ] = " COMMANDE_ADDON " ;
$this -> const [ $r ][ 1 ] = " chaine " ;
$this -> const [ $r ][ 2 ] = " mod_commande_marbre " ;
2013-03-03 21:23:18 +01:00
$this -> const [ $r ][ 3 ] = 'Name of numbering numerotation rules of order' ;
2009-04-28 20:14:50 +02:00
$this -> const [ $r ][ 4 ] = 0 ;
2012-02-05 19:37:52 +01:00
2012-01-27 17:41:47 +01:00
$r ++ ;
$this -> const [ $r ][ 0 ] = " COMMANDE_ADDON_PDF_ODT_PATH " ;
$this -> const [ $r ][ 1 ] = " chaine " ;
$this -> const [ $r ][ 2 ] = " DOL_DATA_ROOT/doctemplates/orders " ;
$this -> const [ $r ][ 3 ] = " " ;
$this -> const [ $r ][ 4 ] = 0 ;
2008-08-07 22:29:46 +02:00
2017-04-17 13:02:40 +02:00
/* $r ++ ;
$this -> const [ $r ][ 0 ] = " COMMANDE_DRAFT_WATERMARK " ;
$this -> const [ $r ][ 1 ] = " chaine " ;
$this -> const [ $r ][ 2 ] = " __(Draft)__ " ;
$this -> const [ $r ][ 3 ] = 'Watermark to show on draft orders' ;
$this -> const [ $r ][ 4 ] = 0 ; */
2018-02-25 10:55:02 +01:00
2014-05-01 19:17:45 +02:00
// Boxes
2014-10-27 21:48:28 +01:00
$this -> boxes = array (
2020-04-10 10:59:32 +02:00
0 => array ( 'file' => 'box_commandes.php' , 'enabledbydefaulton' => 'Home' ),
2 => array ( 'file' => 'box_graph_orders_permonth.php' , 'enabledbydefaulton' => 'Home' )
2014-10-27 21:48:28 +01:00
);
2008-08-07 22:29:46 +02:00
// Permissions
$this -> rights = array ();
$this -> rights_class = 'commande' ;
2020-04-10 10:59:32 +02:00
$r = 0 ;
2008-08-07 22:29:46 +02:00
$r ++ ;
$this -> rights [ $r ][ 0 ] = 81 ;
2020-04-10 11:54:14 +02:00
$this -> rights [ $r ][ 1 ] = 'Read sales orders' ;
2008-08-07 22:29:46 +02:00
$this -> rights [ $r ][ 2 ] = 'r' ;
2016-06-04 12:16:30 +02:00
$this -> rights [ $r ][ 3 ] = 0 ;
2008-08-07 22:29:46 +02:00
$this -> rights [ $r ][ 4 ] = 'lire' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 82 ;
2020-04-10 11:54:14 +02:00
$this -> rights [ $r ][ 1 ] = 'Creeat/modify sales orders' ;
2008-08-07 22:29:46 +02:00
$this -> rights [ $r ][ 2 ] = 'w' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'creer' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 84 ;
2020-04-10 11:54:14 +02:00
$this -> rights [ $r ][ 1 ] = 'Validate sales orders' ;
2008-08-07 22:29:46 +02:00
$this -> rights [ $r ][ 2 ] = 'd' ;
$this -> rights [ $r ][ 3 ] = 0 ;
2015-01-25 21:32:40 +01:00
$this -> rights [ $r ][ 4 ] = 'order_advance' ;
$this -> rights [ $r ][ 5 ] = 'validate' ;
2008-08-07 22:29:46 +02:00
2022-07-28 11:29:36 +02:00
$r ++ ;
$this -> rights [ $r ][ 0 ] = 85 ;
$this -> rights [ $r ][ 1 ] = 'Generate the documents sales orders' ;
$this -> rights [ $r ][ 2 ] = 'd' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'order_advance' ;
$this -> rights [ $r ][ 5 ] = 'generetedoc' ;
2008-08-07 22:29:46 +02:00
$r ++ ;
$this -> rights [ $r ][ 0 ] = 86 ;
2022-07-28 11:29:36 +02:00
$this -> rights [ $r ][ 1 ] = 'Send sales orders by email' ;
2008-08-07 22:29:46 +02:00
$this -> rights [ $r ][ 2 ] = 'd' ;
$this -> rights [ $r ][ 3 ] = 0 ;
2011-05-05 09:25:31 +02:00
$this -> rights [ $r ][ 4 ] = 'order_advance' ;
2020-10-31 14:32:18 +01:00
$this -> rights [ $r ][ 5 ] = 'send' ;
2008-08-07 22:29:46 +02:00
$r ++ ;
$this -> rights [ $r ][ 0 ] = 87 ;
2020-04-10 11:54:14 +02:00
$this -> rights [ $r ][ 1 ] = 'Close sale orders' ;
2008-08-07 22:29:46 +02:00
$this -> rights [ $r ][ 2 ] = 'd' ;
$this -> rights [ $r ][ 3 ] = 0 ;
2020-04-10 11:54:14 +02:00
$this -> rights [ $r ][ 4 ] = 'order_advance' ;
$this -> rights [ $r ][ 5 ] = 'close' ;
2008-08-07 22:29:46 +02:00
$r ++ ;
$this -> rights [ $r ][ 0 ] = 88 ;
2020-04-10 11:54:14 +02:00
$this -> rights [ $r ][ 1 ] = 'Cancel sale orders' ;
2008-08-07 22:29:46 +02:00
$this -> rights [ $r ][ 2 ] = 'd' ;
$this -> rights [ $r ][ 3 ] = 0 ;
2015-03-09 21:20:56 +01:00
$this -> rights [ $r ][ 4 ] = 'order_advance' ;
$this -> rights [ $r ][ 5 ] = 'annuler' ;
2015-05-05 12:39:27 +02:00
2008-08-07 22:29:46 +02:00
$r ++ ;
$this -> rights [ $r ][ 0 ] = 89 ;
2020-04-10 11:54:14 +02:00
$this -> rights [ $r ][ 1 ] = 'Delete sales orders' ;
2008-08-07 22:29:46 +02:00
$this -> rights [ $r ][ 2 ] = 'd' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'supprimer' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 1421 ;
2020-04-10 11:54:14 +02:00
$this -> rights [ $r ][ 1 ] = 'Export sales orders and attributes' ;
2008-08-07 22:29:46 +02:00
$this -> rights [ $r ][ 2 ] = 'r' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'commande' ;
$this -> rights [ $r ][ 5 ] = 'export' ;
2018-02-25 10:55:02 +01:00
2016-09-30 13:02:13 +02:00
// Menus
//-------
2020-04-10 10:59:32 +02:00
$this -> menu = 1 ; // This module add menu entries. They are coded into menu manager.
2018-02-25 10:55:02 +01:00
2008-08-07 22:29:46 +02:00
// Exports
//--------
2020-04-10 10:59:32 +02:00
$r = 0 ;
2008-08-07 22:29:46 +02:00
$r ++ ;
2020-04-10 10:59:32 +02:00
$this -> export_code [ $r ] = $this -> rights_class . '_' . $r ;
$this -> export_label [ $r ] = 'CustomersOrdersAndOrdersLines' ; // Translation key (used only if key ExportDataset_xxx_z not found)
$this -> export_permission [ $r ] = array ( array ( " commande " , " commande " , " export " ));
$this -> export_fields_array [ $r ] = array (
2021-06-22 14:13:18 +02:00
's.rowid' => " IdCompany " , 's.nom' => 'CompanyName' , 'ps.nom' => 'ParentCompany' , 's.address' => 'Address' , 's.zip' => 'Zip' , 's.town' => 'Town' , 'd.nom' => 'State' , 'co.label' => 'Country' ,
2020-04-10 10:59:32 +02:00
'co.code' => " CountryCode " , 's.phone' => 'Phone' , 's.siren' => 'ProfId1' , 's.siret' => 'ProfId2' , 's.ape' => 'ProfId3' , 's.idprof4' => 'ProfId4' , 'c.rowid' => " Id " ,
'c.ref' => " Ref " , 'c.ref_client' => " RefCustomer " , 'c.fk_soc' => " IdCompany " , 'c.date_creation' => " DateCreation " , 'c.date_commande' => " OrderDate " ,
2022-04-04 13:35:08 +02:00
'c.date_livraison' => " DateDeliveryPlanned " , 'c.amount_ht' => " Amount " , 'c.total_ht' => " TotalHT " ,
2020-04-10 10:59:32 +02:00
'c.total_ttc' => " TotalTTC " , 'c.facture' => " Billed " , 'c.fk_statut' => 'Status' , 'c.note_public' => " Note " , 'c.date_livraison' => 'DeliveryDate' ,
'c.fk_user_author' => 'CreatedById' , 'uc.login' => 'CreatedByLogin' , 'c.fk_user_valid' => 'ValidatedById' , 'uv.login' => 'ValidatedByLogin' ,
2022-04-04 13:35:08 +02:00
'pj.ref' => 'ProjectRef' , 'cd.rowid' => 'LineId' , 'cd.description' => " LineDescription " , 'cd.product_type' => 'TypeOfLineServiceOrProduct' ,
2020-04-10 10:59:32 +02:00
'cd.tva_tx' => " LineVATRate " , 'cd.qty' => " LineQty " , 'cd.total_ht' => " LineTotalHT " , 'cd.total_tva' => " LineTotalVAT " , 'cd.total_ttc' => " LineTotalTTC " ,
'p.rowid' => 'ProductId' , 'p.ref' => 'ProductRef' , 'p.label' => 'ProductLabel'
2018-05-27 15:04:12 +02:00
);
2022-09-03 11:17:05 +02:00
if ( isModEnabled ( " multicurrency " )) {
2020-10-31 14:32:18 +01:00
$this -> export_fields_array [ $r ][ 'c.multicurrency_code' ] = 'Currency' ;
$this -> export_fields_array [ $r ][ 'c.multicurrency_tx' ] = 'CurrencyRate' ;
$this -> export_fields_array [ $r ][ 'c.multicurrency_total_ht' ] = 'MulticurrencyAmountHT' ;
$this -> export_fields_array [ $r ][ 'c.multicurrency_total_tva' ] = 'MulticurrencyAmountVAT' ;
$this -> export_fields_array [ $r ][ 'c.multicurrency_total_ttc' ] = 'MulticurrencyAmountTTC' ;
2019-01-21 02:43:08 +01:00
}
2021-12-17 12:38:13 +01:00
// Add multicompany field
if ( ! empty ( $conf -> global -> MULTICOMPANY_ENTITY_IN_EXPORT_IF_SHARED )) {
$nbofallowedentities = count ( explode ( ',' , getEntity ( 'commande' )));
2022-08-28 14:04:21 +02:00
if ( isModEnabled ( 'multicompany' ) && $nbofallowedentities > 1 ) {
2021-12-17 12:38:13 +01:00
$this -> export_fields_array [ $r ][ 'c.entity' ] = 'Entity' ;
}
}
2018-05-27 15:04:12 +02:00
//$this->export_TypeFields_array[$r]=array(
2022-05-17 00:50:59 +02:00
// 's.rowid'=>"Numeric",'s.nom'=>'Text','s.address'=>'Text','s.zip'=>'Text','s.town'=>'Text','co.label'=>'List:c_country:label:label',
2018-05-27 15:04:12 +02:00
// 'co.code'=>'Text','s.phone'=>'Text','s.siren'=>'Text','s.siret'=>'Text','s.ape'=>'Text','s.idprof4'=>'Text','c.ref'=>"Text",'c.ref_client'=>"Text",
2022-04-04 13:35:08 +02:00
// 'c.date_creation'=>"Date",'c.date_commande'=>"Date",'c.amount_ht'=>"Numeric",'c.total_ht'=>"Numeric",
2018-05-27 15:04:12 +02:00
// 'c.total_ttc'=>"Numeric",'c.facture'=>"Boolean",'c.fk_statut'=>'Status','c.note_public'=>"Text",'c.date_livraison'=>'Date','cd.description'=>"Text",
// 'cd.product_type'=>'Boolean','cd.tva_tx'=>"Numeric",'cd.qty'=>"Numeric",'cd.total_ht'=>"Numeric",'cd.total_tva'=>"Numeric",'cd.total_ttc'=>"Numeric",
// 'p.rowid'=>'List:product:ref','p.ref'=>'Text','p.label'=>'Text'
//);
2020-04-10 10:59:32 +02:00
$this -> export_TypeFields_array [ $r ] = array (
2021-06-22 14:13:18 +02:00
's.nom' => 'Text' , 'ps.nom' => 'Text' , 's.address' => 'Text' , 's.zip' => 'Text' , 's.town' => 'Text' , 'co.label' => 'List:c_country:label:label' , 'co.code' => 'Text' , 's.phone' => 'Text' ,
2020-04-10 10:59:32 +02:00
's.siren' => 'Text' , 's.siret' => 'Text' , 's.ape' => 'Text' , 's.idprof4' => 'Text' , 'c.ref' => " Text " , 'c.ref_client' => " Text " , 'c.date_creation' => " Date " ,
2022-04-04 13:35:08 +02:00
'c.date_commande' => " Date " , 'c.date_livraison' => " Date " , 'c.amount_ht' => " Numeric " , 'c.total_ht' => " Numeric " ,
2020-04-10 10:59:32 +02:00
'c.total_ttc' => " Numeric " , 'c.facture' => " Boolean " , 'c.fk_statut' => 'Status' , 'c.note_public' => " Text " , 'c.date_livraison' => 'Date' , 'pj.ref' => 'Text' ,
'cd.description' => " Text " , 'cd.product_type' => 'Boolean' , 'cd.tva_tx' => " Numeric " , 'cd.qty' => " Numeric " , 'cd.total_ht' => " Numeric " , 'cd.total_tva' => " Numeric " ,
2021-12-17 12:38:13 +01:00
'cd.total_ttc' => " Numeric " , 'p.rowid' => 'List:product:ref::product' , 'p.ref' => 'Text' , 'p.label' => 'Text' , 'd.nom' => 'Text' ,
'c.entity' => 'List:entity:label:rowid' ,
2018-05-27 15:04:12 +02:00
);
2020-04-10 10:59:32 +02:00
$this -> export_entities_array [ $r ] = array (
2021-06-22 14:13:18 +02:00
's.rowid' => " company " , 's.nom' => 'company' , 'ps.nom' => 'company' , 's.address' => 'company' , 's.zip' => 'company' , 's.town' => 'company' , 'd.nom' => 'company' , 'co.label' => 'company' ,
2020-04-10 10:59:32 +02:00
'co.code' => 'company' , 's.phone' => 'company' , 's.siren' => 'company' , 's.ape' => 'company' , 's.idprof4' => 'company' , 's.siret' => 'company' , 'c.rowid' => " order " ,
'c.ref' => " order " , 'c.ref_client' => " order " , 'c.fk_soc' => " order " , 'c.date_creation' => " order " , 'c.date_commande' => " order " , 'c.amount_ht' => " order " ,
2022-04-04 13:35:08 +02:00
'c.total_ht' => " order " , 'c.total_ttc' => " order " , 'c.facture' => " order " , 'c.fk_statut' => " order " , 'c.note' => " order " ,
'c.date_livraison' => " order " , 'pj.ref' => 'project' , 'cd.rowid' => 'order_line' , 'cd.description' => " order_line " ,
2020-04-10 10:59:32 +02:00
'cd.product_type' => 'order_line' , 'cd.tva_tx' => " order_line " , 'cd.qty' => " order_line " , 'cd.total_ht' => " order_line " , 'cd.total_tva' => " order_line " ,
'cd.total_ttc' => " order_line " , 'p.rowid' => 'product' , 'p.ref' => 'product' , 'p.label' => 'product'
2018-05-27 15:04:12 +02:00
);
2020-04-10 10:59:32 +02:00
$this -> export_dependencies_array [ $r ] = array ( 'order_line' => 'cd.rowid' , 'product' => 'cd.rowid' ); // To add unique key if we ask a field of a child to avoid the DISTINCT to discard them
2021-03-01 20:37:16 +01:00
$keyforselect = 'commande' ;
$keyforelement = 'order' ;
$keyforaliasextra = 'extra' ;
2015-12-17 20:40:33 +01:00
include DOL_DOCUMENT_ROOT . '/core/extrafieldsinexport.inc.php' ;
2021-03-01 20:37:16 +01:00
$keyforselect = 'commandedet' ;
$keyforelement = 'order_line' ;
$keyforaliasextra = 'extra2' ;
2015-12-17 20:40:33 +01:00
include DOL_DOCUMENT_ROOT . '/core/extrafieldsinexport.inc.php' ;
2021-03-01 20:37:16 +01:00
$keyforselect = 'product' ;
$keyforelement = 'product' ;
$keyforaliasextra = 'extra3' ;
2015-12-17 20:40:33 +01:00
include DOL_DOCUMENT_ROOT . '/core/extrafieldsinexport.inc.php' ;
2021-03-01 20:37:16 +01:00
$keyforselect = 'societe' ;
$keyforelement = 'company' ;
$keyforaliasextra = 'extra4' ;
2020-03-31 11:05:21 +02:00
include DOL_DOCUMENT_ROOT . '/core/extrafieldsinexport.inc.php' ;
2020-04-10 10:59:32 +02:00
$this -> export_sql_start [ $r ] = 'SELECT DISTINCT ' ;
$this -> export_sql_end [ $r ] = ' FROM ' . MAIN_DB_PREFIX . 'societe as s' ;
2021-06-22 14:13:18 +02:00
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'societe_extrafields as extra4 ON s.rowid = extra4.fk_object' ;
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'societe as ps ON ps.rowid = s.parent' ;
2021-02-23 22:03:23 +01:00
if ( empty ( $user -> rights -> societe -> client -> voir )) {
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'societe_commerciaux as sc ON sc.fk_soc = s.rowid' ;
}
2020-04-10 10:59:32 +02:00
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'c_departements as d ON s.fk_departement = d.rowid' ;
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'c_country as co ON s.fk_pays = co.rowid,' ;
$this -> export_sql_end [ $r ] .= ' ' . MAIN_DB_PREFIX . 'commande as c' ;
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'projet as pj ON c.fk_projet = pj.rowid' ;
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'user as uc ON c.fk_user_author = uc.rowid' ;
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'user as uv ON c.fk_user_valid = uv.rowid' ;
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'commande_extrafields as extra ON c.rowid = extra.fk_object' ;
$this -> export_sql_end [ $r ] .= ' , ' . MAIN_DB_PREFIX . 'commandedet as cd' ;
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'commandedet_extrafields as extra2 on cd.rowid = extra2.fk_object' ;
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'product as p on cd.fk_product = p.rowid' ;
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'product_extrafields as extra3 on p.rowid = extra3.fk_object' ;
$this -> export_sql_end [ $r ] .= ' WHERE c.fk_soc = s.rowid AND c.rowid = cd.fk_commande' ;
$this -> export_sql_end [ $r ] .= ' AND c.entity IN (' . getEntity ( 'commande' ) . ')' ;
2021-02-23 22:03:23 +01:00
if ( empty ( $user -> rights -> societe -> client -> voir )) {
$this -> export_sql_end [ $r ] .= ' AND sc.fk_user = ' . ( empty ( $user ) ? 0 : $user -> id );
}
2020-12-27 19:21:37 +01:00
2020-10-05 12:39:26 +02:00
// Imports
//--------
2020-10-07 15:01:28 +02:00
$r = 0 ;
2020-10-05 12:39:26 +02:00
//Import Order Header
$r ++ ;
2020-10-07 15:01:28 +02:00
$this -> import_code [ $r ] = 'commande_' . $r ;
2021-01-26 05:14:01 +01:00
$this -> import_label [ $r ] = 'CustomersOrders' ;
2020-10-05 12:39:26 +02:00
$this -> import_icon [ $r ] = $this -> picto ;
2021-09-02 21:00:31 +02:00
$this -> import_entities_array [ $r ] = array ();
$this -> import_tables_array [ $r ] = array ( 'c' => MAIN_DB_PREFIX . 'commande' , 'extra' => MAIN_DB_PREFIX . 'commande_extrafields' );
$this -> import_tables_creator_array [ $r ] = array ( 'c' => 'fk_user_author' ); // Fields to store import user id
2022-04-04 13:17:45 +02:00
$import_sample = array ();
2021-09-02 21:00:31 +02:00
$this -> import_fields_array [ $r ] = array (
2021-09-02 21:03:49 +02:00
'c.ref' => 'Ref*' ,
2020-10-05 12:39:26 +02:00
'c.ref_client' => 'RefCustomer' ,
'c.fk_soc' => 'ThirdPartyName*' ,
'c.fk_projet' => 'ProjectId' ,
'c.date_creation' => 'DateCreation' ,
2022-04-04 13:17:45 +02:00
'c.date_valid' => 'DateValidation' ,
'c.date_commande' => 'OrderDate*' ,
2020-10-05 12:39:26 +02:00
'c.fk_user_modif' => 'ModifiedById' ,
'c.fk_user_valid' => 'ValidatedById' ,
2021-02-20 08:00:27 +01:00
'c.total_tva' => 'TotalTVA' ,
2020-10-05 12:39:26 +02:00
'c.total_ht' => 'TotalHT' ,
'c.total_ttc' => 'TotalTTC' ,
'c.note_private' => 'NotePrivate' ,
'c.note_public' => 'Note' ,
'c.facture' => 'Invoice(1/0)' ,
'c.date_livraison' => 'DeliveryDate' ,
'c.fk_cond_reglement' => 'Payment Condition' ,
'c.fk_mode_reglement' => 'Payment Mode' ,
2022-04-04 13:17:45 +02:00
'c.model_pdf' => 'Model' ,
'c.fk_statut' => 'Status*'
2021-09-02 21:00:31 +02:00
);
2020-10-05 12:39:26 +02:00
2022-09-03 11:17:05 +02:00
if ( isModEnabled ( " multicurrency " )) {
2020-10-05 12:39:26 +02:00
$this -> import_fields_array [ $r ][ 'c.multicurrency_code' ] = 'Currency' ;
$this -> import_fields_array [ $r ][ 'c.multicurrency_tx' ] = 'CurrencyRate' ;
$this -> import_fields_array [ $r ][ 'c.multicurrency_total_ht' ] = 'MulticurrencyAmountHT' ;
$this -> import_fields_array [ $r ][ 'c.multicurrency_total_tva' ] = 'MulticurrencyAmountVAT' ;
$this -> import_fields_array [ $r ][ 'c.multicurrency_total_ttc' ] = 'MulticurrencyAmountTTC' ;
}
2021-09-02 21:00:31 +02:00
$import_extrafield_sample = array ();
2022-04-04 13:17:45 +02:00
$keyforselect = 'commande' ;
$keyforelement = 'order' ;
$keyforaliasextra = 'extra' ;
include DOL_DOCUMENT_ROOT . '/core/extrafieldsinimport.inc.php' ;
2020-10-05 12:39:26 +02:00
2022-04-04 10:45:50 +02:00
$this -> import_fieldshidden_array [ $r ] = array ( 'extra.fk_object' => 'lastrowid-' . MAIN_DB_PREFIX . 'commande' );
$this -> import_regex_array [ $r ] = array (
2020-10-07 15:01:28 +02:00
'c.multicurrency_code' => 'code@' . MAIN_DB_PREFIX . 'multicurrency'
2022-04-04 10:45:50 +02:00
);
2022-04-04 13:17:45 +02:00
$this -> import_examplevalues_array [ $r ] = array_merge ( $import_sample , $import_extrafield_sample );
2022-04-04 10:45:50 +02:00
$this -> import_updatekeys_array [ $r ] = array ( 'c.ref' => 'Ref' );
$this -> import_convertvalue_array [ $r ] = array (
2022-04-04 13:17:45 +02:00
'c.ref' => array (
'rule' => 'getrefifauto' ,
'class' => ( empty ( $conf -> global -> COMMANDE_ADDON ) ? 'mod_commande_marbre' : $conf -> global -> COMMANDE_ADDON ),
'path' => " /core/modules/commande/ " . ( empty ( $conf -> global -> COMMANDE_ADDON ) ? 'mod_commande_marbre' : $conf -> global -> COMMANDE_ADDON ) . '.php' ,
'classobject' => 'Commande' ,
'pathobject' => '/commande/class/commande.class.php' ,
),
2022-04-04 10:45:50 +02:00
'c.fk_soc' => array (
2020-10-05 12:39:26 +02:00
'rule' => 'fetchidfromref' ,
'file' => '/societe/class/societe.class.php' ,
'class' => 'Societe' ,
'method' => 'fetch' ,
'element' => 'ThirdParty'
2022-04-04 10:45:50 +02:00
),
'c.fk_user_valid' => array (
2020-10-05 12:39:26 +02:00
'rule' => 'fetchidfromref' ,
'file' => '/user/class/user.class.php' ,
'class' => 'User' ,
'method' => 'fetch' ,
'element' => 'user'
2022-04-04 10:45:50 +02:00
),
'c.fk_mode_reglement' => array (
2020-10-05 12:39:26 +02:00
'rule' => 'fetchidfromcodeorlabel' ,
'file' => '/compta/paiement/class/cpaiement.class.php' ,
'class' => 'Cpaiement' ,
'method' => 'fetch' ,
'element' => 'cpayment'
2022-04-04 10:45:50 +02:00
),
);
2020-10-05 12:39:26 +02:00
2022-06-12 20:33:10 +02:00
//Import Order Lines
2020-10-05 12:39:26 +02:00
$r ++ ;
$this -> import_code [ $r ] = 'commande_lines_' . $r ;
2021-03-23 16:59:12 +01:00
$this -> import_label [ $r ] = 'SaleOrderLines' ;
2020-10-05 12:39:26 +02:00
$this -> import_icon [ $r ] = $this -> picto ;
2021-09-02 21:00:31 +02:00
$this -> import_entities_array [ $r ] = array ();
$this -> import_tables_array [ $r ] = array ( 'cd' => MAIN_DB_PREFIX . 'commandedet' , 'extra' => MAIN_DB_PREFIX . 'commandedet_extrafields' );
$this -> import_fields_array [ $r ] = array (
2022-04-04 13:35:08 +02:00
'cd.fk_commande' => 'CustomerOrder*' ,
'cd.fk_parent_line' => 'ParentLine' ,
2020-10-05 12:39:26 +02:00
'cd.fk_product' => 'IdProduct' ,
'cd.description' => 'LineDescription' ,
'cd.tva_tx' => 'LineVATRate' ,
'cd.qty' => 'LineQty' ,
'cd.remise_percent' => 'Reduc. Percent' ,
'cd.price' => 'Price' ,
'cd.subprice' => 'Sub Price' ,
'cd.total_ht' => 'LineTotalHT' ,
'cd.total_tva' => 'LineTotalVAT' ,
'cd.total_ttc' => 'LineTotalTTC' ,
'cd.product_type' => 'TypeOfLineServiceOrProduct' ,
'cd.date_start' => 'Start Date' ,
'cd.date_end' => 'End Date' ,
'cd.buy_price_ht' => 'LineBuyPriceHT' ,
'cd.rang' => 'LinePosition'
2021-09-02 21:00:31 +02:00
);
2020-10-05 12:39:26 +02:00
2022-09-03 11:17:05 +02:00
if ( isModEnabled ( " multicurrency " )) {
2020-10-05 12:39:26 +02:00
$this -> import_fields_array [ $r ][ 'cd.multicurrency_code' ] = 'Currency' ;
$this -> import_fields_array [ $r ][ 'cd.multicurrency_subprice' ] = 'CurrencyRate' ;
$this -> import_fields_array [ $r ][ 'cd.multicurrency_total_ht' ] = 'MulticurrencyAmountHT' ;
$this -> import_fields_array [ $r ][ 'cd.multicurrency_total_tva' ] = 'MulticurrencyAmountVAT' ;
$this -> import_fields_array [ $r ][ 'cd.multicurrency_total_ttc' ] = 'MulticurrencyAmountTTC' ;
}
2022-04-04 13:17:45 +02:00
$import_extrafield_sample = array ();
$keyforselect = 'commandedet' ;
$keyforelement = 'orderline' ;
$keyforaliasextra = 'extra' ;
include DOL_DOCUMENT_ROOT . '/core/extrafieldsinimport.inc.php' ;
2020-10-05 12:39:26 +02:00
2020-10-07 15:01:28 +02:00
$this -> import_fieldshidden_array [ $r ] = [ 'extra.fk_object' => 'lastrowid-' . MAIN_DB_PREFIX . 'commandedet' ];
2020-10-05 12:39:26 +02:00
$this -> import_regex_array [ $r ] = [
'cd.product_type' => '[0|1]$' ,
2020-10-07 15:01:28 +02:00
'cd.fk_product' => 'rowid@' . MAIN_DB_PREFIX . 'product' ,
'cd.multicurrency_code' => 'code@' . MAIN_DB_PREFIX . 'multicurrency'
2020-10-05 12:39:26 +02:00
];
$this -> import_updatekeys_array [ $r ] = [ 'cd.fk_commande' => 'Sales Order Id' , 'cd.fk_product' => 'Product Id' ];
$this -> import_convertvalue_array [ $r ] = [
'cd.fk_commande' => [
'rule' => 'fetchidfromref' ,
'file' => '/commande/class/commande.class.php' ,
'class' => 'Commande' ,
'method' => 'fetch' ,
'element' => 'commande'
],
];
2008-08-07 22:29:46 +02:00
}
/**
2012-01-04 21:23:50 +01:00
* Function called when module is enabled .
* The init function add constants , boxes , permissions and menus ( defined in constructor ) into Dolibarr database .
* It also creates data directories
*
2020-10-31 14:32:18 +01:00
* @ param string $options Options when enabling module ( '' , 'newboxdefonly' , 'noboxes' )
2012-01-04 21:23:50 +01:00
* @ return int 1 if OK , 0 if KO
2008-08-07 22:29:46 +02:00
*/
2019-02-26 21:13:07 +01:00
public function init ( $options = '' )
2008-08-07 22:29:46 +02:00
{
2020-04-10 10:59:32 +02:00
global $conf , $langs ;
2008-08-07 22:29:46 +02:00
// Permissions
2012-03-03 17:37:45 +01:00
$this -> remove ( $options );
2008-08-07 22:29:46 +02:00
2012-01-27 22:35:23 +01:00
//ODT template
2020-04-10 10:59:32 +02:00
$src = DOL_DOCUMENT_ROOT . '/install/doctemplates/orders/template_order.odt' ;
$dirodt = DOL_DATA_ROOT . '/doctemplates/orders' ;
$dest = $dirodt . '/template_order.odt' ;
2012-08-01 14:42:24 +02:00
2021-02-23 22:03:23 +01:00
if ( file_exists ( $src ) && ! file_exists ( $dest )) {
2012-08-22 23:11:24 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/lib/files.lib.php' ;
2012-08-01 14:42:24 +02:00
dol_mkdir ( $dirodt );
2020-04-10 10:59:32 +02:00
$result = dol_copy ( $src , $dest , 0 , 0 );
2021-02-23 22:03:23 +01:00
if ( $result < 0 ) {
2012-08-01 14:42:24 +02:00
$langs -> load ( " errors " );
2020-04-10 10:59:32 +02:00
$this -> error = $langs -> trans ( 'ErrorFailToCopyFile' , $src , $dest );
2012-08-01 14:42:24 +02:00
return 0 ;
}
2012-02-05 19:37:52 +01:00
}
2008-08-07 22:29:46 +02:00
$sql = array (
2021-08-27 22:42:04 +02:00
" DELETE FROM " . MAIN_DB_PREFIX . " document_model WHERE nom = ' " . $this -> db -> escape ( $this -> const [ 0 ][ 2 ]) . " ' AND type = 'order' AND entity = " . (( int ) $conf -> entity ),
" INSERT INTO " . MAIN_DB_PREFIX . " document_model (nom, type, entity) VALUES(' " . $this -> db -> escape ( $this -> const [ 0 ][ 2 ]) . " ', 'order', " . (( int ) $conf -> entity ) . " ) "
2012-08-01 14:42:24 +02:00
);
2004-12-22 21:27:10 +01:00
2019-02-26 21:13:07 +01:00
return $this -> _init ( $sql , $options );
2008-08-07 22:29:46 +02:00
}
2003-09-10 18:06:35 +02:00
}