* Copyright (C) 2004-2010 Laurent Destailleur * Copyright (C) 2004 Eric Seigne * Copyright (C) 2005-2012 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 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 * along with this program. If not, see . * or see https://www.gnu.org/ */ /** * \file htdocs/core/modules/member/modules_member.class.php * \ingroup members * \brief File with parent class for generating members to PDF */ require_once DOL_DOCUMENT_ROOT.'/core/class/commondocgenerator.class.php'; /** * Parent class to manage intervention document templates */ abstract class ModelePDFMember extends CommonDocGenerator { /** * @var string Error code (or message) */ public $error = ''; // phpcs:disable PEAR.NamingConventions.ValidFunctionName.ScopeNotCamelCaps /** * Return list of active generation modules * * @param DoliDB $db Database handler * @param integer $maxfilenamelength Max length of value to show * @return array List of templates */ public static function liste_modeles($db, $maxfilenamelength = 0) { // phpcs:enable $type = 'member'; $list = array(); include_once DOL_DOCUMENT_ROOT.'/core/lib/functions2.lib.php'; $list = getListOfModels($db, $type, $maxfilenamelength); return $list; } } /** * Classe mere des modeles de numerotation des references de members */ abstract class ModeleNumRefMembers { public $code_modifiable; // Editable code public $code_modifiable_invalide; // Modified code if it is invalid public $code_modifiable_null; // Modified code if it is null public $code_null; // /** * @var string Error code (or message) */ public $error = ''; /** * Return if a module can be used or not * * @return boolean true if module can be used */ public function isEnabled() { return true; } /** * Returns the default description of the numbering pattern * * @return string Descriptive text */ public function info() { global $langs; $langs->load("members"); return $langs->trans("NoDescription"); } /** * Return name of module * * @return string Module name */ public function getName() { return $this->name; } /** * Return an example of numbering * * @return string Example */ public function getExample() { global $langs; $langs->load("members"); return $langs->trans("NoExample"); } /** * Checks if the numbers already in the database do not * cause conflicts that would prevent this numbering working. * * @return boolean false if conflict, true if ok */ public function canBeActivated() { return true; } /** * Renvoi prochaine valeur attribuee * * @param Societe $objsoc Object third party * @param Object $object Object we need next value for * @return string Valeur */ public function getNextValue($objsoc, $object) { global $langs; return $langs->trans("NotAvailable"); } /** * Renvoi version du module numerotation * * @return string Valeur */ public function getVersion() { global $langs; $langs->load("admin"); if ($this->version == 'development') { return $langs->trans("VersionDevelopment"); } elseif ($this->version == 'experimental') { return $langs->trans("VersionExperimental"); } elseif ($this->version == 'dolibarr') { return DOL_VERSION; } elseif ($this->version) { return $this->version; } else { return $langs->trans("NotAvailable"); } } /** * Return description of module parameters * * @param Translate $langs Output language * @param Societe $soc Third party object * @return string HTML translated description */ public function getToolTip($langs, $soc) { global $conf; $langs->loadLangs(array("admin", "companies")); $strikestart = ''; $strikeend = ''; if (!empty($conf->global->MAIN_MEMBER_CODE_ALWAYS_REQUIRED) && !empty($this->code_null)) { $strikestart = ''; $strikeend = ' '.yn(1, 1, 2).' ('.$langs->trans("ForcedToByAModule", $langs->transnoentities("yes")).')'; } $s = ''; $s .= $langs->trans("Name").': '.$this->getName().'
'; $s .= $langs->trans("Version").': '.$this->getVersion().'
'; $s .= $langs->trans("MemberCodeDesc").'
'; $s .= $langs->trans("ValidityControledByModule").': '.$this->getName().'
'; $s .= '
'; $s .= ''.$langs->trans("ThisIsModuleRules").':
'; $s .= $langs->trans("Required").': '.$strikestart; $s .= yn(!$this->code_null, 1, 2).$strikeend; $s .= '
'; $s .= $langs->trans("CanBeModifiedIfOk").': '; $s .= yn($this->code_modifiable, 1, 2); $s .= '
'; $s .= $langs->trans("CanBeModifiedIfKo").': '.yn($this->code_modifiable_invalide, 1, 2).'
'; $s .= $langs->trans("AutomaticCode").': '.yn($this->code_auto, 1, 2).'
'; $s .= '
'; $nextval = $this->getNextValue($soc, 0); if (empty($nextval)) { $nextval = $langs->trans("Undefined"); } $s .= $langs->trans("NextValue").' ('.$langs->trans("Member").'): '.$nextval.'
'; return $s; } }