2011-09-21 18:40:52 +02:00
< ? php
2011-09-21 15:05:32 +02:00
/* Copyright ( C ) 2003 - 2005 Rodolphe Quiedeville < rodolphe @ quiedeville . org >
* Copyright ( C ) 2004 - 2010 Laurent Destailleur < eldy @ users . sourceforge . net >
2012-12-30 15:13:49 +01:00
* Copyright ( C ) 2005 - 2011 Regis Houssin < regis . houssin @ capnetworks . com >
2011-09-21 15:05:32 +02:00
* Copyright ( C ) 2011 Juanjo Menent < jmenent @ 2 byte . es >
2013-03-17 12:56:54 +01:00
* Copyright ( C ) 2013 Philippe Grand < philippe . grand @ atoo - net . com >
2011-09-21 15:05:32 +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
2011-09-21 15:05:32 +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
* along with this program . If not , see < http :// www . gnu . org / licenses />.
*/
/**
* \defgroup expedition Module shipping
* \brief Module pour gerer les expeditions de produits
2011-10-24 14:11:49 +02:00
* \file htdocs / core / modules / modExpedition . class . php
2011-09-21 15:05:32 +02:00
* \ingroup expedition
* \brief Fichier de description et activation du module Expedition
*/
2012-08-23 02:04:35 +02:00
include_once DOL_DOCUMENT_ROOT . '/core/modules/DolibarrModules.class.php' ;
2011-09-21 15:05:32 +02:00
/**
2012-10-03 00:30:50 +02:00
* Classe de description et activation du module Expedition
2011-09-21 15:05:32 +02:00
*/
class modExpedition extends DolibarrModules
{
/**
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
2011-09-21 15:05:32 +02:00
*/
2012-07-30 17:17:33 +02:00
function __construct ( $db )
2011-09-21 15:05:32 +02:00
{
2012-11-18 15:24:01 +01:00
global $conf ;
2012-01-04 21:23:50 +01:00
$this -> db = $db ;
$this -> numero = 80 ;
2011-09-21 15:05:32 +02:00
$this -> family = " crm " ;
// Module label (no space allowed), used if translation string 'ModuleXXXName' not found (where XXX is value of numeric property 'numero' of module)
$this -> name = preg_replace ( '/^mod/i' , '' , get_class ( $this ));
$this -> description = " Gestion des expeditions " ;
// Possible values for version are: 'development', 'experimental', 'dolibarr' or version
$this -> version = 'dolibarr' ;
$this -> const_name = 'MAIN_MODULE_' . strtoupper ( $this -> name );
$this -> special = 0 ;
$this -> picto = " sending " ;
// Data directories to create when module is enabled
$this -> dirs = array ( " /expedition/temp " ,
" /expedition/sending " ,
" /expedition/sending/temp " ,
" /expedition/receipt " ,
2013-08-07 13:33:22 +02:00
" /expedition/receipt/temp " ,
2013-08-07 13:35:09 +02:00
" /doctemplates/shipment " ,
" /doctemplates/delivery "
2011-09-21 15:05:32 +02:00
);
// Config pages
$this -> config_page_url = array ( " confexped.php " );
// Dependances
$this -> depends = array ( " modCommande " );
$this -> requiredby = array ();
2012-11-18 15:24:01 +01:00
$this -> conflictwith = array ();
2012-11-20 12:11:19 +01:00
$this -> langfiles = array ( 'deliveries' , 'sendings' );
2011-09-21 15:05:32 +02:00
// Constantes
$this -> const = array ();
$r = 0 ;
$this -> const [ $r ][ 0 ] = " EXPEDITION_ADDON_PDF " ;
$this -> const [ $r ][ 1 ] = " chaine " ;
$this -> const [ $r ][ 2 ] = " rouget " ;
$this -> const [ $r ][ 3 ] = 'Nom du gestionnaire de generation des bons expeditions en PDF' ;
$this -> const [ $r ][ 4 ] = 0 ;
$r ++ ;
2012-08-25 15:21:34 +02:00
$this -> const [ $r ][ 0 ] = " EXPEDITION_ADDON_NUMBER " ;
$this -> const [ $r ][ 1 ] = " chaine " ;
$this -> const [ $r ][ 2 ] = " mod_expedition_safor " ;
$this -> const [ $r ][ 3 ] = 'Nom du gestionnaire de numerotation des expeditions' ;
$this -> const [ $r ][ 4 ] = 0 ;
2011-09-21 15:05:32 +02:00
$r ++ ;
2013-08-06 13:22:00 +02:00
2013-07-10 15:54:28 +02:00
$this -> const [ $r ][ 0 ] = " EXPEDITION_ADDON_PDF_ODT_PATH " ;
$this -> const [ $r ][ 1 ] = " chaine " ;
$this -> const [ $r ][ 2 ] = " DOL_DATA_ROOT/doctemplates/shipment " ;
$this -> const [ $r ][ 3 ] = " " ;
$this -> const [ $r ][ 4 ] = 0 ;
2014-05-21 20:34:52 +02:00
$r ++ ;
2014-05-07 09:33:56 +02:00
2011-09-21 15:05:32 +02:00
$this -> const [ $r ][ 0 ] = " LIVRAISON_ADDON_PDF " ;
$this -> const [ $r ][ 1 ] = " chaine " ;
$this -> const [ $r ][ 2 ] = " typhon " ;
$this -> const [ $r ][ 3 ] = 'Nom du gestionnaire de generation des bons de reception en PDF' ;
$this -> const [ $r ][ 4 ] = 0 ;
$r ++ ;
2013-03-17 12:56:54 +01:00
$this -> const [ $r ][ 0 ] = " LIVRAISON_ADDON_NUMBER " ;
2011-09-21 15:05:32 +02:00
$this -> const [ $r ][ 1 ] = " chaine " ;
$this -> const [ $r ][ 2 ] = " mod_livraison_jade " ;
$this -> const [ $r ][ 3 ] = 'Nom du gestionnaire de numerotation des bons de reception' ;
$this -> const [ $r ][ 4 ] = 0 ;
$r ++ ;
2013-08-06 13:22:00 +02:00
2013-08-07 13:33:22 +02:00
$this -> const [ $r ][ 0 ] = " LIVRAISON_ADDON_PDF_ODT_PATH " ;
2013-07-10 15:54:28 +02:00
$this -> const [ $r ][ 1 ] = " chaine " ;
$this -> const [ $r ][ 2 ] = " DOL_DATA_ROOT/doctemplates/delivery " ;
$this -> const [ $r ][ 3 ] = " " ;
$this -> const [ $r ][ 4 ] = 0 ;
2011-09-21 15:05:32 +02:00
// Boxes
$this -> boxes = array ();
// Permissions
$this -> rights = array ();
$this -> rights_class = 'expedition' ;
$r = 0 ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 101 ;
$this -> rights [ $r ][ 1 ] = 'Lire les expeditions' ;
$this -> rights [ $r ][ 2 ] = 'r' ;
$this -> rights [ $r ][ 3 ] = 1 ;
$this -> rights [ $r ][ 4 ] = 'lire' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 102 ;
$this -> rights [ $r ][ 1 ] = 'Creer modifier les expeditions' ;
$this -> rights [ $r ][ 2 ] = 'w' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'creer' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 104 ;
$this -> rights [ $r ][ 1 ] = 'Valider les expeditions' ;
$this -> rights [ $r ][ 2 ] = 'd' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'valider' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 105 ; // id de la permission
$this -> rights [ $r ][ 1 ] = 'Envoyer les expeditions 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 ] = 'shipping_advance' ;
$this -> rights [ $r ][ 5 ] = 'send' ;
2012-11-18 15:24:01 +01:00
$r ++ ;
$this -> rights [ $r ][ 0 ] = 106 ;
$this -> rights [ $r ][ 1 ] = 'Exporter les expeditions' ;
$this -> rights [ $r ][ 2 ] = 'r' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'shipment' ;
$this -> rights [ $r ][ 5 ] = 'export' ;
2011-09-21 15:05:32 +02:00
$r ++ ;
$this -> rights [ $r ][ 0 ] = 109 ;
$this -> rights [ $r ][ 1 ] = 'Supprimer les expeditions' ;
$this -> rights [ $r ][ 2 ] = 'd' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'supprimer' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 1101 ;
$this -> rights [ $r ][ 1 ] = 'Lire les bons de livraison' ;
$this -> rights [ $r ][ 2 ] = 'r' ;
$this -> rights [ $r ][ 3 ] = 1 ;
$this -> rights [ $r ][ 4 ] = 'livraison' ;
$this -> rights [ $r ][ 5 ] = 'lire' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 1102 ;
$this -> rights [ $r ][ 1 ] = 'Creer modifier les bons de livraison' ;
$this -> rights [ $r ][ 2 ] = 'w' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'livraison' ;
$this -> rights [ $r ][ 5 ] = 'creer' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 1104 ;
$this -> rights [ $r ][ 1 ] = 'Valider les bons de livraison' ;
$this -> rights [ $r ][ 2 ] = 'd' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'livraison' ;
$this -> rights [ $r ][ 5 ] = 'valider' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 1109 ;
$this -> rights [ $r ][ 1 ] = 'Supprimer les bons de livraison' ;
$this -> rights [ $r ][ 2 ] = 'd' ;
$this -> rights [ $r ][ 3 ] = 0 ;
$this -> rights [ $r ][ 4 ] = 'livraison' ;
$this -> rights [ $r ][ 5 ] = 'supprimer' ;
2012-11-20 12:11:19 +01:00
// Exports
//--------
$r = 0 ;
$r ++ ;
$this -> export_code [ $r ] = $this -> rights_class . '_' . $r ;
$this -> export_label [ $r ] = 'Shipments' ; // Translation key (used only if key ExportDataset_xxx_z not found)
$this -> export_permission [ $r ] = array ( array ( " expedition " , " shipment " , " export " ));
2014-08-10 13:37:39 +02:00
$this -> export_fields_array [ $r ] = array ( 's.rowid' => " IdCompany " , 's.nom' => 'CompanyName' , 's.address' => 'Address' , 's.zip' => 'Zip' , 's.town' => 'Town' , '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_customer' => " RefCustomer " , 'c.fk_soc' => " IdCompany " , 'c.date_creation' => " DateCreation " , 'c.date_delivery' => " DateSending " , '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' , 'cd.description' => 'Description' , 'ed.qty' => " Qty " , 'p.rowid' => 'ProductId' , 'p.ref' => 'ProductRef' , 'p.label' => 'ProductLabel' );
//$this->export_TypeFields_array[$r]=array('s.rowid'=>"List:societe:nom",'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'=>"Number",'c.remise_percent'=>"Number",'c.total_ht'=>"Number",'c.total_ttc'=>"Number",'c.facture'=>"Boolean",'c.fk_statut'=>'Status','c.note_public'=>"Text",'c.date_livraison'=>'Date','ed.qty'=>"Text");
$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_customer' => " Text " , 'c.date_creation' => " Date " , 'c.date_delivery' => " Date " , 'c.tracking_number' => " Number " , 'c.height' => " Number " , 'c.width' => " Number " , 'c.weight' => " Number " , 'c.fk_statut' => 'Status' , 'c.note_public' => " Text " , 'ed.qty' => " Number " );
2013-08-06 13:22:00 +02:00
$this -> export_entities_array [ $r ] = array ( 's.rowid' => " company " , 's.nom' => 'company' , 's.address' => 'company' , 's.zip' => 'company' , 's.town' => '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' , 'c.rowid' => " shipment " , 'c.ref' => " shipment " , 'c.ref_customer' => " shipment " , 'c.fk_soc' => " shipment " , 'c.date_creation' => " shipment " , 'c.date_delivery' => " shipment " , 'c.tracking_number' => 'shipment' , 'c.height' => " shipment " , 'c.width' => " shipment " , 'c.size' => 'shipment' , 'c.size_units' => 'shipment' , 'c.weight' => " shipment " , 'c.weight_units' => 'shipment' , 'c.fk_statut' => " shipment " , 'c.note_public' => " shipment " , 'ed.rowid' => 'shipment_line' , 'cd.description' => 'shipment_line' , 'ed.qty' => " shipment_line " , 'p.rowid' => 'product' , 'p.ref' => 'product' , 'p.label' => 'product' );
2012-11-20 12:11:19 +01:00
$this -> export_dependencies_array [ $r ] = array ( 'shipment_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
$this -> export_sql_start [ $r ] = 'SELECT DISTINCT ' ;
2013-08-01 12:49:46 +02:00
$this -> export_sql_end [ $r ] = ' FROM ' . MAIN_DB_PREFIX . 'expedition as c, ' . MAIN_DB_PREFIX . 'societe as s' ;
2014-08-10 13:37:39 +02:00
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'c_country as co ON s.fk_pays = co.rowid,' ;
2013-08-06 13:22:00 +02:00
$this -> export_sql_end [ $r ] .= ' ' . MAIN_DB_PREFIX . 'expeditiondet as ed, ' . MAIN_DB_PREFIX . 'commandedet as cd' ;
2013-08-01 12:49:46 +02:00
$this -> export_sql_end [ $r ] .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'product as p on cd.fk_product = p.rowid' ;
2012-11-20 12:11:19 +01:00
$this -> export_sql_end [ $r ] .= ' WHERE c.fk_soc = s.rowid AND c.rowid = ed.fk_expedition AND ed.fk_origin_line = cd.rowid' ;
$this -> export_sql_end [ $r ] .= ' AND c.entity = ' . $conf -> entity ;
2011-09-21 15:05:32 +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
*
* @ param string $options Options when enabling module ( '' , 'noboxes' )
* @ return int 1 if OK , 0 if KO
2011-09-21 15:05:32 +02:00
*/
2012-01-04 21:23:50 +01:00
function init ( $options = '' )
2011-09-21 15:05:32 +02:00
{
2014-04-23 17:35:21 +02:00
global $conf , $langs ;
2011-09-21 15:05:32 +02:00
// Permissions
2012-03-03 17:37:45 +01:00
$this -> remove ( $options );
2013-08-06 13:22:00 +02:00
2013-07-10 15:54:28 +02:00
//ODT template
$src = DOL_DOCUMENT_ROOT . '/install/doctemplates/shipment/template_shipment.odt' ;
$dirodt = DOL_DATA_ROOT . '/doctemplates/shipment' ;
$dest = $dirodt . '/template_shipment.odt' ;
if ( file_exists ( $src ) && ! file_exists ( $dest ))
{
require_once DOL_DOCUMENT_ROOT . '/core/lib/files.lib.php' ;
dol_mkdir ( $dirodt );
$result = dol_copy ( $src , $dest , 0 , 0 );
if ( $result < 0 )
{
$langs -> load ( " errors " );
$this -> error = $langs -> trans ( 'ErrorFailToCopyFile' , $src , $dest );
return 0 ;
}
}
2011-09-21 15:05:32 +02:00
$sql = array ();
$sql = array (
" DELETE FROM " . MAIN_DB_PREFIX . " document_model WHERE nom = ' " . $this -> const [ 0 ][ 2 ] . " ' AND entity = " . $conf -> entity ,
" INSERT INTO " . MAIN_DB_PREFIX . " document_model (nom, type, entity) VALUES(' " . $this -> const [ 0 ][ 2 ] . " ','shipping', " . $conf -> entity . " ) " ,
2014-05-07 09:33:56 +02:00
" DELETE FROM " . MAIN_DB_PREFIX . " document_model WHERE nom = ' " . $this -> const [ 3 ][ 2 ] . " ' AND entity = " . $conf -> entity ,
2014-05-06 13:31:30 +02:00
" INSERT INTO " . MAIN_DB_PREFIX . " document_model (nom, type, entity) VALUES(' " . $this -> const [ 3 ][ 2 ] . " ','delivery', " . $conf -> entity . " ) " ,
2011-09-21 15:05:32 +02:00
);
2012-01-04 21:23:50 +01:00
return $this -> _init ( $sql , $options );
2011-09-21 15:05:32 +02:00
}
2012-03-03 17:37:45 +01:00
/**
* Function called when module is disabled .
* Remove from database constants , boxes and permissions from Dolibarr database .
* Data directories are not deleted
*
* @ param string $options Options when enabling module ( '' , 'noboxes' )
* @ return int 1 if OK , 0 if KO
*/
function remove ( $options = '' )
{
2011-09-21 15:05:32 +02:00
$sql = array ();
2012-03-03 17:37:45 +01:00
return $this -> _remove ( $sql , $options );
}
2011-09-21 15:05:32 +02:00
}