dolibarr 24.0.0-beta
accounting-files.php
Go to the documentation of this file.
1<?php
2/* Copyright (C) 2001-2006 Rodolphe Quiedeville <rodolphe@quiedeville.org>
3 * Copyright (C) 2004-2019 Laurent Destailleur <eldy@users.sourceforge.net>
4 * Copyright (C) 2017 Pierre-Henry Favre <support@atm-consulting.fr>
5 * Copyright (C) 2020 Maxime DEMAREST <maxime@indelog.fr>
6 * Copyright (C) 2021 Gauthier VERDOL <gauthier.verdol@atm-consulting.fr>
7 * Copyright (C) 2022-2025 Alexandre Spangaro <alexandre@inovea-conseil.com>
8 * Copyright (C) 2024-2026 MDW <mdeweerd@users.noreply.github.com>
9 * Copyright (C) 2024-2026 Frédéric France <frederic.france@free.fr>
10 *
11 * This program is free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License as published by
13 * the Free Software Foundation; either version 3 of the License, or
14 * (at your option) any later version.
15 *
16 * This program is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
20 *
21 * You should have received a copy of the GNU General Public License
22 * along with this program. If not, see <https://www.gnu.org/licenses/>.
23 */
24
31if ((array_key_exists('action', $_GET) && $_GET['action'] == 'dl') || (array_key_exists('action', $_POST) && $_POST['action'] == 'dl')) { // To not replace token when downloading file. Keep $_GET and $_POST here
32 if (!defined('NOTOKENRENEWAL')) {
33 define('NOTOKENRENEWAL', '1');
34 }
35}
36
37// Load Dolibarr environment
38require '../main.inc.php';
39require_once DOL_DOCUMENT_ROOT.'/core/lib/company.lib.php';
40require_once DOL_DOCUMENT_ROOT.'/core/lib/files.lib.php';
41require_once DOL_DOCUMENT_ROOT.'/core/lib/date.lib.php';
42require_once DOL_DOCUMENT_ROOT.'/compta/facture/class/facture.class.php';
43require_once DOL_DOCUMENT_ROOT.'/compta/paiement/class/paiement.class.php';
44require_once DOL_DOCUMENT_ROOT.'/salaries/class/paymentsalary.class.php';
45require_once DOL_DOCUMENT_ROOT.'/compta/sociales/class/chargesociales.class.php';
46require_once DOL_DOCUMENT_ROOT.'/don/class/don.class.php';
47require_once DOL_DOCUMENT_ROOT.'/expensereport/class/expensereport.class.php';
48require_once DOL_DOCUMENT_ROOT.'/fourn/class/fournisseur.facture.class.php';
49require_once DOL_DOCUMENT_ROOT.'/fourn/class/fournisseur.facture.class.php';
50require_once DOL_DOCUMENT_ROOT.'/compta/bank/class/paymentvarious.class.php';
51require_once DOL_DOCUMENT_ROOT.'/core/class/html.formfile.class.php';
52require_once DOL_DOCUMENT_ROOT.'/loan/class/paymentloan.class.php';
53
54if (isModEnabled('project')) {
55 require_once DOL_DOCUMENT_ROOT.'/projet/class/project.class.php';
56 require_once DOL_DOCUMENT_ROOT.'/core/class/html.formprojet.class.php';
57}
58
59// Constant to define payment sens
60const PAY_DEBIT = 0;
61const PAY_CREDIT = 1;
62
72$langs->loadLangs(array("accountancy", "bills", "companies", "salaries", "compta", "trips", "banks", "loan"));
73
74$date_start = GETPOST('date_start', 'alpha');
75$date_startDay = GETPOSTINT('date_startday');
76$date_startMonth = GETPOSTINT('date_startmonth');
77$date_startYear = GETPOSTINT('date_startyear');
78$date_start = dol_mktime(0, 0, 0, $date_startMonth, $date_startDay, $date_startYear, 'tzuserrel');
79$date_stop = GETPOST('date_stop', 'alpha');
80$date_stopDay = GETPOSTINT('date_stopday');
81$date_stopMonth = GETPOSTINT('date_stopmonth');
82$date_stopYear = GETPOSTINT('date_stopyear');
83$date_stop = dol_mktime(23, 59, 59, $date_stopMonth, $date_stopDay, $date_stopYear, 'tzuserrel');
84$action = GETPOST('action', 'aZ09');
85$projectid = GETPOSTINT('projectid');
86
87// Initialize a technical object to manage hooks of page. Note that conf->hooks_modules contains an array of hook context
88$hookmanager->initHooks(array('comptafileslist', 'globallist'));
89
90// Load variable for pagination
91$limit = GETPOSTINT('limit') ? GETPOSTINT('limit') : $conf->liste_limit;
92$sortfield = GETPOST('sortfield', 'aZ09comma');
93$sortorder = GETPOST('sortorder', 'aZ09comma');
94$page = GETPOSTISSET('pageplusone') ? (GETPOSTINT('pageplusone') - 1) : GETPOSTINT("page");
95if (empty($page) || $page == -1) {
96 $page = 0;
97} // If $page is not defined, or '' or -1
98$offset = $limit * $page;
99$pageprev = $page - 1;
100$pagenext = $page + 1;
101if (!$sortfield) {
102 $sortfield = "date,item"; // Set here default search field
103}
104if (!$sortorder) {
105 $sortorder = "DESC";
106}
107
108
109$arrayfields = array(
110 'type' => array('label' => "Type", 'checked' => 1),
111 'date' => array('label' => "Date", 'checked' => 1),
112 'date_due' => array('label' => "DateDue", 'checked' => 1),
113 'ref' => array('label' => "Ref", 'checked' => 1),
114 'documents' => array('label' => "Documents", 'checked' => 1),
115 'paid' => array('label' => "Paid", 'checked' => 1),
116 'total_ht' => array('label' => "TotalHT", 'checked' => 1),
117 'total_ttc' => array('label' => "TotalTTC", 'checked' => 1),
118 'total_vat' => array('label' => "TotalVAT", 'checked' => 1),
119 //...
120);
121
122// Security check
123if (!isModEnabled('comptabilite') && !isModEnabled('accounting')) {
125}
126if ($user->socid > 0) {
128}
129
130// Define $arrayofentities if multientity is set.
131$arrayofentities = array();
132if (isModEnabled('multicompany') && isset($mc) && is_object($mc)) {
133 $arrayofentities = $mc->getEntitiesList();
134}
135
136$entity = (GETPOSTISSET('entity') ? GETPOSTINT('entity') : (GETPOSTISSET('search_entity') ? GETPOSTINT('search_entity') : $conf->entity));
137if (isModEnabled('multicompany') && isset($mc) && is_object($mc)) {
138 if (empty($entity) && getDolGlobalString('MULTICOMPANY_ALLOW_EXPORT_ACCOUNTING_DOC_FOR_ALL_ENTITIES')) {
139 $entity = '0,'.implode(',', array_keys($arrayofentities));
140 }
141}
142if (empty($entity)) {
143 $entity = $conf->entity;
144}
145
146$error = 0;
147
148$listofchoices = array(
149 'selectinvoices' => array('label' => 'Invoices', 'picto' => 'bill', 'lang' => 'bills', 'enabled' => isModEnabled('invoice'), 'perms' => $user->hasRight('facture', 'lire')),
150 'selectsupplierinvoices' => array('label' => 'BillsSuppliers', 'picto' => 'supplier_invoice', 'lang' => 'bills', 'enabled' => isModEnabled('supplier_invoice'), 'perms' => $user->hasRight('fournisseur', 'facture', 'lire')),
151 'selectexpensereports' => array('label' => 'ExpenseReports', 'picto' => 'expensereport', 'lang' => 'trips', 'enabled' => isModEnabled('expensereport'), 'perms' => $user->hasRight('expensereport', 'lire')),
152 'selectdonations' => array('label' => 'Donations', 'picto' => 'donation', 'lang' => 'donation', 'enabled' => isModEnabled('don'), 'perms' => $user->hasRight('don', 'lire')),
153 'selectsocialcontributions' => array('label' => 'SocialContributions', 'picto' => 'bill', 'enabled' => isModEnabled('tax'), 'perms' => $user->hasRight('tax', 'charges', 'lire')),
154 'selectpaymentsofsalaries' => array('label' => 'SalariesPayments', 'picto' => 'salary', 'lang' => 'salaries', 'enabled' => isModEnabled('salaries'), 'perms' => $user->hasRight('salaries', 'read')),
155 'selectvariouspayment' => array('label' => 'VariousPayment', 'picto' => 'payment', 'enabled' => isModEnabled('bank'), 'perms' => $user->hasRight('banque', 'lire')),
156 'selectloanspayment' => array('label' => 'PaymentLoan','picto' => 'loan', 'enabled' => isModEnabled('don'), 'perms' => $user->hasRight('loan', 'read')),
157);
158
159
160
161/*
162 * Actions
163 */
164
165//$parameters = array('socid' => $id);
166//$reshook = $hookmanager->executeHooks('doActions', $parameters, $object); // Note that $object may have been modified by some hooks
167//if ($reshook < 0) setEventMessages($hookmanager->error, $hookmanager->errors, 'errors');
168
169$filesarray = array();
170
171'@phan-var-force array<string,array{id:string,entity:string,date:string,date_due:string,paid:float|int,amount_ht:float|int,amount_ttc:float|int,amount_vat:float|int,amount_localtax1:float|int,amount_localtax2:float|int,amount_revenuestamp:float|int,ref:string,fk:string,item:string,thirdparty_name:string,thirdparty_code:string,country_code:string,vatnum:string,sens:string,currency:string,line?:string,name?:string,files?:mixed}> $filesarray';
172
173$result = false;
174if ($action == 'searchfiles' || $action == 'dl') { // Test on permission not required here. Test is done per object type later.
175 if (empty($date_start)) {
176 setEventMessages($langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("DateStart")), null, 'errors');
177 $error++;
178 }
179 if (empty($date_stop)) {
180 setEventMessages($langs->trans("ErrorFieldRequired", $langs->transnoentitiesnoconv("DateEnd")), null, 'errors');
181 $error++;
182 }
183
184 if (!$error) {
185 $sql = '';
186
187 $sanitizedwheretail = " '".$db->idate($date_start)."' AND '".$db->idate($date_stop)."'";
188
189 // Customer invoices
190 if (GETPOST('selectinvoices') && !empty($listofchoices['selectinvoices']['perms'])) {
191 if (!empty($sql)) {
192 $sql .= " UNION ALL";
193 }
194 $sql .= "SELECT t.rowid as id, t.entity, t.ref, t.paye as paid, t.total_ht, t.total_ttc, t.total_tva as total_vat,";
195 $sql .= " t.localtax1, t.localtax2, t.revenuestamp,";
196 $sql .= " t.multicurrency_code as currency, t.fk_soc, t.datef as date, t.date_lim_reglement as date_due, 'Invoice' as item, s.nom as thirdparty_name, s.code_client as thirdparty_code, c.code as country_code, s.tva_intra as vatnum, ".PAY_CREDIT." as sens";
197 $sql .= " FROM ".MAIN_DB_PREFIX."facture as t LEFT JOIN ".MAIN_DB_PREFIX."societe as s ON s.rowid = t.fk_soc LEFT JOIN ".MAIN_DB_PREFIX."c_country as c ON c.rowid = s.fk_pays";
198 $sql .= " WHERE datef between ".$sanitizedwheretail;
199 $sql .= " AND t.entity IN (".$db->sanitize($entity == 1 ? '0,1' : $entity).')';
200 $sql .= " AND t.fk_statut <> ".Facture::STATUS_DRAFT;
201 if (!empty($projectid)) {
202 $sql .= " AND fk_projet = ".((int) $projectid);
203 }
204 }
205 // Vendor invoices
206 if (GETPOST('selectsupplierinvoices') && !empty($listofchoices['selectsupplierinvoices']['perms'])) {
207 if (!empty($sql)) {
208 $sql .= " UNION ALL";
209 }
210 $sql .= " SELECT t.rowid as id, t.entity, t.ref, t.paye as paid, t.total_ht, t.total_ttc, t.total_tva as total_vat,";
211 $sql .= " t.localtax1, t.localtax2, 0 as revenuestamp,";
212 $sql .= " t.multicurrency_code as currency, t.fk_soc, t.datef as date, t.date_lim_reglement as date_due, 'SupplierInvoice' as item, s.nom as thirdparty_name, s.code_fournisseur as thirdparty_code, c.code as country_code, s.tva_intra as vatnum, ".PAY_DEBIT." as sens";
213 $sql .= " FROM ".MAIN_DB_PREFIX."facture_fourn as t LEFT JOIN ".MAIN_DB_PREFIX."societe as s ON s.rowid = t.fk_soc LEFT JOIN ".MAIN_DB_PREFIX."c_country as c ON c.rowid = s.fk_pays";
214 $sql .= " WHERE datef between ".$sanitizedwheretail;
215 $sql .= " AND t.entity IN (".$db->sanitize($entity == 1 ? '0,1' : $entity).')';
216 $sql .= " AND t.fk_statut <> ".FactureFournisseur::STATUS_DRAFT;
217 if (!empty($projectid)) {
218 $sql .= " AND fk_projet = ".((int) $projectid);
219 }
220 }
221 // Expense reports
222 if (GETPOST('selectexpensereports') && !empty($listofchoices['selectexpensereports']['perms'])) {
223 if (!empty($sql)) {
224 $sql .= " UNION ALL";
225 }
226 // if project filter is used on an expense report,
227 // show only total_ht/total_tva/total_ttc of the line considered by the project
228 if (!empty($projectid)) {
229 $sql .= " SELECT t.rowid as id, t.entity, t.ref, t.paid, SUM(td.total_ht) as total_ht, SUM(td.total_ttc) as total_ttc, SUM(td.total_tva) as total_vat,";
230 $sql .= " 0 as localtax1, 0 as localtax2, 0 as revenuestamp,";
231 $sql .= " td.multicurrency_code as currency, t.fk_user_author as fk_soc, t.date_fin as date, t.date_fin as date_due, 'ExpenseReport' as item, CONCAT(CONCAT(u.lastname, ' '), u.firstname) as thirdparty_name, '' as thirdparty_code, c.code as country_code, '' as vatnum, " . PAY_DEBIT . " as sens";
232 $sql .= " FROM " . MAIN_DB_PREFIX . "expensereport as t";
233 $sql .= " LEFT JOIN " . MAIN_DB_PREFIX . "expensereport_det as td ON t.rowid = td.fk_expensereport";
234 $sql .= " LEFT JOIN " . MAIN_DB_PREFIX . "user as u ON u.rowid = t.fk_user_author";
235 $sql .= " LEFT JOIN " . MAIN_DB_PREFIX . "c_country as c ON c.rowid = u.fk_country";
236 $sql .= " WHERE date_fin between " . $sanitizedwheretail;
237 $sql .= " AND t.entity IN (" . $db->sanitize($entity == 1 ? '0,1' : $entity) . ')';
238 $sql .= " AND t.fk_statut <> " . ExpenseReport::STATUS_DRAFT;
239 $sql .= " AND fk_projet = ".((int) $projectid);
240 } else {
241 $sql .= " SELECT t.rowid as id, t.entity, t.ref, t.paid, t.total_ht, t.total_ttc, t.total_tva as total_vat,";
242 $sql .= " 0 as localtax1, 0 as localtax2, 0 as revenuestamp,";
243 $sql .= " t.multicurrency_code as currency, t.fk_user_author as fk_soc, t.date_fin as date, t.date_fin as date_due, 'ExpenseReport' as item, CONCAT(CONCAT(u.lastname, ' '), u.firstname) as thirdparty_name, '' as thirdparty_code, c.code as country_code, '' as vatnum, " . PAY_DEBIT . " as sens";
244 $sql .= " FROM " . MAIN_DB_PREFIX . "expensereport as t LEFT JOIN " . MAIN_DB_PREFIX . "user as u ON u.rowid = t.fk_user_author LEFT JOIN " . MAIN_DB_PREFIX . "c_country as c ON c.rowid = u.fk_country";
245 $sql .= " WHERE date_fin between " . $sanitizedwheretail;
246 $sql .= " AND t.entity IN (" . $db->sanitize($entity == 1 ? '0,1' : $entity) . ')';
247 $sql .= " AND t.fk_statut <> " . ExpenseReport::STATUS_DRAFT;
248 }
249 }
250 // Donations
251 if (GETPOST('selectdonations') && !empty($listofchoices['selectdonations']['perms'])) {
252 if (!empty($sql)) {
253 $sql .= " UNION ALL";
254 }
255 $sql .= " SELECT t.rowid as id, t.entity, t.ref, paid, amount as total_ht, amount as total_ttc, 0 as total_vat,";
256 $sql .= " 0 as localtax1, 0 as localtax2, 0 as revenuestamp,";
257 $sql .= " '".$db->escape($conf->currency)."' as currency, 0 as fk_soc, t.datedon as date, t.datedon as date_due, 'Donation' as item, t.societe as thirdparty_name, '' as thirdparty_code, c.code as country_code, '' as vatnum, ".PAY_CREDIT." as sens";
258 $sql .= " FROM ".MAIN_DB_PREFIX."don as t LEFT JOIN ".MAIN_DB_PREFIX."c_country as c ON c.rowid = t.fk_country";
259 $sql .= " WHERE datedon between ".$sanitizedwheretail;
260 $sql .= " AND t.entity IN (".$db->sanitize($entity == 1 ? '0,1' : $entity).')';
261 $sql .= " AND t.fk_statut <> ".Don::STATUS_DRAFT;
262 if (!empty($projectid)) {
263 $sql .= " AND fk_projet = ".((int) $projectid);
264 }
265 }
266 // Payments of salaries
267 if (GETPOST('selectpaymentsofsalaries') && !empty($listofchoices['selectpaymentsofsalaries']['perms'])) {
268 if (!empty($sql)) {
269 $sql .= " UNION ALL";
270 }
271 $sql .= " SELECT t.rowid as id, t.entity, t.label as ref, 1 as paid, amount as total_ht, amount as total_ttc, 0 as total_vat,";
272 $sql .= " 0 as localtax1, 0 as localtax2, 0 as revenuestamp,";
273 $sql .= " '".$db->escape($conf->currency)."' as currency, t.fk_user as fk_soc, t.datep as date, t.dateep as date_due, 'SalaryPayment' as item, CONCAT(CONCAT(u.lastname, ' '), u.firstname) as thirdparty_name, '' as thirdparty_code, c.code as country_code, '' as vatnum, ".PAY_DEBIT." as sens";
274 $sql .= " FROM ".MAIN_DB_PREFIX."payment_salary as t LEFT JOIN ".MAIN_DB_PREFIX."user as u ON u.rowid = t.fk_user LEFT JOIN ".MAIN_DB_PREFIX."c_country as c ON c.rowid = u.fk_country";
275 $sql .= " WHERE datep between ".$sanitizedwheretail;
276 $sql .= " AND t.entity IN (".$db->sanitize($entity == 1 ? '0,1' : $entity).')';
277 //$sql.=" AND fk_statut <> ".PaymentSalary::STATUS_DRAFT;
278 if (!empty($projectid)) {
279 $sql .= " AND fk_projet = ".((int) $projectid);
280 }
281 }
282 // Social contributions
283 if (GETPOST('selectsocialcontributions') && !empty($listofchoices['selectsocialcontributions']['perms'])) {
284 if (!empty($sql)) {
285 $sql .= " UNION ALL";
286 }
287 $sql .= " SELECT t.rowid as id, t.entity, t.libelle as ref, t.paye as paid, t.amount as total_ht, t.amount as total_ttc, 0 as total_vat,";
288 $sql .= " 0 as localtax1, 0 as localtax2, 0 as revenuestamp,";
289 $sql .= " '".$db->escape($conf->currency)."' as currency, 0 as fk_soc, t.date_ech as date, t.periode as date_due, 'SocialContributions' as item, '' as thirdparty_name, '' as thirdparty_code, '' as country_code, '' as vatnum, ".PAY_DEBIT." as sens";
290 $sql .= " FROM ".MAIN_DB_PREFIX."chargesociales as t";
291 $sql .= " WHERE t.date_ech between ".$sanitizedwheretail;
292 $sql .= " AND t.entity IN (".$db->sanitize($entity == 1 ? '0,1' : $entity).')';
293 //$sql.=" AND fk_statut <> ".ChargeSociales::STATUS_UNPAID;
294 if (!empty($projectid)) {
295 $sql .= " AND fk_projet = ".((int) $projectid);
296 }
297 }
298 // Various payments
299 if (GETPOST('selectvariouspayment') && !empty($listofchoices['selectvariouspayment']['perms'])) {
300 if (!empty($sql)) {
301 $sql .= " UNION ALL";
302 }
303 $sql .= " SELECT t.rowid as id, t.entity, t.ref, 1 as paid, t.amount as total_ht, t.amount as total_ttc, 0 as total_vat,";
304 $sql .= " 0 as localtax1, 0 as localtax2, 0 as revenuestamp,";
305 $sql .= " '".$db->escape($conf->currency)."' as currency, 0 as fk_soc, t.datep as date, t.datep as date_due, 'VariousPayment' as item, '' as thirdparty_name, '' as thirdparty_code, '' as country_code, '' as vatnum, sens";
306 $sql .= " FROM ".MAIN_DB_PREFIX."payment_various as t";
307 $sql .= " WHERE datep between ".$sanitizedwheretail;
308 $sql .= " AND t.entity IN (".$db->sanitize($entity == 1 ? '0,1' : $entity).')';
309 if (!empty($projectid)) {
310 $sql .= " AND fk_projet = ".((int) $projectid);
311 }
312 }
313 // Loan payments
314 if (GETPOST('selectloanspayment') && !empty($listofchoices['selectloanspayment']['perms']) && empty($projectid)) {
315 if (!empty($sql)) {
316 $sql .= " UNION ALL";
317 }
318 $sql .= " SELECT t.rowid as id, l.entity, l.label as ref, 1 as paid, (t.amount_capital+t.amount_insurance+t.amount_interest) as total_ht, (t.amount_capital+t.amount_insurance+t.amount_interest) as total_ttc, 0 as total_vat,";
319 $sql .= " 0 as localtax1, 0 as localtax2, 0 as revenuestamp,";
320 $sql .= " '".$db->escape($conf->currency)."' as currency, 0 as fk_soc, t.datep as date, t.datep as date_due, 'LoanPayment' as item, '' as thirdparty_name, '' as thirdparty_code, '' as country_code, '' as vatnum, ".PAY_DEBIT." as sens";
321 $sql .= " FROM ".MAIN_DB_PREFIX."payment_loan as t LEFT JOIN ".MAIN_DB_PREFIX."loan as l ON l.rowid = t.fk_loan";
322 $sql .= " WHERE datep between ".$sanitizedwheretail;
323 $sql .= " AND l.entity IN (".$db->sanitize($entity == 1 ? '0,1' : $entity).')';
324 }
325
326 if ($sql) {
327 $sql .= $db->order($sortfield, $sortorder);
328 //print $sql;
329
330 $resd = $db->query($sql);
331 $files = array();
332 $link = '';
333
334 if ($resd) {
335 $numd = $db->num_rows($resd);
336
337 $tmpinvoice = new Facture($db);
338 $tmpinvoicesupplier = new FactureFournisseur($db);
339 $tmpdonation = new Don($db);
340
341 $upload_dir = '';
342 $i = 0;
343 while ($i < $numd) {
344 $objd = $db->fetch_object($resd);
345
346 switch ($objd->item) {
347 case "Invoice":
348 $subdir = '';
349 $subdir .= ($subdir ? '/' : '').dol_sanitizeFileName($objd->ref);
350 $upload_dir = $conf->facture->dir_output.'/'.$subdir;
351 $link = "document.php?modulepart=facture&file=".str_replace('/', '%2F', $subdir).'%2F';
352 $modulepart = "facture";
353 break;
354 case "SupplierInvoice":
355 $tmpinvoicesupplier->fetch($objd->id);
356 $subdir = get_exdir($tmpinvoicesupplier->id, 2, 0, 1, $tmpinvoicesupplier, 'invoice_supplier'); // TODO Use first file
357 $subdir .= ($subdir ? '/' : '').dol_sanitizeFileName($objd->ref);
358 $upload_dir = $conf->fournisseur->facture->dir_output.'/'.$subdir;
359 $link = "document.php?modulepart=facture_fournisseur&file=".str_replace('/', '%2F', $subdir).'%2F';
360 $modulepart = "facture_fournisseur";
361 break;
362 case "ExpenseReport":
363 $subdir = '';
364 $subdir .= ($subdir ? '/' : '').dol_sanitizeFileName($objd->ref);
365 $upload_dir = $conf->expensereport->dir_output.'/'.$subdir;
366 $link = "document.php?modulepart=expensereport&file=".str_replace('/', '%2F', $subdir).'%2F';
367 $modulepart = "expensereport";
368 break;
369 case "SalaryPayment":
370 $subdir = '';
371 $subdir .= ($subdir ? '/' : '').dol_sanitizeFileName($objd->id);
372 $upload_dir = $conf->salaries->dir_output.'/'.$subdir;
373 $link = "document.php?modulepart=salaries&file=".str_replace('/', '%2F', $subdir).'%2F';
374 $modulepart = "salaries";
375 break;
376 case "Donation":
377 $tmpdonation->fetch($objd->id);
378 $subdir = get_exdir(0, 0, 0, 0, $tmpdonation, 'donation');
379 $subdir .= ($subdir ? '/' : '').dol_sanitizeFileName($objd->id);
380 $upload_dir = $conf->don->dir_output.'/'.$subdir;
381 $link = "document.php?modulepart=don&file=".str_replace('/', '%2F', $subdir).'%2F';
382 $modulepart = "don";
383 break;
384 case "SocialContributions":
385 $subdir = '';
386 $subdir .= ($subdir ? '/' : '').dol_sanitizeFileName($objd->id);
387 $upload_dir = $conf->tax->dir_output.'/'.$subdir;
388 $link = "document.php?modulepart=tax&file=".str_replace('/', '%2F', $subdir).'%2F';
389 $modulepart = "tax";
390 break;
391 case "VariousPayment":
392 $subdir = '';
393 $subdir .= ($subdir ? '/' : '').dol_sanitizeFileName($objd->id);
394 $upload_dir = $conf->bank->dir_output.'/'.$subdir;
395 $link = "document.php?modulepart=banque&file=".str_replace('/', '%2F', $subdir).'%2F';
396 $modulepart = "banque";
397 break;
398 case "LoanPayment":
399 // Loan payment has no linked file
400 $subdir = '';
401 $upload_dir = $conf->loan->dir_output.'/'.$subdir;
402 $link = "";
403 $modulepart = "";
404 break;
405 default:
406 $subdir = '';
407 $upload_dir = '';
408 $link = '';
409 $modulepart = '';
410 break;
411 }
412
413 if (!empty($upload_dir)) {
414 $result = true;
415
416 $files = dol_dir_list($upload_dir, "files", 0, '', '(\.meta|_preview.*\.png)$', '', SORT_ASC, 1);
417 //var_dump($upload_dir);
418 //var_dump($files);
419 if (count($files) < 1) {
420 $nofile = array();
421 $nofile['id'] = (int) $objd->id;
422 $nofile['entity'] = (int) $objd->entity;
423 $nofile['date'] = $db->jdate($objd->date);
424 $nofile['date_due'] = $db->jdate($objd->date_due);
425 $nofile['paid'] = (int) $objd->paid;
426 $nofile['amount_ht'] = $objd->total_ht;
427 $nofile['amount_ttc'] = $objd->total_ttc;
428 $nofile['amount_vat'] = $objd->total_vat;
429 $nofile['amount_localtax1'] = $objd->localtax1;
430 $nofile['amount_localtax2'] = $objd->localtax2;
431 $nofile['amount_revenuestamp'] = $objd->revenuestamp;
432 $nofile['ref'] = ($objd->ref ? $objd->ref : $objd->id);
433 $nofile['fk'] = $objd->fk_soc;
434 $nofile['item'] = $objd->item;
435 $nofile['thirdparty_name'] = $objd->thirdparty_name;
436 $nofile['thirdparty_code'] = $objd->thirdparty_code;
437 $nofile['country_code'] = $objd->country_code;
438 $nofile['vatnum'] = $objd->vatnum;
439 $nofile['sens'] = $objd->sens;
440 $nofile['currency'] = $objd->currency;
441 $nofile['link'] = '';
442 $nofile['name'] = '';
443
444
445 $filesarray[$nofile['item'].'_'.$nofile['id']] = $nofile;
446 } else {
447 foreach ($files as $key => $file) {
448 $file['id'] = (int) $objd->id;
449 $file['entity'] = (int) $objd->entity;
450 $file['date'] = $db->jdate($objd->date);
451 $file['date_due'] = $db->jdate($objd->date_due);
452 $file['paid'] = (int) $objd->paid;
453 $file['amount_ht'] = $objd->total_ht;
454 $file['amount_ttc'] = $objd->total_ttc;
455 $file['amount_vat'] = $objd->total_vat;
456 $file['amount_localtax1'] = $objd->localtax1;
457 $file['amount_localtax2'] = $objd->localtax2;
458 $file['amount_revenuestamp'] = $objd->revenuestamp;
459 $file['ref'] = ($objd->ref ? $objd->ref : $objd->id);
460 $file['fk'] = $objd->fk_soc;
461 $file['item'] = $objd->item;
462 $file['thirdparty_name'] = $objd->thirdparty_name;
463 $file['thirdparty_code'] = $objd->thirdparty_code;
464 $file['country_code'] = $objd->country_code;
465 $file['vatnum'] = $objd->vatnum;
466 $file['sens'] = $objd->sens;
467 $file['currency'] = $objd->currency;
468
469 // Save record into array (only the first time it is found)
470 if (empty($filesarray[$file['item'].'_'.$file['id']])) {
471 $filesarray[$file['item'].'_'.$file['id']] = $file;
472 }
473
474 // Add or concat file
475 if (empty($filesarray[$file['item'].'_'.$file['id']]['files'])) {
476 $filesarray[$file['item'].'_'.$file['id']]['files'] = array();
477 }
478 $filesarray[$file['item'].'_'.$file['id']]['files'][] = array(
479 'link' => $link.urlencode($file['name']),
480 'name' => $file['name'],
481 'ref' => $file['ref'],
482 'fullname' => $file['fullname'],
483 'relpath' => '/'.$file['name'],
484 'relpathnamelang' => $langs->trans($file['item']).'/'.$file['name'],
485 'modulepart' => $modulepart,
486 'subdir' => $subdir,
487 'currency' => $file['currency']
488 );
489 //var_dump($file['item'].'_'.$file['id']);
490 //var_dump($filesarray[$file['item'].'_'.$file['id']]['files']);
491 }
492 }
493 }
494
495 $i++;
496 }
497 } else {
499 }
500
501 $db->free($resd);
502 } else {
503 setEventMessages($langs->trans("ErrorSelectAtLeastOne"), null, 'errors');
504 $error++;
505 }
506 }
507}
508
509// zip creation
510
511$dirfortmpfile = (!empty($conf->accounting->dir_temp) ? $conf->accounting->dir_temp : $conf->comptabilite->dir_temp);
512if (empty($dirfortmpfile)) {
513 setEventMessages($langs->trans("ErrorNoAccountingModuleEnabled"), null, 'errors');
514 $error++;
515}
516
517if ($result && $action == "dl" && !$error) { // Test on permission not required here. Test is done per object type later.
518 if (!extension_loaded('zip')) {
519 setEventMessages('PHPZIPExtentionNotLoaded', null, 'errors');
520 } else {
521 dol_mkdir($dirfortmpfile);
522
523 $log = $langs->transnoentitiesnoconv("Type");
524 if (isModEnabled('multicompany') && isset($mc) && is_object($mc)) {
525 $log .= ','.$langs->transnoentitiesnoconv("Entity");
526 }
527 $log .= ','.$langs->transnoentitiesnoconv("Date");
528 $log .= ','.$langs->transnoentitiesnoconv("DateDue");
529 $log .= ','.$langs->transnoentitiesnoconv("Ref");
530 $log .= ','.$langs->transnoentitiesnoconv("TotalHT");
531 $log .= ','.$langs->transnoentitiesnoconv("TotalTTC");
532 $log .= ','.$langs->transnoentitiesnoconv("TotalVAT");
533 $log .= ','.$langs->transcountrynoentities("TotalLT1", $mysoc->country_code);
534 $log .= ','.$langs->transcountrynoentities("TotalLT2", $mysoc->country_code);
535 $log .= ','.$langs->transnoentitiesnoconv("RevenueStamp");
536 $log .= ','.$langs->transnoentitiesnoconv("Paid");
537 $log .= ','.$langs->transnoentitiesnoconv("Document");
538 $log .= ','.$langs->transnoentitiesnoconv("ItemID");
539 $log .= ','.$langs->transnoentitiesnoconv("ThirdParty");
540 $log .= ','.$langs->transnoentitiesnoconv("Code");
541 $log .= ','.$langs->transnoentitiesnoconv("Country");
542 $log .= ','.$langs->transnoentitiesnoconv("VATIntra");
543 $log .= ','.$langs->transnoentitiesnoconv("Sens")."\n";
544 $zipname = $dirfortmpfile.'/'.dol_print_date($date_start, 'dayrfc', 'tzuserrel')."-".dol_print_date($date_stop, 'dayrfc', 'tzuserrel');
545 if (!empty($projectid)) {
546 $project = new Project($db);
547 $project->fetch($projectid);
548 if ($project->ref) {
549 $zipname .= '_'.$project->ref;
550 }
551 }
552 $zipname .= '_export.zip';
553
554 dol_delete_file($zipname);
555
556 $zip = new ZipArchive();
557 $res = $zip->open($zipname, ZipArchive::OVERWRITE | ZipArchive::CREATE);
558 if ($res) {
559 foreach ($filesarray as $key => $file) {
560 if (!empty($file['files'])) {
561 foreach ($file['files'] as $filecursor) {
562 if (file_exists($filecursor["fullname"])) {
563 $zip->addFile($filecursor["fullname"], $filecursor["relpathnamelang"]);
564 }
565 }
566 }
567
568 $log .= '"'.$langs->transnoentitiesnoconv($file['item']).'"';
569 if (isModEnabled('multicompany') && isset($mc) && is_object($mc)) {
570 $log .= ',"'.(empty($arrayofentities[$file['entity']]) ? $file['entity'] : $arrayofentities[$file['entity']]).'"';
571 }
572 $log .= ','.dol_print_date($file['date'], 'dayrfc');
573 $log .= ','.dol_print_date($file['date_due'], 'dayrfc');
574 $log .= ',"'.$file['ref'].'"';
575 $log .= ','.$file['amount_ht'];
576 $log .= ','.$file['amount_ttc'];
577 $log .= ','.$file['amount_vat'];
578 $log .= ','.$file['amount_localtax1'];
579 $log .= ','.$file['amount_localtax2'];
580 $log .= ','.$file['amount_revenuestamp'];
581 $log .= ','.$file['paid'];
582 $log .= ',"'.$file["name"].'"';
583 $log .= ','.$file['fk'];
584 $log .= ',"'.$file['thirdparty_name'].'"';
585 $log .= ',"'.$file['thirdparty_code'].'"';
586 $log .= ',"'.$file['country_code'].'"';
587 $log .= ',"'.$file['vatnum'].'"';
588 $log .= ',"'.$file['sens'].'"';
589 $log .= "\n";
590 }
591 $zip->addFromString('transactions.csv', $log);
592 $zip->close();
593
594 // Then download the zipped file.
595 header('Content-Type: application/zip');
596 header('Content-disposition: attachment; filename='.basename($zipname));
597 header('Content-Length: '.filesize($zipname));
598 readfile($zipname);
599
600 dol_delete_file($zipname);
601
602 exit();
603 } else {
604 setEventMessages($langs->trans("FailedToOpenFile", $zipname), null, 'errors');
605 }
606 }
607}
608
609
610/*
611 * View
612 */
613
614$form = new Form($db);
615$formfile = new FormFile($db);
616$userstatic = new User($db);
617$invoice = new Facture($db);
618$supplier_invoice = new FactureFournisseur($db);
619$expensereport = new ExpenseReport($db);
620$don = new Don($db);
621$salary_payment = new PaymentSalary($db);
622$charge_sociales = new ChargeSociales($db);
623$various_payment = new PaymentVarious($db);
624$payment_loan = new PaymentLoan($db);
625
626$title = $langs->trans("AccountantFiles").' - '.$langs->trans("List");
627$help_url = '';
628
629llxHeader('', $title, $help_url);
630
631$h = 0;
632$head = array();
633$head[$h][0] = $_SERVER["PHP_SELF"];
634$head[$h][1] = $langs->trans("AccountantFiles");
635$head[$h][2] = 'AccountancyFiles';
636
637print dol_get_fiche_head($head, 'AccountancyFiles', '', -1);
638
639
640print '<form name="searchfiles" action="?action=searchfiles" method="POST">'."\n";
641print '<input type="hidden" name="token" value="'.newToken().'">';
642
643print '<div class="neutral">';
644
645print '<span class="opacitylow">'.$langs->trans("ExportAccountingSourceDocHelp");
646if (isModEnabled('accounting')) {
647 print ' '.$langs->trans("ExportAccountingSourceDocHelp2", $langs->transnoentitiesnoconv("Accounting"), $langs->transnoentitiesnoconv("Journals"));
648}
649print '</span><br>';
650print '<br>';
651
652print $langs->trans("ReportPeriod").': ';
653print $form->selectDate($date_start, 'date_start', 0, 0, 0, "", 1, 1, 0, '', '', '', '', 1, '', '', 'tzuserrel');
654print ' - ';
655print $form->selectDate($date_stop, 'date_stop', 0, 0, 0, "", 1, 1, 0, '', '', '', '', 1, '', '', 'tzuserrel');
656print "\n";
657
658// Export is for current company only
659$socid = 0;
660if (isModEnabled('multicompany') && isset($mc) && is_object($mc)) {
661 $mc->getInfo($conf->entity);
662 print ' &nbsp; <span class="marginleftonly marginrightonly'.(!getDolGlobalString('MULTICOMPANY_ALLOW_EXPORT_ACCOUNTING_DOC_FOR_ALL_ENTITIES') ? ' opacitymedium' : '').'">'.$langs->trans("Entity").' : ';
663 if (getDolGlobalString('MULTICOMPANY_ALLOW_EXPORT_ACCOUNTING_DOC_FOR_ALL_ENTITIES')) {
664 $socid = $mc->id;
665 print $mc->select_entities(GETPOSTISSET('search_entity') ? GETPOSTINT('search_entity') : $mc->id, 'search_entity', '', false, false, false, false, true);
666 } else {
667 print $mc->label;
668 }
669 print "</span>\n";
670}
671
672print '<br>';
673
674// Project filter
675if (isModEnabled('project')) {
676 $formproject = new FormProjets($db);
677 $langs->load('projects');
678 print '<div class="paddingtop">';
679 print '<span class="marginrightonly">'.$langs->trans('Project').":</span>";
680 print img_picto('', 'project', 'class="pictofixedwidth"').$formproject->select_projects(($socid > 0 ? $socid : -1), (string) $projectid, 'projectid', 0, 0, 1, 0, 0, 0, 0, '', 1, 0, '');
681 print '<span class="classfortooltip" style="padding: 0px; padding: 0px; padding-right: 3px !important;" title="'.$langs->trans('ExportAccountingProjectHelp').'"><span class="fas fa-info-circle em088 opacityhigh" style=" vertical-align: middle; cursor: help"></span></span>';
682 print '<br>';
683 print '</div>';
684}
685
686$i = 0;
687foreach ($listofchoices as $choice => $val) {
688 if (empty($val['enabled'])) {
689 continue; // list not qualified
690 }
691 $disabled = '';
692 if (empty($val['perms'])) {
693 $disabled = ' disabled';
694 }
695 $checked = (((!GETPOSTISSET('search') && $action != 'searchfiles') || GETPOST($choice)) ? ' checked="checked"' : '');
696 print '<div class="inline-block marginrightonlylarge paddingright margintoponly"><input type="checkbox" id="'.$choice.'" name="'.$choice.'" value="1"'.$checked.$disabled.'><label for="'.$choice.'"> ';
697 print img_picto($langs->trans($val['label']), $val['picto'], 'class=""').' '.$langs->trans($val['label']);
698 print '</label></div>';
699 $i++;
700}
701
702print '<br><br><center><input type="submit" class="button small nomarginleft margintoponly" name="search" value="'.$langs->trans("Search").'"></center>';
703
704print '</div>';
705
706print '</form>'."\n";
707
708print dol_get_fiche_end();
709
710$param = '';
711if (!empty($date_start) && !empty($date_stop)) {
712 $param .= '&date_startday='.GETPOSTINT('date_startday');
713 $param .= '&date_startmonth='.GETPOSTINT('date_startmonth');
714 $param .= '&date_startyear='.GETPOSTINT('date_startyear');
715 $param .= '&date_stopday='.GETPOSTINT('date_stopday');
716 $param .= '&date_stopmonth='.GETPOSTINT('date_stopmonth');
717 $param .= '&date_stopyear='.GETPOSTINT('date_stopyear');
718 foreach ($listofchoices as $choice => $val) {
719 if (GETPOSTINT($choice)) {
720 $param .= '&'.$choice.'=1';
721 }
722 }
723
724 $TData = dol_sort_array($filesarray, $sortfield, $sortorder);
725 '@phan-var-force array<string,array{id:string,entity:string,date:string,date_due:string,paid:float|int,amount_ht:float|int,amount_ttc:float|int,amount_vat:float|int,amount_localtax1:float|int,amount_localtax2:float|int,amount_revenuestamp:float|int,ref:string,fk:string,item:string,thirdparty_name:string,thirdparty_code:string,country_code:string,vatnum:string,sens:string,currency:string,line?:string,name?:string,files?:mixed}> $TData';
726
727
728 $filename = dol_print_date($date_start, 'dayrfc', 'tzuserrel')."-".dol_print_date($date_stop, 'dayrfc', 'tzuserrel').'_export.zip';
729
730 echo dol_print_date($date_start, 'day', 'tzuserrel')." - ".dol_print_date($date_stop, 'day', 'tzuserrel');
731
732 print '<a class="marginleftonly small'.(empty($TData) ? ' butActionRefused' : ' butAction').'" href="'.$_SERVER["PHP_SELF"].'?action=dl&token='.currentToken().'&projectid='.((int) $projectid).'&output=file&file='.urlencode($filename).$param.'"';
733 if (empty($TData)) {
734 print " disabled";
735 }
736 print '>'."\n";
737 print $langs->trans("Download");
738 print '</a><br>';
739
740 $param .= '&action=searchfiles';
741
742 /*
743 print '<input type="hidden" name="token" value="'.currentToken().'">';
744 print '<input type="hidden" name="date_startday" value="'.GETPOST('date_startday', 'int').'" />';
745 print '<input type="hidden" name="date_startmonth" value="'.GETPOST('date_startmonth', 'int').'" />';
746 print '<input type="hidden" name="date_startyear" value="'.GETPOST('date_startyear', 'int').'" />';
747 print '<input type="hidden" name="date_stopday" value="'.GETPOST('date_stopday', 'int').'" />';
748 print '<input type="hidden" name="date_stopmonth" value="'.GETPOST('date_stopmonth', 'int').'" />';
749 print '<input type="hidden" name="date_stopyear" value="'.GETPOST('date_stopyear', 'int').'" />';
750 foreach ($listofchoices as $choice => $val) {
751 print '<input type="hidden" name="'.$choice.'" value="'.GETPOST($choice).'">';
752 }
753
754 print '<input class="butAction butDownload small marginleftonly" type="submit" value="'.$langs->trans("Download").'"';
755 if (empty($TData)) {
756 print " disabled";
757 }
758 print '/>';
759 print '</form>'."\n";
760 */
761
762 print '<br>';
763
764 print '<div class="div-table-responsive">'; // You can use div-table-responsive-no-min if you don't need reserved height for your table
765 print '<table class="noborder centpercent">';
766 print '<tr class="liste_titre">';
767 print_liste_field_titre($arrayfields['type']['label'], $_SERVER["PHP_SELF"], "item", "", $param, '', $sortfield, $sortorder, 'nowrap ');
768 print_liste_field_titre($arrayfields['date']['label'], $_SERVER["PHP_SELF"], "date", "", $param, '', $sortfield, $sortorder, 'center nowrap ');
769 print_liste_field_titre($arrayfields['date_due']['label'], $_SERVER["PHP_SELF"], "date_due", "", $param, '', $sortfield, $sortorder, 'center nowrap ');
770 print_liste_field_titre($arrayfields['ref']['label'], $_SERVER["PHP_SELF"], "", "", $param, '', $sortfield, $sortorder, 'nowraponall ');
771 print '<th>'.$langs->trans("Document").'</th>';
772 print '<th>'.$langs->trans("Paid").'</th>';
773 print '<th class="right">'.$langs->trans("TotalHT").(isModEnabled('multicurrency') ? ' ('.$langs->getCurrencySymbol($conf->currency).')' : '').'</th>';
774 print '<th class="right">'.$langs->trans("TotalTTC").(isModEnabled('multicurrency') ? ' ('.$langs->getCurrencySymbol($conf->currency).')' : '').'</th>';
775 print '<th class="right">'.$langs->trans("TotalVAT").(isModEnabled('multicurrency') ? ' ('.$langs->getCurrencySymbol($conf->currency).')' : '').'</th>';
776
777 print '<th>'.$langs->trans("ThirdParty").'</th>';
778 print '<th class="center">'.$langs->trans("Code").'</th>';
779 print '<th class="center">'.$langs->trans("Country").'</th>';
780 print '<th class="center">'.$langs->trans("VATIntra").'</th>';
781 if (isModEnabled('multicurrency')) {
782 print '<th class="center">'.$langs->trans("Currency").'</th>';
783 }
784 print '</tr>';
785
786 if (empty($TData)) {
787 print '<tr class="oddeven"><td colspan="13"><span class="opacitymedium">'.$langs->trans("NoRecordFound").'</span></td>';
788 if (isModEnabled('multicurrency')) {
789 print '<td></td>';
790 }
791 print '</tr>';
792 } else {
793 // Sort array by date ASC to calculate balance
794
795 $totalET_debit = 0;
796 $totalIT_debit = 0;
797 $totalVAT_debit = 0;
798 $totalET_credit = 0;
799 $totalIT_credit = 0;
800 $totalVAT_credit = 0;
801
802 // Display array
803 foreach ($TData as $data) {
804 $html_class = '';
805 //if (!empty($data['fk_facture'])) $html_class = 'facid-'.$data['fk_facture'];
806 //elseif (!empty($data['fk_paiement'])) $html_class = 'payid-'.$data['fk_paiement'];
807 print '<tr class="oddeven '.$html_class.'">';
808
809 // Type
810 print '<td class="tdoverflowmax150" title="'.dol_escape_htmltag($langs->trans($data['item'])).'">'.$langs->trans($data['item']).'</td>';
811
812 // Date
813 print '<td class="center">';
814 print dol_print_date($data['date'], 'day');
815 print "</td>\n";
816
817 // Date due
818 print '<td class="center">';
819 print dol_print_date($data['date_due'], 'day');
820 print "</td>\n";
821
822 // Ref
823 print '<td class="nowraponall tdoverflowmax150">';
824
825 if ($data['item'] == 'Invoice') {
826 $invoice->id = (int) $data['id'];
827 $invoice->ref = $data['ref'];
828 $invoice->total_ht = $data['amount_ht'];
829 $invoice->total_ttc = $data['amount_ttc'];
830 $invoice->total_tva = $data['amount_vat'];
831 $invoice->total_localtax1 = $data['amount_localtax1'];
832 $invoice->total_localtax2 = $data['amount_localtax2'];
833 $invoice->revenuestamp = $data['amount_revenuestamp'];
834 $invoice->multicurrency_code = $data['currency'];
835 print $invoice->getNomUrl(1, '', 0, 0, '', 0, 0, 0);
836 } elseif ($data['item'] == 'SupplierInvoice') {
837 $supplier_invoice->id = (int) $data['id'];
838 $supplier_invoice->ref = $data['ref'];
839 $supplier_invoice->total_ht = $data['amount_ht'];
840 $supplier_invoice->total_ttc = $data['amount_ttc'];
841 $supplier_invoice->total_tva = $data['amount_vat'];
842 $supplier_invoice->total_localtax1 = $data['amount_localtax1'];
843 $supplier_invoice->total_localtax2 = $data['amount_localtax2'];
844 $supplier_invoice->revenuestamp = $data['amount_revenuestamp'];
845 $supplier_invoice->multicurrency_code = $data['currency'];
846 print $supplier_invoice->getNomUrl(1, '', 0, 0, '', 0, 0, 0);
847 } elseif ($data['item'] == 'ExpenseReport') {
848 $expensereport->id = (int) $data['id'];
849 $expensereport->ref = $data['ref'];
850 print $expensereport->getNomUrl(1, '0', 0, 0, '0', 0);
851 } elseif ($data['item'] == 'SalaryPayment') {
852 $salary_payment->id = (int) $data['id'];
853 $salary_payment->ref = $data['ref'];
854 print $salary_payment->getNomUrl(1);
855 } elseif ($data['item'] == 'Donation') {
856 $don->id = (int) $data['id'];
857 $don->ref = $data['ref'];
858 print $don->getNomUrl(1, 0, '', 0);
859 } elseif ($data['item'] == 'SocialContributions') {
860 $charge_sociales->id = (int) $data['id'];
861 $charge_sociales->ref = $data['ref'];
862 print $charge_sociales->getNomUrl(1, '0', 0, 0, 0);
863 } elseif ($data['item'] == 'VariousPayment') {
864 $various_payment->id = (int) $data['id'];
865 $various_payment->ref = $data['ref'];
866 print $various_payment->getNomUrl(1, '', 0, 0);
867 } elseif ($data['item'] == 'LoanPayment') {
868 $payment_loan->id = (int) $data['id'];
869 $payment_loan->ref = $data['ref'];
870 print $payment_loan->getNomUrl(1, 0, 0, '', 0);
871 } else {
872 print $data['ref'];
873 }
874 print '</td>';
875
876 // File link
877 print '<td class="tdoverflowmax150">';
878 if (!empty($data['files'])) {
879 foreach ($data['files'] as $id => $filecursor) {
880 $tmppreview = $formfile->showPreview($filecursor, $filecursor['modulepart'], $filecursor['subdir'].'/'.$filecursor['name'], 0);
881 if ($tmppreview) {
882 print $tmppreview;
883 }
884 $filename = ($filecursor['name'] ? $filecursor['name'] : $filecursor['ref']);
885 print '<a href='.DOL_URL_ROOT.'/'.$filecursor['link'].' target="_blank" rel="noopener noreferrer" title="'.dol_escape_htmltag($filename).'">';
886 if (empty($tmppreview)) {
887 print img_picto('', 'generic', '', 0, 0, 0, '', 'pictonopreview pictofixedwidth paddingright');
888 }
889 print $filename;
890 print '</a><br>';
891 }
892 }
893 print "</td>\n";
894
895 // Paid
896 print '<td class="center">'.($data['paid'] ? yn($data['paid']) : '').'</td>';
897
898 // Total WOT
899 print '<td class="right"><span class="amount">'.price(price2num($data['sens'] ? $data['amount_ht'] : -$data['amount_ht'], 'MT'))."</span></td>\n";
900 // Total INCT
901 print '<td class="right"><span class="amount">';
902 $tooltip = $langs->trans("TotalVAT").' : '.price(price2num($data['sens'] ? $data['amount_vat'] : -$data['amount_vat'], 'MT'));
903 if (!empty($data['amount_localtax1'])) {
904 $tooltip .= '<br>'.$langs->transcountrynoentities("TotalLT1", $mysoc->country_code).' : '.price(price2num($data['sens'] ? $data['amount_localtax1'] : -$data['amount_localtax1'], 'MT'));
905 }
906 if (!empty($data['amount_localtax2'])) {
907 $tooltip .= '<br>'.$langs->transcountrynoentities("TotalLT2", $mysoc->country_code).' : '.price(price2num($data['sens'] ? $data['amount_localtax2'] : -$data['amount_localtax2'], 'MT'));
908 }
909 if (!empty($data['amount_revenuestamp'])) {
910 $tooltip .= '<br>'.$langs->trans("RevenueStamp").' : '.price(price2num($data['sens'] ? $data['amount_revenuestamp'] : -$data['amount_revenuestamp'], 'MT'));
911 }
912 print '<span class="classfortooltip" title="'.dol_escape_htmltag($tooltip).'">'.price(price2num($data['sens'] ? $data['amount_ttc'] : -$data['amount_ttc'], 'MT')).'</span>';
913 print "</span></td>\n";
914 // Total VAT
915 print '<td class="right"><span class="amount">'.price(price2num($data['sens'] ? $data['amount_vat'] : -$data['amount_vat'], 'MT'))."</span></td>\n";
916
917 print '<td class="tdoverflowmax150" title="'.dol_escape_htmltag($data['thirdparty_name']).'">'.dol_escape_htmltag($data['thirdparty_name'])."</td>\n";
918
919 print '<td class="center">'.$data['thirdparty_code']."</td>\n";
920
921 print '<td class="center">'.$data['country_code']."</td>\n";
922
923 // VAT number
924 print '<td class="tdoverflowmax150 right" title="'.dol_escape_htmltag($data['vatnum']).'">'.dol_escape_htmltag($data['vatnum'])."</td>\n";
925
926 if ($data['sens']) {
927 $totalET_credit += $data['amount_ht'];
928 $totalIT_credit += $data['amount_ttc'];
929 $totalVAT_credit += $data['amount_vat'];
930 } else {
931 $totalET_debit -= $data['amount_ht'];
932 $totalIT_debit -= $data['amount_ttc'];
933 $totalVAT_debit -= $data['amount_vat'];
934 }
935
936 if (isModEnabled('multicurrency')) {
937 print '<td class="center">'.$data['currency']."</td>\n";
938 }
939
940 print "</tr>\n";
941 }
942
943 // Total credits
944 print '<tr class="liste_total">';
945 print '<td colspan="6" class="right">'.$langs->trans('Total').' '.$langs->trans('Income').'</td>';
946 print '<td class="right">'.price(price2num($totalET_credit, 'MT')).'</td>';
947 print '<td class="right">'.price(price2num($totalIT_credit, 'MT')).'</td>';
948 print '<td class="right">'.price(price2num($totalVAT_credit, 'MT')).'</td>';
949 print '<td colspan="4"></td>';
950 if (isModEnabled('multicurrency')) {
951 print '<td></td>';
952 }
953 print "</tr>\n";
954 // Total debits
955 print '<tr class="liste_total">';
956 print '<td colspan="6" class="right">'.$langs->trans('Total').' '.$langs->trans('Outcome').'</td>';
957 print '<td class="right">'.price(price2num($totalET_debit, 'MT')).'</td>';
958 print '<td class="right">'.price(price2num($totalIT_debit, 'MT')).'</td>';
959 print '<td class="right">'.price(price2num($totalVAT_debit, 'MT')).'</td>';
960 print '<td colspan="4"></td>';
961 if (isModEnabled('multicurrency')) {
962 print '<td></td>';
963 }
964 print "</tr>\n";
965 // Balance
966 print '<tr class="liste_total">';
967 print '<td colspan="6" class="right">'.$langs->trans('Total').'</td>';
968 print '<td class="right">'.price(price2num($totalET_credit + $totalET_debit, 'MT')).'</td>';
969 print '<td class="right">'.price(price2num($totalIT_credit + $totalIT_debit, 'MT')).'</td>';
970 print '<td class="right">'.price(price2num($totalVAT_credit + $totalVAT_debit, 'MT')).'</td>';
971 print '<td colspan="4"></td>';
972 if (isModEnabled('multicurrency')) {
973 print '<td></td>';
974 }
975 print "</tr>\n";
976 }
977
978 print "</table>";
979 print '</div>';
980}
981
982
983llxFooter();
984$db->close();
$id
Support class for third parties, contacts, members, users or resources.
Definition account.php:47
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 for managing the social charges.
Class to manage donations.
Definition don.class.php:41
Class to manage Trips and Expenses.
const STATUS_DRAFT
Draft status.
Class to manage suppliers invoices.
Class to manage invoices.
Class to offer components to list and upload files.
Class to manage generation of HTML components Only common components must be here.
Class to manage building of HTML components.
Class to manage payments of loans.
Class to manage payments of salaries.
Class to manage various payments.
Class to manage projects.
Class to manage Dolibarr users.
global $mysoc
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_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_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
$date_start
Variables from include:
dol_mktime($hour, $minute, $second, $month, $day, $year, $gm='auto', $check=1)
Return a timestamp date built from detailed information (by default a local PHP server timestamp) Rep...
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.
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.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='', $dragdropfile=0, $morecssdiv='')
Show tabs of a record.
price2num($amount, $rounding='', $option=0)
Function that return a number with universal decimal format (decimal separator is '.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
dol_sanitizeFileName($str, $newstr='_', $unaccent=1, $includequotes=0, $allowdash=0)
Clean a string to use it as a file name.
price($amount, $form=0, $outlangs='', $trunc=1, $rounding=-1, $forcerounding=-1, $currency_code='')
Function to format a value into an amount for visual output Function used into PDF and HTML pages.
dol_sort_array(&$array, $index, $order='asc', $natsort=0, $case_sensitive=0, $keepindex=0)
Advanced sort array by the value of a given key, which produces ascending (default) or descending out...
yn($yesno, $format=1, $color=0)
Return yes or no in current language.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_print_date($time, $format='', $tzoutput='auto', $outputlangs=null, $encodetooutput=false, $decorate=0)
Output date in a string format according to outputlangs (or langs if not defined).
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
isModEnabled($module)
Is Dolibarr module enabled.
get_exdir($num, $level, $alpha, $withoutslash, $object, $modulepart='')
Return a path to have a the directory according to object where files are stored.
dol_mkdir($dir, $dataroot='', $newmask='')
Creation of a directory (this can create recursive subdir)
dol_escape_htmltag($stringtoescape, $keepb=0, $keepn=0, $noescapetags='', $escapeonlyhtmltags=0, $cleanalsojavascript=0)
Returns text escaped for inclusion in HTML alt or title or value tags, or into values of HTML input f...
print $langs trans("Show") . '< td style="' . $timeColor . '" align="center"> s</td > badge status0 badge status4 badge status3 Error badge status8< td align="center">< span class="badge ' . $badge . '"></span ></td >< td align="center">< a href="#" class="button button-small" onclick="openLogModal(this)" data-req="' . dol_escape_htmltag($reqSafe) . '" data-res="' . dol_escape_htmltag($resSafe) . '" data-err="' . dol_escape_htmltag($errSafe) . '">< span class="fa fa-search-plus"></span ></a ></td ></tr >< tr >< td colspan="' . $colspan . '" class="opacitymedium"></td ></tr ></table ></div ></form > logModal none logModal none s a JSON string
buildzip.php
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.