31require
'../../main.inc.php';
40require_once DOL_DOCUMENT_ROOT.
'/compta/prelevement/class/bonprelevement.class.php';
41require_once DOL_DOCUMENT_ROOT.
'/compta/bank/class/account.class.php';
44$langs->loadLangs(array(
'banks',
'categories',
'withdrawals'));
46$action =
GETPOST(
'action',
'aZ09') ?
GETPOST(
'action',
'aZ09') :
'view';
47$massaction =
GETPOST(
'massaction',
'alpha');
48$confirm =
GETPOST(
'confirm',
'alpha');
49$cancel =
GETPOST(
'cancel',
'alpha');
50$toselect =
GETPOST(
'toselect',
'array:int');
51$contextpage =
GETPOST(
'contextpage',
'aZ') ?
GETPOST(
'contextpage',
'aZ') :
'directdebitcredittransferlist';
52$backtopage =
GETPOST(
'backtopage',
'alpha');
53$optioncss =
GETPOST(
'optioncss',
'alpha');
54$mode =
GETPOST(
'mode',
'alpha');
57$search_ref =
GETPOST(
'search_ref',
'alpha');
58$search_amount =
GETPOST(
'search_amount',
'alpha');
59$search_status =
GETPOSTISARRAY(
'search_status') ?
GETPOST(
'search_status',
'array:int') : (GETPOSTISSET(
'search_status') ?
GETPOST(
'search_status',
'array:intcomma') : array());
64$sortfield =
GETPOST(
'sortfield',
'aZ09comma');
65$sortorder =
GETPOST(
'sortorder',
'aZ09comma');
67if (empty($page) || $page < 0 ||
GETPOST(
'button_search',
'alpha') ||
GETPOST(
'button_removefilter',
'alpha')) {
71$offset = $limit * $page;
78 $sortfield =
"p.datec";
82$hookmanager->initHooks(array(
'withdrawalsreceiptslist'));
84$usercancreate = $user->hasRight(
'prelevement',
'bons',
'creer');
85$permissiontodelete = $user->hasRight(
'prelevement',
'creer');
86if ($type ==
'bank-transfer') {
87 $usercancreate = $user->hasRight(
'paymentbybanktransfer',
'create');
88 $permissiontodelete = $user->hasRight(
'paymentbybanktransfer',
'create');
94 $socid = $user->socid;
96if ($type ==
'bank-transfer') {
97 $result =
restrictedArea($user,
'paymentbybanktransfer',
'',
'',
'');
108if (
GETPOST(
'button_removefilter_x',
'alpha') ||
GETPOST(
'button_removefilter.x',
'alpha') ||
GETPOST(
'button_removefilter',
'alpha')) {
111 $search_status = array();
117if (($massaction ==
"delete" || ($action ==
'delete' && $confirm ==
'yes')) && $permissiontodelete) {
123 foreach ($toselect as $toselectid) {
124 $result = $objecttmp->fetch($toselectid);
126 if ($objecttmp->status != $objecttmp::STATUS_DRAFT || $objecttmp->credite > 0 || $objecttmp->date_creation !=
null) {
127 $langs->load(
"errors");
129 $TMsg[] =
'<div class="error">'.$langs->trans(
'ErrorOnlyDraftStatusCanBeDeletedInMassAction', $objecttmp->ref).
'</div><br>';
132 $result = $objecttmp->delete($user);
150 } elseif ($nbok > 0) {
168$objectclass =
'BonPrelevement';
169$objectlabel =
'BonPrelevement';
170if ($type ==
'bank-transfer') {
171 $uploaddir =
$conf->paymentbybanktransfer->dir_output;
173 $uploaddir =
$conf->prelevement->dir_output;
175include DOL_DOCUMENT_ROOT.
'/core/actions_massactions.inc.php';
185$titlekey =
"WithdrawalsReceipts";
186$title = $langs->trans(
"WithdrawalsReceipts");
187if ($type ==
'bank-transfer') {
188 $titlekey =
"BankTransferReceipts";
189 $title = $langs->trans(
"BankTransferReceipts");
194$sql =
"SELECT p.rowid, p.ref, p.amount, p.statut as status, p.date_trans, p.method_trans, p.date_credit, p.fk_bank_account, p.datec, p.tms as datem";
198$sql .=
" FROM ".MAIN_DB_PREFIX.
"prelevement_bons as p";
199$sql .=
" WHERE p.entity IN (".getEntity(
'invoice').
")";
200if ($type ==
'bank-transfer') {
201 $sql .=
" AND p.type = 'bank-transfer'";
203 $sql .=
" AND p.type = 'debit-order'";
211if (is_array($search_status)) {
212 if (!empty($search_status)) {
213 $sql .=
natural_search(
"p.statut", implode(
',', $search_status), 2);
215} elseif ((
string) $search_status !=
'' && (
string) $search_status !=
'-1') {
220$nbtotalofrecords =
'';
223 $sqlforcount = preg_replace(
'/^'.preg_quote($sqlfields,
'/').
'/',
'SELECT COUNT(*) as nbtotalofrecords', $sql);
224 $sqlforcount = preg_replace(
'/GROUP BY .*$/',
'', $sqlforcount);
225 $resql =
$db->query($sqlforcount);
227 $objforcount =
$db->fetch_object($resql);
228 $nbtotalofrecords = $objforcount->nbtotalofrecords;
233 if (($page * $limit) > (
int) $nbtotalofrecords) {
241$sql .=
$db->order($sortfield, $sortorder);
243 $sql .=
$db->plimit($limit + 1, $offset);
246$resql =
$db->query($sql);
252$num =
$db->num_rows($resql);
257llxHeader(
'', $title, $help_url,
'', 0, 0,
'',
'',
'',
'bodyforlist');
259$arrayofselected = is_array($toselect) ? $toselect : array();
261if ($type ==
'bank-transfer') {
262 $param .=
'&type=bank-transfer';
265 $param .=
'&mode='.urlencode($mode);
267if (!empty($contextpage) && $contextpage != $_SERVER[
"PHP_SELF"]) {
268 $param .=
'&contextpage='.urlencode($contextpage);
270if ($limit > 0 && $limit !=
$conf->liste_limit) {
271 $param .=
'&limit='.((int) $limit);
273if ($optioncss !=
'') {
274 $param .=
'&optioncss='.urlencode($optioncss);
277 $param .=
'&search_amount='.urlencode($search_amount);
279if (is_array($search_status)) {
280 if (!empty($search_status)) {
281 $param .=
'&search_status='.implode(
',', $search_status);
283} elseif ((
string) $search_status !=
'' && (
string) $search_status !=
'-1') {
284 $param .=
'&search_status='.((int) $search_status);
287$arrayofmassactions = array(
291if (!empty($permissiontodelete)) {
292 $arrayofmassactions[
'predeletedraft'] =
img_picto(
'',
'delete',
'class="pictofixedwidth"').$langs->trans(
"Delete");
294$massactionbutton = $form->selectMassAction(
'', $arrayofmassactions);
296print
'<form method="POST" id="searchFormList" action="'.$_SERVER[
"PHP_SELF"].
'">'.
"\n";
297print
'<input type="hidden" name="token" value="'.newToken().
'">';
298if ($optioncss !=
'') {
299 print
'<input type="hidden" name="optioncss" value="'.$optioncss.
'">';
301print
'<input type="hidden" name="formfilteraction" id="formfilteraction" value="list">';
302print
'<input type="hidden" name="action" value="list">';
303print
'<input type="hidden" name="sortfield" value="'.$sortfield.
'">';
304print
'<input type="hidden" name="sortorder" value="'.$sortorder.
'">';
305print
'<input type="hidden" name="page" value="'.$page.
'">';
306print
'<input type="hidden" name="contextpage" value="'.$contextpage.
'">';
307print
'<input type="hidden" name="page_y" value="">';
308print
'<input type="hidden" name="mode" value="'.$mode.
'">';
311 print
'<input type="hidden" name="type" value="'.$type.
'">';
315$newcardbutton .= dolGetButtonTitle($langs->trans(
'ViewList'),
'',
'fa fa-bars imgforviewmode', $_SERVER[
"PHP_SELF"].
'?mode=common'.preg_replace(
'/(&|\?)*mode=[^&]+/',
'', $param),
'', ((empty($mode) || $mode ==
'common') ? 2 : 1), array(
'morecss' =>
'reposition'));
316$newcardbutton .= dolGetButtonTitle($langs->trans(
'ViewKanban'),
'',
'fa fa-th-list imgforviewmode', $_SERVER[
"PHP_SELF"].
'?mode=kanban'.preg_replace(
'/(&|\?)*mode=[^&]+/',
'', $param),
'', ($mode ==
'kanban' ? 2 : 1), array(
'morecss' =>
'reposition'));
318 $newcardbutton .= dolGetButtonTitleSeparator();
319 $newcardbutton .= dolGetButtonTitle($langs->trans(
'NewStandingOrder'),
'',
'fa fa-plus-circle', DOL_URL_ROOT.
'/compta/prelevement/create.php?type='.urlencode($type));
322print_barre_liste($title, $page, $_SERVER[
"PHP_SELF"], $param, $sortfield, $sortorder, $massactionbutton, $num, $nbtotalofrecords,
'generic', 0, $newcardbutton,
'', $limit, 0, 0, 1);
324include DOL_DOCUMENT_ROOT.
'/core/tpl/massactions_pre.tpl.php';
332$parameters = array();
333$reshook = $hookmanager->executeHooks(
'printFieldPreListTitle', $parameters, $object, $action);
334if (empty($reshook)) {
335 $moreforfilter .= $hookmanager->resPrint;
337 $moreforfilter = $hookmanager->resPrint;
340if (!empty($moreforfilter)) {
341 print
'<div class="liste_titre liste_titre_bydiv centpercent">';
342 print $moreforfilter;
346$varpage = empty($contextpage) ? $_SERVER[
"PHP_SELF"] : $contextpage;
347$htmlofselectarray = $form->multiSelectArrayWithCheckbox(
'selectedfields', $arrayfields, $varpage,
$conf->main_checkbox_left_column);
348$selectedfields = ($mode !=
'kanban' ? $htmlofselectarray :
'');
349$selectedfields .= (count($arrayofmassactions) ? $form->showCheckAddButtons(
'checkforselect', 1) :
'');
351print
'<div class="div-table-responsive">';
352print
'<table class="tagtable nobottomiftotal liste'.($moreforfilter ?
" listwithfilterbefore" :
"").
'">'.
"\n";
356print
'<tr class="liste_titre_filter">';
358if (
$conf->main_checkbox_left_column) {
359 print
'<td class="liste_titre center maxwidthsearch">';
360 $searchpicto = $form->showFilterButtons(
'left');
364print
'<td class="liste_titre"><input type="text" class="flat maxwidth100" name="search_ref" value="'.dol_escape_htmltag($search_ref).
'"></td>';
365print
'<td class="liste_titre"> </td>';
366print
'<td class="liste_titre"> </td>';
367print
'<td class="liste_titre"> </td>';
368print
'<td class="liste_titre right"><input type="text" class="flat maxwidth100" name="search_amount" value="'.dol_escape_htmltag($search_amount).
'"></td>';
369print
'<td class="liste_titre"> </td>';
370print
'<td class="liste_titre center minwidth75imp parentonrightofpage">';
371$arrayofstatus = array(
372 BonPrelevement::STATUS_DRAFT => $langs->trans(
'StatusWaiting'),
373 BonPrelevement::STATUS_TRANSFERED => $langs->trans(
'StatusTrans'),
374 BonPrelevement::STATUS_CREDITED => $langs->trans(
'Closed'),
375 BonPrelevement::STATUS_CANCELED => $langs->trans(
'Canceled')
377print $form->multiselectarray(
'search_status', $arrayofstatus, $search_status, 0, 0,
'search_status width200 right onrightofpage', 0, 0,
'');
380if (!
$conf->main_checkbox_left_column) {
381 print
'<td class="liste_titre center maxwidthsearch">';
382 $searchpicto = $form->showFilterButtons();
393print
'<tr class="liste_titre">';
395if (
$conf->main_checkbox_left_column) {
396 print
getTitleFieldOfList($selectedfields, 0, $_SERVER[
"PHP_SELF"],
'',
'',
'',
'', $sortfield, $sortorder,
'center maxwidthsearch ').
"\n";
401print_liste_field_titre(
"DateCreation", $_SERVER[
"PHP_SELF"],
"p.datec",
"", $param,
'', $sortfield, $sortorder,
'center ');
403print_liste_field_titre(
"TransData", $_SERVER[
"PHP_SELF"],
"p.datec",
"", $param,
'', $sortfield, $sortorder,
'center ');
405print_liste_field_titre(
"CreditDate", $_SERVER[
"PHP_SELF"],
"p.datec",
"", $param,
'', $sortfield, $sortorder,
'center ');
407print_liste_field_titre(
"Amount", $_SERVER[
"PHP_SELF"],
"p.amount",
"", $param,
'', $sortfield, $sortorder,
'right ');
409print_liste_field_titre(
"BankAccount", $_SERVER[
"PHP_SELF"],
"p.fk_bank_account",
"", $param,
'', $sortfield, $sortorder);
414if (!
$conf->main_checkbox_left_column) {
415 print
getTitleFieldOfList($selectedfields, 0, $_SERVER[
"PHP_SELF"],
'',
'',
'',
'', $sortfield, $sortorder,
'center maxwidthsearch ').
"\n";
428$imaxinloop = ($limit ? min($num, $limit) : $num);
429while ($i < $imaxinloop) {
430 $obj =
$db->fetch_object($resql);
432 $directdebitorder->id = $obj->rowid;
433 $directdebitorder->ref = $obj->ref;
434 $directdebitorder->date_creation =
$db->jdate($obj->datec);
435 $directdebitorder->date_trans =
$db->jdate($obj->date_trans);
436 $directdebitorder->date_credit =
$db->jdate($obj->date_credit);
437 $directdebitorder->amount = $obj->amount;
438 $directdebitorder->status = $obj->status;
442 if ($mode ==
'kanban') {
444 print
'<tr class="trkanban"><td colspan="'.$savnbfield.
'">';
445 print
'<div class="box-flex-container kanban">';
448 if ($massactionbutton || $massaction) {
450 if (in_array(
$object->id, $arrayofselected)) {
454 print $directdebitorder->getKanbanView(
'', array(
'selected' => in_array($obj->id, $arrayofselected)));
455 if ($i == ($imaxinloop - 1)) {
461 print
'<tr data-rowid="'.$object->id.
'" class="oddeven row-with-select">';
464 if (
$conf->main_checkbox_left_column) {
465 print
'<td class="nowrap center">';
466 if ($massactionbutton || $massaction) {
468 if (in_array(
$object->id, $arrayofselected)) {
471 print
'<input id="cb'.$object->id.
'" class="flat checkforselect" type="checkbox" name="toselect[]" value="'.
$object->id.
'"'.($selected ?
' checked="checked"' :
'').
'>';
480 print $directdebitorder->getNomUrl(1);
486 print
'<td class="center">'.dol_print_date(
$db->jdate($obj->datec),
'day').
"</td>\n";
491 print
'<td class="center">'.dol_print_date(
$db->jdate($obj->date_trans),
'day').
"</td>\n";
496 print
'<td class="center">'.dol_print_date(
$db->jdate($obj->date_credit),
'day').
"</td>\n";
501 print
'<td class="right"><span class="amount">'.price($obj->amount).
"</span></td>\n";
507 if ($obj->fk_bank_account > 0) {
510 $bankaccount->fetch($obj->fk_bank_account);
511 print $bankaccount->getNomUrl(1);
518 print
'<td class="center">';
519 print
$object->LibStatut($obj->status, 5);
526 if (!
$conf->main_checkbox_left_column) {
527 print
'<td class="nowrap center">';
528 if ($massactionbutton || $massaction) {
530 if (in_array(
$object->id, $arrayofselected)) {
533 print
'<input id="cb'.$object->id.
'" class="flat checkforselect" type="checkbox" name="toselect[]" value="'.
$object->id.
'"'.($selected ?
' checked="checked"' :
'').
'>';
547 print
'<tr><td colspan="'.$savnbfield.
'"><span class="opacitymedium">'.$langs->trans(
"None").
'</span></td></tr>';
552$parameters = array(
'arrayfields' => $arrayfields,
'sql' => $sql);
553$reshook = $hookmanager->executeHooks(
'printFieldListFooter', $parameters, $object, $action);
554print $hookmanager->resPrint;
556print
'</table>'.
"\n";
if(! $sortfield) if(! $sortorder) $object
llxFooter($comment='', $zone='private', $disabledoutputofmessages=0)
Empty footer.
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.
Class to manage bank accounts.
Class to manage withdrawal receipts.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
print_liste_field_titre($name, $file="", $field="", $begin="", $param="", $moreattrib="", $sortfield="", $sortorder="", $prefix="", $tooltip="", $forcenowrapcolumntitle=0)
Show title line of an array.
print_barre_liste($title, $page, $file, $options='', $sortfield='', $sortorder='', $morehtmlcenter='', $num=-1, $totalnboflines='', $picto='generic', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limit=-1, $selectlimitsuffix=0, $hidenavigation=0, $pagenavastextinput=0, $morehtmlrightbeforearrow='')
Print a title with navigation controls for pagination.
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2, $allowothertags=array())
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.
GETPOSTISARRAY($paramname, $method=0)
Return true if the parameter $paramname is submit from a POST OR GET as an array.
natural_search($fields, $value, $mode=0, $nofirstand=0, $sqltoadd='')
Generate natural SQL search string for a criteria (this criteria can be tested on one or several fiel...
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
getTitleFieldOfList($name, $thead=0, $file="", $field="", $begin="", $moreparam="", $moreattrib="", $sortfield="", $sortorder="", $prefix="", $disablesortlink=0, $tooltip='', $forcenowrapcolumntitle=0)
Get title line of an array.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
restrictedArea(User $user, $features, $object=0, $tableandshare='', $feature2='', $dbt_keyfield='fk_soc', $dbt_select='rowid', $isdraft=0, $mode=0)
Check permissions of a user to show a page and an object.