dolibarr 21.0.0-beta
payment.php
Go to the documentation of this file.
1<?php
2/* Copyright (C) 2015 Juanjo Menent <jmenent@2byte.es>
3 * Copyright (C) 2020 Maxime DEMAREST <maxime@indelog.fr>
4 * Copyright (C) 2024 MDW <mdeweerd@users.noreply.github.com>
5 * Copyright (C) 2024 Frédéric France <frederic.france@free.fr>
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 3 of the License, or
10 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program. If not, see <https://www.gnu.org/licenses/>.
19 */
20
27// Load Dolibarr environment
28require '../main.inc.php';
29require_once DOL_DOCUMENT_ROOT.'/core/lib/admin.lib.php';
30require_once DOL_DOCUMENT_ROOT.'/core/lib/invoice.lib.php';
31require_once DOL_DOCUMENT_ROOT.'/compta/paiement/class/paiement.class.php';
32
42// Load translation files required by the page
43$langs->loadLangs(array("admin", "other", "errors", "bills"));
44
45if (!$user->admin) {
47}
48
49$action = GETPOST('action', 'aZ09');
50$value = GETPOST('value', 'alpha');
51$label = GETPOST('label', 'alpha');
52$scandir = GETPOST('scan_dir', 'alpha');
53$type = 'invoice';
54
55if (!getDolGlobalString('PAYMENT_ADDON')) {
56 $conf->global->PAYMENT_ADDON = 'mod_payment_cicada.php';
57}
58
59
60/*
61 * Actions
62 */
63$error = 0;
64
65if ($action == 'updateMask') {
66 $maskconstpayment = GETPOST('maskconstpayment', 'aZ09');
67 $maskpayment = GETPOST('maskpayment', 'alpha');
68
69 $res = 0;
70
71 if ($maskconstpayment && preg_match('/_MASK$/', $maskconstpayment)) {
72 $res = dolibarr_set_const($db, $maskconstpayment, $maskpayment, 'chaine', 0, '', $conf->entity);
73 }
74
75 if (!($res > 0)) {
76 $error++;
77 }
78
79 if (!$error) {
80 setEventMessages($langs->trans("SetupSaved"), null, 'mesgs');
81 } else {
82 setEventMessages($langs->trans("Error"), null, 'errors');
83 }
84}
85
86if ($action == 'setmod') {
87 dolibarr_set_const($db, "PAYMENT_ADDON", $value, 'chaine', 0, '', $conf->entity);
88}
89
90if ($action == 'setparams') {
91 $freetext = GETPOST('FACTURE_PAYMENTS_ON_DIFFERENT_THIRDPARTIES_BILLS', 'restricthtml'); // No alpha here, we want exact string
92 $res = dolibarr_set_const($db, "FACTURE_PAYMENTS_ON_DIFFERENT_THIRDPARTIES_BILLS", $freetext, 'chaine', 0, '', $conf->entity);
93 if (!($res > 0)) {
94 $error++;
95 }
96
97 $res = dolibarr_set_const($db, "PAYMENTS_REPORT_GROUP_BY_MOD", GETPOSTINT('PAYMENTS_REPORT_GROUP_BY_MOD'), 'chaine', 0, '', $conf->entity);
98 if (!($res > 0)) {
99 $error++;
100 }
101
102 if ($error) {
103 setEventMessages($langs->trans("Error"), null, 'errors');
104 }
105 if (!$error) {
106 setEventMessages($langs->trans("SetupSaved"), null, 'mesgs');
107 }
108}
109
110
111/*
112 * View
113 */
114
115$dirmodels = array_merge(array('/'), (array) $conf->modules_parts['models']);
116
117llxHeader('', $langs->trans("BillsSetup"), 'EN:Invoice_Configuration|FR:Configuration_module_facture|ES:ConfiguracionFactura', '', 0, 0, '', '', '', 'mod-admin page-payment');
118
119$form = new Form($db);
120
121
122$linkback = '<a href="'.DOL_URL_ROOT.'/admin/modules.php?restore_lastsearch_values=1">'.$langs->trans("BackToModuleList").'</a>';
123print load_fiche_titre($langs->trans("BillsSetup"), $linkback, 'title_setup');
124
126print dol_get_fiche_head($head, 'payment', $langs->trans("Invoices"), -1, 'invoice');
127
128/*
129 * Numbering module
130 */
131
132print load_fiche_titre($langs->trans("PaymentsNumberingModule"), '', '');
133
134print '<div class="div-table-responsive-no-min">';
135print '<table class="noborder centpercent">';
136print '<tr class="liste_titre">';
137print '<td>'.$langs->trans("Name").'</td>';
138print '<td>'.$langs->trans("Description").'</td>';
139print '<td class="nowrap">'.$langs->trans("Example").'</td>';
140print '<td align="center" width="60">'.$langs->trans("Status").'</td>';
141print '<td align="center" width="16">'.$langs->trans("ShortInfo").'</td>';
142print '</tr>'."\n";
143
144clearstatcache();
145
146foreach ($dirmodels as $reldir) {
147 $dir = dol_buildpath($reldir."core/modules/payment/");
148 if (is_dir($dir)) {
149 $handle = opendir($dir);
150 if (is_resource($handle)) {
151 while (($file = readdir($handle)) !== false) {
152 if (!is_dir($dir.$file) || (substr($file, 0, 1) != '.' && substr($file, 0, 3) != 'CVS')) {
153 $filebis = $file;
154 $classname = preg_replace('/\.php$/', '', $file);
155 // For compatibility
156 if (!is_file($dir.$filebis)) {
157 $filebis = $file."/".$file.".modules.php";
158 $classname = "mod_payment_".$file;
159 }
160 // Check if there is a filter on country
161 preg_match('/\-(.*)_(.*)$/', $classname, $reg);
162 if (!empty($reg[2]) && $reg[2] != strtoupper($mysoc->country_code)) {
163 continue;
164 }
165
166 $classname = preg_replace('/\-.*$/', '', $classname);
167 if (!class_exists($classname) && is_readable($dir.$filebis) && (preg_match('/mod_/', $filebis) || preg_match('/mod_/', $classname)) && substr($filebis, dol_strlen($filebis) - 3, 3) == 'php') {
168 // Charging the numbering class
169 require_once $dir.$filebis;
170
171 $module = new $classname($db);
172 '@phan-var-force ModeleNumRefPayments $module';
173
174 // Show modules according to features level
175 if ($module->version == 'development' && getDolGlobalInt('MAIN_FEATURES_LEVEL') < 2) {
176 continue;
177 }
178 if ($module->version == 'experimental' && getDolGlobalInt('MAIN_FEATURES_LEVEL') < 1) {
179 continue;
180 }
181
182 if ($module->isEnabled()) {
183 print '<tr class="oddeven"><td width="100">';
184 echo preg_replace('/\-.*$/', '', preg_replace('/mod_payment_/', '', preg_replace('/\.php$/', '', $file)));
185 print "</td><td>\n";
186
187 print $module->info($langs);
188
189 print '</td>';
190
191 // Show example of numbering module
192 print '<td class="nowrap">';
193 $tmp = $module->getExample();
194 if (preg_match('/^Error/', $tmp)) {
195 $langs->load("errors");
196 print '<div class="error">'.$langs->trans($tmp).'</div>';
197 } elseif ($tmp == 'NotConfigured') {
198 print '<span class="opacitymedium">'.$langs->trans($tmp).'</span>';
199 } else {
200 print $tmp;
201 }
202 print '</td>'."\n";
203
204 print '<td class="center">';
205 //print "> ".$conf->global->PAYMENT_ADDON." - ".$file;
206 if ($conf->global->PAYMENT_ADDON == $file || getDolGlobalString('PAYMENT_ADDON') . '.php' == $file) {
207 print img_picto($langs->trans("Activated"), 'switch_on');
208 } else {
209 print '<a class="reposition" href="'.$_SERVER["PHP_SELF"].'?action=setmod&token='.newToken().'&value='.preg_replace('/\.php$/', '', $file).'" alt="'.$langs->trans("Default").'">'.img_picto($langs->trans("Disabled"), 'switch_off').'</a>';
210 }
211 print '</td>';
212
213 $payment = new Paiement($db);
214 $payment->initAsSpecimen();
215
216 // Example
217 $htmltooltip = '';
218 $htmltooltip .= ''.$langs->trans("Version").': <b>'.$module->getVersion().'</b><br>';
219 $nextval = $module->getNextValue($mysoc, $payment);
220 if ("$nextval" != $langs->trans("NotAvailable")) { // Keep " on nextval
221 $htmltooltip .= $langs->trans("NextValue").': ';
222 if ($nextval) {
223 if (preg_match('/^Error/', $nextval) || $nextval == 'NotConfigured') {
224 $nextval = $langs->trans($nextval);
225 }
226 $htmltooltip .= $nextval.'<br>';
227 } else {
228 $htmltooltip .= $langs->trans($module->error).'<br>';
229 }
230 }
231
232 print '<td class="center">';
233 print $form->textwithpicto('', $htmltooltip, 1, 0);
234
235 if (getDolGlobalString('PAYMENT_ADDON') . '.php' == $file) { // If module is the one used, we show existing errors
236 if (!empty($module->error)) {
237 dol_htmloutput_mesg($module->error, array(), 'error', 1);
238 }
239 }
240
241 print '</td>';
242
243 print "</tr>\n";
244 }
245 }
246 }
247 }
248 closedir($handle);
249 }
250 }
251}
252
253print '</table>';
254print '</div>';
255
256print "<br>";
257
258print load_fiche_titre($langs->trans("OtherOptions"), '', '');
259
260print '<form action="'.$_SERVER["PHP_SELF"].'" method="POST">';
261print '<input type="hidden" name="token" value="'.newToken().'" />';
262print '<input type="hidden" name="action" value="setparams" />';
263
264print '<div class="div-table-responsive-no-min">';
265print '<table class="noborder centpercent">';
266print '<tr class="liste_titre">';
267print '<td>'.$langs->trans("Parameter").'</td>';
268print '<td align="center" width="60">'.$langs->trans("Value").'</td>';
269print '<td width="80">&nbsp;</td>';
270print "</tr>\n";
271
272// Allow payments on different thirdparties bills but same parent company
273print '<tr class="oddeven"><td>';
274print $langs->trans("PaymentOnDifferentThirdBills");
275print '</td><td width="60" align="center">';
276print $form->selectyesno("FACTURE_PAYMENTS_ON_DIFFERENT_THIRDPARTIES_BILLS", getDolGlobalInt('FACTURE_PAYMENTS_ON_DIFFERENT_THIRDPARTIES_BILLS'), 1);
277print '</td><td class="right">';
278print "</td></tr>\n";
279
280// Allow to group payments by mod in rapports
281print '<tr class="oddeven"><td>';
282print $langs->trans("GroupPaymentsByModOnReports");
283print '</td><td width="60" align="center">';
284print $form->selectyesno("PAYMENTS_REPORT_GROUP_BY_MOD", getDolGlobalInt('PAYMENTS_REPORT_GROUP_BY_MOD'), 1);
285print '</td><td class="right">';
286print "</td></tr>\n";
287
288print '</table>';
289print '</div>';
290
291print dol_get_fiche_end();
292
293print $form->buttonsSaveCancel("Modify", '');
294
295print '</form>';
296
297// End of page
298llxFooter();
299$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).
if(!defined('NOREQUIRESOC')) if(!defined( 'NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined( 'NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined( 'NOREQUIREAJAX')) llxHeader($head='', $title='', $help_url='', $target='', $disablejs=0, $disablehead=0, $arrayofjs='', $arrayofcss='', $morequerystring='', $morecssonbody='', $replacemainareaby='', $disablenofollow=0, $disablenoindex=0)
Empty header.
Definition wrapper.php:71
Class to manage generation of HTML components Only common components must be here.
Class to manage payments of customer invoices.
llxFooter()
Footer empty.
Definition document.php:107
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='')
Load a title with picto.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2)
Show picto whatever it's its name (generic function)
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='', $dragdropfile=0)
Show tabs of a record.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
dol_strlen($string, $stringencoding='UTF-8')
Make a strlen call.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
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.
dol_buildpath($path, $type=0, $returnemptyifnotfound=0)
Return path of url or filesystem.
dol_htmloutput_mesg($mesgstring='', $mesgarray=array(), $style='ok', $keepembedded=0)
Print formatted messages to output (Used to show messages on html output).
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
invoice_admin_prepare_head()
Return array head with list of tabs to view object information.
global $conf
The following vars must be defined: $type2label $form $conf, $lang, The following vars may also be de...
Definition member.php:79
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.