2018-10-03 12:22:41 +02:00
< ? php
/* Copyright ( C ) 2018 Quentin Vial - Gouteyron < quentin . vial - gouteyron @ atm - consulting . fr >
*
* 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
* the Free Software Foundation ; either version 3 of the License , or
* ( 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 />.
2018-10-03 12:22:41 +02:00
*/
/**
2023-07-25 23:10:46 +02:00
* \defgroup reception Module Reception
* \brief Module to manage receptions of products
*
* \file htdocs / core / modules / modReception . class . php
* \ingroup reception
* \brief Description and activation file for the module Reception
2018-10-03 12:22:41 +02:00
*/
2020-04-10 10:59:32 +02:00
include_once DOL_DOCUMENT_ROOT . '/core/modules/DolibarrModules.class.php' ;
2018-10-03 12:22:41 +02:00
/**
* Class to describe and enable module Reception
*/
class modReception extends DolibarrModules
{
/**
* Constructor . Define names , constants , directories , boxes , permissions
*
* @ param DoliDB $db Database handler
*/
2019-02-25 20:35:59 +01:00
public function __construct ( $db )
2018-10-03 12:22:41 +02:00
{
global $conf , $user ;
$this -> db = $db ;
2019-06-21 13:25:40 +02:00
$this -> numero = 94160 ;
2018-10-03 12:22:41 +02:00
2018-10-23 14:31:58 +02:00
$this -> family = " srm " ;
2019-06-21 13:25:40 +02:00
$this -> module_position = '40' ;
2018-10-03 12:22:41 +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 ));
2022-01-28 16:35:14 +01:00
$this -> description = " ReceptionDescription " ;
2018-10-03 12:22:41 +02:00
// Possible values for version are: 'development', 'experimental', 'dolibarr' or version
2020-08-17 14:10:43 +02:00
$this -> version = 'dolibarr' ;
2018-10-03 12:22:41 +02:00
$this -> const_name = 'MAIN_MODULE_' . strtoupper ( $this -> name );
2020-04-20 18:38:25 +02:00
$this -> picto = " dollyrevert " ;
2018-10-03 12:22:41 +02:00
// Data directories to create when module is enabled
$this -> dirs = array ( " /reception/receipt " ,
2020-10-31 14:32:18 +01:00
" /reception/receipt/temp " ,
" /doctemplates/receptions "
);
2018-10-03 12:22:41 +02:00
// Config pages
$this -> config_page_url = array ( " reception_setup.php " );
// Dependencies
$this -> depends = array ( " modFournisseur " );
$this -> requiredby = array ();
$this -> conflictwith = array ();
$this -> langfiles = array ( 'receptions' );
// Constants
$this -> const = array ();
2020-04-10 10:59:32 +02:00
$r = 0 ;
2018-10-03 12:22:41 +02:00
$this -> const [ $r ][ 0 ] = " RECEPTION_ADDON_PDF " ;
$this -> const [ $r ][ 1 ] = " chaine " ;
$this -> const [ $r ][ 2 ] = " squille " ;
$this -> const [ $r ][ 3 ] = 'Nom du gestionnaire de generation des bons receptions en PDF' ;
$this -> const [ $r ][ 4 ] = 0 ;
$r ++ ;
$this -> const [ $r ][ 0 ] = " RECEPTION_ADDON_NUMBER " ;
$this -> const [ $r ][ 1 ] = " chaine " ;
$this -> const [ $r ][ 2 ] = " mod_reception_beryl " ;
$this -> const [ $r ][ 3 ] = 'Name for numbering manager for receptions' ;
$this -> const [ $r ][ 4 ] = 0 ;
$r ++ ;
$this -> const [ $r ][ 0 ] = " RECEPTION_ADDON_PDF_ODT_PATH " ;
$this -> const [ $r ][ 1 ] = " chaine " ;
$this -> const [ $r ][ 2 ] = " DOL_DATA_ROOT/doctemplates/receptions " ;
$this -> const [ $r ][ 3 ] = " " ;
$this -> const [ $r ][ 4 ] = 0 ;
$r ++ ;
$this -> const [ $r ][ 0 ] = " MAIN_SUBMODULE_RECEPTION " ;
$this -> const [ $r ][ 1 ] = " chaine " ;
$this -> const [ $r ][ 2 ] = " 1 " ;
$this -> const [ $r ][ 3 ] = " Enable receptions " ;
$this -> const [ $r ][ 4 ] = 0 ;
$r ++ ;
// Boxes
$this -> boxes = array ();
// Permissions
$this -> rights = array ();
$this -> rights_class = 'reception' ;
2020-04-10 10:59:32 +02:00
$r = 0 ;
2018-10-03 12:22:41 +02:00
$r ++ ;
$this -> rights [ $r ][ 0 ] = $this -> numero . $r ;
$this -> rights [ $r ][ 1 ] = 'Lire les receptions' ;
$this -> rights [ $r ][ 2 ] = 'r' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'lire' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = $this -> numero . $r ;
$this -> rights [ $r ][ 1 ] = 'Creer modifier les receptions' ;
$this -> rights [ $r ][ 2 ] = 'w' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'creer' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = $this -> numero . $r ;
$this -> rights [ $r ][ 1 ] = 'Valider les receptions' ;
$this -> rights [ $r ][ 2 ] = 'd' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'reception_advance' ;
$this -> rights [ $r ][ 5 ] = 'validate' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = $this -> numero . $r ; // id de la permission
$this -> rights [ $r ][ 1 ] = 'Envoyer les receptions aux clients' ; // libelle de la permission
$this -> rights [ $r ][ 2 ] = 'd' ; // type de la permission (deprecie a ce jour)
$this -> rights [ $r ][ 3 ] = 0 ; // La permission est-elle une permission par defaut
$this -> rights [ $r ][ 4 ] = 'reception_advance' ;
2020-10-31 14:32:18 +01:00
$this -> rights [ $r ][ 5 ] = 'send' ;
2018-10-03 12:22:41 +02:00
$r ++ ;
$this -> rights [ $r ][ 0 ] = $this -> numero . $r ;
$this -> rights [ $r ][ 1 ] = 'Exporter les receptions' ;
$this -> rights [ $r ][ 2 ] = 'r' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'reception' ;
$this -> rights [ $r ][ 5 ] = 'export' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = $this -> numero . $r ;
$this -> rights [ $r ][ 1 ] = 'Supprimer les receptions' ;
$this -> rights [ $r ][ 2 ] = 'd' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'supprimer' ;
// Menus
//-------
2020-04-10 10:59:32 +02:00
$this -> menu = 1 ; // This module add menu entries. They are coded into menu manager.
2018-12-15 14:12:39 +01:00
2018-10-03 12:22:41 +02:00
// Exports
//--------
2020-04-10 10:59:32 +02:00
$r = 0 ;
2018-10-11 15:28:28 +02:00
include_once DOL_DOCUMENT_ROOT . '/fourn/class/fournisseur.commande.class.php' ;
2020-04-10 10:59:32 +02:00
$shipment = new CommandeFournisseur ( $this -> db );
$contact_arrays = $shipment -> liste_type_contact ( 'external' , '' , 0 , 0 , '' );
if ( is_array ( $contact_arrays ) && count ( $contact_arrays ) > 0 ) {
$idcontacts = join ( ',' , array_keys ( $shipment -> liste_type_contact ( 'external' , '' , 0 , 0 , '' )));
2018-10-03 12:22:41 +02:00
} else {
2020-04-10 10:59:32 +02:00
$idcontacts = 0 ;
2018-10-03 12:22:41 +02:00
}
$r ++ ;
2020-04-10 10:59:32 +02:00
$this -> export_code [ $r ] = $this -> rights_class . '_' . $r ;
$this -> export_label [ $r ] = 'Receptions' ; // Translation key (used only if key ExportDataset_xxx_z not found)
$this -> export_permission [ $r ] = array ( array ( " reception " , " reception " , " export " ));
$this -> export_fields_array [ $r ] = array (
's.rowid' => " IdCompany " , 's.nom' => 'ThirdParty' , 's.address' => 'Address' , 's.zip' => 'Zip' , 's.town' => 'Town' ,
'd.nom' => 'State' , 'co.label' => 'Country' , 'co.code' => 'CountryCode' , 's.phone' => 'Phone' , 's.siren' => 'ProfId1' , 's.siret' => 'ProfId2' , 's.ape' => 'ProfId3' , 's.idprof4' => 'ProfId4' , 's.idprof5' => 'ProfId5' , 's.idprof6' => 'ProfId6' ,
'c.rowid' => " Id " , 'c.ref' => " Ref " , 'c.ref_supplier' => " RefSupplier " , 'c.fk_soc' => " IdCompany " , 'c.date_creation' => " DateCreation " , 'c.date_delivery' => " DateDeliveryPlanned " , 'c.tracking_number' => " TrackingNumber " , 'c.height' => " Height " , 'c.width' => " Width " , 'c.size' => " Depth " , 'c.size_units' => 'SizeUnits' , 'c.weight' => " Weight " , 'c.weight_units' => " WeightUnits " , 'c.fk_statut' => 'Status' , 'c.note_public' => " NotePublic " , 'ed.rowid' => 'LineId' ,
'ed.comment' => 'Description' , 'ed.qty' => " Qty " ,
'p.rowid' => 'ProductId' , 'p.ref' => 'ProductRef' , 'p.label' => 'ProductLabel' , 'p.weight' => 'ProductWeight' , 'p.weight_units' => 'WeightUnits' , 'p.volume' => 'ProductVolume' , 'p.volume_units' => 'VolumeUnits'
2018-12-15 14:12:39 +01:00
);
2021-02-23 22:03:23 +01:00
if ( $idcontacts && ! empty ( $conf -> global -> RECEPTION_ADD_CONTACTS_IN_EXPORT )) {
$this -> export_fields_array [ $r ] += array ( 'sp.rowid' => 'IdContact' , 'sp.lastname' => 'Lastname' , 'sp.firstname' => 'Firstname' , 'sp.note_public' => 'NotePublic' );
}
2022-05-17 00:50:59 +02:00
//$this->export_TypeFields_array[$r]=array('s.rowid'=>"Numeric",'s.nom'=>'Text','s.address'=>'Text','s.zip'=>'Text','s.town'=>'Text','co.label'=>'List:c_country:label:label','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",'c.date_creation'=>"Date",'c.date_commande'=>"Date",'c.amount_ht'=>"Numeric",'c.remise_percent'=>"Numeric",'c.total_ht'=>"Numeric",'c.total_ttc'=>"Numeric",'c.facture'=>"Boolean",'c.fk_statut'=>'Status','c.note_public'=>"Text",'c.date_livraison'=>'Date','ed.qty'=>"Text");
2020-04-10 10:59:32 +02:00
$this -> export_TypeFields_array [ $r ] = array (
's.nom' => 'Text' , 's.address' => 'Text' , 's.zip' => 'Text' , 's.town' => 'Text' ,
'co.label' => 'List:c_country:label:label' , 'co.code' => 'Text' , 's.phone' => 'Text' , 's.siren' => 'Text' , 's.siret' => 'Text' , 's.ape' => 'Text' , 's.idprof4' => 'Text' ,
'c.ref' => " Text " , 'c.ref_supplier' => " Text " , 'c.date_creation' => " Date " , 'c.date_delivery' => " Date " , 'c.tracking_number' => " Numeric " , 'c.height' => " Numeric " , 'c.width' => " Numeric " , 'c.weight' => " Numeric " , 'c.fk_statut' => 'Status' , 'c.note_public' => " Text " ,
'ed.qty' => " Numeric " , 'd.nom' => 'Text'
2018-12-15 14:12:39 +01:00
);
2020-04-10 10:59:32 +02:00
$this -> export_entities_array [ $r ] = array (
's.rowid' => " company " , 's.nom' => 'company' , 's.address' => 'company' , 's.zip' => 'company' , 's.town' => 'company' ,
'd.nom' => 'company' , 'co.label' => 'company' , 'co.code' => 'company' , 's.fk_pays' => 'company' , 's.phone' => 'company' , 's.siren' => 'company' , 's.ape' => 'company' , 's.siret' => 'company' , 's.idprof4' => 'company' , 's.idprof5' => 'company' , 's.idprof6' => 'company' ,
2020-04-25 19:13:20 +02:00
'c.rowid' => " reception " , 'c.ref' => " reception " , 'c.ref_supplier' => " reception " , 'c.fk_soc' => " reception " , 'c.date_creation' => " reception " , 'c.date_delivery' => " reception " , 'c.tracking_number' => 'reception' , 'c.height' => " reception " , 'c.width' => " reception " , 'c.size' => 'reception' , 'c.size_units' => 'reception' , 'c.weight' => " reception " , 'c.weight_units' => 'reception' , 'c.fk_statut' => " reception " , 'c.note_public' => " reception " ,
'ed.rowid' => 'reception_line' , 'ed.comment' => 'reception_line' , 'ed.qty' => " reception_line " ,
2020-04-10 10:59:32 +02:00
'p.rowid' => 'product' , 'p.ref' => 'product' , 'p.label' => 'product' , 'p.weight' => 'product' , 'p.weight_units' => 'product' , 'p.volume' => 'product' , 'p.volume_units' => 'product'
2018-12-15 14:12:39 +01:00
);
2021-02-23 22:03:23 +01:00
if ( $idcontacts && ! empty ( $conf -> global -> RECEPTION_ADD_CONTACTS_IN_EXPORT )) {
$this -> export_entities_array [ $r ] += array ( 'sp.rowid' => 'contact' , 'sp.lastname' => 'contact' , 'sp.firstname' => 'contact' , 'sp.note_public' => 'contact' );
}
2020-04-10 10:59:32 +02:00
$this -> export_dependencies_array [ $r ] = array ( 'reception_line' => 'ed.rowid' , 'product' => 'ed.rowid' ); // To add unique key if we ask a field of a child to avoid the DISTINCT to discard them
2021-02-23 22:03:23 +01:00
if ( $idcontacts && ! empty ( $conf -> global -> RECEPTION_ADD_CONTACTS_IN_EXPORT )) {
2021-03-01 20:37:16 +01:00
$keyforselect = 'socpeople' ;
$keyforelement = 'contact' ;
$keyforaliasextra = 'extra3' ;
2020-10-31 14:32:18 +01:00
include DOL_DOCUMENT_ROOT . '/core/extrafieldsinexport.inc.php' ;
2018-10-03 12:22:41 +02:00
}
2021-03-01 20:37:16 +01:00
$keyforselect = 'reception' ;
$keyforelement = 'reception' ;
$keyforaliasextra = 'extra' ;
2018-10-03 12:22:41 +02:00
include DOL_DOCUMENT_ROOT . '/core/extrafieldsinexport.inc.php' ;
2021-03-01 20:37:16 +01:00
$keyforselect = 'commande_fournisseur_dispatch' ;
$keyforelement = 'reception_line' ;
$keyforaliasextra = 'extra2' ;
2018-10-03 12:22:41 +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 . 'reception as c' ;
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'reception_extrafields as extra ON c.rowid = extra.fk_object,' ;
$this -> export_sql_end [ $r ] .= ' ' . MAIN_DB_PREFIX . 'societe as s' ;
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_fournisseur_dispatch as ed' ;
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'commande_fournisseur_dispatch_extrafields as extra2 ON ed.rowid = extra2.fk_object' ;
$this -> export_sql_end [ $r ] .= ' , ' . MAIN_DB_PREFIX . 'commande_fournisseurdet as cd' ;
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'product as p on cd.fk_product = p.rowid' ;
if ( $idcontacts && ! empty ( $conf -> global -> RECEPTION_ADD_CONTACTS_IN_EXPORT )) {
2021-03-22 12:00:41 +01:00
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'element_contact as ee ON ee.element_id = cd.fk_commande AND ee.fk_c_type_contact IN (' . $this -> db -> sanitize ( $idcontacts ) . ')' ;
2020-10-31 14:32:18 +01:00
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'socpeople as sp ON sp.rowid = ee.fk_socpeople' ;
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'socpeople_extrafields as extra3 ON sp.rowid = extra3.fk_object' ;
2018-10-03 12:22:41 +02:00
}
2020-04-10 10:59:32 +02:00
$this -> export_sql_end [ $r ] .= ' WHERE c.fk_soc = s.rowid AND c.rowid = ed.fk_reception AND ed.fk_commandefourndet = cd.rowid' ;
$this -> export_sql_end [ $r ] .= ' AND c.entity IN (' . getEntity ( 'reception' ) . ')' ;
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 );
}
2018-10-03 12:22:41 +02: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 ( '' , 'noboxes' )
2018-10-03 12:22:41 +02:00
* @ return int 1 if OK , 0 if KO
*/
2019-02-25 23:15:48 +01:00
public function init ( $options = '' )
2018-10-03 12:22:41 +02:00
{
2020-04-10 10:59:32 +02:00
global $conf , $langs ;
2018-10-03 12:22:41 +02:00
// Permissions
$this -> remove ( $options );
//ODT template
2020-04-10 10:59:32 +02:00
$src = DOL_DOCUMENT_ROOT . '/install/doctemplates/reception/template_reception.odt' ;
$dirodt = DOL_DATA_ROOT . '/doctemplates/reception' ;
$dest = $dirodt . '/template_reception.odt' ;
2018-10-03 12:22:41 +02:00
2021-02-23 22:03:23 +01:00
if ( file_exists ( $src ) && ! file_exists ( $dest )) {
2018-10-03 12:22:41 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/lib/files.lib.php' ;
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 ) {
2018-10-03 12:22:41 +02:00
$langs -> load ( " errors " );
2020-04-10 10:59:32 +02:00
$this -> error = $langs -> trans ( 'ErrorFailToCopyFile' , $src , $dest );
2018-10-03 12:22:41 +02:00
return 0 ;
}
}
$sql = array ();
$sql = array (
2023-04-10 13:03:09 +02:00
" DELETE FROM " . MAIN_DB_PREFIX . " document_model WHERE nom = ' " . $this -> db -> escape ( $this -> const [ 0 ][ 2 ]) . " ' AND type = 'reception' AND entity = " . (( int ) $conf -> entity ),
" INSERT INTO " . MAIN_DB_PREFIX . " document_model (nom, type, entity) VALUES(' " . $this -> db -> escape ( $this -> const [ 0 ][ 2 ]) . " ','reception', " . (( int ) $conf -> entity ) . " ) " ,
//"DELETE FROM ".MAIN_DB_PREFIX."const WHERE name IN ('STOCK_CALCULATE_ON_SUPPLIER_BILL', 'STOCK_CALCULATE_ON_SUPPLIER_VALIDATE_ORDER', 'STOCK_CALCULATE_ON_SUPPLIER_DISPATCH_ORDER', 'STOCK_CALCULATE_ON_RECEPTION', 'STOCK_CALCULATE_ON_RECEPTION_CLOSE') AND entity = ".((int) $conf->entity),
//"INSERT INTO ".MAIN_DB_PREFIX."const (name, value, entity) VALUES ('STOCK_CALCULATE_ON_RECEPTION_CLOSE', 1, ".((int) $conf->entity).")"
2018-10-03 12:22:41 +02:00
);
2019-01-27 11:55:16 +01:00
return $this -> _init ( $sql , $options );
2018-10-03 12:22:41 +02:00
}
}