2005-04-13 11:51:00 +02:00
< ? php
2006-02-21 00:43:46 +01:00
/* Copyright ( C ) 2005 Matthieu Valleton < mv @ seeschloss . org >
2007-10-10 01:15:25 +02:00
* Copyright ( C ) 2005 - 2007 Laurent Destailleur < eldy @ users . sourceforge . net >
2005-04-13 11:51:00 +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
* the Free Software Foundation ; either version 2 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
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 59 Temple Place - Suite 330 , Boston , MA 02111 - 1307 , USA .
*/
2005-07-10 21:54:48 +02:00
/**
2007-05-05 00:47:11 +02:00
\defgroup category Module categorie
2005-07-10 21:54:48 +02:00
\brief Module pour g<EFBFBD> rer les cat<EFBFBD> gories
2008-10-28 21:37:30 +01:00
\version $Id $
2005-04-13 11:51:00 +02:00
*/
/**
2005-07-10 21:54:48 +02:00
\file htdocs / includes / modules / modCategorie . class . php
2007-05-05 00:47:11 +02:00
\ingroup category
2005-07-10 21:54:48 +02:00
\brief Fichier de description et activation du module Categorie
2005-04-13 11:51:00 +02:00
*/
2007-10-10 01:15:25 +02:00
include_once ( DOL_DOCUMENT_ROOT . " /includes/modules/DolibarrModules.class.php " );
2005-04-13 11:51:00 +02:00
2006-07-23 03:38:43 +02:00
2006-01-22 19:31:56 +01:00
/**
2006-07-23 03:38:43 +02:00
\class modCategorie
\brief Classe de description et activation du module Categorie
2005-04-13 11:51:00 +02:00
*/
class modCategorie extends DolibarrModules
{
2006-07-23 03:38:43 +02:00
/**
* \brief Constructeur . d<EFBFBD> finit les noms , constantes et bo<EFBFBD> tes
* \param DB handler d ' acc<EFBFBD> s base
*/
function modCategorie ( $DB )
{
$this -> db = $DB ;
$this -> numero = 1780 ;
2007-12-03 03:18:10 +01:00
$this -> family = " technic " ;
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)
$this -> name = eregi_replace ( '^mod' , '' , get_class ( $this ));
2007-12-03 03:18:10 +01:00
$this -> description = " Gestion des cat<61> gories (produits, clients, fournisseurs...) " ;
2006-07-23 03:38:43 +02:00
2008-12-15 23:25:59 +01:00
// Possible values for version are: 'development', 'experimental', 'dolibarr' or version
$this -> version = 'dolibarr' ;
2008-10-06 09:39:52 +02:00
$this -> const_name = 'MAIN_MODULE_' . strtoupper ( $this -> name );
2006-07-23 03:38:43 +02:00
$this -> special = 0 ;
2008-12-05 00:06:45 +01:00
$this -> picto = 'generic' ;
2006-07-23 03:38:43 +02:00
// Dir
$this -> dirs = array ();
2008-12-05 00:06:45 +01:00
// Dependencies
2006-07-23 03:38:43 +02:00
$this -> depends = array ( " modProduit " );
2008-12-05 00:06:45 +01:00
// Config pages
$this -> config_page_url = array ();
$this -> langfiles = array ( " products " , " companies " , " categories " );
2006-07-23 03:38:43 +02:00
// Constantes
$this -> const = array ();
// Boxes
$this -> boxes = array ();
// Permissions
$this -> rights = array ();
$this -> rights_class = 'categorie' ;
$r = 0 ;
$this -> rights [ $r ][ 0 ] = 241 ; // id de la permission
2008-10-28 21:37:30 +01:00
$this -> rights [ $r ][ 1 ] = 'Lire les categories' ; // libelle de la permission
2006-07-23 03:38:43 +02:00
$this -> rights [ $r ][ 2 ] = 'r' ; // type de la permission (d<> pr<70> ci<63> <20> ce jour)
$this -> rights [ $r ][ 3 ] = 1 ; // La permission est-elle une permission par d<> faut
$this -> rights [ $r ][ 4 ] = 'lire' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 242 ; // id de la permission
2008-10-28 21:37:30 +01:00
$this -> rights [ $r ][ 1 ] = 'Creer/modifier les categories' ; // libelle de la permission
2006-07-23 03:38:43 +02:00
$this -> rights [ $r ][ 2 ] = 'w' ; // type de la permission (d<> pr<70> ci<63> <20> ce jour)
$this -> rights [ $r ][ 3 ] = 0 ; // La permission est-elle une permission par d<> faut
$this -> rights [ $r ][ 4 ] = 'creer' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 243 ; // id de la permission
2008-10-28 21:37:30 +01:00
$this -> rights [ $r ][ 1 ] = 'Supprimer les categories' ; // libelle de la permission
2006-07-23 03:38:43 +02:00
$this -> rights [ $r ][ 2 ] = 'd' ; // type de la permission (d<> pr<70> ci<63> <20> ce jour)
$this -> rights [ $r ][ 3 ] = 0 ; // La permission est-elle une permission par d<> faut
$this -> rights [ $r ][ 4 ] = 'supprimer' ;
$r ++ ;
$this -> rights [ $r ][ 0 ] = 244 ; // id de la permission
2008-10-28 21:37:30 +01:00
$this -> rights [ $r ][ 1 ] = 'Voir le contenu des categories cachees' ; // libelle de la permission
2006-07-23 03:38:43 +02:00
$this -> rights [ $r ][ 2 ] = 'r' ; // type de la permission (d<> pr<70> ci<63> <20> ce jour)
$this -> rights [ $r ][ 3 ] = 1 ; // La permission est-elle une permission par d<> faut
$this -> rights [ $r ][ 4 ] = 'voir' ;
$r ++ ;
2008-12-05 00:06:45 +01:00
// Exports
//--------
$r = 0 ;
$r ++ ;
2008-12-06 01:02:54 +01:00
$this -> export_code [ $r ] = 'category_' . $r ;
2008-12-05 00:06:45 +01:00
$this -> export_label [ $r ] = 'List of supplier categories' ;
$this -> export_permission [ $r ] = array ( array ( " categorie " , " lire " ));
2008-12-06 01:02:54 +01:00
$this -> export_fields_array [ $r ] = array ( 'u.rowid' => " CategId " , 'u.label' => " Label " , 'u.description' => " Description " , 's.rowid' => 'CompanyId' , 's.nom' => 'Name' , 's.prefix_comm' => " Prefix " , 's.client' => " Customer " , 's.datec' => " DateCreation " , 's.tms' => " DateLastModification " , 's.code_client' => " CustomerCode " , 's.address' => " Address " , 's.cp' => " Zip " , 's.ville' => " Town " , 'p.libelle' => " Country " , 'p.code' => " CountryCode " , 's.tel' => " Phone " , 's.fax' => " Fax " , 's.url' => " Url " , 's.email' => " Email " , 's.siret' => " IdProf1 " , 's.siren' => " IdProf2 " , 's.ape' => " IdProf3 " , 's.idprof4' => " IdProf4 " , 's.tva_intra' => " VATIntraShort " , 's.capital' => " Capital " , 's.note' => " Note " );
$this -> export_entities_array [ $r ] = array ( 'u.rowid' => " category " , 'u.label' => " category " , 'u.description' => " category " , 's.rowid' => 'company' , 's.nom' => 'company' , 's.prefix_comm' => " company " , 's.client' => " company " , 's.datec' => " company " , 's.tms' => " company " , 's.code_client' => " company " , 's.address' => " company " , 's.cp' => " company " , 's.ville' => " company " , 'p.libelle' => " company " , 'p.code' => " company " , 's.tel' => " company " , 's.fax' => " company " , 's.url' => " company " , 's.email' => " company " , 's.siret' => " company " , 's.siren' => " company " , 's.ape' => " company " , 's.idprof4' => " company " , 's.tva_intra' => " company " , 's.capital' => " company " , 's.note' => " company " );
$this -> export_alias_array [ $r ] = array ( 'u.rowid' => " idcateg " , 'u.label' => " label " , 'u.description' => " description " , 's.rowid' => 'idsoc' , 's.nom' => 'name' , 's.prefix_comm' => " prefix " , 's.client' => " iscustomer " , 's.datec' => " datecreation " , 's.tms' => " datelastmodification " , 's.code_client' => " customercode " , 's.address' => " address " , 's.cp' => " zip " , 's.ville' => " town " , 'p.libelle' => " country " , 'p.code' => " countrycode " , 's.tel' => " phone " , 's.fax' => " fax " , 's.url' => " url " , 's.email' => " email " , 's.siret' => " idprof1 " , 's.siren' => " idprof2 " , 's.ape' => " idprof3 " , 's.idprof4' => " idprof4 " , 's.tva_intra' => " vatintra " , 's.capital' => " capital " , 's.note' => " note " );
2008-12-05 00:06:45 +01:00
$this -> export_sql_start [ $r ] = 'SELECT DISTINCT ' ;
2008-12-06 01:02:54 +01:00
$this -> export_sql_end [ $r ] = ' FROM ' . MAIN_DB_PREFIX . 'categorie as u, ' . MAIN_DB_PREFIX . 'categorie_fournisseur as cf, ' . MAIN_DB_PREFIX . 'societe as s LEFT JOIN ' . MAIN_DB_PREFIX . 'c_typent as t ON s.fk_typent = t.id LEFT JOIN ' . MAIN_DB_PREFIX . 'c_pays as p ON s.fk_pays = p.rowid LEFT JOIN ' . MAIN_DB_PREFIX . 'c_effectif as ce ON s.fk_effectif = ce.id LEFT JOIN ' . MAIN_DB_PREFIX . 'c_forme_juridique as cfj ON s.fk_forme_juridique = cfj.code' ;
2008-12-05 00:06:45 +01:00
$this -> export_sql_end [ $r ] .= ' WHERE u.rowid = cf.fk_categorie AND cf.fk_societe = s.rowid' ;
$this -> export_sql_end [ $r ] .= ' AND u.type = 1' ; // Supplier categories
$r ++ ;
2008-12-06 01:02:54 +01:00
$this -> export_code [ $r ] = 'category_' . $r ;
2008-12-05 00:06:45 +01:00
$this -> export_label [ $r ] = 'List of customer/prospect categories' ;
$this -> export_permission [ $r ] = array ( array ( " categorie " , " lire " ));
2008-12-17 20:15:54 +01:00
$this -> export_fields_array [ $r ] = array ( 'u.rowid' => " CategId " , 'u.label' => " Label " , 'u.description' => " Description " , 's.rowid' => 'CompanyId' , 's.nom' => 'Name' , 's.prefix_comm' => " Prefix " , 's.client' => " Customer " , 's.datec' => " DateCreation " , 's.tms' => " DateLastModification " , 's.code_client' => " CustomerCode " , 's.address' => " Address " , 's.cp' => " Zip " , 's.ville' => " Town " , 'p.libelle' => " Country " , 'p.code' => " CountryCode " , 's.tel' => " Phone " , 's.fax' => " Fax " , 's.url' => " Url " , 's.email' => " Email " , 's.siret' => " IdProf1 " , 's.siren' => " IdProf2 " , 's.ape' => " IdProf3 " , 's.idprof4' => " IdProf4 " , 's.tva_intra' => " VATIntraShort " , 's.capital' => " Capital " , 's.note' => " Note " , 's.fk_prospectlevel' => 'ProspectLevel' , 'fk_stcomm' => 'ProspectStatus' );
$this -> export_entities_array [ $r ] = array ( 'u.rowid' => " category " , 'u.label' => " category " , 'u.description' => " category " , 's.rowid' => 'company' , 's.nom' => 'company' , 's.prefix_comm' => " company " , 's.client' => " company " , 's.datec' => " company " , 's.tms' => " company " , 's.code_client' => " company " , 's.address' => " company " , 's.cp' => " company " , 's.ville' => " company " , 'p.libelle' => " company " , 'p.code' => " company " , 's.tel' => " company " , 's.fax' => " company " , 's.url' => " company " , 's.email' => " company " , 's.siret' => " company " , 's.siren' => " company " , 's.ape' => " company " , 's.idprof4' => " company " , 's.tva_intra' => " company " , 's.capital' => " company " , 's.note' => " company " , 's.fk_prospectlevel' => 'company' , 'fk_stcomm' => 'company' );
$this -> export_alias_array [ $r ] = array ( 'u.rowid' => " idcateg " , 'u.label' => " label " , 'u.description' => " description " , 's.rowid' => 'idsoc' , 's.nom' => 'name' , 's.prefix_comm' => " prefix " , 's.client' => " iscustomer " , 's.datec' => " datecreation " , 's.tms' => " datelastmodification " , 's.code_client' => " customercode " , 's.address' => " address " , 's.cp' => " zip " , 's.ville' => " town " , 'p.libelle' => " country " , 'p.code' => " countrycode " , 's.tel' => " phone " , 's.fax' => " fax " , 's.url' => " url " , 's.email' => " email " , 's.siret' => " idprof1 " , 's.siren' => " idprof2 " , 's.ape' => " idprof3 " , 's.idprof4' => " idprof4 " , 's.tva_intra' => " vatintra " , 's.capital' => " capital " , 's.note' => " note " , 's.fk_prospectlevel' => 'prospectlevel' , 'fk_stcomm' => 'prospectstatus' );
2008-12-05 00:06:45 +01:00
$this -> export_sql_start [ $r ] = 'SELECT DISTINCT ' ;
2008-12-06 01:02:54 +01:00
$this -> export_sql_end [ $r ] = ' FROM ' . MAIN_DB_PREFIX . 'categorie as u, ' . MAIN_DB_PREFIX . 'categorie_societe as cf, ' . MAIN_DB_PREFIX . 'societe as s LEFT JOIN ' . MAIN_DB_PREFIX . 'c_typent as t ON s.fk_typent = t.id LEFT JOIN ' . MAIN_DB_PREFIX . 'c_pays as p ON s.fk_pays = p.rowid LEFT JOIN ' . MAIN_DB_PREFIX . 'c_effectif as ce ON s.fk_effectif = ce.id LEFT JOIN ' . MAIN_DB_PREFIX . 'c_forme_juridique as cfj ON s.fk_forme_juridique = cfj.code' ;
2008-12-05 00:06:45 +01:00
$this -> export_sql_end [ $r ] .= ' WHERE u.rowid = cf.fk_categorie AND cf.fk_societe = s.rowid' ;
$this -> export_sql_end [ $r ] .= ' AND u.type = 2' ; // Customer/Prospect categories
$r ++ ;
2008-12-06 01:02:54 +01:00
$this -> export_code [ $r ] = 'category_' . $r ;
2008-12-05 00:06:45 +01:00
$this -> export_label [ $r ] = 'List of products categories' ;
$this -> export_permission [ $r ] = array ( array ( " categorie " , " lire " ));
$this -> export_fields_array [ $r ] = array ( 'u.rowid' => " CategId " , 'u.label' => " Label " , 'u.description' => " Description " , 'p.rowid' => 'ProductId' , 'p.ref' => 'Ref' );
$this -> export_entities_array [ $r ] = array ( 'u.rowid' => " category " , 'u.label' => " category " , 'u.description' => " category " , 'p.rowid' => 'product' , 'p.ref' => 'product' );
$this -> export_alias_array [ $r ] = array ( 'u.rowid' => " idcateg " , 'u.label' => " label " , 'u.description' => " description " , 'p.rowid' => 'idprod' , 'p.ref' => 'ref' );
$this -> export_sql_start [ $r ] = 'SELECT DISTINCT ' ;
$this -> export_sql_end [ $r ] = ' FROM ' . MAIN_DB_PREFIX . 'categorie as u, ' . MAIN_DB_PREFIX . 'categorie_product as cp, ' . MAIN_DB_PREFIX . 'product as p' ;
$this -> export_sql_end [ $r ] .= ' WHERE u.rowid = cp.fk_categorie AND cp.fk_product = p.rowid' ;
$this -> export_sql_end [ $r ] .= ' AND u.type = 0' ; // Supplier categories
2006-07-23 03:38:43 +02:00
}
/**
* \brief Fonction appel<EFBFBD> e lors de l ' activation du module . Ins<EFBFBD> re en base les constantes , boites , permissions du module .
* D<EFBFBD> finit <EFBFBD> galement les r<EFBFBD> pertoires de donn<EFBFBD> es <EFBFBD> cr<EFBFBD> er pour ce module .
*/
function init ()
{
// Permissions
$this -> remove ();
$sql = array ();
return $this -> _init ( $sql );
}
/**
* \brief Fonction appel<EFBFBD> e lors de la d<EFBFBD> sactivation d ' un module .
* Supprime de la base les constantes , boites et permissions du module .
*/
function remove ()
{
$sql = array ();
return $this -> _remove ( $sql );
}
2005-04-13 11:51:00 +02:00
}
?>