* 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/barcode/modules_barcode.class.php * \ingroup barcode * \brief File with parent classes for barcode document modules and numbering modules */ require_once DOL_DOCUMENT_ROOT.'/core/lib/functions.lib.php'; require_once DOL_DOCUMENT_ROOT.'/core/class/commonnumrefgenerator.class.php'; /** * Parent class for barcode document generators (image) * * @property 'development'|'experimental'|'dolibarr' $version Dolibarr version of loaded document */ abstract class ModeleBarCode { /** * @var string Error code (or message) */ public $error = ''; /** * Return if a model can be used or not * * @return boolean true if model can be used */ public function isEnabled() { return true; } /** * Return description * * @param Translate $langs Lang object to use for output * @return string Descriptive text */ abstract public function info($langs); /** * Save an image file on disk (with no output) * * @param string $code Value to encode * @param string $encoding Mode of encoding ('QRCODE', 'EAN13', ...) * @param string $readable Code can be read * @param integer $scale Scale (not used with this engine) * @param integer $nooutputiferror No output if error (not used with this engine) * @return int Return integer <0 if KO, >0 if OK */ public function writeBarCode($code, $encoding, $readable = 'Y', $scale = 1, $nooutputiferror = 0) { return -1; // Error by default, this method must be implemented by the driver } } /** * Parent class for barcode numbering models * * @property string $nom Name for the GeneratorModel */ abstract class ModeleNumRefBarCode extends CommonNumRefGenerator { // variables inherited from CommonNumRefGenerator public $code_null; /** * Return next value available * * @param ?CommonObject $objcommon Object Product, Thirdparty * @param string $type Type of barcode (EAN, ISBN, ...) * @return string Value */ public function getNextValue($objcommon = null, $type = '') { global $langs; return $langs->trans("Function_getNextValue_InModuleNotWorking"); } /** * Return an example of result returned by getNextValue * * @param ?Translate $langs Object langs * @param ?CommonObject $object Object product * @return string Return string example */ abstract public function getExample($langs = null, $object = null); /** * Return description of module parameters * * @param Translate $langs Output language * @param ?Societe $soc Third party object * @param int $type -1=Nothing, 0=Product, 1=Service * @return string HTML translated description */ public function getToolTip($langs, $soc, $type) { $langs->loadLangs(array("admin", "companies")); $s = ''; $s .= $langs->trans("Name").': '.$this->name.'
'; $s .= $langs->trans("Version").': '.$this->getVersion().'
'; if ($type != -1) { $s .= $langs->trans("ValidityControledByModule").': '.$this->getName($langs).'
'; } $s .= '
'; $s .= ''.$langs->trans("ThisIsModuleRules").':
'; if ($type == 0) { $s .= $langs->trans("RequiredIfProduct").': '; if (getDolGlobalString('MAIN_BARCODE_CODE_ALWAYS_REQUIRED') && !empty($this->code_null)) { $s .= ''; } $s .= yn(!$this->code_null, 1, 2); if (getDolGlobalString('MAIN_BARCODE_CODE_ALWAYS_REQUIRED') && !empty($this->code_null)) { $s .= ' '.yn(1, 1, 2).' ('.$langs->trans("ForcedToByAModule", $langs->transnoentities("yes")).')'; } $s .= '
'; } if ($type == 1) { $s .= $langs->trans("RequiredIfService").': '; if (getDolGlobalString('MAIN_BARCODE_CODE_ALWAYS_REQUIRED') && !empty($this->code_null)) { $s .= ''; } $s .= yn(!$this->code_null, 1, 2); if (getDolGlobalString('MAIN_BARCODE_CODE_ALWAYS_REQUIRED') && !empty($this->code_null)) { $s .= ' '.yn(1, 1, 2).' ('.$langs->trans("ForcedToByAModule", $langs->transnoentities("yes")).')'; } $s .= '
'; } if ($type == -1) { $s .= $langs->trans("Required").': '; if (getDolGlobalString('MAIN_BARCODE_CODE_ALWAYS_REQUIRED') && !empty($this->code_null)) { $s .= ''; } $s .= yn(!$this->code_null, 1, 2); if (getDolGlobalString('MAIN_BARCODE_CODE_ALWAYS_REQUIRED') && !empty($this->code_null)) { $s .= ' '.yn(1, 1, 2).' ('.$langs->trans("ForcedToByAModule", $langs->transnoentities("yes")).')'; } $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, ''); if (empty($nextval)) { $nextval = $langs->trans("Undefined"); } $s .= $langs->trans("NextValue").': '.$nextval.'
'; return $s; } /** * Check validity of code according to its rules * * @param DoliDB $db Database handler * @param string $code Code to check/correct * @param Product|Societe $object Object product or ThirdParty * @param int<0,1> $thirdparty_type 0 = customer/prospect , 1 = supplier * @param string $type type of barcode (EAN, ISBN, ...) * @return int<-7,0> 0 if OK * -1 ErrorBadCustomerCodeSyntax * -2 ErrorCustomerCodeRequired * -3 ErrorCustomerCodeAlreadyUsed * -4 ErrorPrefixRequired * -7 ErrorBadClass */ abstract public function verif($db, &$code, $object, $thirdparty_type, $type); }