From 0b1d544dbd36cfc117f7c686a43e0fbea4a0da2a Mon Sep 17 00:00:00 2001 From: Regis Houssin Date: Sat, 19 May 2007 12:53:48 +0000 Subject: [PATCH] =?UTF-8?q?Add:=20mod=E8le=20de=20num=E9rotation=20param?= =?UTF-8?q?=E9trable=20"saphir"=20pour=20les=20bons=20de=20livraisons=20Fi?= =?UTF-8?q?x:=20uniformisation=20du=20code?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- htdocs/admin/commande.php | 2 +- htdocs/admin/livraison.php | 8 +- htdocs/admin/propale.php | 2 +- .../modules/commande/mod_commande_saphir.php | 40 +- .../modules/facture/pluton/pluton.modules.php | 26 +- .../modules/propale/mod_propale_saphir.php | 38 +- htdocs/livraison/mods/mod_livraison_jade.php | 4 +- .../livraison/mods/mod_livraison_saphir.php | 452 ++++++++++++++++++ 8 files changed, 515 insertions(+), 57 deletions(-) create mode 100644 htdocs/livraison/mods/mod_livraison_saphir.php diff --git a/htdocs/admin/commande.php b/htdocs/admin/commande.php index 3fa15930145..30d11a85407 100644 --- a/htdocs/admin/commande.php +++ b/htdocs/admin/commande.php @@ -136,7 +136,7 @@ if ($_POST["action"] == 'deliverycostline') // défini les constantes du modèle saphir if ($_POST["action"] == 'updateMatrice') dolibarr_set_const($db, "COMMANDE_NUM_MATRICE",$_POST["matrice"]); -if ($_POST["action"] == 'updatePrefixCommande') dolibarr_set_const($db, "COMMANDE_NUM_PREFIX",$_POST["prefixcommande"]); +if ($_POST["action"] == 'updatePrefix') dolibarr_set_const($db, "COMMANDE_NUM_PREFIX",$_POST["prefix"]); if ($_POST["action"] == 'setOffset') dolibarr_set_const($db, "COMMANDE_NUM_DELTA",$_POST["offset"]); if ($_POST["action"] == 'setFiscalMonth') dolibarr_set_const($db, "SOCIETE_FISCAL_MONTH_START",$_POST["fiscalmonth"]); if ($_POST["action"] == 'setNumRestart') dolibarr_set_const($db, "COMMANDE_NUM_RESTART_BEGIN_YEAR",$_POST["numrestart"]); diff --git a/htdocs/admin/livraison.php b/htdocs/admin/livraison.php index 66868d7c032..5fb39432385 100644 --- a/htdocs/admin/livraison.php +++ b/htdocs/admin/livraison.php @@ -4,7 +4,7 @@ * Copyright (C) 2004 Sebastien Di Cintio * Copyright (C) 2004 Benoit Mortier * Copyright (C) 2004 Eric Seigne - * Copyright (C) 2005-2006 Regis Houssin + * Copyright (C) 2005-2007 Regis Houssin * * 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 @@ -101,6 +101,12 @@ if ($_GET["action"] == 'setmod') dolibarr_set_const($db, "LIVRAISON_ADDON",$_GET["value"]); } +// défini les constantes du modèle saphir +if ($_POST["action"] == 'updateMatrice') dolibarr_set_const($db, "LIVRAISON_NUM_MATRICE",$_POST["matrice"]); +if ($_POST["action"] == 'updatePrefix') dolibarr_set_const($db, "LIVRAISON_NUM_PREFIX",$_POST["prefix"]); +if ($_POST["action"] == 'setOffset') dolibarr_set_const($db, "LIVRAISON_NUM_DELTA",$_POST["offset"]); +if ($_POST["action"] == 'setFiscalMonth') dolibarr_set_const($db, "SOCIETE_FISCAL_MONTH_START",$_POST["fiscalmonth"]); +if ($_POST["action"] == 'setNumRestart') dolibarr_set_const($db, "LIVRAISON_NUM_RESTART_BEGIN_YEAR",$_POST["numrestart"]); /* diff --git a/htdocs/admin/propale.php b/htdocs/admin/propale.php index 0e1eb6646bc..cabc79057e1 100644 --- a/htdocs/admin/propale.php +++ b/htdocs/admin/propale.php @@ -148,7 +148,7 @@ if ($_GET["action"] == 'setmod') // défini les constantes du modèle saphir if ($_POST["action"] == 'updateMatrice') dolibarr_set_const($db, "PROPALE_NUM_MATRICE",$_POST["matrice"]); -if ($_POST["action"] == 'updatePrefixPropale') dolibarr_set_const($db, "PROPALE_NUM_PREFIX",$_POST["prefixpropale"]); +if ($_POST["action"] == 'updatePrefix') dolibarr_set_const($db, "PROPALE_NUM_PREFIX",$_POST["prefix"]); if ($_POST["action"] == 'setOffset') dolibarr_set_const($db, "PROPALE_NUM_DELTA",$_POST["offset"]); if ($_POST["action"] == 'setFiscalMonth') dolibarr_set_const($db, "SOCIETE_FISCAL_MONTH_START",$_POST["fiscalmonth"]); if ($_POST["action"] == 'setNumRestart') dolibarr_set_const($db, "PROPALE_NUM_RESTART_BEGIN_YEAR",$_POST["numrestart"]); diff --git a/htdocs/includes/modules/commande/mod_commande_saphir.php b/htdocs/includes/modules/commande/mod_commande_saphir.php index 3021c2f0571..72cf177eb79 100644 --- a/htdocs/includes/modules/commande/mod_commande_saphir.php +++ b/htdocs/includes/modules/commande/mod_commande_saphir.php @@ -75,8 +75,8 @@ function info() // Paramétrage du prefix des commandes $texte.= 'Préfix des commandes'; $texte.= '
'; - $texte.= ''; - $texte.= ''; + $texte.= ''; + $texte.= ''; $texte.= ''; $texte.= ''.$form->textwithhelp('',$langs->trans("PrefixOrderDesc"),1,1).''; $texte.= '
'; @@ -122,10 +122,10 @@ function info() { global $conf; - $this->prefixorder = $conf->global->COMMANDE_NUM_PREFIX; - $this->ordernummatrice = $conf->global->COMMANDE_NUM_MATRICE; + $this->prefix = $conf->global->COMMANDE_NUM_PREFIX; + $this->matrice = $conf->global->COMMANDE_NUM_MATRICE; - if ($this->ordernummatrice != '') + if ($this->matrice != '') { $resultatMatrice = Array(); $numMatrice = ''; @@ -143,7 +143,7 @@ function info() ); // on détermine l'emplacement des tirets - $resultTiret = preg_split('/'.$matriceTiret.'/',$this->ordernummatrice, -1, PREG_SPLIT_OFFSET_CAPTURE); + $resultTiret = preg_split('/'.$matriceTiret.'/',$this->matrice, -1, PREG_SPLIT_OFFSET_CAPTURE); $j = 0; @@ -178,7 +178,7 @@ function info() } else if ($idMatrice == 'prefix' && $resultatMatrice[0] == 'PREF') { - $prefix = $this->prefixorder; + $prefix = $this->prefix; $numMatrice .= $prefix; } else if ($idMatrice == 'year') @@ -236,10 +236,10 @@ function info() { global $db,$conf; - $this->prefixorder = $conf->global->COMMANDE_NUM_PREFIX; - $this->ordernummatrice = $conf->global->COMMANDE_NUM_MATRICE; + $this->prefix = $conf->global->COMMANDE_NUM_PREFIX; + $this->matrice = $conf->global->COMMANDE_NUM_MATRICE; - if ($this->ordernummatrice != '') + if ($this->matrice != '') { $resultatMatrice = Array(); $numMatrice = Array(); @@ -257,7 +257,7 @@ function info() ); // on détermine l'emplacement des tirets - $resultTiret = preg_split('/'.$matriceTiret.'/',$this->ordernummatrice, -1, PREG_SPLIT_OFFSET_CAPTURE); + $resultTiret = preg_split('/'.$matriceTiret.'/',$this->matrice, -1, PREG_SPLIT_OFFSET_CAPTURE); $j = 0; $k = 0; @@ -301,7 +301,7 @@ function info() } else if ($idMatrice == 'prefix' && $resultatMatrice[0] == 'PREF') { - $prefix = $this->prefixorder; + $prefix = $this->prefix; $numMatrice[$k] = '$prefix'; $searchLast .= $prefix; $searchLastWithNoYear .= $prefix; @@ -367,7 +367,7 @@ function info() // On récupère la valeur max (réponse immédiate car champ indéxé) $posindice = $numbitcounter; - $comyy=''; + $searchyy=''; $sql = "SELECT MAX(ref)"; $sql.= " FROM ".MAIN_DB_PREFIX."commande"; if ($conf->global->COMMANDE_NUM_RESTART_BEGIN_YEAR) $sql.= " WHERE ref like '${searchLast}%'"; @@ -375,14 +375,14 @@ function info() if ($resql) { $row = $db->fetch_row($resql); - if ($row) $comyy = substr($row[0],0,-$posindice); + if ($row) $searchyy = substr($row[0],0,-$posindice); } if ($conf->global->COMMANDE_NUM_DELTA != '') { //on vérifie si il y a une année précédente //pour éviter que le delta soit appliqué de nouveau sur la nouvelle année - $lastyy=''; + $previousyy=''; $sql = "SELECT MAX(ref)"; $sql.= " FROM ".MAIN_DB_PREFIX."commande"; $sql.= " WHERE ref like '${searchLastWithPreviousYear}%'"; @@ -390,17 +390,17 @@ function info() if ($resql) { $row = $db->fetch_row($resql); - if ($row) $lastyy = substr($row[0],0,-$posindice); + if ($row) $previousyy = substr($row[0],0,-$posindice); } } // Si au moins un champ respectant le modèle a été trouvée - if (eregi('^'.$searchLastWithNoYear.'',$comyy)) + if (eregi('^'.$searchLastWithNoYear.'',$searchyy)) { // Recherche rapide car restreint par un like sur champ indexé $sql = "SELECT MAX(0+SUBSTRING(ref,-".$posindice."))"; $sql.= " FROM ".MAIN_DB_PREFIX."commande"; - $sql.= " WHERE ref like '${comyy}%'"; + $sql.= " WHERE ref like '${searchyy}%'"; $resql=$db->query($sql); if ($resql) { @@ -408,7 +408,7 @@ function info() $max = $row[0]; } } - else if ($conf->global->COMMANDE_NUM_DELTA != '' && !eregi('^'.$searchLastWithPreviousYear.'',$lastyy)) + else if ($conf->global->COMMANDE_NUM_DELTA != '' && !eregi('^'.$searchLastWithPreviousYear.'',$previousyy)) { // on applique le delta une seule fois $max=$conf->global->COMMANDE_NUM_DELTA?$conf->global->COMMANDE_NUM_DELTA-1:0; @@ -446,7 +446,7 @@ function info() function commande_get_num($objsoc=0) { return $this->getNextValue($objsoc); - } + } } ?> \ No newline at end of file diff --git a/htdocs/includes/modules/facture/pluton/pluton.modules.php b/htdocs/includes/modules/facture/pluton/pluton.modules.php index 9c16e08be60..119ca203555 100644 --- a/htdocs/includes/modules/facture/pluton/pluton.modules.php +++ b/htdocs/includes/modules/facture/pluton/pluton.modules.php @@ -136,10 +136,10 @@ function info() global $conf; $this->prefixinvoice = $conf->global->FACTURE_NUM_PREFIX; - $this->prefixcreditnote = $conf->global->AVOIR_NUM_PREFIX; - $this->facturenummatrice = $conf->global->FACTURE_NUM_MATRICE; + $this->prefixcreditnote = $conf->global->AVOIR_NUM_PREFIX; + $this->matrice = $conf->global->FACTURE_NUM_MATRICE; - if ($this->facturenummatrice != '') + if ($this->matrice != '') { $resultatMatrice = Array(); $numMatrice = ''; @@ -157,7 +157,7 @@ function info() ); // on détermine l'emplacement des tirets - $resultTiret = preg_split('/'.$matriceTiret.'/',$this->facturenummatrice, -1, PREG_SPLIT_OFFSET_CAPTURE); + $resultTiret = preg_split('/'.$matriceTiret.'/',$this->matrice, -1, PREG_SPLIT_OFFSET_CAPTURE); $j = 0; @@ -268,9 +268,9 @@ function info() $this->prefixinvoice = $conf->global->FACTURE_NUM_PREFIX; $this->prefixcreditnote = $conf->global->AVOIR_NUM_PREFIX; - $this->facturenummatrice = $conf->global->FACTURE_NUM_MATRICE; + $this->matrice = $conf->global->FACTURE_NUM_MATRICE; - if ($this->facturenummatrice != '') + if ($this->matrice != '') { $resultatMatrice = Array(); $numMatrice = Array(); @@ -288,7 +288,7 @@ function info() ); // on détermine l'emplacement des tirets - $resultTiret = preg_split('/'.$matriceTiret.'/',$this->facturenummatrice, -1, PREG_SPLIT_OFFSET_CAPTURE); + $resultTiret = preg_split('/'.$matriceTiret.'/',$this->matrice, -1, PREG_SPLIT_OFFSET_CAPTURE); $j = 0; $k = 0; @@ -406,7 +406,7 @@ function info() // On récupère la valeur max (réponse immédiate car champ indéxé) $posindice = $numbitcounter; - $fayy=''; + $searchyy=''; $sql = "SELECT MAX(facnumber)"; $sql.= " FROM ".MAIN_DB_PREFIX."facture"; if ($conf->global->FACTURE_NUM_RESTART_BEGIN_YEAR) $sql.= " WHERE facnumber like '${searchLast}%'"; @@ -421,7 +421,7 @@ function info() { //on vérifie si il y a une année précédente //pour éviter que le delta soit appliqué de nouveau sur la nouvelle année - $lastyy=''; + $previousyy=''; $sql = "SELECT MAX(facnumber)"; $sql.= " FROM ".MAIN_DB_PREFIX."facture"; $sql.= " WHERE facnumber like '${searchLastWithPreviousYear}%'"; @@ -429,17 +429,17 @@ function info() if ($resql) { $row = $db->fetch_row($resql); - if ($row) $lastyy = substr($row[0],0,-$posindice); + if ($row) $previousyy = substr($row[0],0,-$posindice); } } // Si au moins un champ respectant le modèle a été trouvée - if (eregi('^'.$searchLastWithNoYear.'',$fayy)) + if (eregi('^'.$searchLastWithNoYear.'',$searchyy)) { // Recherche rapide car restreint par un like sur champ indexé $sql = "SELECT MAX(0+SUBSTRING(facnumber,-".$posindice."))"; $sql.= " FROM ".MAIN_DB_PREFIX."facture"; - $sql.= " WHERE facnumber like '${fayy}%'"; + $sql.= " WHERE facnumber like '${searchyy}%'"; $resql=$db->query($sql); if ($resql) { @@ -447,7 +447,7 @@ function info() $max = $row[0]; } } - else if ($conf->global->PROPALE_NUM_DELTA != '' && !eregi('^'.$searchLastWithPreviousYear.'',$lastyy)) + else if ($conf->global->PROPALE_NUM_DELTA != '' && !eregi('^'.$searchLastWithPreviousYear.'',$previousyy)) { // on applique le delta une seule fois $max=$conf->global->FACTURE_NUM_DELTA?$conf->global->FACTURE_NUM_DELTA-1:0; diff --git a/htdocs/includes/modules/propale/mod_propale_saphir.php b/htdocs/includes/modules/propale/mod_propale_saphir.php index 2c792dd5454..a8028b5e72c 100644 --- a/htdocs/includes/modules/propale/mod_propale_saphir.php +++ b/htdocs/includes/modules/propale/mod_propale_saphir.php @@ -75,8 +75,8 @@ function info() // Paramétrage du prefix des commandes $texte.= 'Préfix des propositions commerciales'; $texte.= '
'; - $texte.= ''; - $texte.= ''; + $texte.= ''; + $texte.= ''; $texte.= ''; $texte.= ''.$form->textwithhelp('',$langs->trans("PrefixProposalDesc"),1,1).''; $texte.= '
'; @@ -122,10 +122,10 @@ function info() { global $conf; - $this->prefixproposal = $conf->global->PROPALE_NUM_PREFIX; - $this->proposalnummatrice = $conf->global->PROPALE_NUM_MATRICE; + $this->prefix = $conf->global->PROPALE_NUM_PREFIX; + $this->matrice = $conf->global->PROPALE_NUM_MATRICE; - if ($this->proposalnummatrice != '') + if ($this->matrice != '') { $resultatMatrice = Array(); $numMatrice = ''; @@ -143,7 +143,7 @@ function info() ); // on détermine l'emplacement des tirets - $resultTiret = preg_split('/'.$matriceTiret.'/',$this->proposalnummatrice, -1, PREG_SPLIT_OFFSET_CAPTURE); + $resultTiret = preg_split('/'.$matriceTiret.'/',$this->matrice, -1, PREG_SPLIT_OFFSET_CAPTURE); $j = 0; @@ -178,7 +178,7 @@ function info() } else if ($idMatrice == 'prefix' && $resultatMatrice[0] == 'PREF') { - $prefix = $this->prefixproposal; + $prefix = $this->prefix; $numMatrice .= $prefix; } else if ($idMatrice == 'year') @@ -236,10 +236,10 @@ function info() { global $db,$conf; - $this->prefixproposal = $conf->global->PROPALE_NUM_PREFIX; - $this->proposalnummatrice = $conf->global->PROPALE_NUM_MATRICE; + $this->prefix = $conf->global->PROPALE_NUM_PREFIX; + $this->matrice = $conf->global->PROPALE_NUM_MATRICE; - if ($this->proposalnummatrice != '') + if ($this->matrice != '') { $resultatMatrice = Array(); $numMatrice = Array(); @@ -257,7 +257,7 @@ function info() ); // on détermine l'emplacement des tirets - $resultTiret = preg_split('/'.$matriceTiret.'/',$this->proposalnummatrice, -1, PREG_SPLIT_OFFSET_CAPTURE); + $resultTiret = preg_split('/'.$matriceTiret.'/',$this->matrice, -1, PREG_SPLIT_OFFSET_CAPTURE); $j = 0; $k = 0; @@ -301,7 +301,7 @@ function info() } else if ($idMatrice == 'prefix' && $resultatMatrice[0] == 'PREF') { - $prefix = $this->prefixproposal; + $prefix = $this->prefix; $numMatrice[$k] = '$prefix'; $searchLast .= $prefix; $searchLastWithNoYear .= $prefix; @@ -367,7 +367,7 @@ function info() // On récupère la valeur max (réponse immédiate car champ indéxé) $posindice = $numbitcounter; - $pryy=''; + $searchyy=''; $sql = "SELECT MAX(ref)"; $sql.= " FROM ".MAIN_DB_PREFIX."propal"; if ($conf->global->PROPALE_NUM_RESTART_BEGIN_YEAR) $sql.= " WHERE ref like '${searchLast}%'"; @@ -375,14 +375,14 @@ function info() if ($resql) { $row = $db->fetch_row($resql); - if ($row) $pryy = substr($row[0],0,-$posindice); + if ($row) $searchyy = substr($row[0],0,-$posindice); } if ($conf->global->PROPALE_NUM_DELTA != '') { //on vérifie si il y a une année précédente //pour éviter que le delta soit appliqué de nouveau sur la nouvelle année - $lastyy=''; + $previousyy=''; $sql = "SELECT MAX(ref)"; $sql.= " FROM ".MAIN_DB_PREFIX."propal"; $sql.= " WHERE ref like '${searchLastWithPreviousYear}%'"; @@ -390,17 +390,17 @@ function info() if ($resql) { $row = $db->fetch_row($resql); - if ($row) $lastyy = substr($row[0],0,-$posindice); + if ($row) $previousyy = substr($row[0],0,-$posindice); } } // Si au moins un champ respectant le modèle a été trouvée - if (eregi('^'.$searchLastWithNoYear.'',$pryy)) + if (eregi('^'.$searchLastWithNoYear.'',$searchyy)) { // Recherche rapide car restreint par un like sur champ indexé $sql = "SELECT MAX(0+SUBSTRING(ref,-".$posindice."))"; $sql.= " FROM ".MAIN_DB_PREFIX."propal"; - $sql.= " WHERE ref like '${pryy}%'"; + $sql.= " WHERE ref like '${searchyy}%'"; $resql=$db->query($sql); if ($resql) { @@ -408,7 +408,7 @@ function info() $max = $row[0]; } } - else if ($conf->global->PROPALE_NUM_DELTA != '' && !eregi('^'.$searchLastWithPreviousYear.'',$lastyy)) + else if ($conf->global->PROPALE_NUM_DELTA != '' && !eregi('^'.$searchLastWithPreviousYear.'',$previousyy)) { // on applique le delta une seule fois $max=$conf->global->PROPALE_NUM_DELTA?$conf->global->PROPALE_NUM_DELTA-1:0; diff --git a/htdocs/livraison/mods/mod_livraison_jade.php b/htdocs/livraison/mods/mod_livraison_jade.php index aee1a168ac1..9a5b538bf52 100644 --- a/htdocs/livraison/mods/mod_livraison_jade.php +++ b/htdocs/livraison/mods/mod_livraison_jade.php @@ -1,6 +1,6 @@ - * Copyright (C) 2005-2006 Regis Houssin + * Copyright (C) 2005-2007 Regis Houssin * * 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 @@ -29,7 +29,7 @@ \version $Revision$ */ -include_once("modules_livraison.php"); +require_once(DOL_DOCUMENT_ROOT ."/livraison/mods/modules_livraison.php"); /** diff --git a/htdocs/livraison/mods/mod_livraison_saphir.php b/htdocs/livraison/mods/mod_livraison_saphir.php new file mode 100644 index 00000000000..6655fea826b --- /dev/null +++ b/htdocs/livraison/mods/mod_livraison_saphir.php @@ -0,0 +1,452 @@ + + * Copyright (C) 2004-2007 Laurent Destailleur + * Copyright (C) 2005-2007 Regis Houssin + * + * 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. + * or see http://www.gnu.org/ + * + * $Id$ + * $Source$ + * + */ + +/** + \file htdocs/includes/modules/commande/mod_livraison_saphir.php + \ingroup commande + \brief Fichier contenant la classe du modèle de numérotation de référence de livraison Saphir + \version $Revision$ +*/ + +require_once(DOL_DOCUMENT_ROOT ."/livraison/mods/modules_livraison.php"); + +/** + \class mod_livraison_saphir + \brief Classe du modèle de numérotation de référence de livraison Saphir +*/ +class mod_livraison_saphir extends ModeleNumRefDeliveryOrder +{ + var $prefixorder=''; + var $ordernummatrice=''; + var $error=''; + + /** \brief Constructeur + */ + function mod_livraison_saphir() + { + $this->nom = "Saphir"; + } + + /** \brief Renvoi la description du modele de numérotation + * \return string Texte descripif + */ +function info() + { + global $conf,$langs; + + $langs->load("bills"); + + $form = new Form($db); + + $texte = $langs->trans('SaphirNumRefModelDesc1')."
\n"; + $texte.= ''; + + // Paramétrage de la matrice + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + + // Paramétrage du prefix des commandes + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + + // On détermine un offset sur le compteur + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + + // On défini le debut d'année fiscale + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + + // On défini si le compteur se remet à zero en debut d'année + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + $texte.= ''; + + $texte.= '
Matrice de disposition des objets (prefix,mois,année,compteur...)
'.$form->textwithhelp('',$langs->trans("MatriceOrderDesc"),1,1).'
Préfix des bons de livraions
'.$form->textwithhelp('',$langs->trans("PrefixOrderDesc"),1,1).'
Appliquer un offset sur le compteur
'.$form->textwithhelp('',$langs->trans("OffsetDesc"),1,1).'
Début d\'année fiscale
'; + $texte.= $form->select_month($conf->global->SOCIETE_FISCAL_MONTH_START,'fiscalmonth',1); + $texte.= ''.$form->textwithwarning('',$langs->trans("FiscalMonthStartDesc"),1).'
Le compteur se remet à zéro en début d\'année
'; + $texte.= $form->selectyesno('numrestart',$conf->global->LIVRAISON_NUM_RESTART_BEGIN_YEAR,1); + $texte.= ''.$form->textwithhelp('',$langs->trans("NumRestartDesc"),1,1).'

'; + + return $texte; + } + + /** \brief Renvoi un exemple de numérotation + * \return string Example + */ + function getExample() + { + global $conf; + + $this->prefix = $conf->global->LIVRAISON_NUM_PREFIX; + $this->matrice = $conf->global->LIVRAISON_NUM_MATRICE; + + if ($this->matrice != '') + { + $resultatMatrice = Array(); + $numMatrice = ''; + + $matricePrefix = "PREF|COM"; // PREF : prefix libre (ex: BL pour bon de livraison), COM : prefix du client + $matriceYear = "[A]{2,4}"; // l'année est sur 2 ou 4 chiffres + $matriceMonth = "[M]{2}"; // le mois est sur 2 chiffres + $matriceCounter = "[C]{1,}"; //le compteur a un nombre de chiffres libre + $matriceTiret = "[-]{1}"; // on recherche si il y a des tirets de séparation + + $matrice = Array('prefix'=>$matricePrefix, + 'year'=>$matriceYear, + 'month'=>$matriceMonth, + 'counter'=>$matriceCounter + ); + + // on détermine l'emplacement des tirets + $resultTiret = preg_split('/'.$matriceTiret.'/',$this->matrice, -1, PREG_SPLIT_OFFSET_CAPTURE); + + $j = 0; + + // on détermine les objets de la matrice + for ($i = 0; $i < count($resultTiret); $i++) + { + foreach($resultTiret[$i] as $idResultTiret => $valueResultTiret) + { + // Ajout des tirets + if ($j != $resultTiret[$i][1]) + { + $numMatrice .= '-'; + $j = $resultTiret[$i][1]; + } + foreach($matrice as $idMatrice => $valueMatrice) + { + $resultCount = eregi(''.$valueMatrice.'',$valueResultTiret,$resultatMatrice); + if ($resultCount) + { + // On récupère le préfix utilisé + if ($idMatrice == 'prefix' && $resultatMatrice[0] == 'COM') + { + if ($objsoc->prefix_comm) + { + $prefix = $objsoc->prefix_comm; + } + else + { + $prefix = 'COM'; + } + $numMatrice .= $prefix; + } + else if ($idMatrice == 'prefix' && $resultatMatrice[0] == 'PREF') + { + $prefix = $this->prefix; + $numMatrice .= $prefix; + } + else if ($idMatrice == 'year') + { + // On récupère le nombre de chiffres pour l'année + $numbityear = $resultCount; + // On défini le mois du début d'année fiscale + $fiscal_current_month = date("n"); + $create_month = $fiscal_current_month; + + // On change d'année fiscal si besoin + if($conf->global->SOCIETE_FISCAL_MONTH_START && $fiscal_current_month >= $conf->global->SOCIETE_FISCAL_MONTH_START && $create_month >= $conf->global->SOCIETE_FISCAL_MONTH_START) + { + $yy = substr(strftime("%Y",mktime(0,0,0,date("m"),date("d"),date("Y")+1)),$numbityear); + } + else + { + $yy = substr(strftime("%Y",time()),$numbityear); + } + $numMatrice .= $yy; + } + else if ($idMatrice == 'month') + { + // On récupère le mois si besoin + $mm = strftime("%m",time()); + $numMatrice .= $mm; + } + else if ($idMatrice == 'counter') + { + // On récupère le nombre de chiffres pour le compteur + $numbitcounter = $resultCount; + } + } + } + } + } + + // On récupère le nombre de chiffres du compteur + $arg = '%0'.$numbitcounter.'s'; + $num = sprintf($arg,$conf->global->LIVRAISON_NUM_DELTA?$conf->global->LIVRAISON_NUM_DELTA:1); + + // Construction de l'exemple de numérotation + $numExample = $numMatrice.$num; + + return $numExample; + } + } + + /** \brief Renvoi prochaine valeur attribuée + * \param objsoc Objet société + * \param commande Objet commande + * \return string Valeur + */ + function getNextValue($objsoc=0) + { + global $db,$conf; + + $this->prefix = $conf->global->LIVRAISON_NUM_PREFIX; + $this->matrice = $conf->global->LIVRAISON_NUM_MATRICE; + + if ($this->matrice != '') + { + $resultatMatrice = Array(); + $numMatrice = Array(); + + $matricePrefix = "PREF|COM"; // PREF : prefix libre (ex: C pour commande), COM : prefix du client + $matriceYear = "[A]{2,4}"; // l'année est sur 2 ou 4 chiffres + $matriceMonth = "[M]{2}"; // le mois est sur 2 chiffres + $matriceCounter = "[C]{1,}"; //le compteur a un nombre de chiffres libre + $matriceTiret = "[-]{1}"; // on recherche si il y a des tirets de séparation + + $matrice = Array('prefix'=>$matricePrefix, + 'year'=>$matriceYear, + 'month'=>$matriceMonth, + 'counter'=>$matriceCounter + ); + + // on détermine l'emplacement des tirets + $resultTiret = preg_split('/'.$matriceTiret.'/',$this->matrice, -1, PREG_SPLIT_OFFSET_CAPTURE); + + $j = 0; + $k = 0; + + // on détermine les objets de la matrice + for ($i = 0; $i < count($resultTiret); $i++) + { + foreach($resultTiret[$i] as $idResultTiret => $valueResultTiret) + { + // Ajout des tirets + if ($j != $resultTiret[$i][1]) + { + $numMatrice[$k] = '-'; + $searchLast .= '-'; + $searchLastWithNoYear .= '-'; + $searchLastWithPreviousYear .= '-'; + $j = $resultTiret[$i][1]; + $k++; + } + foreach($matrice as $idMatrice => $valueMatrice) + { + $resultCount = eregi(''.$valueMatrice.'',$valueResultTiret,$resultatMatrice); + if ($resultCount) + { + // On récupère le préfix utilisé + if ($idMatrice == 'prefix' && $resultatMatrice[0] == 'COM') + { + if ($objsoc->prefix_comm) + { + $prefix = $objsoc->prefix_comm; + } + else + { + $prefix = 'COM'; + } + $numMatrice[$k] = '$prefix'; + $searchLast .= $prefix; + $searchLastWithNoYear .= $prefix; + $searchLastWithPreviousYear .= $prefix; + $k++; + } + else if ($idMatrice == 'prefix' && $resultatMatrice[0] == 'PREF') + { + $prefix = $this->prefix; + $numMatrice[$k] = '$prefix'; + $searchLast .= $prefix; + $searchLastWithNoYear .= $prefix; + $searchLastWithPreviousYear .= $prefix; + $k++; + } + else if ($idMatrice == 'year') + { + // On récupère le nombre de chiffres pour l'année + $numbityear = $resultCount; + // On défini le mois du début d'année fiscale + $current_month = date("n"); + + if (is_object($commande) && $commande->date) + { + $create_month = strftime("%m",$commande->date); + } + else + { + $create_month = $current_month; + } + + // On change d'année fiscal si besoin + if($conf->global->SOCIETE_FISCAL_MONTH_START && $current_month >= $conf->global->SOCIETE_FISCAL_MONTH_START && $create_month >= $conf->global->SOCIETE_FISCAL_MONTH_START) + { + $yy = substr(strftime("%Y",mktime(0,0,0,date("m"),date("d"),date("Y")+1)),$numbityear); + } + else + { + $yy = substr(strftime("%Y",time()),$numbityear); + } + $numMatrice[$k] = '$yy'; + $searchLast .= $yy; + for ($l = 1; $l <= $numbityear; $l++) + { + $searchLastWithNoYear .= '[0-9]'; + } + $previousYear = substr(strftime("%Y",mktime(0,0,0,date("m"),date("d"),date("Y")-1)),$numbityear); + $searchLastWithPreviousYear .= $previousYear; + $k++; + } + else if ($idMatrice == 'month') + { + // On récupère le mois si besoin + $mm = strftime("%m",time()); + $numMatrice[$k] = '$mm'; + $searchLast .= $mm; + $searchLastWithNoYear .= $mm; + $searchLastWithPreviousYear .= $mm; + $k++; + } + else if ($idMatrice == 'counter') + { + // On récupère le nombre de chiffres pour le compteur + $numbitcounter = $resultCount; + $numMatrice[$k] = '$num'; + $k++; + } + } + } + } + } + + // On récupère la valeur max (réponse immédiate car champ indéxé) + $posindice = $numbitcounter; + $searchyy=''; + $sql = "SELECT MAX(ref)"; + $sql.= " FROM ".MAIN_DB_PREFIX."livraison"; + if ($conf->global->LIVRAISON_NUM_RESTART_BEGIN_YEAR) $sql.= " WHERE ref like '${searchLast}%'"; + $resql=$db->query($sql); + if ($resql) + { + $row = $db->fetch_row($resql); + if ($row) $searchyy = substr($row[0],0,-$posindice); + } + + if ($conf->global->LIVRAISON_NUM_DELTA != '') + { + //on vérifie si il y a une année précédente + //pour éviter que le delta soit appliqué de nouveau sur la nouvelle année + $previousyy=''; + $sql = "SELECT MAX(ref)"; + $sql.= " FROM ".MAIN_DB_PREFIX."livraison"; + $sql.= " WHERE ref like '${searchLastWithPreviousYear}%'"; + $resql=$db->query($sql); + if ($resql) + { + $row = $db->fetch_row($resql); + if ($row) $previousyy = substr($row[0],0,-$posindice); + } + } + + // Si au moins un champ respectant le modèle a été trouvée + if (eregi('^'.$searchLastWithNoYear.'',$searchyy)) + { + // Recherche rapide car restreint par un like sur champ indexé + $sql = "SELECT MAX(0+SUBSTRING(ref,-".$posindice."))"; + $sql.= " FROM ".MAIN_DB_PREFIX."livraison"; + $sql.= " WHERE ref like '${searchyy}%'"; + $resql=$db->query($sql); + if ($resql) + { + $row = $db->fetch_row($resql); + $max = $row[0]; + } + } + else if ($conf->global->LIVRAISON_NUM_DELTA != '' && !eregi('^'.$searchLastWithPreviousYear.'',$previousyy)) + { + // on applique le delta une seule fois + $max=$conf->global->LIVRAISON_NUM_DELTA?$conf->global->LIVRAISON_NUM_DELTA-1:0; + } + else + { + $max=0; + } + + // On applique le nombre de chiffres du compteur + $arg = '%0'.$numbitcounter.'s'; + $num = sprintf($arg,$max+1); + $numFinal = ''; + + foreach($numMatrice as $objetMatrice) + { + if ($objetMatrice == '-') $numFinal .= $objetMatrice; + if ($objetMatrice == '$prefix') $numFinal .= $prefix; + if ($objetMatrice == '$yy') $numFinal .= $yy; + if ($objetMatrice == '$mm') $numFinal .= $mm; + if ($objetMatrice == '$num') $numFinal .= $num; + } + + dolibarr_syslog("mod_livraison_saphir::getNextValue return ".$numFinal); + return $numFinal; + } + } + + + /** \brief Renvoie la référence de commande suivante non utilisée + * \param objsoc Objet société + * \param commande Objet commande + * \return string Texte descripif + */ + function commande_get_num($objsoc=0) + { + return $this->getNextValue($objsoc); + } +} + +?> \ No newline at end of file