* Copyright (C) 2004-2007 Laurent Destailleur * Copyright (C) 2004 Eric Seigne * 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/ */ /** \file htdocs/includes/modules/societe/modules_societe.class.php \ingroup societe \brief Fichier contenant la classe mère de module de generation societes \version $Id$ */ /** \class ModeleThirdPartyCode \brief Classe mère des modèles de numérotation des codes tiers */ class ModeleThirdPartyCode { var $error=''; /** \brief Renvoi la description par defaut du modele de numérotation * \return string Texte descripif */ function info($langs) { $langs->load("bills"); return $langs->trans("NoDescription"); } /** \brief Renvoi nom module * \return string Nom du module */ function getNom($langs) { return $this->nom; } /** \brief Renvoi un exemple de numérotation * \return string Example */ function getExample($langs) { $langs->load("bills"); return $langs->trans("NoExample"); } /** \brief Test si les numéros déjà en vigueur dans la base ne provoquent pas de * de conflits qui empechera cette numérotation de fonctionner. * \return boolean false si conflit, true si ok */ function canBeActivated() { return true; } /** \brief Renvoi prochaine valeur attribuée * \return string Valeur */ function getNextValue($langs) { return $langs->trans("NotAvailable"); } /** \brief Renvoi version du module numerotation * \return string Valeur */ function getVersion() { global $langs; $langs->load("admin"); if ($this->version == 'development') return $langs->trans("VersionDevelopment"); if ($this->version == 'experimental') return $langs->trans("VersionExperimental"); if ($this->version == 'dolibarr') return DOL_VERSION; return $langs->trans("NotAvailable"); } /** * \brief Renvoi la liste des modèles actifs * \param db Handler de base */ function liste_modeles($db) { $liste=array(); $sql =""; $resql = $db->query($sql); if ($resql) { $num = $db->num_rows($resql); $i = 0; while ($i < $num) { $row = $db->fetch_row($resql); $liste[$row[0]]=$row[1]; $i++; } } else { return -1; } return $liste; } /** * \brief Return description of module parameters * \param langs Output language * \param soc Third party object * \param type -1=Nothing, 0=Customer, 1=Supplier * \return string HTML translated description */ function getToolTip($langs,$soc,$type) { $s=''; $s.=$langs->trans("Version").': '.$this->getVersion().'
'; if ($type == 0) $s.=$langs->trans("CustomerCodeDesc").'
'; if ($type == 1) $s.=$langs->trans("SupplierCodeDesc").'
'; if ($type != -1) $s.=$langs->trans("ValidityControledByModule").': '.$this->getNom($langs).'
'; $s.='
'; $s.=''.$langs->trans("ThisIsModuleRules").':
'; if ($type == 0) $s.=$langs->trans("RequiredIfCustomer").': '.yn(!$this->code_null).'
'; if ($type == 1) $s.=$langs->trans("RequiredIfSupplier").': '.yn(!$this->code_null).'
'; if ($type == -1) $s.=$langs->trans("Required").': '.yn(!$this->code_null).'
'; $s.=$langs->trans("CanBeModifiedIfOk").': '.yn($this->code_modifiable).'
'; $s.=$langs->trans("CanBeModifiedIfKo").': '.yn($this->code_modifiable_invalide).'
'; $s.=$langs->trans("AutomaticCode").': '.yn($this->code_auto).'
'; if ($type == 0) $s.=$langs->trans("Example").': '.$this->getExample($langs,$soc,0).''; if ($type == 1) $s.=$langs->trans("Example").': '.$this->getExample($langs,$soc,1).''; return $s; } } /** \class ModeleAccountancyCode \brief Classe mère des modèles de numérotation des codes compta */ class ModeleAccountancyCode { var $error=''; /** \brief Renvoi la description par defaut du modele de numérotation * \return string Texte descripif */ function info($langs) { $langs->load("bills"); return $langs->trans("NoDescription"); } /** \brief Renvoi un exemple de numérotation * \return string Example */ function getExample($langs) { $langs->load("bills"); return $langs->trans("NoExample"); } /** \brief Test si les numéros déjà en vigueur dans la base ne provoquent pas de * de conflits qui empechera cette numérotation de fonctionner. * \return boolean false si conflit, true si ok */ function canBeActivated() { return true; } /** \brief Renvoi prochaine valeur attribuée * \return string Valeur */ function getNextValue($langs) { return $langs->trans("NotAvailable"); } } ?>