* Copyright (C) 2006-2009 Laurent Destailleur * Copyright (C) 2014 Floran Henry * Copyright (C) 2024 Frédéric France * Copyright (C) 2024 MDW * * 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/contract/mod_contract_olive.php * \ingroup contract * \brief File of class to manage contract numbering rules Olive */ require_once DOL_DOCUMENT_ROOT.'/core/modules/contract/modules_contract.php'; /** * Class to manage contract numbering rules Olive */ class mod_contract_olive extends ModelNumRefContracts { // variables inherited from ModelNumRefContracts class public $name = 'Olive'; public $version = 'dolibarr'; /** * Constructor */ public function __construct() { $this->code_null = 1; $this->code_modifiable = 1; $this->code_modifiable_invalide = 1; $this->code_modifiable_null = 1; $this->code_auto = 0; } /** * Return description of module * * @param Translate $langs Lang object to use for output * @return string Descriptive text */ public function info($langs) { global $langs; $langs->load("companies"); return $langs->trans("LeopardNumRefModelDesc"); } /** * Return numbering example * * @return string Example */ public function getExample() { return ''; } /** * Return an example of result returned by getNextValue * * @param Societe $objsoc Object thirdparty * @param Contrat $contract Object contract * @return string|int<-1,0> Value if OK, <=0 if KO */ public function getNextValue($objsoc, $contract) { return ''; } /** * Check validity of code according to its rules * * @param DoliDB $db Database handler * @param string $code Code to check/correct * @param Product $product Object product * @param int $type 0 = product , 1 = service * @return int 0 if OK * -1 ErrorBadProductCodeSyntax * -2 ErrorProductCodeRequired * -3 ErrorProductCodeAlreadyUsed * -4 ErrorPrefixRequired */ public function verif($db, &$code, $product, $type) { global $conf; $result = 0; $code = strtoupper(trim($code)); if (empty($code) && $this->code_null && !getDolGlobalString('MAIN_CONTRACT_CODE_ALWAYS_REQUIRED')) { $result = 0; } elseif (empty($code) && (!$this->code_null || getDolGlobalString('MAIN_CONTRACT_CODE_ALWAYS_REQUIRED'))) { $result = -2; } dol_syslog("mod_contract_olive::verif type=".$type." result=".$result); return $result; } }