dolibarr  19.0.0-dev
defaultaccounts.php
Go to the documentation of this file.
1 <?php
2 /* Copyright (C) 2013-2014 Olivier Geffroy <jeff@jeffinfo.com>
3  * Copyright (C) 2013-2014 Florian Henry <florian.henry@open-concept.pro>
4  * Copyright (C) 2013-2023 Alexandre Spangaro <aspangaro@open-dsi.fr>
5  * Copyright (C) 2014-2015 Ari Elbaz (elarifr) <github@accedinfo.com>
6  * Copyright (C) 2014 Marcos García <marcosgdf@gmail.com>
7  * Copyright (C) 2014 Juanjo Menent <jmenent@2byte.es>
8  * Copyright (C) 2015 Jean-François Ferry <jfefe@aternatik.fr>
9  *
10  * This program is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 3 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with this program. If not, see <https://www.gnu.org/licenses/>.
22  *
23  */
24 
30 require '../../main.inc.php';
31 
32 // Class
33 require_once DOL_DOCUMENT_ROOT.'/core/lib/admin.lib.php';
34 require_once DOL_DOCUMENT_ROOT.'/core/lib/accounting.lib.php';
35 require_once DOL_DOCUMENT_ROOT.'/core/class/html.formaccounting.class.php';
36 
37 // Load translation files required by the page
38 $langs->loadLangs(array("compta", "bills", "admin", "accountancy", "salaries", "loan"));
39 
40 // Security check
41 if (!$user->hasRight('accounting', 'chartofaccount')) {
43 }
44 
45 $action = GETPOST('action', 'aZ09');
46 
47 
48 $list_account_main = array(
49  'ACCOUNTING_ACCOUNT_CUSTOMER',
50  'ACCOUNTING_ACCOUNT_SUPPLIER',
51  'SALARIES_ACCOUNTING_ACCOUNT_PAYMENT',
52 );
53 
54 $list_account = array();
55 
56 $list_account[] = '---Product---';
57 $list_account[] = 'ACCOUNTING_PRODUCT_SOLD_ACCOUNT';
58 if ($mysoc->isInEEC()) {
59  $list_account[] = 'ACCOUNTING_PRODUCT_SOLD_INTRA_ACCOUNT';
60 }
61 $list_account[] = 'ACCOUNTING_PRODUCT_SOLD_EXPORT_ACCOUNT';
62 $list_account[] = 'ACCOUNTING_PRODUCT_BUY_ACCOUNT';
63 if ($mysoc->isInEEC()) {
64  $list_account[] = 'ACCOUNTING_PRODUCT_BUY_INTRA_ACCOUNT';
65 }
66 $list_account[] = 'ACCOUNTING_PRODUCT_BUY_EXPORT_ACCOUNT';
67 
68 $list_account[] = '---Service---';
69 $list_account[] = 'ACCOUNTING_SERVICE_SOLD_ACCOUNT';
70 if ($mysoc->isInEEC()) {
71  $list_account[] = 'ACCOUNTING_SERVICE_SOLD_INTRA_ACCOUNT';
72 }
73 $list_account[] = 'ACCOUNTING_SERVICE_SOLD_EXPORT_ACCOUNT';
74 $list_account[] = 'ACCOUNTING_SERVICE_BUY_ACCOUNT';
75 if ($mysoc->isInEEC()) {
76  $list_account[] = 'ACCOUNTING_SERVICE_BUY_INTRA_ACCOUNT';
77 }
78 $list_account[] = 'ACCOUNTING_SERVICE_BUY_EXPORT_ACCOUNT';
79 
80 $list_account[] = '---Others---';
81 $list_account[] = 'ACCOUNTING_VAT_BUY_ACCOUNT';
82 $list_account[] = 'ACCOUNTING_VAT_SOLD_ACCOUNT';
83 $list_account[] = 'ACCOUNTING_VAT_PAY_ACCOUNT';
84 if (!empty($conf->global->ACCOUNTING_FORCE_ENABLE_VAT_REVERSE_CHARGE)) {
85  $list_account[] = 'ACCOUNTING_VAT_BUY_REVERSE_CHARGES_CREDIT';
86  $list_account[] = 'ACCOUNTING_VAT_BUY_REVERSE_CHARGES_DEBIT';
87 }
88 if (isModEnabled('banque')) {
89  $list_account[] = 'ACCOUNTING_ACCOUNT_TRANSFER_CASH';
90 }
91 if (!empty($conf->global->INVOICE_USE_RETAINED_WARRANTY)) {
92  $list_account[] = 'ACCOUNTING_ACCOUNT_CUSTOMER_RETAINED_WARRANTY';
93 }
94 if (isModEnabled('don')) {
95  $list_account[] = 'DONATION_ACCOUNTINGACCOUNT';
96 }
97 if (isModEnabled('adherent')) {
98  $list_account[] = 'ADHERENT_SUBSCRIPTION_ACCOUNTINGACCOUNT';
99 }
100 if (isModEnabled('loan')) {
101  $list_account[] = 'LOAN_ACCOUNTING_ACCOUNT_CAPITAL';
102  $list_account[] = 'LOAN_ACCOUNTING_ACCOUNT_INTEREST';
103  $list_account[] = 'LOAN_ACCOUNTING_ACCOUNT_INSURANCE';
104 }
105 $list_account[] = 'ACCOUNTING_ACCOUNT_SUSPENSE';
106 if (isModEnabled('societe')) {
107  $list_account[] = '---Deposits---';
108 }
109 
110 /*
111  * Actions
112  */
113 if ($action == 'update') {
114  $error = 0;
115  // Process $list_account_main
116  foreach ($list_account_main as $constname) {
117  $constvalue = GETPOST($constname, 'alpha');
118 
119  if (!dolibarr_set_const($db, $constname, $constvalue, 'chaine', 0, '', $conf->entity)) {
120  $error++;
121  }
122  }
123  // Process $list_account
124  foreach ($list_account as $constname) {
125  $reg = array();
126  if (preg_match('/---(.*)---/', $constname, $reg)) { // This is a separator
127  continue;
128  }
129 
130  $constvalue = GETPOST($constname, 'alpha');
131 
132  if (!dolibarr_set_const($db, $constname, $constvalue, 'chaine', 0, '', $conf->entity)) {
133  $error++;
134  }
135  }
136 
137  $constname = 'ACCOUNTING_ACCOUNT_CUSTOMER_DEPOSIT';
138  $constvalue = GETPOST($constname, 'int');
139  if (!dolibarr_set_const($db, $constname, $constvalue, 'chaine', 0, '', $conf->entity)) {
140  $error++;
141  }
142 
143  $constname = 'ACCOUNTING_ACCOUNT_SUPPLIER_DEPOSIT';
144  $constvalue = GETPOST($constname, 'int');
145  if (!dolibarr_set_const($db, $constname, $constvalue, 'chaine', 0, '', $conf->entity)) {
146  $error++;
147  }
148 
149 
150  if (!$error) {
151  setEventMessages($langs->trans("SetupSaved"), null, 'mesgs');
152  } else {
153  setEventMessages($langs->trans("Error"), null, 'errors');
154  }
155 }
156 
157 if ($action == 'setACCOUNTING_ACCOUNT_CUSTOMER_USE_AUXILIARY_ON_DEPOSIT') {
158  $setDisableAuxiliaryAccountOnCustomerDeposit = GETPOST('value', 'int');
159  $res = dolibarr_set_const($db, "ACCOUNTING_ACCOUNT_CUSTOMER_USE_AUXILIARY_ON_DEPOSIT", $setDisableAuxiliaryAccountOnCustomerDeposit, 'yesno', 0, '', $conf->entity);
160  if (!($res > 0)) {
161  $error++;
162  }
163 
164  if (!$error) {
165  setEventMessages($langs->trans("SetupSaved"), null, 'mesgs');
166  } else {
167  setEventMessages($langs->trans("Error"), null, 'mesgs');
168  }
169 }
170 
171 if ($action == 'setACCOUNTING_ACCOUNT_SUPPLIER_USE_AUXILIARY_ON_DEPOSIT') {
172  $setDisableAuxiliaryAccountOnSupplierDeposit = GETPOST('value', 'int');
173  $res = dolibarr_set_const($db, "ACCOUNTING_ACCOUNT_SUPPLIER_USE_AUXILIARY_ON_DEPOSIT", $setDisableAuxiliaryAccountOnSupplierDeposit, 'yesno', 0, '', $conf->entity);
174  if (!($res > 0)) {
175  $error++;
176  }
177 
178  if (!$error) {
179  setEventMessages($langs->trans("SetupSaved"), null, 'mesgs');
180  } else {
181  setEventMessages($langs->trans("Error"), null, 'mesgs');
182  }
183 }
184 
185 
186 /*
187  * View
188  */
189 
190 $form = new Form($db);
191 $formaccounting = new FormAccounting($db);
192 
193 llxHeader();
194 
195 $linkback = '';
196 print load_fiche_titre($langs->trans('MenuDefaultAccounts'), $linkback, 'title_accountancy');
197 
198 print '<span class="opacitymedium">'.$langs->trans("DefaultBindingDesc").'</span><br>';
199 print '<br>';
200 
201 print '<form action="'.$_SERVER["PHP_SELF"].'" method="post">';
202 print '<input type="hidden" name="token" value="'.newToken().'">';
203 print '<input type="hidden" name="action" value="update">';
204 
205 
206 // Define main accounts for thirdparty
207 
208 print '<div class="div-table-responsive-no-min">';
209 print '<table class="noborder centpercent">';
210 print '<tr class="liste_titre"><td>'.$langs->trans("ThirdParties").' | '.$langs->trans("Users").'</td><td></td></tr>';
211 
212 foreach ($list_account_main as $key) {
213  print '<tr class="oddeven value">';
214  // Param
215  $label = $langs->trans($key);
216  $keydesc = $key.'_Desc';
217 
218  $htmltext = $langs->trans($keydesc);
219  print '<td class="fieldrequired">';
220  if ($key == 'ACCOUNTING_ACCOUNT_CUSTOMER') {
221  print img_picto('', 'company', 'class="pictofixedwidth"');
222  } elseif ($key == 'ACCOUNTING_ACCOUNT_SUPPLIER') {
223  print img_picto('', 'company', 'class="pictofixedwidth"');
224  } else {
225  print img_picto('', 'user', 'class="pictofixedwidth"');
226  }
227  print $form->textwithpicto($label, $htmltext);
228  print '</td>';
229  // Value
230  print '<td class="right">'; // Do not force class=right, or it align also the content of the select box
231  $key_value = getDolGlobalString($key);
232  print $formaccounting->select_account($key_value, $key, 1, '', 1, 1, 'minwidth100 maxwidth300 maxwidthonsmartphone', 'accountsmain');
233  print '</td>';
234  print '</tr>';
235 }
236 print "</table>\n";
237 print "</div>\n";
238 
239 
240 print '<div class="div-table-responsive-no-min">';
241 print '<table class="noborder centpercent">';
242 
243 foreach ($list_account as $key) {
244  $reg = array();
245  if (preg_match('/---(.*)---/', $key, $reg)) {
246  print '<tr class="liste_titre"><td>'.$langs->trans($reg[1]).'</td><td></td></tr>';
247  } else {
248  print '<tr class="oddeven value">';
249  // Param
250  $label = $langs->trans($key);
251  print '<td>';
252  if (preg_match('/^ACCOUNTING_PRODUCT/', $key)) {
253  print img_picto('', 'product', 'class="pictofixedwidth"');
254  } elseif (preg_match('/^ACCOUNTING_SERVICE/', $key)) {
255  print img_picto('', 'service', 'class="pictofixedwidth"');
256  } elseif (preg_match('/^ACCOUNTING_VAT_PAY_ACCOUNT/', $key)) {
257  print img_picto('', 'payment_vat', 'class="pictofixedwidth"');
258  } elseif (preg_match('/^ACCOUNTING_VAT/', $key)) {
259  print img_picto('', 'vat', 'class="pictofixedwidth"');
260  } elseif (preg_match('/^ACCOUNTING_ACCOUNT_CUSTOMER/', $key)) {
261  print img_picto('', 'bill', 'class="pictofixedwidth"');
262  } elseif (preg_match('/^LOAN_ACCOUNTING_ACCOUNT/', $key)) {
263  print img_picto('', 'loan', 'class="pictofixedwidth"');
264  } elseif (preg_match('/^DONATION_ACCOUNTING/', $key)) {
265  print img_picto('', 'donation', 'class="pictofixedwidth"');
266  } elseif (preg_match('/^ADHERENT_SUBSCRIPTION/', $key)) {
267  print img_picto('', 'member', 'class="pictofixedwidth"');
268  } elseif (preg_match('/^ACCOUNTING_ACCOUNT_TRANSFER/', $key)) {
269  print img_picto('', 'bank_account', 'class="pictofixedwidth"');
270  } elseif (preg_match('/^ACCOUNTING_ACCOUNT_SUSPENSE/', $key)) {
271  print img_picto('', 'question', 'class="pictofixedwidth"');
272  }
273  print $label;
274  print '</td>';
275  // Value
276  print '<td class="right">'; // Do not force class=right, or it align also the content of the select box
277  print $formaccounting->select_account(getDolGlobalString($key), $key, 1, '', 1, 1, 'minwidth100 maxwidth300 maxwidthonsmartphone', 'accounts');
278  print '</td>';
279  print '</tr>';
280  }
281 }
282 
283 
284 // Customer deposit account
285 print '<tr class="oddeven value">';
286 // Param
287 print '<td>';
288 print img_picto('', 'bill', 'class="pictofixedwidth"') . $langs->trans('ACCOUNTING_ACCOUNT_CUSTOMER_DEPOSIT');
289 print '</td>';
290 // Value
291 print '<td class="right">'; // Do not force class=right, or it align also the content of the select box
292 print $formaccounting->select_account(getDolGlobalString('ACCOUNTING_ACCOUNT_CUSTOMER_DEPOSIT'), 'ACCOUNTING_ACCOUNT_CUSTOMER_DEPOSIT', 1, '', 1, 1, 'minwidth100 maxwidth300 maxwidthonsmartphone', 'accounts');
293 print '</td>';
294 print '</tr>';
295 
296 if (isModEnabled('societe') && getDolGlobalString('ACCOUNTING_ACCOUNT_CUSTOMER_DEPOSIT') && getDolGlobalString('ACCOUNTING_ACCOUNT_CUSTOMER_DEPOSIT') != '-1') {
297  print '<tr class="oddeven">';
298  print '<td>' . img_picto('', 'bill', 'class="pictofixedwidth"') . $langs->trans("UseAuxiliaryAccountOnCustomerDeposit") . '</td>';
299  if (getDolGlobalInt('ACCOUNTING_ACCOUNT_CUSTOMER_USE_AUXILIARY_ON_DEPOSIT')) {
300  print '<td class="right"><a class="reposition" href="' . $_SERVER['PHP_SELF'] . '?token=' . newToken() . '&action=setACCOUNTING_ACCOUNT_CUSTOMER_USE_AUXILIARY_ON_DEPOSIT&value=0">';
301  print img_picto($langs->trans("Activated"), 'switch_on', '', false, 0, 0, '', 'warning');
302  print '</a></td>';
303  } else {
304  print '<td class="right"><a class="reposition" href="' . $_SERVER['PHP_SELF'] . '?token=' . newToken() . '&action=setACCOUNTING_ACCOUNT_CUSTOMER_USE_AUXILIARY_ON_DEPOSIT&value=1">';
305  print img_picto($langs->trans("Disabled"), 'switch_off');
306  print '</a></td>';
307  }
308  print '</tr>';
309 }
310 
311 // Supplier deposit account
312 print '<tr class="oddeven value">';
313 // Param
314 print '<td>';
315 print img_picto('', 'supplier_invoice', 'class="pictofixedwidth"') . $langs->trans('ACCOUNTING_ACCOUNT_SUPPLIER_DEPOSIT');
316 print '</td>';
317 // Value
318 print '<td class="right">'; // Do not force class=right, or it align also the content of the select box
319 print $formaccounting->select_account(getDolGlobalString('ACCOUNTING_ACCOUNT_SUPPLIER_DEPOSIT'), 'ACCOUNTING_ACCOUNT_SUPPLIER_DEPOSIT', 1, '', 1, 1, 'minwidth100 maxwidth300 maxwidthonsmartphone', 'accounts');
320 print '</td>';
321 print '</tr>';
322 
323 if (isModEnabled('societe') && getDolGlobalString('ACCOUNTING_ACCOUNT_SUPPLIER_DEPOSIT') && getDolGlobalString('ACCOUNTING_ACCOUNT_SUPPLIER_DEPOSIT') != '-1') {
324  print '<tr class="oddeven">';
325  print '<td>' . img_picto('', 'supplier_invoice', 'class="pictofixedwidth"') . $langs->trans("UseAuxiliaryAccountOnSupplierDeposit") . '</td>';
326  if (getDolGlobalInt('ACCOUNTING_ACCOUNT_SUPPLIER_USE_AUXILIARY_ON_DEPOSIT')) {
327  print '<td class="right"><a class="reposition" href="' . $_SERVER['PHP_SELF'] . '?token=' . newToken() . '&action=setACCOUNTING_ACCOUNT_SUPPLIER_USE_AUXILIARY_ON_DEPOSIT&value=0">';
328  print img_picto($langs->trans("Activated"), 'switch_on', '', false, 0, 0, '', 'warning');
329  print '</a></td>';
330  } else {
331  print '<td class="right"><a class="reposition" href="' . $_SERVER['PHP_SELF'] . '?token=' . newToken() . '&action=setACCOUNTING_ACCOUNT_SUPPLIER_USE_AUXILIARY_ON_DEPOSIT&value=1">';
332  print img_picto($langs->trans("Disabled"), 'switch_off');
333  print '</a></td>';
334  }
335  print '</tr>';
336 }
337 
338 print "</table>\n";
339 print "</div>\n";
340 
341 print '<div class="center"><input type="submit" class="button button-edit" name="button" value="'.$langs->trans('Save').'"></div>';
342 
343 print '</form>';
344 
345 // End of page
346 llxFooter();
347 $db->close();
dolibarr_set_const($db, $name, $value, $type='chaine', $visible=0, $note='', $entity=1)
Insert a parameter (key,value) into database (delete old key then insert it again).
Definition: admin.lib.php:638
if(!defined('NOREQUIRESOC')) if(!defined('NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined('NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined('NOREQUIREAJAX')) llxHeader()
Empty header.
Definition: wrapper.php:56
llxFooter()
Empty footer.
Definition: wrapper.php:70
Class to manage generation of HTML components for accounting management.
Class to manage generation of HTML components Only common components must be here.
if($cancel &&! $id) if($action=='add' &&! $cancel) if($action=='delete') if($id) $form
Actions.
Definition: card.php:143
load_fiche_titre($titre, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='')
Load a title with picto.
getDolGlobalInt($key, $default=0)
Return dolibarr global constant int value.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=false, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
newToken()
Return the value of token currently saved into session with name 'newtoken'.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0)
Set event messages in dol_events session object.
getDolGlobalString($key, $default='')
Return dolibarr global constant string value.
isModEnabled($module)
Is Dolibarr module enabled.
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.