dolibarr  20.0.0-beta
mod_codecompta_aquarium.php
Go to the documentation of this file.
1 <?php
2 /* Copyright (C) 2004-2007 Rodolphe Quiedeville <rodolphe@quiedeville.org>
3  * Copyright (C) 2005 Eric Seigne <eric.seigne@ryxeo.com>
4  * Copyright (C) 2006-2011 Laurent Destailleur <eldy@users.sourceforge.net>
5  * Copyright (C) 2024 MDW <mdeweerd@users.noreply.github.com>
6  * Copyright (C) 2024 Frédéric France <frederic.france@free.fr>
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; either version 3 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program. If not, see <https://www.gnu.org/licenses/>.
20  * or see https://www.gnu.org/
21  */
22 
28 require_once DOL_DOCUMENT_ROOT.'/core/modules/societe/modules_societe.class.php';
29 
30 
35 {
39  public $name = 'Aquarium';
40 
44  public $code;
45 
50  public $version = 'dolibarr'; // 'development', 'experimental', 'dolibarr'
51 
52  public $prefixcustomeraccountancycode;
53 
54  public $prefixsupplieraccountancycode;
55 
56  public $position = 20;
57 
58 
62  public function __construct()
63  {
64  global $conf;
65  if (!isset($conf->global->COMPANY_AQUARIUM_MASK_CUSTOMER) || trim($conf->global->COMPANY_AQUARIUM_MASK_CUSTOMER) == '') {
66  $conf->global->COMPANY_AQUARIUM_MASK_CUSTOMER = '411';
67  }
68  if (!isset($conf->global->COMPANY_AQUARIUM_MASK_SUPPLIER) || trim($conf->global->COMPANY_AQUARIUM_MASK_SUPPLIER) == '') {
69  $conf->global->COMPANY_AQUARIUM_MASK_SUPPLIER = '401';
70  }
71 
72  if (getDolGlobalString('COMPANY_AQUARIUM_NO_PREFIX')) {
73  $this->prefixcustomeraccountancycode = '';
74  $this->prefixsupplieraccountancycode = '';
75  } else {
76  $this->prefixcustomeraccountancycode = getDolGlobalString('COMPANY_AQUARIUM_MASK_CUSTOMER');
77  $this->prefixsupplieraccountancycode = getDolGlobalString('COMPANY_AQUARIUM_MASK_SUPPLIER');
78  }
79  }
80 
81 
88  public function info($langs)
89  {
90  global $conf;
91  global $form;
92 
93  $langs->load("companies");
94 
95  $tooltip = '';
96  $texte = '<form action="'.$_SERVER["PHP_SELF"].'" method="POST">';
97  $texte .= '<input type="hidden" name="token" value="'.newToken().'">';
98  $texte .= '<input type="hidden" name="page_y" value="">';
99  $texte .= '<input type="hidden" name="action" value="setModuleOptions">';
100  $texte .= '<input type="hidden" name="param1" value="COMPANY_AQUARIUM_MASK_SUPPLIER">';
101  $texte .= '<input type="hidden" name="param2" value="COMPANY_AQUARIUM_MASK_CUSTOMER">';
102  $texte .= '<table class="nobordernopadding" width="100%">';
103  $s1 = $form->textwithpicto('<input type="text" class="flat" size="4" name="value1" value="' . getDolGlobalString('COMPANY_AQUARIUM_MASK_SUPPLIER').'">', $tooltip, 1, 1);
104  $s2 = $form->textwithpicto('<input type="text" class="flat" size="4" name="value2" value="' . getDolGlobalString('COMPANY_AQUARIUM_MASK_CUSTOMER').'">', $tooltip, 1, 1);
105  $texte .= '<tr><td>';
106  // trans remove html entities
107  $texte .= $langs->trans("ModuleCompanyCodeCustomer".$this->name, '{s2}')."<br>\n";
108  $texte .= $langs->trans("ModuleCompanyCodeSupplier".$this->name, '{s1}')."<br>\n";
109  $texte = str_replace(array('{s1}', '{s2}'), array($s1, $s2), $texte);
110  $texte .= "<br>\n";
111  if (getDolGlobalInt('COMPANY_AQUARIUM_REMOVE_SPECIAL')) {
112  $texte .= $langs->trans('RemoveSpecialChars').' = '.yn(1)."<br>\n";
113  }
114  //if (!empty($conf->global->COMPANY_AQUARIUM_REMOVE_ALPHA)) $texte.=$langs->trans('COMPANY_AQUARIUM_REMOVE_ALPHA').' = '.yn($conf->global->COMPANY_AQUARIUM_REMOVE_ALPHA)."<br>\n";
115  if (getDolGlobalString('COMPANY_AQUARIUM_CLEAN_REGEX')) {
116  $texte .= $langs->trans('COMPANY_AQUARIUM_CLEAN_REGEX').' = ' . getDolGlobalString('COMPANY_AQUARIUM_CLEAN_REGEX')."<br>\n";
117  }
118 
119  if (getDolGlobalString('COMPANY_AQUARIUM_NO_PREFIX')) {
120  $texte .= $langs->trans('COMPANY_AQUARIUM_NO_PREFIX').' = ' . getDolGlobalString('COMPANY_AQUARIUM_NO_PREFIX')."<br>\n";
121  }
122  $texte .= '</td>';
123  $texte .= '<td class="right"><input type="submit" class="button button-edit reposition smallpaddingimp" name="modify" value="'.$langs->trans("Modify").'"></td>';
124  $texte .= '</tr></table>';
125  $texte .= '</form>';
126 
127  return $texte;
128  }
129 
138  public function getExample($langs, $objsoc = '', $type = -1)
139  {
140  $s = '';
141  $s .= $this->prefixcustomeraccountancycode.'CUSTCODE';
142  $s .= "<br>\n";
143  $s .= $this->prefixsupplieraccountancycode.'SUPPCODE';
144  return $s;
145  }
146 
147 
148  // phpcs:disable PEAR.NamingConventions.ValidFunctionName.ScopeNotCamelCaps
157  public function get_code($db, $societe, $type = '')
158  {
159  // phpcs:enable
160  global $conf;
161 
162  $i = 0;
163  $this->db = $db;
164 
165  dol_syslog("mod_codecompta_aquarium::get_code search code for type=".$type." company=".(!empty($societe->name) ? $societe->name : ''));
166 
167  // Regle gestion compte compta
168  if ($type == 'customer') {
169  $codetouse = (!empty($societe->code_client) ? $societe->code_client : 'CUSTCODE');
170  $prefix = $this->prefixcustomeraccountancycode;
171  } elseif ($type == 'supplier') {
172  $codetouse = (!empty($societe->code_fournisseur) ? $societe->code_fournisseur : 'SUPPCODE');
173  $prefix = $this->prefixsupplieraccountancycode;
174  } else {
175  $this->error = 'Bad value for parameter type';
176  return -1;
177  }
178 
179  //$conf->global->COMPANY_AQUARIUM_CLEAN_REGEX='^..(..)..';
180 
181  // Remove special char if COMPANY_AQUARIUM_REMOVE_SPECIAL is set to 1 or not set (default)
182  if (!isset($conf->global->COMPANY_AQUARIUM_REMOVE_SPECIAL) || getDolGlobalString('COMPANY_AQUARIUM_REMOVE_SPECIAL')) {
183  $codetouse = preg_replace('/([^a-z0-9])/i', '', $codetouse);
184  }
185  // Remove special alpha if COMPANY_AQUARIUM_REMOVE_ALPHA is set to 1
186  if (getDolGlobalString('COMPANY_AQUARIUM_REMOVE_ALPHA')) {
187  $codetouse = preg_replace('/([a-z])/i', '', $codetouse);
188  }
189  // Apply a regex replacement pattern on code if COMPANY_AQUARIUM_CLEAN_REGEX is set. Value must be a regex with parenthesis. The part into parenthesis is kept, the rest removed.
190  if (getDolGlobalString('COMPANY_AQUARIUM_CLEAN_REGEX')) { // Example: $conf->global->COMPANY_AQUARIUM_CLEAN_REGEX='^..(..)..';
191  $codetouse = preg_replace('/' . getDolGlobalString('COMPANY_AQUARIUM_CLEAN_REGEX').'/', '\1\2\3', $codetouse);
192  }
193 
194  $codetouse = $prefix.strtoupper($codetouse);
195 
196  $is_dispo = $this->verif($db, $codetouse, $societe, $type);
197  $this->code = $codetouse;
198  dol_syslog("mod_codecompta_aquarium::get_code found code=".$this->code);
199  return $is_dispo;
200  }
201 
202 
212  public function verif($db, $code, $societe, $type)
213  {
214  $sql = "SELECT ";
215  if ($type == 'customer') {
216  $sql .= "code_compta";
217  } elseif ($type == 'supplier') {
218  $sql .= "code_compta_fournisseur";
219  }
220  $sql .= " FROM ".MAIN_DB_PREFIX."societe";
221  $sql .= " WHERE ";
222  if ($type == 'customer') {
223  $sql .= "code_compta";
224  } elseif ($type == 'supplier') {
225  $sql .= "code_compta_fournisseur";
226  }
227  $sql .= " = '".$db->escape($code)."'";
228  if (!empty($societe->id)) {
229  $sql .= " AND rowid <> ".$societe->id;
230  }
231 
232  $resql = $db->query($sql);
233  if ($resql) {
234  if ($db->num_rows($resql) == 0) {
235  dol_syslog("mod_codecompta_aquarium::verif code '".$code."' available");
236  return 1; // Dispo
237  } else {
238  dol_syslog("mod_codecompta_aquarium::verif code '".$code."' not available");
239  return 0; // Non dispo
240  }
241  } else {
242  $this->error = $db->error()." sql=".$sql;
243  return -1; // Erreur
244  }
245  }
246 }
Parent class for third parties accountancy code generators.
Class to manage accountancy code of thirdparties with Aquarium rules.
info($langs)
Return description of module.
verif($db, $code, $societe, $type)
Return if a code is available.
get_code($db, $societe, $type='')
Set accountancy account code for a third party into this->code.
getExample($langs, $objsoc='', $type=-1)
Return an example of result returned by getNextValue.
if(isModEnabled('invoice') && $user->hasRight('facture', 'lire')) if((isModEnabled('fournisseur') &&!getDolGlobalString('MAIN_USE_NEW_SUPPLIERMOD') && $user->hasRight("fournisseur", "facture", "lire"))||(isModEnabled('supplier_invoice') && $user->hasRight("supplier_invoice", "lire"))) if(isModEnabled('don') && $user->hasRight('don', 'lire')) if(isModEnabled('tax') && $user->hasRight('tax', 'charges', 'lire')) if(isModEnabled('invoice') &&isModEnabled('order') && $user->hasRight("commande", "lire") &&!getDolGlobalString('WORKFLOW_DISABLE_CREATE_INVOICE_FROM_ORDER')) $sql
Social contributions to pay.
Definition: index.php:745
yn($yesno, $case=1, $color=0)
Return yes or no in current language.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
getDolGlobalString($key, $default='')
Return dolibarr global constant string value.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
$conf db name
Only used if Module[ID]Name translation string is not found.
Definition: repair.php:126
print *****$script_file(".$version.") pid code
1: frais de port 2: ecotaxe 3: option line (when qty = 0)