dolibarr 24.0.0-beta
rapport.php
Go to the documentation of this file.
1<?php
2/* Copyright (C) 2017 ATM-Consulting <support@atm-consulting.fr>
3 * Copyright (C) 2020 Maxime DEMAREST <maxime@indelog.fr>
4 * Copyright (C) 2024 Frédéric France <frederic.france@free.fr>
5 * Copyright (C) 2026 Alexandre Spangaro <alexandre@inovea-conseil.com>
6 * Copyright (C) 2026 MDW <mdeweerd@users.noreply.github.com>
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 */
21
28// Load Dolibarr environment
29require '../../main.inc.php';
30
39require_once DOL_DOCUMENT_ROOT.'/core/modules/rapport/pdf_paiement_fourn.class.php';
40require_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';
41require_once DOL_DOCUMENT_ROOT.'/core/class/html.formfile.class.php';
42require_once DOL_DOCUMENT_ROOT.'/core/class/html.formother.class.php';
43
44$langs->loadLangs(array('bills'));
45
46// Security check
47$socid = '';
48if (!empty($user->socid)) {
49 $socid = $user->socid;
50}
51$result = restrictedArea($user, 'fournisseur', 0, 'facture_fourn', 'facture');
52
54
55$action = GETPOST('action', 'aZ09');
56$fileToRemove = GETPOST('removefile', 'alpha');
57
58$socid = 0;
59if ($user->socid > 0) {
60 $action = '';
61 $socid = $user->socid;
62}
63
64$dir = getMultidirOutput($object).'/payments';
65if (!$user->hasRight("societe", "client", "voir") || $socid) {
66 $dir .= '/private/'.$user->id; // If user has no permission to see all, output dir is specific to user
67}
68
69$year = GETPOSTINT("year");
70if (!$year) {
71 $year = date("Y");
72}
73
74$permissiontoread = ($user->hasRight("fournisseur", "facture", "lire") || $user->hasRight("supplier_invoice", "lire"));
75$permissiontoadd = ($user->hasRight("fournisseur", "facture", "creer") || $user->hasRight("supplier_invoice", "creer"));
76
77
78/*
79 * Actions
80 */
81
82if ($action == 'builddoc' && $permissiontoread) {
83 $rap = new pdf_paiement_fourn($db);
84
85 $outputlangs = $langs;
86 if (GETPOST('lang_id', 'aZ09')) {
87 $outputlangs = new Translate("", $conf);
88 $outputlangs->setDefaultLang(GETPOST('lang_id', 'aZ09'));
89 }
90
91 // We save charset_output to restore it because write_file can change it if needed for
92 // output format that does not support UTF8.
93 $sav_charset_output = $outputlangs->charset_output;
94 if ($rap->write_file($dir, GETPOSTINT("remonth"), GETPOSTINT("reyear"), $outputlangs) > 0) {
95 $outputlangs->charset_output = $sav_charset_output;
96 } else {
97 $outputlangs->charset_output = $sav_charset_output;
98 dol_print_error($db, $rap->error);
99 }
100
101 $year = GETPOSTINT("reyear");
102}
103
104// Delete file from disk
105if ($action == 'removedoc' && $permissiontoread && $fileToRemove) {
106 $fileDirectory = dirname($dir.'/'.$fileToRemove);
107 if (dol_delete_file($dir.'/'.$fileToRemove)) {
108 // Delete empty directory after file deletion
109 if (empty(dol_dir_list($fileDirectory))) {
110 dol_delete_dir($fileDirectory);
111 }
112 setEventMessages($langs->trans("FileWasRemoved", $fileToRemove), null, 'mesgs');
113 } else {
114 setEventMessages($langs->trans("ErrorFailToDeleteFile", $fileToRemove), null, 'errors');
115 }
116}
117
118
119/*
120 * View
121 */
122
123$formother = new FormOther($db);
124$formfile = new FormFile($db);
125
126$titre = ($year ? $langs->trans("PaymentsReportsForYear", $year) : $langs->trans("PaymentsReports"));
127
128llxHeader('', $titre, '', '', 0, 0, '', '', '', 'mod-fourn-facture page-rapport');
129
130print load_fiche_titre($titre, '', 'supplier_invoice');
131
132// Formulaire de generation
133print '<form method="post" action="rapport.php?year='.$year.'">';
134print '<input type="hidden" name="token" value="'.newToken().'">';
135print '<input type="hidden" name="action" value="builddoc">';
136$cmonth = GETPOST("remonth") ? GETPOST("remonth") : date("n", time());
137$syear = GETPOST("reyear") ? GETPOST("reyear") : date("Y", time());
138
139print $formother->select_month($cmonth, 'remonth');
140
141print $formother->selectyear($syear, 'reyear');
142
143print '<input type="submit" class="button" value="'.$langs->trans("Create").'">';
144print '</form>';
145print '<br>';
146
147clearstatcache();
148
149// Show link on other years
150$linkforyear = array();
151$found = 0;
152if (is_dir($dir)) {
153 $handle = opendir($dir);
154 if (is_resource($handle)) {
155 while (($file = readdir($handle)) !== false) {
156 if (is_dir($dir.'/'.$file) && !preg_match('/^\./', $file) && is_numeric($file)) {
157 $found = 1;
158 $linkforyear[] = $file;
159 }
160 }
161 }
162}
163asort($linkforyear);
164foreach ($linkforyear as $cursoryear) {
165 print '<a href="'.$_SERVER["PHP_SELF"].'?year='.$cursoryear.'">'.$cursoryear.'</a> &nbsp;';
166}
167
168if ($year) {
169 if (is_dir($dir.'/'.$year)) {
170 $handle = opendir($dir.'/'.$year);
171
172 if ($found) {
173 print '<br>';
174 }
175 print '<br>';
176 print '<table width="100%" class="noborder">';
177 print '<tr class="liste_titre">';
178 print '<td>'.$langs->trans("Reporting").'</td>';
179 print '<td class="right">'.$langs->trans("Size").'</td>';
180 print '<td class="right">'.$langs->trans("Date").'</td>';
181 print '<td class="right"></td>';
182 print '</tr>';
183
184 if (is_resource($handle)) {
185 while (($file = readdir($handle)) !== false) {
186 if (preg_match('/^supplier_payment/i', $file)) {
187 $tfile = $dir.'/'.$year.'/'.$file;
188 $relativepath = $year.'/'.$file;
189 print '<tr class="oddeven"><td><a data-ajax="false" href="'.DOL_URL_ROOT.'/document.php?modulepart=facture_fournisseur&amp;file=payments/'.urlencode($relativepath).'">'.img_picto('', 'pdf').' '.$file.'</a>'.$formfile->showPreview(['name' => $file,'fullname' => $tfile], 'facture_fournisseur', 'payments/'.$relativepath, 0).'</td>';
190 print '<td class="right">'.dol_print_size(dol_filesize($tfile)).'</td>';
191 print '<td class="right">'.dol_print_date(dol_filemtime($tfile), "dayhour").'</td>';
192 print '<td class="right"><a href="rapport.php?removefile='.urlencode($relativepath).'&action=removedoc&token='.newToken().'">'.img_delete().'</a></td>';
193 print '</tr>';
194 }
195 }
196 closedir($handle);
197 }
198
199 print '</table>';
200 }
201}
202
203// End of page
204llxFooter();
205$db->close();
if(! $sortfield) if(! $sortorder) $object
Definition account.php:100
llxFooter($comment='', $zone='private', $disabledoutputofmessages=0)
Empty footer.
Definition wrapper.php:91
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:73
Class to manage suppliers invoices.
Class to offer components to list and upload files.
Class to help generate other html components Only common components are here.
Class to manage translations.
Class permettant de generer les rapports de paiement.
if(!isModEnabled('ai')||!getDolGlobalString('AI_ASSISTANT_ENABLED')) global $conf
The main.inc.php has been included so the following variable are now defined:
if(!isModEnabled('ai')||!getDolGlobalString('AI_ASSISTANT_ENABLED')) global $db
API class for accounts.
dol_filemtime($pathoffile)
Return time of a file.
dol_filesize($pathoffile)
Return size of a file.
dol_delete_file($file, $disableglob=0, $nophperrors=0, $nohook=0, $object=null, $allowdotdot=false, $indexdatabase=1, $nolog=0)
Remove a file or several files with a mask.
dol_delete_dir($dir, $nophperrors=0)
Remove a directory (not recursive, so content must be empty).
dol_dir_list($utf8_path, $types="all", $recursive=0, $filter="", $excludefilter=null, $sortcriteria="name", $sortorder=SORT_ASC, $mode=0, $nohook=0, $relativename="", $donotfollowsymlinks=0, $nbsecondsold=0)
Scan a directory and return a list of files/directories.
Definition files.lib.php:64
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, $allowothertags=array())
Show picto whatever it's its name (generic function)
img_delete($titlealt='default', $other='class="pictodelete"', $morecss='')
Show delete logo.
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
getMultidirOutput($object, $module='', $forobject=0, $mode='output')
Return the full path of the directory where a module (or an object of a module) stores its files.
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...
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='', $morecssonpicto='widthpictotitle')
Load a title with picto.
print $langs trans('Date')." left Ref Label right Qty right Price right TotalHT right TotalTTC right right right right right right right right right centpercent right TotalHT right n right VAT right n right TotalVAT right n No sujeto a RE IRPF right TotalLT1 right n right TotalLT2 right n right TotalTTC right n takeposcustomercurrency takeposcustomercurrency takeposcustomercurrency takeposcustomercurrency right TotalTTC takeposcustomercurrency right takeposcustomercurrency n right Paid right PaymentTypeShortLIQ right SELECT p pos_change as p datep as date
Definition receipt.php:487
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.