2012-06-09 19:16:31 +02:00
< ? php
2024-07-16 12:50:37 +02:00
/* Copyright ( C ) 2002 - 2006 Rodolphe Quiedeville < rodolphe @ quiedeville . org >
* Copyright ( C ) 2004 Eric Seigne < eric . seigne @ ryxeo . com >
* Copyright ( C ) 2004 - 2016 Laurent Destailleur < eldy @ users . sourceforge . net >
* Copyright ( C ) 2005 Marc Barilley / Ocebo < marc @ ocebo . com >
* Copyright ( C ) 2005 - 2015 Regis Houssin < regis . houssin @ inodbox . com >
* Copyright ( C ) 2006 Andre Cianfarani < acianfa @ free . fr >
* Copyright ( C ) 2010 - 2020 Juanjo Menent < jmenent @ 2 byte . es >
* Copyright ( C ) 2012 Christophe Battarel < christophe . battarel @ altairis . fr >
* Copyright ( C ) 2013 Florian Henry < florian . henry @ open - concept . pro >
* Copyright ( C ) 2013 Cédric Salvador < csalvador @ gpcsolutions . fr >
* Copyright ( C ) 2015 Jean - François Ferry < jfefe @ aternatik . fr >
* Copyright ( C ) 2015 - 2022 Ferran Marcet < fmarcet @ 2 byte . es >
* Copyright ( C ) 2017 Josep Lluís Amador < joseplluis @ lliuretic . cat >
* Copyright ( C ) 2018 Charlene Benke < charlie @ patas - monkey . com >
* Copyright ( C ) 2019 - 2024 Alexandre Spangaro < alexandre @ inovea - conseil . com >
* Copyright ( C ) 2021 - 2024 Anthony Berton < anthony . berton @ bb2a . fr >
2024-04-28 22:16:12 +02:00
* Copyright ( C ) 2023 Nick Fragoulis
2024-07-16 12:50:37 +02:00
* Copyright ( C ) 2023 Joachim Kueter < git - jk @ bloxera . com >
* Copyright ( C ) 2024 MDW < mdeweerd @ users . noreply . github . com >
2025-01-22 09:03:45 +01:00
* Copyright ( C ) 2024 - 2025 Frédéric France < frederic . france @ free . fr >
2024-07-16 12:50:37 +02:00
* Copyright ( C ) 2024 Solution Libre SAS < contact @ solution - libre . fr >
2024-08-20 10:16:43 +02:00
* Copyright ( C ) 2024 William Mead < william . mead @ manchenumerique . fr >
2012-06-09 19:16:31 +02:00
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
2013-01-16 15:36:08 +01:00
* the Free Software Foundation ; either version 3 of the License , or
2012-06-09 19:16:31 +02:00
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
2019-09-23 21:55:30 +02:00
* along with this program . If not , see < https :// www . gnu . org / licenses />.
2012-06-09 19:16:31 +02:00
*/
/**
2012-06-11 19:28:04 +02:00
* \file htdocs / compta / facture / list . php
2024-05-13 10:45:20 +02:00
* \ingroup invoice
2016-06-21 15:16:33 +02:00
* \brief List of customer invoices
2012-06-09 19:16:31 +02:00
*/
2022-09-07 20:08:59 +02:00
// Load Dolibarr environment
2012-08-22 23:24:21 +02:00
require '../../main.inc.php' ;
2012-08-22 23:11:24 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/class/html.formfile.class.php' ;
require_once DOL_DOCUMENT_ROOT . '/core/class/html.formother.class.php' ;
2016-04-08 01:00:02 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/class/html.formcompany.class.php' ;
2022-08-29 12:02:49 +02:00
if ( isModEnabled ( 'margin' )) {
2020-10-21 16:10:48 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/class/html.formmargin.class.php' ;
}
2012-08-22 23:11:24 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/modules/facture/modules_facture.php' ;
2016-06-21 15:16:33 +02:00
require_once DOL_DOCUMENT_ROOT . '/compta/bank/class/account.class.php' ;
2012-08-22 23:11:24 +02:00
require_once DOL_DOCUMENT_ROOT . '/compta/facture/class/facture.class.php' ;
require_once DOL_DOCUMENT_ROOT . '/core/class/discount.class.php' ;
require_once DOL_DOCUMENT_ROOT . '/compta/paiement/class/paiement.class.php' ;
2022-04-15 11:32:53 +02:00
require_once DOL_DOCUMENT_ROOT . '/compta/facture/class/facture-rec.class.php' ;
2012-08-22 23:11:24 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/lib/functions2.lib.php' ;
require_once DOL_DOCUMENT_ROOT . '/core/lib/invoice.lib.php' ;
require_once DOL_DOCUMENT_ROOT . '/core/lib/date.lib.php' ;
2016-04-08 02:39:57 +02:00
require_once DOL_DOCUMENT_ROOT . '/core/lib/company.lib.php' ;
2018-02-12 14:02:51 +01:00
require_once DOL_DOCUMENT_ROOT . '/projet/class/project.class.php' ;
2024-02-27 15:30:37 +01:00
if ( isModEnabled ( 'order' )) {
2021-02-23 21:09:01 +01:00
require_once DOL_DOCUMENT_ROOT . '/commande/class/commande.class.php' ;
}
2018-02-12 14:02:51 +01:00
2024-11-04 23:53:20 +01:00
/**
* @ var Conf $conf
* @ var DoliDB $db
* @ var HookManager $hookmanager
* @ var Societe $mysoc
* @ var Translate $langs
* @ var User $user
*/
2018-05-27 09:27:09 +02:00
// Load translation files required by the page
2018-12-11 13:25:09 +01:00
$langs -> loadLangs ( array ( 'bills' , 'companies' , 'products' , 'categories' ));
2012-06-09 19:16:31 +02:00
2024-11-07 12:25:31 +01:00
$search_all = trim ( GETPOST ( 'search_all' , 'alphanohtml' ));
2012-06-09 19:16:31 +02:00
Fix: GETPOST(...,'int') to GETPOSTINT(...) (#28448)
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: Update spelling exceptions
* Qual: Ignore Phan Notice
2024-02-27 14:05:53 +01:00
$id = ( GETPOSTINT ( 'id' ) ? GETPOSTINT ( 'id' ) : GETPOSTINT ( 'facid' )); // For backward compatibility
2019-11-12 09:46:08 +01:00
$ref = GETPOST ( 'ref' , 'alpha' );
2024-02-07 20:44:36 +01:00
$socid = GETPOSTINT ( 'socid' );
2016-07-25 19:43:07 +02:00
2020-09-16 19:39:50 +02:00
$action = GETPOST ( 'action' , 'aZ09' );
2019-11-12 09:46:08 +01:00
$massaction = GETPOST ( 'massaction' , 'alpha' );
Fix: GETPOST(...,'int') to GETPOSTINT(...) (#28448)
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: GETPOST(...,'int') to GETPOSTINT(...)
# Fix: GETPOST(...,'int') to GETPOSTINT(...)
Converted using Phan plugin
* Fix: Update spelling exceptions
* Qual: Ignore Phan Notice
2024-02-27 14:05:53 +01:00
$show_files = GETPOSTINT ( 'show_files' );
2019-11-12 09:46:08 +01:00
$confirm = GETPOST ( 'confirm' , 'alpha' );
2016-07-25 19:43:07 +02:00
$toselect = GETPOST ( 'toselect' , 'array' );
2022-10-11 03:01:09 +02:00
$optioncss = GETPOST ( 'optioncss' , 'alpha' );
2023-12-04 12:01:45 +01:00
$contextpage = GETPOST ( 'contextpage' , 'aZ' ) ? GETPOST ( 'contextpage' , 'aZ' ) : 'invoicelist' ;
2023-10-15 23:13:20 +02:00
$mode = GETPOST ( 'mode' , 'aZ' ); // The output mode ('list', 'kanban', 'hierarchy', 'calendar', ...)
2019-01-27 11:55:16 +01:00
2021-02-23 21:09:01 +01:00
if ( $contextpage == 'poslist' ) {
2022-10-11 03:01:09 +02:00
$optioncss = 'print' ;
2019-04-28 18:12:33 +02:00
}
2024-02-09 15:58:49 +01:00
$userid = GETPOSTINT ( 'userid' );
2023-12-04 12:01:45 +01:00
$search_ref = GETPOST ( 'sf_ref' ) ? GETPOST ( 'sf_ref' , 'alpha' ) : GETPOST ( 'search_ref' , 'alpha' );
2019-11-12 09:46:08 +01:00
$search_refcustomer = GETPOST ( 'search_refcustomer' , 'alpha' );
2024-03-04 11:00:21 +01:00
$search_type = GETPOST ( 'search_type' , 'intcomma' );
$search_subtype = GETPOST ( 'search_subtype' , 'intcomma' );
2019-11-12 09:46:08 +01:00
$search_project_ref = GETPOST ( 'search_project_ref' , 'alpha' );
$search_project = GETPOST ( 'search_project' , 'alpha' );
2021-05-20 12:36:26 +02:00
$search_company = GETPOST ( 'search_company' , 'alpha' );
$search_company_alias = GETPOST ( 'search_company_alias' , 'alpha' );
2022-10-17 15:08:32 +02:00
$search_parent_name = trim ( GETPOST ( 'search_parent_name' , 'alphanohtml' ));
2019-11-12 09:46:08 +01:00
$search_montant_ht = GETPOST ( 'search_montant_ht' , 'alpha' );
$search_montant_vat = GETPOST ( 'search_montant_vat' , 'alpha' );
$search_montant_localtax1 = GETPOST ( 'search_montant_localtax1' , 'alpha' );
$search_montant_localtax2 = GETPOST ( 'search_montant_localtax2' , 'alpha' );
$search_montant_ttc = GETPOST ( 'search_montant_ttc' , 'alpha' );
2020-04-10 10:59:32 +02:00
$search_login = GETPOST ( 'search_login' , 'alpha' );
2020-02-27 14:10:00 +01:00
$search_multicurrency_code = GETPOST ( 'search_multicurrency_code' , 'alpha' );
$search_multicurrency_tx = GETPOST ( 'search_multicurrency_tx' , 'alpha' );
$search_multicurrency_montant_ht = GETPOST ( 'search_multicurrency_montant_ht' , 'alpha' );
$search_multicurrency_montant_vat = GETPOST ( 'search_multicurrency_montant_vat' , 'alpha' );
$search_multicurrency_montant_ttc = GETPOST ( 'search_multicurrency_montant_ttc' , 'alpha' );
2019-11-12 09:46:08 +01:00
$search_status = GETPOST ( 'search_status' , 'intcomma' );
2024-04-03 17:29:23 +02:00
$search_paymentmode = GETPOST ( 'search_paymentmode' , 'intcomma' );
$search_paymentterms = GETPOST ( 'search_paymentterms' , 'intcomma' );
2019-11-12 09:46:08 +01:00
$search_module_source = GETPOST ( 'search_module_source' , 'alpha' );
$search_pos_source = GETPOST ( 'search_pos_source' , 'alpha' );
$search_town = GETPOST ( 'search_town' , 'alpha' );
$search_zip = GETPOST ( 'search_zip' , 'alpha' );
2020-08-28 21:27:50 +02:00
$search_state = GETPOST ( " search_state " );
2024-04-03 17:50:24 +02:00
$search_country = GETPOST ( " search_country " , 'aZ09' );
2023-09-18 11:19:45 +02:00
$search_customer_code = GETPOST ( " search_customer_code " , 'alphanohtml' );
2024-04-03 17:29:23 +02:00
$search_type_thirdparty = GETPOST ( " search_type_thirdparty " , 'intcomma' );
2024-03-22 02:35:37 +01:00
$search_user = GETPOST ( 'search_user' , 'intcomma' );
$search_sale = GETPOST ( 'search_sale' , 'intcomma' );
2025-02-18 13:56:44 +01:00
2024-02-09 15:58:49 +01:00
$search_date_startday = GETPOSTINT ( 'search_date_startday' );
$search_date_startmonth = GETPOSTINT ( 'search_date_startmonth' );
$search_date_startyear = GETPOSTINT ( 'search_date_startyear' );
$search_date_endday = GETPOSTINT ( 'search_date_endday' );
$search_date_endmonth = GETPOSTINT ( 'search_date_endmonth' );
$search_date_endyear = GETPOSTINT ( 'search_date_endyear' );
2025-02-18 13:56:44 +01:00
$search_date_start = GETPOSTDATE ( 'search_date_valid_start' , 'getpost' ); // Use tzserver because date invoice is a date without hour
$search_date_end = GETPOSTDATE ( 'search_date_valid_end' , 'getpostend' );
2024-02-09 15:58:49 +01:00
$search_date_valid_startday = GETPOSTINT ( 'search_date_valid_startday' );
$search_date_valid_startmonth = GETPOSTINT ( 'search_date_valid_startmonth' );
$search_date_valid_startyear = GETPOSTINT ( 'search_date_valid_startyear' );
$search_date_valid_endday = GETPOSTINT ( 'search_date_valid_endday' );
$search_date_valid_endmonth = GETPOSTINT ( 'search_date_valid_endmonth' );
$search_date_valid_endyear = GETPOSTINT ( 'search_date_valid_endyear' );
2025-02-18 13:56:44 +01:00
$search_date_valid_start = GETPOSTDATE ( 'search_date_valid_start' , 'getpost' );
$search_date_valid_end = GETPOSTDATE ( 'search_date_valid_end' , 'getpostend' );
2024-02-09 15:58:49 +01:00
$search_datelimit_startday = GETPOSTINT ( 'search_datelimit_startday' );
$search_datelimit_startmonth = GETPOSTINT ( 'search_datelimit_startmonth' );
$search_datelimit_startyear = GETPOSTINT ( 'search_datelimit_startyear' );
$search_datelimit_endday = GETPOSTINT ( 'search_datelimit_endday' );
$search_datelimit_endmonth = GETPOSTINT ( 'search_datelimit_endmonth' );
$search_datelimit_endyear = GETPOSTINT ( 'search_datelimit_endyear' );
2025-02-18 13:56:44 +01:00
$search_datelimit_start = GETPOSTDATE ( 'search_datelimit_start' , 'getpost' ); // Use tzserver because date invoice is a date without hour
$search_datelimit_end = GETPOSTDATE ( 'search_datelimit_end' , 'getpostend' );
$search_datec_start = GETPOSTDATE ( 'search_datec_start' , 'getpost' , 'tzuserrel' );
$search_datec_end = GETPOSTDATE ( 'search_datec_end' , 'getpostend' , 'tzuserrel' );
$search_datem_start = GETPOSTDATE ( 'search_datem_start' , 'getpost' , 'tzuserrel' );
$search_datem_end = GETPOSTDATE ( 'search_datem_end' , 'getpostend' , 'tzuserrel' );
2024-04-03 17:29:23 +02:00
$search_categ_cus = GETPOST ( " search_categ_cus " , 'intcomma' );
$search_product_category = GETPOST ( 'search_product_category' , 'intcomma' );
2022-04-27 08:50:58 +02:00
$search_fac_rec_source_title = GETPOST ( " search_fac_rec_source_title " , 'alpha' );
2024-10-19 01:02:21 +02:00
$search_fk_fac_rec_source = GETPOST ( 'search_fk_fac_rec_source' , 'int' );
2024-12-16 13:45:48 +01:00
$search_import_key = trim ( GETPOST ( " search_import_key " , " alpha " ));
2021-03-31 18:39:59 +02:00
2024-07-03 02:59:41 +02:00
$search_option = GETPOST ( 'search_option' );
if ( $search_option == 'late' ) {
2017-09-26 11:55:19 +02:00
$search_status = '1' ;
}
2012-06-09 19:16:31 +02:00
2024-02-09 15:58:49 +01:00
$limit = GETPOSTINT ( 'limit' ) ? GETPOSTINT ( 'limit' ) : $conf -> liste_limit ;
2022-01-13 11:09:37 +01:00
$sortfield = GETPOST ( 'sortfield' , 'aZ09comma' );
$sortorder = GETPOST ( 'sortorder' , 'aZ09comma' );
2024-03-01 01:52:40 +01:00
$page = GETPOSTISSET ( 'pageplusone' ) ? ( GETPOSTINT ( 'pageplusone' ) - 1 ) : GETPOSTINT ( " page " );
2021-02-23 21:09:01 +01:00
if ( empty ( $page ) || $page < 0 || GETPOST ( 'button_search' , 'alpha' ) || GETPOST ( 'button_removefilter' , 'alpha' )) {
$page = 0 ;
} // If $page is not defined, or '' or -1 or if we click on clear filters
2015-12-16 19:38:40 +01:00
$offset = $limit * $page ;
2023-11-27 11:39:32 +01:00
if ( ! $sortorder && getDolGlobalString ( 'INVOICE_DEFAULT_UNPAYED_SORT_ORDER' ) && $search_status == '1' ) {
2024-01-05 04:18:53 +01:00
$sortorder = getDolGlobalString ( 'INVOICE_DEFAULT_UNPAYED_SORT_ORDER' );
2021-02-23 21:09:01 +01:00
}
if ( ! $sortorder ) {
$sortorder = 'DESC' ;
}
if ( ! $sortfield ) {
$sortfield = 'f.datef' ;
}
2012-06-09 19:16:31 +02:00
$pageprev = $page - 1 ;
$pagenext = $page + 1 ;
2025-02-18 13:56:44 +01:00
$diroutputmassaction = $conf -> invoice -> dir_output . '/temp/massgeneration/' . $user -> id ;
2016-02-08 18:04:42 +01:00
2019-11-12 09:46:08 +01:00
$now = dol_now ();
2022-02-10 13:01:47 +01:00
$error = 0 ;
2016-04-08 01:00:02 +02:00
2024-06-30 21:02:50 +02:00
// Initialize a technical object to manage hooks of page. Note that conf->hooks_modules contains an array of hook context
2018-03-31 18:48:27 +02:00
$object = new Facture ( $db );
2023-06-02 00:40:10 +02:00
$hookmanager -> initHooks ( array ( $contextpage ));
2016-04-08 01:00:02 +02:00
$extrafields = new ExtraFields ( $db );
2012-06-09 19:16:31 +02:00
2023-06-02 00:40:10 +02:00
// Fetch optionals attributes and labels
2020-08-04 12:47:09 +02:00
$extrafields -> fetch_name_optionals_label ( $object -> table_element );
2019-10-06 14:41:52 +02:00
2019-11-12 09:46:08 +01:00
$search_array_options = $extrafields -> getOptionalsFromPost ( $object -> table_element , '' , 'search_' );
2012-06-09 19:16:31 +02:00
2015-10-17 02:41:09 +02:00
// List of fields to search into when doing a "search in all"
$fieldstosearchall = array (
2024-03-08 12:34:25 +01:00
'f.ref' => 'Ref' ,
'f.ref_client' => 'RefCustomer' ,
'f.note_public' => 'NotePublic' ,
's.nom' => " ThirdParty " ,
's.code_client' => " CustomerCodeShort " ,
's.name_alias' => " AliasNameShort " ,
's.zip' => " Zip " ,
's.town' => " Town " ,
'pd.description' => 'Description' ,
2015-10-17 02:41:09 +02:00
);
2021-02-23 21:09:01 +01:00
if ( empty ( $user -> socid )) {
$fieldstosearchall [ " f.note_private " ] = " NotePrivate " ;
}
2015-10-17 02:41:09 +02:00
2019-11-12 09:46:08 +01:00
$checkedtypetiers = 0 ;
$arrayfields = array (
2024-03-08 12:34:25 +01:00
'f.ref' => array ( 'label' => " Ref " , 'checked' => 1 , 'position' => 5 ),
'f.ref_client' => array ( 'label' => " RefCustomer " , 'checked' => - 1 , 'position' => 10 ),
'f.type' => array ( 'label' => " Type " , 'checked' => 0 , 'position' => 15 ),
2024-04-08 12:02:31 +02:00
'f.subtype' => array ( 'label' => " InvoiceSubtype " , 'checked' => 0 , 'position' => 17 ),
2024-03-08 12:34:25 +01:00
'f.datef' => array ( 'label' => " DateInvoice " , 'checked' => 1 , 'position' => 20 ),
'f.date_valid' => array ( 'label' => " DateValidation " , 'checked' => 0 , 'position' => 22 ),
'f.date_lim_reglement' => array ( 'label' => " DateDue " , 'checked' => 1 , 'position' => 25 ),
'f.date_closing' => array ( 'label' => " DateClosing " , 'checked' => 0 , 'position' => 30 ),
'p.ref' => array ( 'label' => " ProjectRef " , 'langs' => 'projects' , 'checked' => 1 , 'enabled' => ( ! isModEnabled ( 'project' ) ? 0 : 1 ), 'position' => 40 ),
'p.title' => array ( 'label' => " ProjectLabel " , 'checked' => 0 , 'enabled' => ( ! isModEnabled ( 'project' ) ? 0 : 1 ), 'position' => 41 ),
's.nom' => array ( 'label' => " ThirdParty " , 'checked' => 1 , 'position' => 50 ),
2024-06-04 02:44:15 +02:00
's.name_alias' => array ( 'label' => " AliasNameShort " , 'checked' => - 1 , 'position' => 51 ),
2024-03-08 12:34:25 +01:00
's.code_client' => array ( 'label' => " CustomerCodeShort " , 'checked' => - 1 , 'position' => 52 ),
's2.nom' => array ( 'label' => 'ParentCompany' , 'position' => 32 , 'checked' => 0 ),
's.town' => array ( 'label' => " Town " , 'checked' => - 1 , 'position' => 55 ),
2024-06-04 02:38:04 +02:00
's.zip' => array ( 'label' => " Zip " , 'checked' => - 1 , 'position' => 60 ),
2024-03-08 12:34:25 +01:00
'state.nom' => array ( 'label' => " StateShort " , 'checked' => 0 , 'position' => 65 ),
'country.code_iso' => array ( 'label' => " Country " , 'checked' => 0 , 'position' => 70 ),
'typent.code' => array ( 'label' => " ThirdPartyType " , 'checked' => $checkedtypetiers , 'position' => 75 ),
'f.fk_mode_reglement' => array ( 'label' => " PaymentMode " , 'checked' => 1 , 'position' => 80 ),
'f.fk_cond_reglement' => array ( 'label' => " PaymentConditionsShort " , 'checked' => 1 , 'position' => 85 ),
'f.module_source' => array ( 'label' => " POSModule " , 'langs' => 'cashdesk' , 'checked' => ( $contextpage == 'poslist' ? 1 : 0 ), 'enabled' => " (isModEnabled('cashdesk') || isModEnabled('takepos') || getDolGlobalInt('INVOICE_SHOW_POS')) " , 'position' => 90 ),
'f.pos_source' => array ( 'label' => " POSTerminal " , 'langs' => 'cashdesk' , 'checked' => ( $contextpage == 'poslist' ? 1 : 0 ), 'enabled' => " (isModEnabled('cashdesk') || isModEnabled('takepos') || getDolGlobalInt('INVOICE_SHOW_POS')) " , 'position' => 91 ),
'f.total_ht' => array ( 'label' => " AmountHT " , 'checked' => 1 , 'position' => 95 ),
'f.total_tva' => array ( 'label' => " AmountVAT " , 'checked' => 0 , 'position' => 100 ),
'f.total_localtax1' => array ( 'label' => $langs -> transcountry ( " AmountLT1 " , $mysoc -> country_code ), 'checked' => 0 , 'enabled' => ( $mysoc -> localtax1_assuj == " 1 " ), 'position' => 110 ),
'f.total_localtax2' => array ( 'label' => $langs -> transcountry ( " AmountLT2 " , $mysoc -> country_code ), 'checked' => 0 , 'enabled' => ( $mysoc -> localtax2_assuj == " 1 " ), 'position' => 120 ),
'f.total_ttc' => array ( 'label' => " AmountTTC " , 'checked' => 0 , 'position' => 130 ),
2024-09-28 13:40:07 +02:00
'dynamount_payed' => array ( 'label' => " AlreadyPaid " , 'checked' => 0 , 'position' => 140 ),
'rtp' => array ( 'label' => " RemainderToPay " , 'checked' => 0 , 'position' => 150 ), // Not enabled by default because slow
2024-03-08 12:34:25 +01:00
'f.multicurrency_code' => array ( 'label' => 'Currency' , 'checked' => 0 , 'enabled' => ( ! isModEnabled ( 'multicurrency' ) ? 0 : 1 ), 'position' => 280 ),
'f.multicurrency_tx' => array ( 'label' => 'CurrencyRate' , 'checked' => 0 , 'enabled' => ( ! isModEnabled ( 'multicurrency' ) ? 0 : 1 ), 'position' => 285 ),
'f.multicurrency_total_ht' => array ( 'label' => 'MulticurrencyAmountHT' , 'checked' => 0 , 'enabled' => ( ! isModEnabled ( 'multicurrency' ) ? 0 : 1 ), 'position' => 290 ),
'f.multicurrency_total_vat' => array ( 'label' => 'MulticurrencyAmountVAT' , 'checked' => 0 , 'enabled' => ( ! isModEnabled ( 'multicurrency' ) ? 0 : 1 ), 'position' => 291 ),
'f.multicurrency_total_ttc' => array ( 'label' => 'MulticurrencyAmountTTC' , 'checked' => 0 , 'enabled' => ( ! isModEnabled ( 'multicurrency' ) ? 0 : 1 ), 'position' => 292 ),
'multicurrency_dynamount_payed' => array ( 'label' => 'MulticurrencyAlreadyPaid' , 'checked' => 0 , 'enabled' => ( ! isModEnabled ( 'multicurrency' ) ? 0 : 1 ), 'position' => 295 ),
'multicurrency_rtp' => array ( 'label' => 'MulticurrencyRemainderToPay' , 'checked' => 0 , 'enabled' => ( ! isModEnabled ( 'multicurrency' ) ? 0 : 1 ), 'position' => 296 ), // Not enabled by default because slow
2024-02-09 15:58:49 +01:00
'total_pa' => array ( 'label' => (( getDolGlobalString ( 'MARGIN_TYPE' ) == '1' ) ? 'BuyingPrice' : 'CostPrice' ), 'checked' => 0 , 'position' => 300 , 'enabled' => ( ! isModEnabled ( 'margin' ) || ! $user -> hasRight ( 'margins' , 'liretous' ) ? 0 : 1 )),
'total_margin' => array ( 'label' => 'Margin' , 'checked' => 0 , 'position' => 301 , 'enabled' => ( ! isModEnabled ( 'margin' ) || ! $user -> hasRight ( 'margins' , 'liretous' ) ? 0 : 1 )),
'total_margin_rate' => array ( 'label' => 'MarginRate' , 'checked' => 0 , 'position' => 302 , 'enabled' => ( ! isModEnabled ( 'margin' ) || ! $user -> hasRight ( 'margins' , 'liretous' ) || ! getDolGlobalString ( 'DISPLAY_MARGIN_RATES' ) ? 0 : 1 )),
'total_mark_rate' => array ( 'label' => 'MarkRate' , 'checked' => 0 , 'position' => 303 , 'enabled' => ( ! isModEnabled ( 'margin' ) || ! $user -> hasRight ( 'margins' , 'liretous' ) || ! getDolGlobalString ( 'DISPLAY_MARK_RATES' ) ? 0 : 1 )),
2024-03-08 12:34:25 +01:00
'f.datec' => array ( 'label' => " DateCreation " , 'checked' => 0 , 'position' => 500 ),
'f.tms' => array ( 'type' => 'timestamp' , 'label' => 'DateModificationShort' , 'enabled' => 1 , 'visible' => - 1 , 'notnull' => 1 , 'position' => 502 ),
2025-02-18 13:59:51 +01:00
'u.login' => array ( 'label' => " UserAuthor " , 'checked' => 1 , 'visible' => - 1 , 'position' => 504 ),
2024-03-08 12:34:25 +01:00
'sale_representative' => array ( 'label' => " SaleRepresentativesOfThirdParty " , 'checked' => 0 , 'position' => 506 ),
2023-03-18 01:20:14 +01:00
//'f.fk_user_author' =>array('type'=>'integer:User:user/class/user.class.php', 'label'=>'UserAuthor', 'enabled'=>1, 'visible'=>-1, 'position'=>506),
//'f.fk_user_modif' =>array('type'=>'integer:User:user/class/user.class.php', 'label'=>'UserModif', 'enabled'=>1, 'visible'=>-1, 'notnull'=>-1, 'position'=>508),
//'f.fk_user_valid' =>array('type'=>'integer:User:user/class/user.class.php', 'label'=>'UserValidation', 'enabled'=>1, 'visible'=>-1, 'position'=>510),
//'f.fk_user_closing' =>array('type'=>'integer:User:user/class/user.class.php', 'label'=>'UserClosing', 'enabled'=>1, 'visible'=>-1, 'position'=>512),
2024-03-08 12:34:25 +01:00
'f.note_public' => array ( 'label' => 'NotePublic' , 'checked' => 0 , 'position' => 520 , 'enabled' => ( ! getDolGlobalInt ( 'MAIN_LIST_HIDE_PUBLIC_NOTES' ))),
'f.note_private' => array ( 'label' => 'NotePrivate' , 'checked' => 0 , 'position' => 521 , 'enabled' => ( ! getDolGlobalInt ( 'MAIN_LIST_HIDE_PRIVATE_NOTES' ))),
'f.fk_fac_rec_source' => array ( 'label' => 'GeneratedFromTemplate' , 'checked' => 0 , 'position' => 530 , 'enabled' => '1' ),
2024-12-16 13:45:48 +01:00
'f.import_key' => array ( 'type' => 'varchar(14)' , 'label' => 'ImportId' , 'enabled' => 1 , 'visible' => - 2 , 'position' => 999 ),
2024-03-08 12:34:25 +01:00
'f.fk_statut' => array ( 'label' => " Status " , 'checked' => 1 , 'position' => 1000 ),
2016-04-08 01:00:02 +02:00
);
2018-09-27 15:38:43 +02:00
2023-11-27 11:39:32 +01:00
if ( getDolGlobalString ( " INVOICE_USE_SITUATION " ) && getDolGlobalString ( 'INVOICE_USE_RETAINED_WARRANTY' )) {
2024-03-08 12:34:25 +01:00
$arrayfields [ 'f.retained_warranty' ] = array ( 'label' => $langs -> trans ( " RetainedWarranty " ), 'checked' => 0 , 'position' => 86 );
2018-09-27 15:38:43 +02:00
}
2024-04-08 12:02:31 +02:00
$subtypearray = $object -> getArrayOfInvoiceSubtypes ( 0 );
if ( empty ( $subtypearray )) {
unset ( $arrayfields [ 'f.subtype' ]);
}
2021-03-28 19:15:59 +02:00
// Overwrite $arrayfields from columns into ->fields (transition before removal of $arrayoffields)
foreach ( $object -> fields as $key => $val ) {
// If $val['visible']==0, then we never show the field
2023-03-18 01:20:14 +01:00
2021-03-28 19:15:59 +02:00
if ( ! empty ( $val [ 'visible' ])) {
2024-09-05 16:05:37 +02:00
$visible = ( int ) dol_eval (( string ) $val [ 'visible' ], 1 , 1 , '1' );
2021-03-28 19:15:59 +02:00
$newkey = '' ;
2023-12-04 12:01:45 +01:00
if ( array_key_exists ( $key , $arrayfields )) {
$newkey = $key ;
} elseif ( array_key_exists ( 'f.' . $key , $arrayfields )) {
$newkey = 'f.' . $key ;
} elseif ( array_key_exists ( 's.' . $key , $arrayfields )) {
$newkey = 's.' . $key ;
}
2021-03-28 19:15:59 +02:00
if ( $newkey ) {
$arrayfields [ $newkey ] = array (
2024-03-08 12:34:25 +01:00
'label' => $val [ 'label' ],
'checked' => (( $visible < 0 ) ? 0 : 1 ),
2024-07-09 17:26:49 +02:00
'enabled' => ( abs ( $visible ) != 3 && ( bool ) dol_eval ( $val [ 'enabled' ], 1 )),
2024-03-08 12:34:25 +01:00
'position' => $val [ 'position' ],
2021-06-10 20:53:29 +02:00
'help' => empty ( $val [ 'help' ]) ? '' : $val [ 'help' ],
2021-03-28 19:15:59 +02:00
);
}
}
}
2016-04-08 01:00:02 +02:00
// Extra fields
2020-12-01 02:41:19 +01:00
include DOL_DOCUMENT_ROOT . '/core/tpl/extrafields_list_array_fields.tpl.php' ;
2020-11-06 12:19:45 +01:00
2024-04-08 12:02:31 +02:00
2019-09-02 03:58:00 +02:00
$object -> fields = dol_sort_array ( $object -> fields , 'position' );
$arrayfields = dol_sort_array ( $arrayfields , 'position' );
2024-03-20 22:35:39 +01:00
'@phan-var-force array<string,array{label:string,checked?:int<0,1>,position?:int,help?:string}> $arrayfields' ; // dol_sort_array looses type for Phan
2016-04-08 01:00:02 +02:00
2025-01-20 15:26:06 +01:00
// Check only if it's an internal user, external users are already filtered by $socid
2024-12-02 12:10:39 +01:00
if ( empty ( $user -> socid ) && ! $user -> hasRight ( 'societe' , 'client' , 'voir' )) {
2023-11-24 15:36:05 +01:00
$search_sale = $user -> id ;
}
// Security check
$fieldid = ( ! empty ( $ref ) ? 'ref' : 'rowid' );
if ( ! empty ( $user -> socid )) {
$socid = $user -> socid ;
}
2025-01-13 11:58:16 +01:00
if ( empty ( $user -> socid ) && ! $user -> hasRight ( 'societe' , 'client' , 'voir' )) {
$search_sale = $user -> id ;
}
2023-11-24 15:36:05 +01:00
$result = restrictedArea ( $user , 'facture' , $id , '' , '' , 'fk_soc' , $fieldid );
2012-06-09 19:16:31 +02:00
/*
* Actions
*/
2021-02-23 21:09:01 +01:00
if ( GETPOST ( 'cancel' , 'alpha' )) {
2021-03-01 20:37:16 +01:00
$action = 'list' ;
$massaction = '' ;
2021-02-23 21:09:01 +01:00
}
if ( ! GETPOST ( 'confirmmassaction' , 'alpha' ) && $massaction != 'presend' && $massaction != 'confirm_presend' ) {
$massaction = '' ;
}
2016-07-25 21:50:41 +02:00
2024-03-08 12:34:25 +01:00
$parameters = array ( 'socid' => $socid , 'arrayfields' => & $arrayfields );
2019-11-12 09:46:08 +01:00
$reshook = $hookmanager -> executeHooks ( 'doActions' , $parameters , $object , $action ); // Note that $action and $object may have been modified by some hooks
2021-02-23 21:09:01 +01:00
if ( $reshook < 0 ) {
setEventMessages ( $hookmanager -> error , $hookmanager -> errors , 'errors' );
}
2016-04-08 01:00:02 +02:00
include DOL_DOCUMENT_ROOT . '/core/actions_changeselectedfields.inc.php' ;
// Do we click on purge search criteria ?
2021-02-23 21:09:01 +01:00
if ( GETPOST ( 'button_removefilter_x' , 'alpha' ) || GETPOST ( 'button_removefilter' , 'alpha' ) || GETPOST ( 'button_removefilter.x' , 'alpha' )) { // All tests are required to be compatible with all browsers
2019-11-12 09:46:08 +01:00
$search_user = '' ;
$search_sale = '' ;
$search_product_category = '' ;
$search_ref = '' ;
$search_refcustomer = '' ;
$search_type = '' ;
2023-10-18 02:33:14 +02:00
$search_subtype = '' ;
2019-11-12 09:46:08 +01:00
$search_project_ref = '' ;
$search_project = '' ;
2021-05-20 12:36:26 +02:00
$search_company = '' ;
$search_company_alias = '' ;
2022-10-17 15:08:32 +02:00
$search_parent_name = '' ;
2019-11-12 09:46:08 +01:00
$search_montant_ht = '' ;
$search_montant_vat = '' ;
$search_montant_localtax1 = '' ;
$search_montant_localtax2 = '' ;
$search_montant_ttc = '' ;
2020-04-10 10:59:32 +02:00
$search_login = '' ;
2020-02-27 14:10:00 +01:00
$search_multicurrency_code = '' ;
$search_multicurrency_tx = '' ;
$search_multicurrency_montant_ht = '' ;
$search_multicurrency_montant_vat = '' ;
$search_multicurrency_montant_ttc = '' ;
2019-11-12 09:46:08 +01:00
$search_status = '' ;
$search_paymentmode = '' ;
$search_paymentterms = '' ;
$search_module_source = '' ;
$search_pos_source = '' ;
$search_town = '' ;
$search_zip = " " ;
$search_state = " " ;
$search_country = '' ;
$search_type_thirdparty = '' ;
2023-09-18 11:19:45 +02:00
$search_customer_code = '' ;
2021-03-31 18:39:59 +02:00
$search_date_startday = '' ;
$search_date_startmonth = '' ;
$search_date_startyear = '' ;
$search_date_endday = '' ;
$search_date_endmonth = '' ;
$search_date_endyear = '' ;
2019-12-23 21:01:17 +01:00
$search_date_start = '' ;
$search_date_end = '' ;
2021-03-31 18:39:59 +02:00
$search_date_valid_startday = '' ;
$search_date_valid_startmonth = '' ;
$search_date_valid_startyear = '' ;
$search_date_valid_endday = '' ;
$search_date_valid_endmonth = '' ;
$search_date_valid_endyear = '' ;
2020-04-06 23:38:30 +02:00
$search_date_valid_start = '' ;
$search_date_valid_end = '' ;
2021-06-10 06:22:03 +02:00
$search_datelimit_startday = '' ;
$search_datelimit_startmonth = '' ;
$search_datelimit_startyear = '' ;
$search_datelimit_endday = '' ;
$search_datelimit_endmonth = '' ;
$search_datelimit_endyear = '' ;
2019-12-23 21:01:17 +01:00
$search_datelimit_start = '' ;
$search_datelimit_end = '' ;
2025-02-18 13:56:44 +01:00
$search_datec_start = '' ;
$search_datec_end = '' ;
$search_datem_start = '' ;
$search_datem_end = '' ;
2022-04-27 08:50:58 +02:00
$search_fac_rec_source_title = '' ;
2024-08-20 10:16:43 +02:00
$search_option = '' ;
2024-12-16 13:45:48 +01:00
$search_import_key = '' ;
2024-08-20 10:16:43 +02:00
$search_categ_cus = 0 ;
2024-12-16 13:45:48 +01:00
$search_all = '' ;
2022-05-08 18:25:22 +02:00
$toselect = array ();
2019-11-12 09:46:08 +01:00
$search_array_options = array ();
2016-04-08 01:00:02 +02:00
}
2021-02-23 21:09:01 +01:00
if ( empty ( $reshook )) {
2019-11-12 09:46:08 +01:00
$objectclass = 'Facture' ;
$objectlabel = 'Invoices' ;
2022-12-15 14:46:29 +01:00
$permissiontoread = $user -> hasRight ( " facture " , " lire " );
$permissiontoadd = $user -> hasRight ( " facture " , " creer " );
$permissiontodelete = $user -> hasRight ( " facture " , " supprimer " );
2025-02-18 13:56:44 +01:00
$uploaddir = $conf -> invoice -> dir_output ;
2016-07-25 21:50:41 +02:00
include DOL_DOCUMENT_ROOT . '/core/actions_massactions.inc.php' ;
2015-12-02 01:38:15 +01:00
}
2012-06-09 19:16:31 +02:00
2023-06-13 20:47:33 +02:00
if ( $action == 'makepayment_confirm' && $user -> hasRight ( 'facture' , 'paiement' )) {
2021-05-20 14:00:43 +02:00
require_once DOL_DOCUMENT_ROOT . '/compta/paiement/class/paiement.class.php' ;
2020-10-31 14:32:18 +01:00
$arrayofselected = is_array ( $toselect ) ? $toselect : array ();
2021-05-20 14:00:43 +02:00
if ( ! empty ( $arrayofselected )) {
2024-02-09 15:58:49 +01:00
$bankid = GETPOSTINT ( 'bankid' );
$paiementid = GETPOSTINT ( 'paiementid' );
$paiementdate = dol_mktime ( 12 , 0 , 0 , GETPOSTINT ( 'datepaimentmonth' ), GETPOSTINT ( 'datepaimentday' ), GETPOSTINT ( 'datepaimentyear' ));
2022-02-10 13:01:47 +01:00
if ( empty ( $paiementdate )) {
setEventMessages ( $langs -> trans ( " ErrorFieldRequired " , $langs -> transnoentitiesnoconv ( " Date " )), null , 'errors' );
$error ++ ;
$action = 'makepayment' ;
}
if ( ! $error ) {
foreach ( $arrayofselected as $toselectid ) {
$errorpayment = 0 ;
$facture = new Facture ( $db );
$result = $facture -> fetch ( $toselectid );
$db -> begin ();
if ( $result < 0 ) {
setEventMessage ( $facture -> error , 'errors' );
$errorpayment ++ ;
} else {
2023-08-06 00:16:25 +02:00
if ( $facture -> type != Facture :: TYPE_CREDIT_NOTE && $facture -> status == Facture :: STATUS_VALIDATED && $facture -> paye == 0 ) {
2022-02-10 13:01:47 +01:00
$paiementAmount = $facture -> getSommePaiement ();
$totalcreditnotes = $facture -> getSumCreditNotesUsed ();
$totaldeposits = $facture -> getSumDepositsUsed ();
2024-10-14 21:18:24 +02:00
2024-09-28 13:05:24 +02:00
$totalallpayments = $paiementAmount + $totalcreditnotes + $totaldeposits ;
$remaintopay = price2num ( $facture -> total_ttc - $totalallpayments );
2023-05-03 23:09:09 +02:00
// hook to finalize the remaining amount, considering e.g. cash discount agreements
2024-03-08 12:34:25 +01:00
$parameters = array ( 'remaintopay' => $remaintopay );
2023-05-05 17:14:32 +02:00
$reshook = $hookmanager -> executeHooks ( 'finalizeAmountOfInvoice' , $parameters , $facture , $action ); // Note that $action and $object may have been modified by some hooks
2023-05-03 23:09:09 +02:00
if ( $reshook > 0 ) {
if ( ! empty ( $remain = $hookmanager -> resArray [ 'remaintopay' ])) {
$remaintopay = $remain ;
}
} elseif ( $reshook < 0 ) {
$error ++ ;
setEventMessages ( $facture -> ref . ' ' . $langs -> trans ( " ProcessingError " ), $hookmanager -> errors , 'errors' );
}
2022-02-10 13:01:47 +01:00
if ( $remaintopay != 0 ) {
$resultBank = $facture -> setBankAccount ( $bankid );
if ( $resultBank < 0 ) {
setEventMessages ( $facture -> error , null , 'errors' );
2021-05-20 14:00:43 +02:00
$errorpayment ++ ;
2021-05-20 13:41:23 +02:00
} else {
2022-02-10 13:01:47 +01:00
$paiement = new Paiement ( $db );
$paiement -> datepaye = $paiementdate ;
$paiement -> amounts [ $facture -> id ] = $remaintopay ; // Array with all payments dispatching with invoice id
$paiement -> multicurrency_amounts [ $facture -> id ] = $remaintopay ;
$paiement -> paiementid = $paiementid ;
$paiement_id = $paiement -> create ( $user , 1 , $facture -> thirdparty );
if ( $paiement_id < 0 ) {
$langs -> load ( " errors " );
setEventMessages ( $facture -> ref . ' ' . $langs -> trans ( $paiement -> error ), $paiement -> errors , 'errors' );
2021-05-20 14:00:43 +02:00
$errorpayment ++ ;
2022-02-10 13:01:47 +01:00
} else {
$result = $paiement -> addPaymentToBank ( $user , 'payment' , '' , $bankid , '' , '' );
if ( $result < 0 ) {
$langs -> load ( " errors " );
setEventMessages ( $facture -> ref . ' ' . $langs -> trans ( $paiement -> error ), $paiement -> errors , 'errors' );
$errorpayment ++ ;
}
2021-05-20 13:41:23 +02:00
}
}
2022-02-10 13:01:47 +01:00
} else {
setEventMessage ( $langs -> trans ( 'NoPaymentAvailable' , $facture -> ref ), 'warnings' );
$errorpayment ++ ;
2021-05-20 13:41:23 +02:00
}
2021-05-20 14:00:43 +02:00
} else {
2022-02-10 13:01:47 +01:00
setEventMessage ( $langs -> trans ( 'BulkPaymentNotPossibleForInvoice' , $facture -> ref ), 'warnings' );
2021-05-20 14:00:43 +02:00
$errorpayment ++ ;
2021-05-20 13:41:23 +02:00
}
2022-02-10 13:01:47 +01:00
}
if ( empty ( $errorpayment )) {
setEventMessage ( $langs -> trans ( 'PaymentRegisteredAndInvoiceSetToPaid' , $facture -> ref ));
$db -> commit ();
2021-05-20 13:41:23 +02:00
} else {
2022-02-10 13:01:47 +01:00
$db -> rollback ();
2021-05-20 13:41:23 +02:00
}
}
}
2021-05-20 14:00:43 +02:00
}
2020-11-25 12:47:10 +01:00
} elseif ( $massaction == 'withdrawrequest' ) {
2017-10-13 13:28:26 +02:00
$langs -> load ( " withdrawals " );
2023-10-15 15:32:35 +02:00
if ( ! $user -> hasRight ( 'prelevement' , 'bons' , 'creer' )) {
2017-10-13 13:28:26 +02:00
$error ++ ;
setEventMessages ( $langs -> trans ( " NotEnoughPermissions " ), null , 'errors' );
2020-05-21 15:05:19 +02:00
} else {
2017-10-13 13:28:26 +02:00
//Checking error
$error = 0 ;
2019-11-12 09:46:08 +01:00
$arrayofselected = is_array ( $toselect ) ? $toselect : array ();
$listofbills = array ();
2021-02-23 21:09:01 +01:00
foreach ( $arrayofselected as $toselectid ) {
2019-11-12 09:46:08 +01:00
$objecttmp = new Facture ( $db );
$result = $objecttmp -> fetch ( $toselectid );
2020-11-25 12:47:10 +01:00
if ( $result > 0 ) {
2022-05-22 17:09:08 +02:00
$totalpaid = $objecttmp -> getSommePaiement ();
2017-10-13 13:28:26 +02:00
$totalcreditnotes = $objecttmp -> getSumCreditNotesUsed ();
$totaldeposits = $objecttmp -> getSumDepositsUsed ();
2022-05-22 17:09:08 +02:00
$objecttmp -> resteapayer = price2num ( $objecttmp -> total_ttc - $totalpaid - $totalcreditnotes - $totaldeposits , 'MT' );
2023-05-03 23:09:09 +02:00
// hook to finalize the remaining amount, considering e.g. cash discount agreements
2024-03-08 12:34:25 +01:00
$parameters = array ( 'remaintopay' => $objecttmp -> resteapayer );
2023-05-05 17:14:32 +02:00
$reshook = $hookmanager -> executeHooks ( 'finalizeAmountOfInvoice' , $parameters , $objecttmp , $action ); // Note that $action and $object may have been modified by some hooks
2023-05-03 23:09:09 +02:00
if ( $reshook > 0 ) {
if ( ! empty ( $remaintopay = $hookmanager -> resArray [ 'remaintopay' ])) {
$objecttmp -> resteapayer = $remaintopay ;
}
} elseif ( $reshook < 0 ) {
$error ++ ;
setEventMessages ( $objecttmp -> ref . ' ' . $langs -> trans ( " ProcessingError " ), $hookmanager -> errors , 'errors' );
}
2021-05-25 21:21:09 +02:00
if ( $objecttmp -> statut == Facture :: STATUS_DRAFT ) {
$error ++ ;
setEventMessages ( $objecttmp -> ref . ' ' . $langs -> trans ( " Draft " ), $objecttmp -> errors , 'errors' );
} elseif ( $objecttmp -> paye || $objecttmp -> resteapayer == 0 ) {
2017-10-13 13:28:26 +02:00
$error ++ ;
setEventMessages ( $objecttmp -> ref . ' ' . $langs -> trans ( " AlreadyPaid " ), $objecttmp -> errors , 'errors' );
2019-11-12 09:46:08 +01:00
} elseif ( $objecttmp -> resteapayer < 0 ) {
2017-10-13 13:28:26 +02:00
$error ++ ;
setEventMessages ( $objecttmp -> ref . ' ' . $langs -> trans ( " AmountMustBePositive " ), $objecttmp -> errors , 'errors' );
}
$rsql = " SELECT pfd.rowid, pfd.traite, pfd.date_demande as date_demande " ;
$rsql .= " , pfd.date_traite as date_traite " ;
$rsql .= " , pfd.amount " ;
$rsql .= " , u.rowid as user_id, u.lastname, u.firstname, u.login " ;
2022-10-28 17:51:25 +02:00
$rsql .= " FROM " . MAIN_DB_PREFIX . " prelevement_demande as pfd " ;
2017-10-13 13:28:26 +02:00
$rsql .= " , " . MAIN_DB_PREFIX . " user as u " ;
2021-03-30 17:53:25 +02:00
$rsql .= " WHERE fk_facture = " . (( int ) $objecttmp -> id );
2017-10-13 13:28:26 +02:00
$rsql .= " AND pfd.fk_user_demande = u.rowid " ;
$rsql .= " AND pfd.traite = 0 " ;
$rsql .= " ORDER BY pfd.date_demande DESC " ;
$result_sql = $db -> query ( $rsql );
2021-02-23 21:09:01 +01:00
if ( $result_sql ) {
2017-10-13 13:28:26 +02:00
$numprlv = $db -> num_rows ( $result_sql );
2024-11-16 17:59:26 +01:00
} else {
$numprlv = 0 ;
2017-10-13 13:28:26 +02:00
}
2019-11-12 09:46:08 +01:00
if ( $numprlv > 0 ) {
2017-10-13 13:28:26 +02:00
$error ++ ;
2018-08-03 09:57:29 +02:00
setEventMessages ( $objecttmp -> ref . ' ' . $langs -> trans ( " RequestAlreadyDone " ), $objecttmp -> errors , 'warnings' );
2020-05-21 15:05:19 +02:00
} elseif ( ! empty ( $objecttmp -> mode_reglement_code ) && $objecttmp -> mode_reglement_code != 'PRE' ) {
2024-07-30 11:16:19 +02:00
$langs -> load ( " errors " );
2017-10-13 13:28:26 +02:00
$error ++ ;
2024-07-30 11:16:19 +02:00
setEventMessages ( $objecttmp -> ref . ' ' . $langs -> trans ( " ErrorThisPaymentModeIsNotDirectDebit " ), $objecttmp -> errors , 'errors' );
2020-05-21 15:05:19 +02:00
} else {
2019-11-12 09:46:08 +01:00
$listofbills [] = $objecttmp ; // $listofbills will only contains invoices with good payment method and no request already done
2018-08-03 09:57:29 +02:00
}
2017-10-13 13:28:26 +02:00
}
}
2018-08-03 09:57:29 +02:00
//Massive withdraw request for request with no errors
2021-02-23 21:09:01 +01:00
if ( ! empty ( $listofbills )) {
2019-11-12 09:46:08 +01:00
$nbwithdrawrequestok = 0 ;
2021-02-23 21:09:01 +01:00
foreach ( $listofbills as $aBill ) {
2017-10-13 13:28:26 +02:00
$db -> begin ();
2020-06-14 21:46:32 +02:00
$result = $aBill -> demande_prelevement ( $user , $aBill -> resteapayer , 'direct-debit' , 'facture' );
2021-02-23 21:09:01 +01:00
if ( $result > 0 ) {
2017-10-13 13:28:26 +02:00
$db -> commit ();
$nbwithdrawrequestok ++ ;
2020-05-21 15:05:19 +02:00
} else {
2017-10-13 13:28:26 +02:00
$db -> rollback ();
setEventMessages ( $aBill -> error , $aBill -> errors , 'errors' );
}
}
2021-02-23 21:09:01 +01:00
if ( $nbwithdrawrequestok > 0 ) {
2017-10-13 13:28:26 +02:00
setEventMessages ( $langs -> trans ( " WithdrawRequestsDone " , $nbwithdrawrequestok ), null , 'mesgs' );
}
}
}
2017-01-27 01:21:20 +01:00
}
2017-06-13 18:50:31 +02:00
2012-06-09 19:16:31 +02:00
/*
* View
*/
$form = new Form ( $db );
2012-06-23 20:39:20 +02:00
$formother = new FormOther ( $db );
2012-06-09 19:16:31 +02:00
$formfile = new FormFile ( $db );
2020-10-21 16:10:48 +02:00
$formmargin = null ;
2022-08-29 12:02:49 +02:00
if ( isModEnabled ( 'margin' )) {
2020-10-21 16:10:48 +02:00
$formmargin = new FormMargin ( $db );
}
2019-11-12 09:46:08 +01:00
$bankaccountstatic = new Account ( $db );
$facturestatic = new Facture ( $db );
$formcompany = new FormCompany ( $db );
2021-05-17 23:27:33 +02:00
$companystatic = new Societe ( $db );
2022-10-17 15:08:32 +02:00
$companyparent = new Societe ( $db );
2024-02-07 20:44:36 +01:00
2022-10-17 15:08:32 +02:00
$company_url_list = array ();
2024-02-07 20:44:36 +01:00
if ( $socid > 0 ) {
$soc = new Societe ( $db );
$soc -> fetch ( $socid );
if ( empty ( $search_company )) {
$search_company = $soc -> name ;
}
2024-11-16 17:59:26 +01:00
} else {
$soc = null ;
2024-02-07 20:44:36 +01:00
}
2024-11-16 17:59:26 +01:00
$title = $langs -> trans ( 'BillsCustomers' ) . ' ' . (( $socid > 0 && $soc !== null ) ? ' - ' . $soc -> name : '' );
2023-10-15 23:13:20 +02:00
$help_url = 'EN:Customers_Invoices|FR:Factures_Clients|ES:Facturas_a_clientes' ;
2023-08-23 02:52:05 +02:00
2022-12-07 10:11:57 +01:00
$varpage = empty ( $contextpage ) ? $_SERVER [ " PHP_SELF " ] : $contextpage ;
$selectedfields = $form -> multiSelectArrayWithCheckbox ( 'selectedfields' , $arrayfields , $varpage ); // This also change content of $arrayfields
2023-10-15 23:13:20 +02:00
// Build and execute select
// --------------------------------------------------------------------
2015-07-02 22:07:13 +02:00
$sql = 'SELECT' ;
2024-04-28 22:16:12 +02:00
if ( $search_all ) {
2021-02-23 21:09:01 +01:00
$sql = 'SELECT DISTINCT' ;
}
2023-10-18 02:33:14 +02:00
$sql .= ' f.rowid as id, f.ref, f.ref_client, f.fk_soc, f.type, f.subtype, f.note_private, f.note_public, f.increment, f.fk_mode_reglement, f.fk_cond_reglement, f.total_ht, f.total_tva, f.total_ttc,' ;
2019-11-12 09:46:08 +01:00
$sql .= ' f.localtax1 as total_localtax1, f.localtax2 as total_localtax2,' ;
2020-04-01 17:09:01 +02:00
$sql .= ' f.fk_user_author,' ;
2020-02-27 14:10:00 +01:00
$sql .= ' f.fk_multicurrency, f.multicurrency_code, f.multicurrency_tx, f.multicurrency_total_ht, f.multicurrency_total_tva as multicurrency_total_vat, f.multicurrency_total_ttc,' ;
2021-03-28 19:15:59 +02:00
$sql .= ' f.datef, f.date_valid, f.date_lim_reglement as datelimite, f.module_source, f.pos_source,' ;
2024-12-16 13:45:48 +01:00
$sql .= ' f.paye as paye, f.fk_statut, f.import_key, f.close_code,' ;
2024-02-15 14:08:08 +01:00
$sql .= ' f.datec as date_creation, f.tms as date_modification, f.date_closing as date_closing,' ;
2019-11-12 09:46:08 +01:00
$sql .= ' f.retained_warranty, f.retained_warranty_date_limit, f.situation_final, f.situation_cycle_ref, f.situation_counter,' ;
2023-03-06 14:51:41 +01:00
$sql .= ' s.rowid as socid, s.nom as name, s.name_alias as alias, s.email, s.phone, s.fax, s.address, s.town, s.zip, s.fk_pays, s.client, s.fournisseur, s.code_client, s.code_fournisseur, s.code_compta as code_compta_client, s.code_compta_fournisseur,' ;
2022-10-17 15:08:32 +02:00
$sql .= " s.parent as fk_parent, " ;
$sql .= " s2.nom as name2, " ;
2021-05-17 23:54:31 +02:00
$sql .= ' typent.code as typent_code,' ;
$sql .= ' state.code_departement as state_code, state.nom as state_name,' ;
$sql .= ' country.code as country_code,' ;
2022-04-15 11:32:53 +02:00
$sql .= ' f.fk_fac_rec_source,' ;
2021-05-17 23:54:31 +02:00
$sql .= ' p.rowid as project_id, p.ref as project_ref, p.title as project_label,' ;
2021-09-24 11:16:34 +02:00
$sql .= ' u.login, u.lastname, u.firstname, u.email as user_email, u.statut as user_statut, u.entity, u.photo, u.office_phone, u.office_fax, u.user_mobile, u.job, u.gender' ;
2022-04-06 14:53:22 +02:00
// We need dynamount_payed to be able to sort on status (value is surely wrong because we can count several lines several times due to other left join or link with contacts. But what we need is just 0 or > 0).
2024-01-11 09:58:34 +01:00
// A Better solution to be able to sort on already paid or remain to pay is to store amount_payed in a denormalized field.
2024-03-04 11:00:21 +01:00
// We disable this. It create a bug when searching with search_all and sorting on status. Also it create performance troubles.
2022-04-06 14:53:22 +02:00
/*
2024-03-04 11:00:21 +01:00
if ( ! $search_all ) {
2021-02-23 21:09:01 +01:00
$sql .= ', SUM(pf.amount) as dynamount_payed, SUM(pf.multicurrency_amount) as multicurrency_dynamount_payed' ;
}
2022-04-06 14:53:22 +02:00
*/
2016-04-08 01:00:02 +02:00
// Add fields from extrafields
2019-11-12 09:46:08 +01:00
if ( ! empty ( $extrafields -> attributes [ $object -> table_element ][ 'label' ])) {
2021-02-23 21:09:01 +01:00
foreach ( $extrafields -> attributes [ $object -> table_element ][ 'label' ] as $key => $val ) {
2021-08-27 22:42:04 +02:00
$sql .= ( $extrafields -> attributes [ $object -> table_element ][ 'type' ][ $key ] != 'separate' ? " , ef. " . $key . " as options_ " . $key : '' );
2021-02-23 21:09:01 +01:00
}
2019-10-26 18:13:20 +02:00
}
2016-04-08 01:00:02 +02:00
// Add fields from hooks
2019-11-12 09:46:08 +01:00
$parameters = array ();
2022-10-18 10:45:48 +02:00
$reshook = $hookmanager -> executeHooks ( 'printFieldListSelect' , $parameters , $object , $action ); // Note that $action and $object may have been modified by hook
2019-11-12 09:46:08 +01:00
$sql .= $hookmanager -> resPrint ;
2023-06-02 00:40:10 +02:00
$sql = preg_replace ( '/,\s*$/' , '' , $sql );
2022-11-26 01:23:45 +01:00
$sqlfields = $sql ; // $sql fields to remove for count total
2019-11-12 09:46:08 +01:00
$sql .= ' FROM ' . MAIN_DB_PREFIX . 'societe as s' ;
2022-10-17 15:08:32 +02:00
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . " societe as s2 ON s2.rowid = s.parent " ;
2019-11-12 09:46:08 +01:00
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . " c_country as country on (country.rowid = s.fk_pays) " ;
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . " c_typent as typent on (typent.id = s.fk_typent) " ;
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . " c_departements as state on (state.rowid = s.fk_departement) " ;
$sql .= ', ' . MAIN_DB_PREFIX . 'facture as f' ;
2022-04-06 17:32:56 +02:00
if ( $sortfield == " f.datef " ) {
$sql .= $db -> hintindex ( 'idx_facture_datef' );
}
2022-04-30 19:50:20 +02:00
if ( isset ( $extrafields -> attributes [ $object -> table_element ][ 'label' ]) && is_array ( $extrafields -> attributes [ $object -> table_element ][ 'label' ]) && count ( $extrafields -> attributes [ $object -> table_element ][ 'label' ])) {
2021-02-23 21:09:01 +01:00
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . $object -> table_element . " _extrafields as ef on (f.rowid = ef.fk_object) " ;
}
2024-03-04 11:00:21 +01:00
if ( $search_all ) {
2023-11-24 16:30:31 +01:00
$sql .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'facturedet as pd ON f.rowid = pd.fk_facture' ;
2021-02-23 21:09:01 +01:00
}
2022-04-27 08:50:58 +02:00
if ( ! empty ( $search_fac_rec_source_title )) {
2023-11-24 16:30:31 +01:00
$sql .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'facture_rec as facrec ON f.fk_fac_rec_source = facrec.rowid' ;
2022-04-27 08:50:58 +02:00
}
2019-11-12 09:46:08 +01:00
$sql .= " LEFT JOIN " . MAIN_DB_PREFIX . " projet as p ON p.rowid = f.fk_projet " ;
2020-06-19 10:08:19 +02:00
$sql .= ' LEFT JOIN ' . MAIN_DB_PREFIX . 'user AS u ON f.fk_user_author = u.rowid' ;
2021-03-18 16:21:54 +01:00
// Add table from hooks
$parameters = array ();
$reshook = $hookmanager -> executeHooks ( 'printFieldListFrom' , $parameters , $object ); // Note that $action and $object may have been modified by hook
$sql .= $hookmanager -> resPrint ;
2020-06-19 10:08:19 +02:00
2019-11-12 09:46:08 +01:00
$sql .= ' WHERE f.fk_soc = s.rowid' ;
$sql .= ' AND f.entity IN (' . getEntity ( 'invoice' ) . ')' ;
2021-02-23 21:09:01 +01:00
if ( $socid > 0 ) {
2021-04-26 19:12:23 +02:00
$sql .= ' AND s.rowid = ' . (( int ) $socid );
2021-02-23 21:09:01 +01:00
}
if ( $userid ) {
if ( $userid == - 1 ) {
$sql .= ' AND f.fk_user_author IS NULL' ;
} else {
2021-03-22 13:31:06 +01:00
$sql .= ' AND f.fk_user_author = ' . (( int ) $userid );
2017-10-13 13:28:26 +02:00
}
2012-06-09 19:16:31 +02:00
}
2021-02-23 21:09:01 +01:00
if ( $search_ref ) {
$sql .= natural_search ( 'f.ref' , $search_ref );
}
if ( $search_refcustomer ) {
$sql .= natural_search ( 'f.ref_client' , $search_refcustomer );
}
if ( $search_type != '' && $search_type != '-1' ) {
$sql .= " AND f.type IN ( " . $db -> sanitize ( $db -> escape ( $search_type )) . " ) " ;
}
2023-10-18 02:33:14 +02:00
if ( $search_subtype != '' && $search_subtype != '-1' ) {
$sql .= " AND f.subtype IN ( " . $db -> sanitize ( $db -> escape ( $search_subtype )) . " ) " ;
}
2021-02-23 21:09:01 +01:00
if ( $search_project_ref ) {
$sql .= natural_search ( 'p.ref' , $search_project_ref );
}
if ( $search_project ) {
$sql .= natural_search ( 'p.title' , $search_project );
}
2022-12-08 10:34:48 +01:00
if ( empty ( $arrayfields [ 's.name_alias' ][ 'checked' ]) && $search_company ) {
2022-12-07 10:11:57 +01:00
$sql .= natural_search ( array ( " s.nom " , " s.name_alias " ), $search_company );
} else {
if ( $search_company ) {
$sql .= natural_search ( 's.nom' , $search_company );
}
if ( $search_company_alias ) {
$sql .= natural_search ( 's.name_alias' , $search_company_alias );
}
2021-02-23 21:09:01 +01:00
}
2022-10-17 15:08:32 +02:00
if ( $search_parent_name ) {
$sql .= natural_search ( 's2.nom' , $search_parent_name );
}
2023-09-18 11:19:45 +02:00
if ( $search_customer_code ) {
$sql .= natural_search ( 's.code_client' , $search_customer_code );
2023-02-17 10:14:20 +01:00
}
2021-02-23 21:09:01 +01:00
if ( $search_town ) {
$sql .= natural_search ( 's.town' , $search_town );
}
if ( $search_zip ) {
$sql .= natural_search ( " s.zip " , $search_zip );
}
if ( $search_state ) {
$sql .= natural_search ( " state.nom " , $search_state );
}
2021-08-30 13:56:31 +02:00
if ( strlen ( trim ( $search_country ))) {
$arrayofcode = getCountriesInEEC ();
$country_code_in_EEC = $country_code_in_EEC_without_me = '' ;
foreach ( $arrayofcode as $key => $value ) {
$country_code_in_EEC .= ( $country_code_in_EEC ? " , " : " " ) . " ' " . $value . " ' " ;
if ( $value != $mysoc -> country_code ) {
$country_code_in_EEC_without_me .= ( $country_code_in_EEC_without_me ? " , " : " " ) . " ' " . $value . " ' " ;
}
}
if ( $search_country == 'special_allnotme' ) {
$sql .= " AND country.code <> ' " . $db -> escape ( $mysoc -> country_code ) . " ' " ;
} elseif ( $search_country == 'special_eec' ) {
$sql .= " AND country.code IN ( " . $db -> sanitize ( $country_code_in_EEC , 1 ) . " ) " ;
} elseif ( $search_country == 'special_eecnotme' ) {
$sql .= " AND country.code IN ( " . $db -> sanitize ( $country_code_in_EEC_without_me , 1 ) . " ) " ;
} elseif ( $search_country == 'special_noteec' ) {
$sql .= " AND country.code NOT IN ( " . $db -> sanitize ( $country_code_in_EEC , 1 ) . " ) " ;
} else {
$sql .= natural_search ( " country.code " , $search_country );
}
2021-02-23 21:09:01 +01:00
}
if ( $search_type_thirdparty != '' && $search_type_thirdparty != '-1' ) {
$sql .= " AND s.fk_typent IN ( " . $db -> sanitize ( $db -> escape ( $search_type_thirdparty )) . ')' ;
}
if ( $search_montant_ht != '' ) {
2021-02-28 07:32:23 +01:00
$sql .= natural_search ( 'f.total_ht' , $search_montant_ht , 1 );
2021-02-23 21:09:01 +01:00
}
if ( $search_montant_vat != '' ) {
2021-02-28 07:32:23 +01:00
$sql .= natural_search ( 'f.total_tva' , $search_montant_vat , 1 );
2021-02-23 21:09:01 +01:00
}
if ( $search_montant_localtax1 != '' ) {
$sql .= natural_search ( 'f.localtax1' , $search_montant_localtax1 , 1 );
}
if ( $search_montant_localtax2 != '' ) {
$sql .= natural_search ( 'f.localtax2' , $search_montant_localtax2 , 1 );
}
if ( $search_montant_ttc != '' ) {
$sql .= natural_search ( 'f.total_ttc' , $search_montant_ttc , 1 );
}
if ( $search_multicurrency_code != '' ) {
2021-08-27 23:36:06 +02:00
$sql .= " AND f.multicurrency_code = ' " . $db -> escape ( $search_multicurrency_code ) . " ' " ;
2021-02-23 21:09:01 +01:00
}
if ( $search_multicurrency_tx != '' ) {
$sql .= natural_search ( 'f.multicurrency_tx' , $search_multicurrency_tx , 1 );
}
if ( $search_multicurrency_montant_ht != '' ) {
$sql .= natural_search ( 'f.multicurrency_total_ht' , $search_multicurrency_montant_ht , 1 );
}
if ( $search_multicurrency_montant_vat != '' ) {
$sql .= natural_search ( 'f.multicurrency_total_tva' , $search_multicurrency_montant_vat , 1 );
}
if ( $search_multicurrency_montant_ttc != '' ) {
$sql .= natural_search ( 'f.multicurrency_total_ttc' , $search_multicurrency_montant_ttc , 1 );
}
if ( $search_login ) {
2021-05-18 18:18:00 +02:00
$sql .= natural_search ( array ( 'u.login' , 'u.firstname' , 'u.lastname' ), $search_login );
2021-02-23 21:09:01 +01:00
}
if ( $search_status != '-1' && $search_status != '' ) {
if ( is_numeric ( $search_status ) && $search_status >= 0 ) {
if ( $search_status == '0' ) {
$sql .= " AND f.fk_statut = 0 " ; // draft
}
if ( $search_status == '1' ) {
$sql .= " AND f.fk_statut = 1 " ; // unpayed
}
if ( $search_status == '2' ) {
2024-01-11 09:58:34 +01:00
$sql .= " AND f.fk_statut = 2 " ; // paid Not that some corrupted data may contains f.fk_statut = 1 AND f.paye = 1 (it means paid too but should not happen. If yes, reopen and reclassify billed)
2021-02-23 21:09:01 +01:00
}
if ( $search_status == '3' ) {
2024-01-11 09:58:34 +01:00
$sql .= " AND f.fk_statut = 3 " ; // abandoned
2021-02-23 21:09:01 +01:00
}
2020-05-21 15:05:19 +02:00
} else {
2020-09-18 17:24:31 +02:00
$sql .= " AND f.fk_statut IN ( " . $db -> sanitize ( $db -> escape ( $search_status )) . " ) " ; // When search_status is '1,2' for example
2018-06-26 11:18:31 +02:00
}
2016-07-05 18:33:13 +02:00
}
2019-12-23 21:01:17 +01:00
2021-02-23 21:09:01 +01:00
if ( $search_paymentmode > 0 ) {
2021-06-09 15:36:47 +02:00
$sql .= " AND f.fk_mode_reglement = " . (( int ) $search_paymentmode );
2021-02-23 21:09:01 +01:00
}
if ( $search_paymentterms > 0 ) {
2021-06-09 15:36:47 +02:00
$sql .= " AND f.fk_cond_reglement = " . (( int ) $search_paymentterms );
2021-02-23 21:09:01 +01:00
}
if ( $search_module_source ) {
$sql .= natural_search ( " f.module_source " , $search_module_source );
}
if ( $search_pos_source ) {
$sql .= natural_search ( " f.pos_source " , $search_pos_source );
}
if ( $search_date_start ) {
$sql .= " AND f.datef >= ' " . $db -> idate ( $search_date_start ) . " ' " ;
}
if ( $search_date_end ) {
$sql .= " AND f.datef <= ' " . $db -> idate ( $search_date_end ) . " ' " ;
}
if ( $search_date_valid_start ) {
$sql .= " AND f.date_valid >= ' " . $db -> idate ( $search_date_valid_start ) . " ' " ;
}
if ( $search_date_valid_end ) {
$sql .= " AND f.date_valid <= ' " . $db -> idate ( $search_date_valid_end ) . " ' " ;
}
if ( $search_datelimit_start ) {
$sql .= " AND f.date_lim_reglement >= ' " . $db -> idate ( $search_datelimit_start ) . " ' " ;
}
if ( $search_datelimit_end ) {
$sql .= " AND f.date_lim_reglement <= ' " . $db -> idate ( $search_datelimit_end ) . " ' " ;
}
2025-02-18 13:56:44 +01:00
if ( $search_datec_start ) {
$sql .= " AND f.datec >= ' " . $db -> idate ( $search_datec_start ) . " ' " ;
}
if ( $search_datec_end ) {
$sql .= " AND f.datec <= ' " . $db -> idate ( $search_datec_end ) . " ' " ;
}
if ( $search_datem_start ) {
$sql .= " AND f.tms >= ' " . $db -> idate ( $search_datem_start ) . " ' " ;
}
if ( $search_datem_end ) {
$sql .= " AND f.tms <= ' " . $db -> idate ( $search_datem_end ) . " ' " ;
}
2024-07-03 02:59:41 +02:00
if ( $search_option == 'late' ) {
2025-02-18 13:56:44 +01:00
$sql .= " AND f.date_lim_reglement < ' " . $db -> idate ( dol_now () - $conf -> invoice -> client -> warning_delay ) . " ' " ;
2021-02-23 21:09:01 +01:00
}
2023-11-24 15:36:05 +01:00
/* if ( $search_sale > 0 ) {
2021-06-09 15:36:47 +02:00
$sql .= " AND s.rowid = sc.fk_soc AND sc.fk_user = " . (( int ) $search_sale );
2023-11-24 15:36:05 +01:00
} */
2022-04-27 08:50:58 +02:00
if ( ! empty ( $search_fac_rec_source_title )) {
$sql .= natural_search ( 'facrec.titre' , $search_fac_rec_source_title );
2022-04-15 11:32:53 +02:00
}
2024-10-19 01:02:21 +02:00
if ( $search_fk_fac_rec_source ) {
$sql .= ' AND f.fk_fac_rec_source = ' . ( int ) $search_fk_fac_rec_source ;
}
2024-12-16 13:45:48 +01:00
if ( $search_import_key ) {
$sql .= natural_search ( " s.import_key " , $search_import_key );
}
2024-04-28 22:16:12 +02:00
// Search on user
if ( $search_user > 0 ) {
$sql .= " AND EXISTS ( " ;
$sql .= " SELECT ec.fk_c_type_contact, ec.element_id, ec.fk_socpeople " ;
2024-12-02 00:49:13 +01:00
$sql .= " FROM " . MAIN_DB_PREFIX . " element_contact as ec " ;
$sql .= " INNER JOIN " . MAIN_DB_PREFIX . " c_type_contact as tc " ;
2024-04-28 22:16:12 +02:00
$sql .= " ON ec.fk_c_type_contact = tc.rowid AND tc.element='facture' AND tc.source='internal' " ;
$sql .= " WHERE ec.element_id = f.rowid AND ec.fk_socpeople = " . (( int ) $search_user ) . " ) " ;
}
2023-11-24 15:36:05 +01:00
// Search on sale representative
if ( $search_sale && $search_sale != '-1' ) {
if ( $search_sale == - 2 ) {
2023-11-24 16:30:31 +01:00
$sql .= " AND NOT EXISTS (SELECT sc.fk_soc FROM " . MAIN_DB_PREFIX . " societe_commerciaux as sc WHERE sc.fk_soc = f.fk_soc) " ;
2023-11-24 15:36:05 +01:00
} elseif ( $search_sale > 0 ) {
$sql .= " AND EXISTS (SELECT sc.fk_soc FROM " . MAIN_DB_PREFIX . " societe_commerciaux as sc WHERE sc.fk_soc = f.fk_soc AND sc.fk_user = " . (( int ) $search_sale ) . " ) " ;
}
}
2025-02-18 13:56:44 +01:00
2022-10-11 03:01:09 +02:00
// Search for tag/category ($searchCategoryProductList is an array of ID)
$searchCategoryProductList = $search_product_category ? array ( $search_product_category ) : array ();
$searchCategoryProductOperator = 0 ;
if ( ! empty ( $searchCategoryProductList )) {
$searchCategoryProductSqlList = array ();
$listofcategoryid = '' ;
foreach ( $searchCategoryProductList as $searchCategoryProduct ) {
if ( intval ( $searchCategoryProduct ) == - 2 ) {
2022-10-31 14:52:54 +01:00
$searchCategoryProductSqlList [] = " NOT EXISTS (SELECT ck.fk_product FROM " . MAIN_DB_PREFIX . " categorie_product as ck, " . MAIN_DB_PREFIX . " facturedet as fd WHERE fd.fk_facture = f.rowid AND fd.fk_product = ck.fk_product) " ;
2022-10-11 03:01:09 +02:00
} elseif ( intval ( $searchCategoryProduct ) > 0 ) {
2022-10-31 08:13:11 +01:00
if ( $searchCategoryProductOperator == 0 ) {
2022-10-31 14:52:54 +01:00
$searchCategoryProductSqlList [] = " EXISTS (SELECT ck.fk_product FROM " . MAIN_DB_PREFIX . " categorie_product as ck, " . MAIN_DB_PREFIX . " facturedet as fd WHERE fd.fk_facture = f.rowid AND fd.fk_product = ck.fk_product AND ck.fk_categorie = " . (( int ) $searchCategoryProduct ) . " ) " ;
2022-10-31 08:13:11 +01:00
} else {
$listofcategoryid .= ( $listofcategoryid ? ', ' : '' ) . (( int ) $searchCategoryProduct );
}
2022-10-11 03:01:09 +02:00
}
}
if ( $listofcategoryid ) {
2022-10-31 14:52:54 +01:00
$searchCategoryProductSqlList [] = " EXISTS (SELECT ck.fk_product FROM " . MAIN_DB_PREFIX . " categorie_product as ck, " . MAIN_DB_PREFIX . " facturedet as fd WHERE fd.fk_facture = f.rowid AND fd.fk_product = ck.fk_product AND ck.fk_categorie IN ( " . $db -> sanitize ( $listofcategoryid ) . " )) " ;
2022-10-11 03:01:09 +02:00
}
if ( $searchCategoryProductOperator == 1 ) {
if ( ! empty ( $searchCategoryProductSqlList )) {
$sql .= " AND ( " . implode ( ' OR ' , $searchCategoryProductSqlList ) . " ) " ;
}
} else {
if ( ! empty ( $searchCategoryProductSqlList )) {
$sql .= " AND ( " . implode ( ' AND ' , $searchCategoryProductSqlList ) . " ) " ;
}
}
}
2022-12-28 16:20:35 +01:00
$searchCategoryCustomerList = $search_categ_cus ? array ( $search_categ_cus ) : array ();
2022-10-11 03:01:09 +02:00
$searchCategoryCustomerOperator = 0 ;
// Search for tag/category ($searchCategoryCustomerList is an array of ID)
if ( ! empty ( $searchCategoryCustomerList )) {
$searchCategoryCustomerSqlList = array ();
$listofcategoryid = '' ;
foreach ( $searchCategoryCustomerList as $searchCategoryCustomer ) {
if ( intval ( $searchCategoryCustomer ) == - 2 ) {
$searchCategoryCustomerSqlList [] = " NOT EXISTS (SELECT ck.fk_soc FROM " . MAIN_DB_PREFIX . " categorie_societe as ck WHERE s.rowid = ck.fk_soc) " ;
} elseif ( intval ( $searchCategoryCustomer ) > 0 ) {
2022-10-31 08:13:11 +01:00
if ( $searchCategoryCustomerOperator == 0 ) {
$searchCategoryCustomerSqlList [] = " EXISTS (SELECT ck.fk_soc FROM " . MAIN_DB_PREFIX . " categorie_societe as ck WHERE s.rowid = ck.fk_soc AND ck.fk_categorie = " . (( int ) $searchCategoryCustomer ) . " ) " ;
} else {
$listofcategoryid .= ( $listofcategoryid ? ', ' : '' ) . (( int ) $searchCategoryCustomer );
}
2022-10-11 03:01:09 +02:00
}
}
if ( $listofcategoryid ) {
$searchCategoryCustomerSqlList [] = " EXISTS (SELECT ck.fk_soc FROM " . MAIN_DB_PREFIX . " categorie_societe as ck WHERE s.rowid = ck.fk_soc AND ck.fk_categorie IN ( " . $db -> sanitize ( $listofcategoryid ) . " )) " ;
}
if ( $searchCategoryCustomerOperator == 1 ) {
if ( ! empty ( $searchCategoryCustomerSqlList )) {
$sql .= " AND ( " . implode ( ' OR ' , $searchCategoryCustomerSqlList ) . " ) " ;
}
} else {
if ( ! empty ( $searchCategoryCustomerSqlList )) {
$sql .= " AND ( " . implode ( ' AND ' , $searchCategoryCustomerSqlList ) . " ) " ;
}
}
}
2016-04-08 01:00:02 +02:00
// Add where from extra fields
2017-11-27 15:24:29 +01:00
include DOL_DOCUMENT_ROOT . '/core/tpl/extrafields_list_search_sql.tpl.php' ;
2016-04-08 01:00:02 +02:00
// Add where from hooks
2019-11-12 09:46:08 +01:00
$parameters = array ();
2022-10-18 10:45:48 +02:00
$reshook = $hookmanager -> executeHooks ( 'printFieldListWhere' , $parameters , $object , $action ); // Note that $action and $object may have been modified by hook
2019-11-12 09:46:08 +01:00
$sql .= $hookmanager -> resPrint ;
2016-04-08 01:00:02 +02:00
2024-03-04 11:00:21 +01:00
if ( $search_all ) {
$sql .= natural_search ( array_keys ( $fieldstosearchall ), $search_all );
2016-04-08 02:39:57 +02:00
}
2021-03-18 16:51:02 +01:00
// Add HAVING from hooks
$parameters = array ();
2023-10-15 23:13:20 +02:00
$reshook = $hookmanager -> executeHooks ( 'printFieldListHaving' , $parameters , $object , $action ); // Note that $action and $object may have been modified by hook
2021-12-09 17:19:31 +01:00
$sql .= empty ( $hookmanager -> resPrint ) ? " " : " HAVING 1=1 " . $hookmanager -> resPrint ;
2021-03-18 16:51:02 +01:00
2022-11-26 01:23:45 +01:00
// Count total nb of records
2017-01-15 20:49:20 +01:00
$nbtotalofrecords = '' ;
2023-04-28 16:05:25 +02:00
if ( ! getDolGlobalInt ( 'MAIN_DISABLE_FULL_SCANLIST' )) {
2022-04-06 11:34:49 +02:00
/* The fast and low memory method to get and count full list converts the sql into a sql count */
2022-11-26 01:23:45 +01:00
$sqlforcount = preg_replace ( '/^' . preg_quote ( $sqlfields , '/' ) . '/' , 'SELECT COUNT(*) as nbtotalofrecords' , $sql );
$sqlforcount = preg_replace ( '/GROUP BY .*$/' , '' , $sqlforcount );
2022-04-06 11:34:49 +02:00
$resql = $db -> query ( $sqlforcount );
2022-04-06 17:32:56 +02:00
if ( $resql ) {
$objforcount = $db -> fetch_object ( $resql );
$nbtotalofrecords = $objforcount -> nbtotalofrecords ;
} else {
dol_print_error ( $db );
}
2023-12-17 22:59:15 +01:00
2022-11-26 01:23:45 +01:00
if (( $page * $limit ) > $nbtotalofrecords ) { // if total resultset is smaller then paging size (filtering), goto and load page 0
2018-04-24 11:37:57 +02:00
$page = 0 ;
$offset = 0 ;
}
2022-04-06 11:34:49 +02:00
$db -> free ( $resql );
2014-05-12 11:00:58 +02:00
}
2022-04-06 17:32:56 +02:00
// Complete request and execute it with limit
2022-11-26 01:23:45 +01:00
$sql .= $db -> order ( $sortfield , $sortorder );
2022-04-06 17:32:56 +02:00
if ( $limit ) {
$sql .= $db -> plimit ( $limit + 1 , $offset );
}
2012-06-09 19:16:31 +02:00
$resql = $db -> query ( $sql );
2023-10-15 23:13:20 +02:00
if ( ! $resql ) {
dol_print_error ( $db );
exit ;
}
2018-11-22 11:36:30 +01:00
2023-10-15 23:13:20 +02:00
$num = $db -> num_rows ( $resql );
2012-06-09 19:16:31 +02:00
2023-10-15 23:13:20 +02:00
$arrayofselected = is_array ( $toselect ) ? $toselect : array ();
2018-11-27 11:09:47 +01:00
2024-03-04 11:00:21 +01:00
if ( $num == 1 && getDolGlobalString ( 'MAIN_SEARCH_DIRECT_OPEN_IF_ONLY_ONE' ) && $search_all ) {
2023-10-15 23:13:20 +02:00
$obj = $db -> fetch_object ( $resql );
$id = $obj -> id ;
2018-11-27 11:09:47 +01:00
2024-01-11 12:51:00 +01:00
header ( " Location: " . DOL_URL_ROOT . '/compta/facture/card.php?id=' . $id );
2023-10-15 23:13:20 +02:00
exit ;
}
2023-06-02 00:40:10 +02:00
2023-10-15 23:13:20 +02:00
// Output page
// --------------------------------------------------------------------
2018-11-27 11:09:47 +01:00
2024-07-15 20:52:09 +02:00
llxHeader ( '' , $title , $help_url , '' , 0 , 0 , '' , '' , '' , 'bodyforlist' );
2012-06-09 19:16:31 +02:00
2024-10-19 01:02:21 +02:00
if ( $search_fk_fac_rec_source ) {
$object = new FactureRec ( $db );
2024-10-25 12:30:50 +02:00
$object -> fetch (( int ) $search_fk_fac_rec_source );
2024-10-19 01:02:21 +02:00
$head = invoice_rec_prepare_head ( $object );
2024-10-25 12:30:50 +02:00
2024-10-19 01:02:21 +02:00
print dol_get_fiche_head ( $head , 'generated' , $langs -> trans ( 'InvoicesGeneratedFromRec' ), - 1 , 'bill' ); // Add a div
}
2024-03-08 02:49:49 +01:00
$param = '&socid=' . urlencode (( string ) ( $socid ));
2023-10-15 23:13:20 +02:00
if ( ! empty ( $mode )) {
$param .= '&mode=' . urlencode ( $mode );
}
if ( ! empty ( $contextpage ) && $contextpage != $_SERVER [ " PHP_SELF " ]) {
$param .= '&contextpage=' . urlencode ( $contextpage );
}
if ( $limit > 0 && $limit != $conf -> liste_limit ) {
$param .= '&limit=' . (( int ) $limit );
}
2024-12-16 13:45:48 +01:00
if ( $optioncss != '' ) {
$param .= '&optioncss=' . urlencode ( $optioncss );
}
if ( $show_files ) {
$param .= '&show_files=' . urlencode (( string ) ( $show_files ));
}
2024-03-04 11:00:21 +01:00
if ( $search_all ) {
$param .= '&search_all=' . urlencode ( $search_all );
2023-10-15 23:13:20 +02:00
}
if ( $search_date_startday ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_date_startday=' . urlencode (( string ) ( $search_date_startday ));
2023-10-15 23:13:20 +02:00
}
if ( $search_date_startmonth ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_date_startmonth=' . urlencode (( string ) ( $search_date_startmonth ));
2023-10-15 23:13:20 +02:00
}
if ( $search_date_startyear ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_date_startyear=' . urlencode (( string ) ( $search_date_startyear ));
2023-10-15 23:13:20 +02:00
}
if ( $search_date_endday ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_date_endday=' . urlencode (( string ) ( $search_date_endday ));
2023-10-15 23:13:20 +02:00
}
if ( $search_date_endmonth ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_date_endmonth=' . urlencode (( string ) ( $search_date_endmonth ));
2023-10-15 23:13:20 +02:00
}
if ( $search_date_endyear ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_date_endyear=' . urlencode (( string ) ( $search_date_endyear ));
2023-10-15 23:13:20 +02:00
}
if ( $search_date_valid_startday ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_date_valid_startday=' . urlencode (( string ) ( $search_date_valid_startday ));
2023-10-15 23:13:20 +02:00
}
if ( $search_date_valid_startmonth ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_date_valid_startmonth=' . urlencode (( string ) ( $search_date_valid_startmonth ));
2023-10-15 23:13:20 +02:00
}
if ( $search_date_valid_startyear ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_date_valid_startyear=' . urlencode (( string ) ( $search_date_valid_startyear ));
2023-10-15 23:13:20 +02:00
}
if ( $search_date_valid_endday ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_date_valid_endday=' . urlencode (( string ) ( $search_date_valid_endday ));
2023-10-15 23:13:20 +02:00
}
if ( $search_date_valid_endmonth ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_date_valid_endmonth=' . urlencode (( string ) ( $search_date_valid_endmonth ));
2023-10-15 23:13:20 +02:00
}
if ( $search_date_valid_endyear ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_date_valid_endyear=' . urlencode (( string ) ( $search_date_valid_endyear ));
2023-10-15 23:13:20 +02:00
}
if ( $search_datelimit_startday ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_datelimit_startday=' . urlencode (( string ) ( $search_datelimit_startday ));
2023-10-15 23:13:20 +02:00
}
if ( $search_datelimit_startmonth ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_datelimit_startmonth=' . urlencode (( string ) ( $search_datelimit_startmonth ));
2023-10-15 23:13:20 +02:00
}
if ( $search_datelimit_startyear ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_datelimit_startyear=' . urlencode (( string ) ( $search_datelimit_startyear ));
2023-10-15 23:13:20 +02:00
}
if ( $search_datelimit_endday ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_datelimit_endday=' . urlencode (( string ) ( $search_datelimit_endday ));
2023-10-15 23:13:20 +02:00
}
if ( $search_datelimit_endmonth ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_datelimit_endmonth=' . urlencode (( string ) ( $search_datelimit_endmonth ));
2023-10-15 23:13:20 +02:00
}
if ( $search_datelimit_endyear ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_datelimit_endyear=' . urlencode (( string ) ( $search_datelimit_endyear ));
2023-10-15 23:13:20 +02:00
}
if ( $search_ref ) {
$param .= '&search_ref=' . urlencode ( $search_ref );
}
if ( $search_refcustomer ) {
$param .= '&search_refcustomer=' . urlencode ( $search_refcustomer );
}
if ( $search_project_ref ) {
$param .= '&search_project_ref=' . urlencode ( $search_project_ref );
}
if ( $search_project ) {
$param .= '&search_project=' . urlencode ( $search_project );
}
if ( $search_type != '' ) {
$param .= '&search_type=' . urlencode ( $search_type );
}
2023-10-18 02:33:14 +02:00
if ( $search_subtype != '' ) {
$param .= '&search_subtype=' . urlencode ( $search_subtype );
}
2023-10-15 23:13:20 +02:00
if ( $search_company ) {
$param .= '&search_company=' . urlencode ( $search_company );
}
if ( $search_company_alias ) {
$param .= '&search_company_alias=' . urlencode ( $search_company_alias );
}
if ( $search_parent_name != '' ) {
$param .= '&search_parent_name=' . urlencode ( $search_parent_name );
}
if ( $search_town ) {
$param .= '&search_town=' . urlencode ( $search_town );
}
if ( $search_zip ) {
$param .= '&search_zip=' . urlencode ( $search_zip );
}
if ( $search_country ) {
$param .= " &search_country= " . urlencode ( $search_country );
}
if ( $search_type_thirdparty != '' ) {
$param .= '&search_type_thirdparty=' . urlencode ( $search_type_thirdparty );
}
if ( $search_customer_code ) {
$param .= '&search_customer_code=' . urlencode ( $search_customer_code );
}
if ( $search_sale > 0 ) {
2024-04-28 22:16:12 +02:00
$param .= '&search_sale=' . urlencode (( string ) $search_sale );
2023-10-15 23:13:20 +02:00
}
if ( $search_user > 0 ) {
2024-04-28 22:16:12 +02:00
$param .= '&search_user=' . urlencode (( string ) $search_user );
2023-10-15 23:13:20 +02:00
}
if ( $search_login ) {
$param .= '&search_login=' . urlencode ( $search_login );
}
if ( $search_product_category > 0 ) {
2024-04-28 22:16:12 +02:00
$param .= '&search_product_category=' . urlencode (( string ) $search_product_category );
2023-10-15 23:13:20 +02:00
}
if ( $search_montant_ht != '' ) {
$param .= '&search_montant_ht=' . urlencode ( $search_montant_ht );
}
if ( $search_montant_vat != '' ) {
$param .= '&search_montant_vat=' . urlencode ( $search_montant_vat );
}
if ( $search_montant_localtax1 != '' ) {
$param .= '&search_montant_localtax1=' . urlencode ( $search_montant_localtax1 );
}
if ( $search_montant_localtax2 != '' ) {
$param .= '&search_montant_localtax2=' . urlencode ( $search_montant_localtax2 );
}
if ( $search_montant_ttc != '' ) {
$param .= '&search_montant_ttc=' . urlencode ( $search_montant_ttc );
}
if ( $search_multicurrency_code != '' ) {
$param .= '&search_multicurrency_code=' . urlencode ( $search_multicurrency_code );
}
if ( $search_multicurrency_tx != '' ) {
$param .= '&search_multicurrency_tx=' . urlencode ( $search_multicurrency_tx );
}
if ( $search_multicurrency_montant_ht != '' ) {
$param .= '&search_multicurrency_montant_ht=' . urlencode ( $search_multicurrency_montant_ht );
}
if ( $search_multicurrency_montant_vat != '' ) {
$param .= '&search_multicurrency_montant_vat=' . urlencode ( $search_multicurrency_montant_vat );
}
if ( $search_multicurrency_montant_ttc != '' ) {
$param .= '&search_multicurrency_montant_ttc=' . urlencode ( $search_multicurrency_montant_ttc );
}
if ( $search_status != '' ) {
$param .= '&search_status=' . urlencode ( $search_status );
}
if ( $search_paymentmode > 0 ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_paymentmode=' . urlencode (( string ) ( $search_paymentmode ));
2023-10-15 23:13:20 +02:00
}
if ( $search_paymentterms > 0 ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_paymentterms=' . urlencode (( string ) ( $search_paymentterms ));
2023-10-15 23:13:20 +02:00
}
if ( $search_module_source ) {
$param .= '&search_module_source=' . urlencode ( $search_module_source );
}
if ( $search_pos_source ) {
$param .= '&search_pos_source=' . urlencode ( $search_pos_source );
}
2024-07-03 02:59:41 +02:00
if ( $search_option ) {
$param .= " &search_option= " . urlencode ( $search_option );
2023-10-15 23:13:20 +02:00
}
if ( $search_categ_cus > 0 ) {
2024-03-08 02:49:49 +01:00
$param .= '&search_categ_cus=' . urlencode (( string ) ( $search_categ_cus ));
2023-10-15 23:13:20 +02:00
}
if ( ! empty ( $search_fac_rec_source_title )) {
$param .= '&search_fac_rec_source_title=' . urlencode ( $search_fac_rec_source_title );
}
2024-10-19 01:02:21 +02:00
if ( $search_fk_fac_rec_source ) {
$param .= '&search_fk_fac_rec_source=' . ( int ) $search_fk_fac_rec_source ;
}
2024-12-16 13:45:48 +01:00
if ( $search_import_key != '' ) {
$param .= '&search_import_key=' . urlencode ( $search_import_key );
}
2022-02-10 13:01:47 +01:00
2023-10-15 23:13:20 +02:00
// Add $param from extra fields
include DOL_DOCUMENT_ROOT . '/core/tpl/extrafields_list_search_param.tpl.php' ;
// Add $param from hooks
2024-05-23 14:41:56 +02:00
$parameters = array ( 'param' => & $param );
2023-10-15 23:13:20 +02:00
$reshook = $hookmanager -> executeHooks ( 'printFieldListSearchParam' , $parameters , $object , $action ); // Note that $action and $object may have been modified by hook
$param .= $hookmanager -> resPrint ;
$arrayofmassactions = array (
2024-03-08 12:34:25 +01:00
'validate' => img_picto ( '' , 'check' , 'class="pictofixedwidth"' ) . $langs -> trans ( " Validate " ),
'generate_doc' => img_picto ( '' , 'pdf' , 'class="pictofixedwidth"' ) . $langs -> trans ( " ReGeneratePDF " ),
'builddoc' => img_picto ( '' , 'pdf' , 'class="pictofixedwidth"' ) . $langs -> trans ( " PDFMerge " ),
'presend' => img_picto ( '' , 'email' , 'class="pictofixedwidth"' ) . $langs -> trans ( " SendByMail " ),
2023-10-15 23:13:20 +02:00
);
2018-03-30 16:54:38 +02:00
2023-10-15 23:13:20 +02:00
if ( $user -> hasRight ( 'facture' , 'paiement' )) {
$arrayofmassactions [ 'makepayment' ] = img_picto ( '' , 'payment' , 'class="pictofixedwidth"' ) . $langs -> trans ( " MakePaymentAndClassifyPayed " );
}
if ( isModEnabled ( 'prelevement' ) && $user -> hasRight ( 'prelevement' , 'bons' , 'creer' )) {
$langs -> load ( " withdrawals " );
$arrayofmassactions [ 'withdrawrequest' ] = img_picto ( '' , 'payment' , 'class="pictofixedwidth"' ) . $langs -> trans ( " MakeWithdrawRequest " );
}
if ( $user -> hasRight ( 'facture' , 'supprimer' )) {
2023-11-27 11:39:32 +01:00
if ( getDolGlobalString ( 'INVOICE_CAN_REMOVE_DRAFT_ONLY' )) {
2023-10-15 23:13:20 +02:00
$arrayofmassactions [ 'predeletedraft' ] = img_picto ( '' , 'delete' , 'class="pictofixedwidth"' ) . $langs -> trans ( " Deletedraft " );
2023-11-27 11:39:32 +01:00
} elseif ( getDolGlobalString ( 'INVOICE_CAN_ALWAYS_BE_REMOVED' )) { // mass deletion never possible on invoices on such situation
2023-10-15 23:13:20 +02:00
$arrayofmassactions [ 'predelete' ] = img_picto ( '' , 'delete' , 'class="pictofixedwidth"' ) . $langs -> trans ( " Delete " );
}
}
if ( in_array ( $massaction , array ( 'presend' , 'predelete' , 'makepayment' ))) {
$arrayofmassactions = array ();
}
$massactionbutton = $form -> selectMassAction ( '' , $arrayofmassactions );
2025-01-22 09:03:45 +01:00
// Show the new button only when this page is not opened from the Extended POS
2023-10-15 23:13:20 +02:00
$newcardbutton = '' ;
if ( $contextpage != 'poslist' ) {
$url = DOL_URL_ROOT . '/compta/facture/card.php?action=create' ;
2024-10-25 20:45:12 +02:00
if ( ! empty ( $object -> socid )) {
$url .= '&socid=' . urlencode (( string ) $object -> socid );
}
if ( ! empty ( $object -> id )) {
$url .= '&fac_rec=' . urlencode (( string ) $object -> id );
2023-10-15 23:13:20 +02:00
}
$newcardbutton = '' ;
2024-03-08 12:34:25 +01:00
$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' ));
$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' ));
2023-10-15 23:13:20 +02:00
$newcardbutton .= dolGetButtonTitleSeparator ();
$newcardbutton .= dolGetButtonTitle ( $langs -> trans ( 'NewBill' ), '' , 'fa fa-plus-circle' , $url , '' , $user -> hasRight ( " facture " , " creer " ));
}
$i = 0 ;
print '<form method="POST" id="searchFormList" name="searchFormList" action="' . $_SERVER [ " PHP_SELF " ] . '">' . " \n " ;
if ( $optioncss != '' ) {
print '<input type="hidden" name="optioncss" value="' . $optioncss . '">' ;
}
print '<input type="hidden" name="token" value="' . newToken () . '">' ;
print '<input type="hidden" name="formfilteraction" id="formfilteraction" value="list">' ;
if ( ! in_array ( $massaction , array ( 'makepayment' ))) {
print '<input type="hidden" name="action" value="list">' ;
}
print '<input type="hidden" name="sortfield" value="' . $sortfield . '">' ;
print '<input type="hidden" name="sortorder" value="' . $sortorder . '">' ;
print '<input type="hidden" name="search_status" value="' . $search_status . '">' ;
print '<input type="hidden" name="contextpage" value="' . $contextpage . '">' ;
print '<input type="hidden" name="socid" value="' . $socid . '">' ;
print '<input type="hidden" name="mode" value="' . $mode . '">' ;
print_barre_liste ( $title , $page , $_SERVER [ " PHP_SELF " ], $param , $sortfield , $sortorder , $massactionbutton , $num , $nbtotalofrecords , 'bill' , 0 , $newcardbutton , '' , $limit , 0 , 0 , 1 );
$topicmail = " SendBillRef " ;
$modelmail = " facture_send " ;
$objecttmp = new Facture ( $db );
$trackid = 'inv' . $object -> id ;
include DOL_DOCUMENT_ROOT . '/core/tpl/massactions_pre.tpl.php' ;
if ( $massaction == 'makepayment' ) {
$formconfirm = '' ;
$formquestion = array (
// 'text' => $langs->trans("ConfirmClone"),
// array('type' => 'checkbox', 'name' => 'clone_content', 'label' => $langs->trans("CloneMainAttributes"), 'value' => 1),
// array('type' => 'checkbox', 'name' => 'update_prices', 'label' => $langs->trans("PuttingPricesUpToDate"), 'value' => 1),
array ( 'type' => 'date' , 'name' => 'datepaiment' , 'label' => $langs -> trans ( " Date " ), 'datenow' => 1 ),
array ( 'type' => 'other' , 'name' => 'paiementid' , 'label' => $langs -> trans ( " PaymentMode " ), 'value' => $form -> select_types_paiements ( GETPOST ( 'search_paymentmode' ), 'paiementid' , '' , 0 , 0 , 1 , 0 , 1 , '' , 1 )),
2024-03-08 12:34:25 +01:00
array ( 'type' => 'other' , 'name' => 'bankid' , 'label' => $langs -> trans ( " BankAccount " ), 'value' => $form -> select_comptes ( '' , 'bankid' , 0 , '' , 0 , '' , 0 , '' , 1 )),
2023-10-15 23:13:20 +02:00
//array('type' => 'other', 'name' => 'invoicesid', 'label' => '', 'value'=>'<input type="hidden" id="invoicesid" name="invoicesid" value="'.implode('#',GETPOST('toselect','array')).'">'),
);
$formconfirm = $form -> formconfirm ( $_SERVER [ " PHP_SELF " ], $langs -> trans ( 'MakePaymentAndClassifyPayed' ), $langs -> trans ( 'EnterPaymentReceivedFromCustomer' ), 'makepayment_confirm' , $formquestion , 1 , 0 , 200 , 500 , 1 );
print $formconfirm ;
}
2021-05-20 13:15:32 +02:00
2024-03-04 11:00:21 +01:00
if ( $search_all ) {
2023-10-15 23:13:20 +02:00
foreach ( $fieldstosearchall as $key => $val ) {
$fieldstosearchall [ $key ] = $langs -> trans ( $val );
2017-10-13 13:28:26 +02:00
}
2024-03-04 11:00:21 +01:00
print '<div class="divsearchfieldfilter">' . $langs -> trans ( " FilterOnInto " , $search_all ) . implode ( ', ' , $fieldstosearchall ) . '</div>' ;
2023-10-15 23:13:20 +02:00
}
2017-06-13 18:50:31 +02:00
2023-10-15 23:13:20 +02:00
// If the user can view prospects other than his'
$moreforfilter = '' ;
if ( $user -> hasRight ( " user " , " user " , " lire " )) {
$langs -> load ( " commercial " );
2023-09-18 10:54:45 +02:00
$moreforfilter .= '<div class="divsearchfield">' ;
2023-10-15 23:13:20 +02:00
$tmptitle = $langs -> trans ( 'ThirdPartiesOfSaleRepresentative' );
$moreforfilter .= img_picto ( $tmptitle , 'user' , 'class="pictofixedwidth"' ) . $formother -> select_salesrepresentatives ( $search_sale , 'search_sale' , $user , 0 , $tmptitle , 'maxwidth200' );
2023-09-18 10:54:45 +02:00
$moreforfilter .= '</div>' ;
2023-10-15 23:13:20 +02:00
}
// If the user can view prospects other than his'
if ( $user -> hasRight ( " user " , " user " , " lire " )) {
$moreforfilter .= '<div class="divsearchfield">' ;
$tmptitle = $langs -> trans ( 'LinkedToSpecificUsers' );
$moreforfilter .= img_picto ( $tmptitle , 'user' , 'class="pictofixedwidth"' ) . $form -> select_dolusers ( $search_user , 'search_user' , $tmptitle , '' , 0 , '' , '' , 0 , 0 , 0 , '' , 0 , '' , 'maxwidth200' );
$moreforfilter .= '</div>' ;
}
// Filter on product tags
2024-02-27 15:30:37 +01:00
if ( isModEnabled ( 'category' ) && $user -> hasRight ( " categorie " , " lire " ) && ( $user -> hasRight ( " produit " , " lire " ) || $user -> hasRight ( " service " , " lire " ))) {
2023-10-15 23:13:20 +02:00
include_once DOL_DOCUMENT_ROOT . '/categories/class/categorie.class.php' ;
$moreforfilter .= '<div class="divsearchfield">' ;
$tmptitle = $langs -> trans ( 'IncludingProductWithTag' );
2024-11-16 17:59:26 +01:00
$cate_arbo = $form -> select_all_categories ( Categorie :: TYPE_PRODUCT , '' , 'parent' , 0 , 0 , 1 );
2023-10-15 23:13:20 +02:00
$moreforfilter .= img_picto ( $tmptitle , 'category' , 'class="pictofixedwidth"' ) . $form -> selectarray ( 'search_product_category' , $cate_arbo , $search_product_category , $tmptitle , 0 , 0 , '' , 0 , 0 , 0 , 0 , 'maxwidth300 widthcentpercentminusx' , 1 );
$moreforfilter .= '</div>' ;
}
2024-02-27 15:30:37 +01:00
if ( isModEnabled ( 'category' ) && $user -> hasRight ( " categorie " , " lire " )) {
2023-10-15 23:13:20 +02:00
require_once DOL_DOCUMENT_ROOT . '/categories/class/categorie.class.php' ;
$moreforfilter .= '<div class="divsearchfield">' ;
$tmptitle = $langs -> trans ( 'CustomersProspectsCategoriesShort' );
$moreforfilter .= img_picto ( $tmptitle , 'category' , 'class="pictofixedwidth"' ) . $formother -> select_categories ( 'customer' , $search_categ_cus , 'search_categ_cus' , 1 , $tmptitle );
$moreforfilter .= '</div>' ;
}
// alert on due date
$moreforfilter .= '<div class="divsearchfield">' ;
2024-07-03 02:59:41 +02:00
$moreforfilter .= '<label for="search_option">' . $langs -> trans ( 'Alert' ) . ' </label><input type="checkbox" name="search_option" id="search_option" value="late"' . ( $search_option == 'late' ? ' checked' : '' ) . '>' ;
2023-10-15 23:13:20 +02:00
$moreforfilter .= '</div>' ;
2023-09-18 10:54:45 +02:00
2023-10-15 23:13:20 +02:00
$parameters = array ();
$reshook = $hookmanager -> executeHooks ( 'printFieldPreListTitle' , $parameters , $object , $action ); // Note that $action and $object may have been modified by hook
if ( empty ( $reshook )) {
$moreforfilter .= $hookmanager -> resPrint ;
} else {
$moreforfilter = $hookmanager -> resPrint ;
}
2016-09-29 07:01:58 +02:00
2023-10-15 23:13:20 +02:00
if ( ! empty ( $moreforfilter )) {
print '<div class="liste_titre liste_titre_bydiv centpercent">' ;
print $moreforfilter ;
print '</div>' ;
}
2022-06-24 13:07:28 +02:00
2023-10-15 23:13:20 +02:00
$varpage = empty ( $contextpage ) ? $_SERVER [ " PHP_SELF " ] : $contextpage ;
2024-02-29 16:48:52 +01:00
$selectedfields = $form -> multiSelectArrayWithCheckbox ( 'selectedfields' , $arrayfields , $varpage , getDolGlobalString ( 'MAIN_CHECKBOX_LEFT_COLUMN' )); // This also change content of $arrayfields
2023-10-15 23:13:20 +02:00
2025-01-22 09:03:45 +01:00
// Show the massaction checkboxes only when this page is not opened from the Extended POS
2023-10-15 23:13:20 +02:00
if ( $massactionbutton && $contextpage != 'poslist' ) {
$selectedfields .= $form -> showCheckAddButtons ( 'checkforselect' , 1 );
}
print '<div class="div-table-responsive">' ;
print '<table class="tagtable nobottomiftotal liste' . ( $moreforfilter ? " listwithfilterbefore " : " " ) . '">' . " \n " ;
// Fields title search
// --------------------------------------------------------------------
print '<tr class="liste_titre_filter">' ;
// Action column
if ( getDolGlobalString ( 'MAIN_CHECKBOX_LEFT_COLUMN' )) {
print '<td class="liste_titre center maxwidthsearch actioncolumn">' ;
$searchpicto = $form -> showFilterButtons ( 'left' );
print $searchpicto ;
print '</td>' ;
}
2023-11-27 11:39:32 +01:00
if ( getDolGlobalString ( 'MAIN_VIEW_LINE_NUMBER_IN_LIST' )) {
2023-10-15 23:13:20 +02:00
print '<td class="liste_titre">' ;
print '</td>' ;
}
// Ref
if ( ! empty ( $arrayfields [ 'f.ref' ][ 'checked' ])) {
2025-01-14 16:51:03 +01:00
print '<td class="liste_titre">' ;
2023-10-15 23:13:20 +02:00
print '<input class="flat maxwidth50imp" type="text" name="search_ref" value="' . dol_escape_htmltag ( $search_ref ) . '">' ;
print '</td>' ;
}
// Ref customer
if ( ! empty ( $arrayfields [ 'f.ref_client' ][ 'checked' ])) {
print '<td class="liste_titre">' ;
print '<input class="flat maxwidth50imp" type="text" name="search_refcustomer" value="' . dol_escape_htmltag ( $search_refcustomer ) . '">' ;
print '</td>' ;
}
// Type
if ( ! empty ( $arrayfields [ 'f.type' ][ 'checked' ])) {
print '<td class="liste_titre maxwidthonsmartphone">' ;
$listtype = array (
2024-03-08 12:34:25 +01:00
Facture :: TYPE_STANDARD => $langs -> trans ( " InvoiceStandard " ),
Facture :: TYPE_DEPOSIT => $langs -> trans ( " InvoiceDeposit " ),
Facture :: TYPE_CREDIT_NOTE => $langs -> trans ( " InvoiceAvoir " ),
Facture :: TYPE_REPLACEMENT => $langs -> trans ( " InvoiceReplacement " ),
2023-10-15 23:13:20 +02:00
);
2023-11-27 11:39:32 +01:00
if ( getDolGlobalString ( 'INVOICE_USE_SITUATION' )) {
2023-10-15 23:13:20 +02:00
$listtype [ Facture :: TYPE_SITUATION ] = $langs -> trans ( " InvoiceSituation " );
}
//$listtype[Facture::TYPE_PROFORMA]=$langs->trans("InvoiceProForma"); // A proformat invoice is not an invoice but must be an order.
2024-03-08 12:34:25 +01:00
// @phan-suppress-next-line PhanPluginSuspiciousParamOrder
2025-01-14 16:51:03 +01:00
print $form -> selectarray ( 'search_type' , $listtype , $search_type , 1 , 0 , 0 , '' , 0 , 0 , 0 , '' , 'maxwidth75' );
2023-10-15 23:13:20 +02:00
print '</td>' ;
}
2023-10-18 02:33:14 +02:00
// Invoice Subtype
if ( ! empty ( $arrayfields [ 'f.subtype' ][ 'checked' ])) {
print '<td class="liste_titre maxwidthonsmartphone" align="center">' ;
print $form -> selectarray ( 'search_subtype' , $subtypearray , $search_subtype , 1 , 0 , 0 , '' , 0 , 0 , 0 , '' , 'maxwidth100' );
print '</td>' ;
}
2023-10-15 23:13:20 +02:00
// Date invoice
if ( ! empty ( $arrayfields [ 'f.datef' ][ 'checked' ])) {
print '<td class="liste_titre center">' ;
2023-12-02 20:27:09 +01:00
print '<div class="nowrapfordate">' ;
2023-10-15 23:13:20 +02:00
print $form -> selectDate ( $search_date_start ? $search_date_start : - 1 , 'search_date_start' , 0 , 0 , 1 , '' , 1 , 0 , 0 , '' , '' , '' , '' , 1 , '' , $langs -> trans ( 'From' ));
print '</div>' ;
2023-12-02 20:27:09 +01:00
print '<div class="nowrapfordate">' ;
2023-10-15 23:13:20 +02:00
print $form -> selectDate ( $search_date_end ? $search_date_end : - 1 , 'search_date_end' , 0 , 0 , 1 , '' , 1 , 0 , 0 , '' , '' , '' , '' , 1 , '' , $langs -> trans ( 'to' ));
print '</div>' ;
print '</td>' ;
}
// Date valid
if ( ! empty ( $arrayfields [ 'f.date_valid' ][ 'checked' ])) {
print '<td class="liste_titre center">' ;
2023-12-02 20:27:09 +01:00
print '<div class="nowrapfordate">' ;
2023-10-15 23:13:20 +02:00
print $form -> selectDate ( $search_date_valid_start ? $search_date_valid_start : - 1 , 'search_date_valid_start' , 0 , 0 , 1 , '' , 1 , 0 , 0 , '' , '' , '' , '' , 1 , '' , $langs -> trans ( 'From' ));
print '</div>' ;
2023-12-02 20:27:09 +01:00
print '<div class="nowrapfordate">' ;
2023-10-15 23:13:20 +02:00
print $form -> selectDate ( $search_date_valid_end ? $search_date_valid_end : - 1 , 'search_date_valid_end' , 0 , 0 , 1 , '' , 1 , 0 , 0 , '' , '' , '' , '' , 1 , '' , $langs -> trans ( 'to' ));
print '</div>' ;
print '</td>' ;
}
// Date due
if ( ! empty ( $arrayfields [ 'f.date_lim_reglement' ][ 'checked' ])) {
print '<td class="liste_titre center">' ;
2023-12-02 20:27:09 +01:00
print '<div class="nowrapfordate">' ;
2023-10-15 23:13:20 +02:00
print $form -> selectDate ( $search_datelimit_start ? $search_datelimit_start : - 1 , 'search_datelimit_start' , 0 , 0 , 1 , '' , 1 , 0 , 0 , '' , '' , '' , '' , 1 , '' , $langs -> trans ( 'From' ));
print '</div>' ;
2023-12-02 20:27:09 +01:00
print '<div class="nowrapfordate">' ;
2023-10-15 23:13:20 +02:00
print $form -> selectDate ( $search_datelimit_end ? $search_datelimit_end : - 1 , 'search_datelimit_end' , 0 , 0 , 1 , '' , 1 , 0 , 0 , '' , '' , '' , '' , 1 , '' , $langs -> trans ( 'to' ));
print '</div>' ;
print '</td>' ;
}
// Project ref
if ( ! empty ( $arrayfields [ 'p.ref' ][ 'checked' ])) {
print '<td class="liste_titre"><input class="flat maxwidth50imp" type="text" name="search_project_ref" value="' . dol_escape_htmltag ( $search_project_ref ) . '"></td>' ;
}
// Project label
if ( ! empty ( $arrayfields [ 'p.title' ][ 'checked' ])) {
print '<td class="liste_titre"><input class="flat maxwidth50imp" type="text" name="search_project" value="' . dol_escape_htmltag ( $search_project ) . '"></td>' ;
}
// Thirdparty
if ( ! empty ( $arrayfields [ 's.nom' ][ 'checked' ])) {
print '<td class="liste_titre"><input class="flat maxwidth75imp" type="text" name="search_company" value="' . dol_escape_htmltag ( $search_company ) . '"' . ( $socid > 0 ? " disabled " : " " ) . '></td>' ;
}
// Alias
if ( ! empty ( $arrayfields [ 's.name_alias' ][ 'checked' ])) {
print '<td class="liste_titre"><input class="flat maxwidth75imp" type="text" name="search_company_alias" value="' . dol_escape_htmltag ( $search_company_alias ) . '"></td>' ;
}
// Parent company
if ( ! empty ( $arrayfields [ 's2.nom' ][ 'checked' ])) {
print '<td class="liste_titre">' ;
print '<input class="flat maxwidth100" type="text" name="search_parent_name" value="' . dol_escape_htmltag ( $search_parent_name ) . '">' ;
print '</td>' ;
}
// Customer Code
if ( ! empty ( $arrayfields [ 's.code_client' ][ 'checked' ])) {
print '<td class="liste_titre"><input class="flat maxwidth75imp" type="text" name="search_customer_code" value="' . dol_escape_htmltag ( $search_customer_code ) . '"></td>' ;
}
// Town
if ( ! empty ( $arrayfields [ 's.town' ][ 'checked' ])) {
print '<td class="liste_titre"><input class="flat maxwidth75imp" type="text" name="search_town" value="' . dol_escape_htmltag ( $search_town ) . '"></td>' ;
}
// Zip
if ( ! empty ( $arrayfields [ 's.zip' ][ 'checked' ])) {
print '<td class="liste_titre"><input class="flat maxwidth50imp" type="text" name="search_zip" value="' . dol_escape_htmltag ( $search_zip ) . '"></td>' ;
}
// State
if ( ! empty ( $arrayfields [ 'state.nom' ][ 'checked' ])) {
print '<td class="liste_titre">' ;
print '<input class="flat maxwidth50imp" type="text" name="search_state" value="' . dol_escape_htmltag ( $search_state ) . '">' ;
print '</td>' ;
}
// Country
if ( ! empty ( $arrayfields [ 'country.code_iso' ][ 'checked' ])) {
print '<td class="liste_titre center">' ;
2024-11-16 17:59:26 +01:00
print $form -> select_country ( $search_country , 'search_country' , '' , 0 , 'minwidth150imp maxwidth150' , 'code2' , 1 , 0 , 1 , array (), 1 );
2023-10-15 23:13:20 +02:00
print '</td>' ;
}
// Company type
if ( ! empty ( $arrayfields [ 'typent.code' ][ 'checked' ])) {
print '<td class="liste_titre maxwidthonsmartphone center">' ;
2023-11-27 11:39:32 +01:00
print $form -> selectarray ( " search_type_thirdparty " , $formcompany -> typent_array ( 0 ), $search_type_thirdparty , 1 , 0 , 0 , '' , 0 , 0 , 0 , ( ! getDolGlobalString ( 'SOCIETE_SORT_ON_TYPEENT' ) ? 'ASC' : $conf -> global -> SOCIETE_SORT_ON_TYPEENT ), 'maxwidth100' , 1 );
2023-10-15 23:13:20 +02:00
print '</td>' ;
}
// Payment mode
if ( ! empty ( $arrayfields [ 'f.fk_mode_reglement' ][ 'checked' ])) {
print '<td class="liste_titre">' ;
print $form -> select_types_paiements ( $search_paymentmode , 'search_paymentmode' , '' , 0 , 1 , 1 , 0 , 1 , 'minwidth100 maxwidth100' , 1 );
print '</td>' ;
}
// Payment terms
if ( ! empty ( $arrayfields [ 'f.fk_cond_reglement' ][ 'checked' ])) {
print '<td class="liste_titre left">' ;
print $form -> getSelectConditionsPaiements ( $search_paymentterms , 'search_paymentterms' , - 1 , 1 , 1 , 'minwidth100 maxwidth100' );
print '</td>' ;
}
// Module source
if ( ! empty ( $arrayfields [ 'f.module_source' ][ 'checked' ])) {
print '<td class="liste_titre">' ;
print '<input class="flat maxwidth75" type="text" name="search_module_source" value="' . dol_escape_htmltag ( $search_module_source ) . '">' ;
print '</td>' ;
}
// POS Terminal
if ( ! empty ( $arrayfields [ 'f.pos_source' ][ 'checked' ])) {
print '<td class="liste_titre">' ;
print '<input class="flat maxwidth50" type="text" name="search_pos_source" value="' . dol_escape_htmltag ( $search_pos_source ) . '">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'f.total_ht' ][ 'checked' ])) {
// Amount without tax
print '<td class="liste_titre right">' ;
print '<input class="flat" type="text" size="4" name="search_montant_ht" value="' . dol_escape_htmltag ( $search_montant_ht ) . '">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'f.total_tva' ][ 'checked' ])) {
// Amount vat
print '<td class="liste_titre right">' ;
print '<input class="flat" type="text" size="4" name="search_montant_vat" value="' . dol_escape_htmltag ( $search_montant_vat ) . '">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'f.total_localtax1' ][ 'checked' ])) {
// Localtax1
print '<td class="liste_titre right">' ;
print '<input class="flat" type="text" size="4" name="search_montant_localtax1" value="' . dol_escape_htmltag ( $search_montant_localtax1 ) . '">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'f.total_localtax2' ][ 'checked' ])) {
// Localtax2
print '<td class="liste_titre right">' ;
print '<input class="flat" type="text" size="4" name="search_montant_localtax2" value="' . dol_escape_htmltag ( $search_montant_localtax2 ) . '">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'f.total_ttc' ][ 'checked' ])) {
// Amount inc tax
print '<td class="liste_titre right">' ;
print '<input class="flat" type="text" size="4" name="search_montant_ttc" value="' . dol_escape_htmltag ( $search_montant_ttc ) . '">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'u.login' ][ 'checked' ])) {
// Author
print '<td class="liste_titre" align="center">' ;
print '<input class="flat" size="4" type="text" name="search_login" value="' . dol_escape_htmltag ( $search_login ) . '">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'sale_representative' ][ 'checked' ])) {
print '<td class="liste_titre"></td>' ;
}
if ( ! empty ( $arrayfields [ 'f.retained_warranty' ][ 'checked' ])) {
print '<td class="liste_titre" align="right">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'dynamount_payed' ][ 'checked' ])) {
print '<td class="liste_titre right">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'rtp' ][ 'checked' ])) {
print '<td class="liste_titre">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'f.multicurrency_code' ][ 'checked' ])) {
// Currency
print '<td class="liste_titre">' ;
print $form -> selectMultiCurrency ( $search_multicurrency_code , 'search_multicurrency_code' , 1 );
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'f.multicurrency_tx' ][ 'checked' ])) {
// Currency rate
print '<td class="liste_titre">' ;
print '<input class="flat" type="text" size="4" name="search_multicurrency_tx" value="' . dol_escape_htmltag ( $search_multicurrency_tx ) . '">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'f.multicurrency_total_ht' ][ 'checked' ])) {
// Amount
print '<td class="liste_titre right">' ;
print '<input class="flat" type="text" size="4" name="search_multicurrency_montant_ht" value="' . dol_escape_htmltag ( $search_multicurrency_montant_ht ) . '">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'f.multicurrency_total_vat' ][ 'checked' ])) {
// Amount
print '<td class="liste_titre right">' ;
print '<input class="flat" type="text" size="4" name="search_multicurrency_montant_vat" value="' . dol_escape_htmltag ( $search_multicurrency_montant_vat ) . '">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'f.multicurrency_total_ttc' ][ 'checked' ])) {
// Amount
print '<td class="liste_titre right">' ;
print '<input class="flat" type="text" size="4" name="search_multicurrency_montant_ttc" value="' . dol_escape_htmltag ( $search_multicurrency_montant_ttc ) . '">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'multicurrency_dynamount_payed' ][ 'checked' ])) {
print '<td class="liste_titre">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'multicurrency_rtp' ][ 'checked' ])) {
print '<td class="liste_titre right">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'total_pa' ][ 'checked' ])) {
print '<td class="liste_titre right">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'total_margin' ][ 'checked' ])) {
print '<td class="liste_titre right">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'total_margin_rate' ][ 'checked' ])) {
print '<td class="liste_titre right">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'total_mark_rate' ][ 'checked' ])) {
print '<td class="liste_titre right">' ;
print '</td>' ;
}
2022-06-24 13:07:28 +02:00
2023-10-15 23:13:20 +02:00
// Extra fields
include DOL_DOCUMENT_ROOT . '/core/tpl/extrafields_list_search_input.tpl.php' ;
// Fields from hook
2024-03-08 12:34:25 +01:00
$parameters = array ( 'arrayfields' => $arrayfields );
2023-10-15 23:13:20 +02:00
$reshook = $hookmanager -> executeHooks ( 'printFieldListOption' , $parameters , $object , $action ); // Note that $action and $object may have been modified by hook
print $hookmanager -> resPrint ;
// Date creation
if ( ! empty ( $arrayfields [ 'f.datec' ][ 'checked' ])) {
2025-02-18 13:56:44 +01:00
print '<td class="liste_titre center">' ;
print '<div class="nowrapfordate">' ;
print $form -> selectDate ( $search_datec_start ? $search_datec_start : - 1 , 'search_datec_start' , 1 , 1 , 1 , '' , 1 , 0 , 0 , '' , '' , '' , '' , 1 , '' , $langs -> trans ( 'From' ), 'tzuserrel' );
print '</div>' ;
print '<div class="nowrapfordate">' ;
print $form -> selectDate ( $search_datec_end ? $search_datec_end : - 1 , 'search_datec_end' , 1 , 1 , 1 , '' , 1 , 0 , 0 , '' , '' , '' , '' , 1 , '' , $langs -> trans ( 'to' ), 'tzuserrel' );
print '</div>' ;
2023-10-15 23:13:20 +02:00
print '</td>' ;
}
// Date modification
if ( ! empty ( $arrayfields [ 'f.tms' ][ 'checked' ])) {
2025-02-18 13:56:44 +01:00
print '<td class="liste_titre center">' ;
print '<div class="nowrapfordate">' ;
print $form -> selectDate ( $search_datem_start ? $search_datem_start : - 1 , 'search_datem_start' , 1 , 1 , 1 , '' , 1 , 0 , 0 , '' , '' , '' , '' , 1 , '' , $langs -> trans ( 'From' ), 'tzuserrel' );
print '</div>' ;
print '<div class="nowrapfordate">' ;
print $form -> selectDate ( $search_datem_end ? $search_datem_end : - 1 , 'search_datem_end' , 1 , 1 , 1 , '' , 1 , 0 , 0 , '' , '' , '' , '' , 1 , '' , $langs -> trans ( 'to' ), 'tzuserrel' );
print '</div>' ;
2023-10-15 23:13:20 +02:00
print '</td>' ;
}
// Date closing
if ( ! empty ( $arrayfields [ 'f.date_closing' ][ 'checked' ])) {
print '<td class="liste_titre">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'f.note_public' ][ 'checked' ])) {
// Note public
print '<td class="liste_titre">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'f.note_private' ][ 'checked' ])) {
// Note private
print '<td class="liste_titre">' ;
print '</td>' ;
}
if ( ! empty ( $arrayfields [ 'f.fk_fac_rec_source' ][ 'checked' ])) {
// Template Invoice
print '<td class="liste_titre maxwidthonsmartphone right">' ;
print '<input class="flat maxwidth50imp" type="text" name="search_fac_rec_source_title" id="search_fac_rec_source_title" value="' . dol_escape_htmltag ( $search_fac_rec_source_title ) . '">' ;
print '</td>' ;
}
2024-12-16 13:45:48 +01:00
// Import key
if ( ! empty ( $arrayfields [ 'f.import_key' ][ 'checked' ])) {
print '<td class="liste_titre maxwidthonsmartphone center">' ;
print '<input class="flat searchstring maxwidth50" type="text" name="search_import_key" value="' . dol_escape_htmltag ( $search_import_key ) . '">' ;
print '</td>' ;
}
2023-10-15 23:13:20 +02:00
// Status
if ( ! empty ( $arrayfields [ 'f.fk_statut' ][ 'checked' ])) {
2024-06-22 14:48:16 +02:00
print '<td class="liste_titre center parentonrightofpage">' ;
2024-03-08 12:34:25 +01:00
$liststatus = array ( '0' => $langs -> trans ( " BillShortStatusDraft " ), '0,1' => $langs -> trans ( " BillShortStatusDraft " ) . '+' . $langs -> trans ( " BillShortStatusNotPaid " ), '1' => $langs -> trans ( " BillShortStatusNotPaid " ), '1,2' => $langs -> trans ( " BillShortStatusNotPaid " ) . '+' . $langs -> trans ( " BillShortStatusPaid " ), '2' => $langs -> trans ( " BillShortStatusPaid " ), '3' => $langs -> trans ( " BillShortStatusCanceled " ));
// @phan-suppress-next-line PhanPluginSuspiciousParamOrder
2023-10-15 23:13:20 +02:00
print $form -> selectarray ( 'search_status' , $liststatus , $search_status , 1 , 0 , 0 , '' , 0 , 0 , 0 , '' , 'search_status width100 onrightofpage' , 1 );
print '</td>' ;
}
// Action column
2023-11-27 11:39:32 +01:00
if ( ! getDolGlobalString ( 'MAIN_CHECKBOX_LEFT_COLUMN' )) {
2023-10-15 23:13:20 +02:00
print '<td class="liste_titre center maxwidthsearch actioncolumn">' ;
$searchpicto = $form -> showFilterButtons ();
print $searchpicto ;
print '</td>' ;
}
print " </tr> \n " ;
$totalarray = array ();
$totalarray [ 'nbfield' ] = 0 ;
// Fields title label
// --------------------------------------------------------------------
print '<tr class="liste_titre">' ;
if ( getDolGlobalString ( 'MAIN_CHECKBOX_LEFT_COLUMN' )) {
print_liste_field_titre ( $selectedfields , $_SERVER [ " PHP_SELF " ], " " , '' , '' , 'align="center"' , $sortfield , $sortorder , 'maxwidthsearch ' );
$totalarray [ 'nbfield' ] ++ ;
}
2023-11-27 11:39:32 +01:00
if ( getDolGlobalString ( 'MAIN_VIEW_LINE_NUMBER_IN_LIST' )) {
2023-10-15 23:13:20 +02:00
print_liste_field_titre ( '#' , $_SERVER [ 'PHP_SELF' ], '' , '' , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.ref' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'f.ref' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 'f.ref' , '' , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.ref_client' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'f.ref_client' ][ 'label' ], $_SERVER [ " PHP_SELF " ], 'f.ref_client' , '' , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.type' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'f.type' ][ 'label' ], $_SERVER [ " PHP_SELF " ], 'f.type' , '' , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
2023-10-18 02:33:14 +02:00
if ( ! empty ( $arrayfields [ 'f.subtype' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'f.subtype' ][ 'label' ], $_SERVER [ " PHP_SELF " ], 'f.subtype' , '' , $param , '' , $sortfield , $sortorder );
}
2023-10-15 23:13:20 +02:00
if ( ! empty ( $arrayfields [ 'f.datef' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.datef' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 'f.datef' , '' , $param , '' , $sortfield , $sortorder , 'center ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.date_valid' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.date_valid' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 'f.date_valid' , '' , $param , '' , $sortfield , $sortorder , 'center ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.date_lim_reglement' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.date_lim_reglement' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], " f.date_lim_reglement " , '' , $param , '' , $sortfield , $sortorder , 'center ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'p.ref' ][ 'checked' ])) {
2023-12-14 00:25:46 +01:00
$langs -> load ( " projects " );
2023-10-15 23:13:20 +02:00
print_liste_field_titre ( $arrayfields [ 'p.ref' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], " p.ref " , '' , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'p.title' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'p.title' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], " p.title " , '' , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 's.nom' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 's.nom' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 's.nom' , '' , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 's.name_alias' ][ 'checked' ])) {
2024-09-29 21:52:31 +02:00
// False positive @phan-suppress-next-line PhanTypeInvalidDimOffset
2023-10-15 23:13:20 +02:00
print_liste_field_titre ( $arrayfields [ 's.name_alias' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 's.name_alias' , '' , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 's2.nom' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 's2.nom' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 's2.nom' , '' , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 's.code_client' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 's.code_client' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 's.code_client' , '' , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 's.town' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 's.town' ][ 'label' ], $_SERVER [ " PHP_SELF " ], 's.town' , '' , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 's.zip' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 's.zip' ][ 'label' ], $_SERVER [ " PHP_SELF " ], 's.zip' , '' , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'state.nom' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'state.nom' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " state.nom " , " " , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'country.code_iso' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'country.code_iso' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " country.code_iso " , " " , $param , '' , $sortfield , $sortorder , 'center ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'typent.code' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'typent.code' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " typent.code " , " " , $param , '' , $sortfield , $sortorder , 'center ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.fk_mode_reglement' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'f.fk_mode_reglement' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " f.fk_mode_reglement " , " " , $param , " " , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.fk_cond_reglement' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'f.fk_cond_reglement' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " f.fk_cond_reglement " , " " , $param , " " , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.module_source' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'f.module_source' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " f.module_source " , " " , $param , " " , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.pos_source' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'f.pos_source' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " f.pos_source " , " " , $param , " " , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.total_ht' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.total_ht' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 'f.total_ht' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.total_tva' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.total_tva' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 'f.total_tva' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.total_localtax1' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.total_localtax1' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 'f.localtax1' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.total_localtax2' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.total_localtax2' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 'f.localtax2' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.total_ttc' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.total_ttc' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 'f.total_ttc' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'u.login' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'u.login' ][ 'label' ], $_SERVER [ " PHP_SELF " ], 'u.login' , '' , $param , '' , $sortfield , $sortorder , 'center ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'sale_representative' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'sale_representative' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " " , " " , " $param " , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.retained_warranty' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.retained_warranty' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], '' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'dynamount_payed' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'dynamount_payed' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], '' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'rtp' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'rtp' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], '' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.multicurrency_code' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'f.multicurrency_code' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 'f.multicurrency_code' , '' , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.multicurrency_tx' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'f.multicurrency_tx' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 'f.multicurrency_tx' , '' , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.multicurrency_total_ht' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.multicurrency_total_ht' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 'f.multicurrency_total_ht' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.multicurrency_total_vat' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.multicurrency_total_vat' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 'f.multicurrency_total_tva' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.multicurrency_total_ttc' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.multicurrency_total_ttc' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], 'f.multicurrency_total_ttc' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'multicurrency_dynamount_payed' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'multicurrency_dynamount_payed' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], '' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'multicurrency_rtp' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'multicurrency_rtp' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], '' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'total_pa' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'total_pa' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], '' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'total_margin' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'total_margin' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], '' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'total_margin_rate' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'total_margin_rate' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], '' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'total_mark_rate' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'total_mark_rate' ][ 'label' ], $_SERVER [ 'PHP_SELF' ], '' , '' , $param , '' , $sortfield , $sortorder , 'right ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
// Extra fields
include DOL_DOCUMENT_ROOT . '/core/tpl/extrafields_list_search_title.tpl.php' ;
// Hook fields
2024-03-08 12:34:25 +01:00
$parameters = array ( 'arrayfields' => $arrayfields , 'param' => $param , 'sortfield' => $sortfield , 'sortorder' => $sortorder , 'totalarray' => $totalarray );
2023-10-15 23:13:20 +02:00
$reshook = $hookmanager -> executeHooks ( 'printFieldListTitle' , $parameters , $object , $action ); // Note that $action and $object may have been modified by hook
print $hookmanager -> resPrint ;
if ( ! empty ( $arrayfields [ 'f.datec' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.datec' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " f.datec " , " " , $param , '' , $sortfield , $sortorder , 'nowraponall center ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.tms' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.tms' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " f.tms " , " " , $param , '' , $sortfield , $sortorder , 'nowraponall center ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.date_closing' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.date_closing' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " f.date_closing " , " " , $param , '' , $sortfield , $sortorder , 'nowraponall center ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.note_public' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'f.note_public' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " f.note_public " , " " , $param , '' , $sortfield , $sortorder , 'center nowrap ' );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.note_private' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'f.note_private' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " f.note_private " , " " , $param , '' , $sortfield , $sortorder , 'center nowrap ' );
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! empty ( $arrayfields [ 'f.fk_fac_rec_source' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'f.fk_fac_rec_source' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " facrec.titre " , " " , $param , '' , $sortfield , $sortorder );
$totalarray [ 'nbfield' ] ++ ;
}
2024-12-16 13:45:48 +01:00
// Import key
if ( ! empty ( $arrayfields [ 'f.import_key' ][ 'checked' ])) {
print_liste_field_titre ( $arrayfields [ 'f.import_key' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " f.import_key " , " " , $param , '' , $sortfield , $sortorder , 'center ' );
$totalarray [ 'nbfield' ] ++ ;
}
// Status
2023-10-15 23:13:20 +02:00
if ( ! empty ( $arrayfields [ 'f.fk_statut' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $arrayfields [ 'f.fk_statut' ][ 'label' ], $_SERVER [ " PHP_SELF " ], " f.fk_statut,f.paye,f.type " , " " , $param , '' , $sortfield , $sortorder , 'center ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! getDolGlobalString ( 'MAIN_CHECKBOX_LEFT_COLUMN' )) {
2023-11-24 16:30:31 +01:00
print_liste_field_titre ( $selectedfields , $_SERVER [ " PHP_SELF " ], " " , '' , '' , '' , $sortfield , $sortorder , 'maxwidthsearch center ' );
2023-10-15 23:13:20 +02:00
$totalarray [ 'nbfield' ] ++ ;
}
2019-09-06 11:35:52 +02:00
2023-10-15 23:13:20 +02:00
print " </tr> \n " ;
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
$projectstatic = new Project ( $db );
$discount = new DiscountAbsolute ( $db );
$userstatic = new User ( $db );
2022-06-24 13:07:28 +02:00
2023-10-15 23:13:20 +02:00
// Loop on record
// --------------------------------------------------------------------
if ( $num > 0 ) {
$i = 0 ;
$savnbfield = $totalarray [ 'nbfield' ];
$totalarray = array ();
$totalarray [ 'nbfield' ] = 0 ;
$totalarray [ 'val' ] = array ();
$totalarray [ 'val' ][ 'f.total_ht' ] = 0 ;
$totalarray [ 'val' ][ 'f.total_tva' ] = 0 ;
2024-03-08 12:34:25 +01:00
$totalarray [ 'val' ][ 'f.total_localtax1' ] = 0 ;
$totalarray [ 'val' ][ 'f.total_localtax1' ] = 0 ;
2023-10-15 23:13:20 +02:00
$totalarray [ 'val' ][ 'f.total_ttc' ] = 0 ;
2024-09-28 13:05:24 +02:00
$totalarray [ 'val' ][ 'dynamount_payed' ] = 0 ;
2023-11-27 17:11:40 +01:00
$totalarray [ 'val' ][ 'rtp' ] = 0 ;
2023-10-15 23:13:20 +02:00
$typenArray = $formcompany -> typent_array ( 1 );
$with_margin_info = false ;
if ( isModEnabled ( 'margin' ) && (
! empty ( $arrayfields [ 'total_pa' ][ 'checked' ])
|| ! empty ( $arrayfields [ 'total_margin' ][ 'checked' ])
|| ! empty ( $arrayfields [ 'total_margin_rate' ][ 'checked' ])
|| ! empty ( $arrayfields [ 'total_mark_rate' ][ 'checked' ])
)
) {
$with_margin_info = true ;
}
$total_ht = 0 ;
$total_margin = 0 ;
$imaxinloop = ( $limit ? min ( $num , $limit ) : $num );
while ( $i < $imaxinloop ) {
$obj = $db -> fetch_object ( $resql );
2022-06-24 13:07:28 +02:00
2023-10-15 23:13:20 +02:00
$datelimit = $db -> jdate ( $obj -> datelimite );
$facturestatic -> id = $obj -> id ;
$facturestatic -> ref = $obj -> ref ;
2024-03-01 19:05:46 +01:00
$facturestatic -> ref_client = $obj -> ref_client ; // deprecated
$facturestatic -> ref_customer = $obj -> ref_client ;
2023-10-15 23:13:20 +02:00
$facturestatic -> type = $obj -> type ;
2023-10-18 02:33:14 +02:00
$facturestatic -> subtype = $obj -> subtype ;
2023-10-15 23:13:20 +02:00
$facturestatic -> total_ht = $obj -> total_ht ;
$facturestatic -> total_tva = $obj -> total_tva ;
$facturestatic -> total_ttc = $obj -> total_ttc ;
$facturestatic -> multicurrency_code = $obj -> multicurrency_code ;
$facturestatic -> multicurrency_tx = $obj -> multicurrency_tx ;
$facturestatic -> multicurrency_total_ht = $obj -> multicurrency_total_ht ;
$facturestatic -> multicurrency_total_tva = $obj -> multicurrency_total_vat ;
$facturestatic -> multicurrency_total_ttc = $obj -> multicurrency_total_ttc ;
$facturestatic -> statut = $obj -> fk_statut ; // deprecated
$facturestatic -> status = $obj -> fk_statut ;
$facturestatic -> close_code = $obj -> close_code ;
$facturestatic -> total_ttc = $obj -> total_ttc ;
$facturestatic -> paye = $obj -> paye ;
$facturestatic -> socid = $obj -> fk_soc ;
$facturestatic -> date = $db -> jdate ( $obj -> datef );
$facturestatic -> date_validation = $db -> jdate ( $obj -> date_valid );
$facturestatic -> date_lim_reglement = $db -> jdate ( $obj -> datelimite );
$facturestatic -> note_public = $obj -> note_public ;
$facturestatic -> note_private = $obj -> note_private ;
2023-11-27 11:39:32 +01:00
if ( getDolGlobalString ( 'INVOICE_USE_SITUATION' ) && getDolGlobalString ( 'INVOICE_USE_RETAINED_WARRANTY' )) {
2023-10-15 23:13:20 +02:00
$facturestatic -> retained_warranty = $obj -> retained_warranty ;
$facturestatic -> retained_warranty_date_limit = $obj -> retained_warranty_date_limit ;
$facturestatic -> situation_final = $obj -> retained_warranty_date_limit ;
$facturestatic -> situation_final = $obj -> retained_warranty_date_limit ;
$facturestatic -> situation_cycle_ref = $obj -> situation_cycle_ref ;
$facturestatic -> situation_counter = $obj -> situation_counter ;
}
2022-06-24 13:07:28 +02:00
2023-10-15 23:13:20 +02:00
$companystatic -> id = $obj -> socid ;
$companystatic -> name = $obj -> name ;
$companystatic -> name_alias = $obj -> alias ;
$companystatic -> client = $obj -> client ;
$companystatic -> fournisseur = $obj -> fournisseur ;
$companystatic -> code_client = $obj -> code_client ;
$companystatic -> code_compta_client = $obj -> code_compta_client ;
$companystatic -> code_fournisseur = $obj -> code_fournisseur ;
$companystatic -> code_compta_fournisseur = $obj -> code_compta_fournisseur ;
$companystatic -> email = $obj -> email ;
$companystatic -> phone = $obj -> phone ;
$companystatic -> fax = $obj -> fax ;
$companystatic -> address = $obj -> address ;
$companystatic -> zip = $obj -> zip ;
$companystatic -> town = $obj -> town ;
$companystatic -> country_code = $obj -> country_code ;
$projectstatic -> id = $obj -> project_id ;
$projectstatic -> ref = $obj -> project_ref ;
$projectstatic -> title = $obj -> project_label ;
$paiement = $facturestatic -> getSommePaiement ();
$totalcreditnotes = $facturestatic -> getSumCreditNotesUsed ();
$totaldeposits = $facturestatic -> getSumDepositsUsed ();
2024-09-28 13:05:24 +02:00
$totalallpayments = $paiement + $totalcreditnotes + $totaldeposits ;
$remaintopay = $obj -> total_ttc - $totalallpayments ;
2023-10-15 23:13:20 +02:00
$multicurrency_paiement = $facturestatic -> getSommePaiement ( 1 );
$multicurrency_totalcreditnotes = $facturestatic -> getSumCreditNotesUsed ( 1 );
$multicurrency_totaldeposits = $facturestatic -> getSumDepositsUsed ( 1 );
2024-09-28 13:05:24 +02:00
$totalallpayments = $paiement + $totalcreditnotes + $totaldeposits ;
$remaintopay = price2num ( $facturestatic -> total_ttc - $totalallpayments );
2023-10-15 23:13:20 +02:00
$multicurrency_totalpay = $multicurrency_paiement + $multicurrency_totalcreditnotes + $multicurrency_totaldeposits ;
$multicurrency_remaintopay = price2num ( $facturestatic -> multicurrency_total_ttc - $multicurrency_totalpay );
if ( $facturestatic -> status == Facture :: STATUS_CLOSED && $facturestatic -> close_code == 'discount_vat' ) { // If invoice closed with discount for anticipated payment
$remaintopay = 0 ;
$multicurrency_remaintopay = 0 ;
}
if ( $facturestatic -> type == Facture :: TYPE_CREDIT_NOTE && $obj -> paye == 1 ) { // If credit note closed, we take into account the amount not yet consumed
2024-11-16 17:59:26 +01:00
$remaincreditnote = $discount -> getAvailableDiscounts ( $companystatic , null , 'rc.fk_facture_source=' . $facturestatic -> id );
2023-10-15 23:13:20 +02:00
$remaintopay = - $remaincreditnote ;
2024-09-28 13:05:24 +02:00
$totalallpayments = price2num ( $facturestatic -> total_ttc - $remaintopay );
2024-11-16 17:59:26 +01:00
$multicurrency_remaincreditnote = $discount -> getAvailableDiscounts ( $companystatic , null , 'rc.fk_facture_source=' . $facturestatic -> id , 0 , 0 , 1 );
2023-10-15 23:13:20 +02:00
$multicurrency_remaintopay = - $multicurrency_remaincreditnote ;
$multicurrency_totalpay = price2num ( $facturestatic -> multicurrency_total_ttc - $multicurrency_remaintopay );
2022-02-03 10:39:03 +01:00
}
2022-08-13 12:03:41 +02:00
2023-10-15 23:13:20 +02:00
$facturestatic -> alreadypaid = $paiement ;
2024-06-22 14:48:16 +02:00
$facturestatic -> totalpaid = $paiement ;
2024-09-28 13:05:24 +02:00
$facturestatic -> totalcreditnotes = $totalcreditnotes ;
$facturestatic -> totaldeposits = $totaldeposits ;
2023-10-15 23:13:20 +02:00
$marginInfo = array ();
2024-08-07 03:05:02 +02:00
if ( $with_margin_info ) {
2023-10-15 23:13:20 +02:00
$facturestatic -> fetch_lines ();
$marginInfo = $formmargin -> getMarginInfosArray ( $facturestatic );
$total_ht += $obj -> total_ht ;
$total_margin += $marginInfo [ 'total_margin' ];
}
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
$object = $facturestatic ;
2020-02-24 05:23:34 +01:00
2023-10-15 23:13:20 +02:00
if ( $mode == 'kanban' ) {
if ( $i == 0 ) {
print '<tr class="trkanban"><td colspan="' . $savnbfield . '">' ;
print '<div class="box-flex-container kanban">' ;
2020-10-21 16:10:48 +02:00
}
2023-10-15 23:13:20 +02:00
// Output Kanban
if ( $massactionbutton || $massaction ) { // If we are in select mode (massactionbutton defined) or if we have already selected and sent an action ($massaction) defined
$selected = 0 ;
if ( in_array ( $object -> id , $arrayofselected )) {
$selected = 1 ;
2021-10-23 16:07:47 +02:00
}
2023-10-15 23:13:20 +02:00
}
2024-03-08 12:34:25 +01:00
$arraydata = array ( 'alreadypaid' => $paiement , 'thirdparty' => $companystatic -> getNomUrl ( 1 , '' , 12 ), 'userauthor' => $userstatic -> getNomUrl ( 1 ), 'selected' => in_array ( $object -> id , $arrayofselected ));
2023-10-15 23:13:20 +02:00
print $facturestatic -> getKanbanView ( '' , $arraydata );
if ( $i == ( $imaxinloop - 1 )) {
print '</div>' ;
print '</td></tr>' ;
}
} else {
// Show line of result
$j = 0 ;
print '<tr data-rowid="' . $object -> id . '" class="oddeven"' ;
if ( $contextpage == 'poslist' ) {
print ' onclick="parent.$(\'#poslines\').load(\'invoice.php?action=history&placeid=' . $obj -> id . '\', function() {parent.$.colorbox.close();' ;
if ( strpos ( $obj -> ref , 'PROV' ) !== false ) {
//If is a draft invoice, load var to be able to add products
$place = str_replace ( " ) " , " " , str_replace ( " (PROV-POS " . $_SESSION [ " takeposterminal " ] . " - " , " " , $obj -> ref ));
2024-04-04 11:21:15 +02:00
print 'parent.place=\'' . dol_escape_js ( $place ) . '\'' ;
2023-01-10 12:43:55 +01:00
}
2023-10-15 23:13:20 +02:00
print '});"' ;
}
print '>' ;
2020-04-08 11:23:31 +02:00
2023-10-15 23:13:20 +02:00
// Action column
if ( getDolGlobalString ( 'MAIN_CHECKBOX_LEFT_COLUMN' )) {
print '<td class="nowrap center">' ;
if (( $massactionbutton || $massaction ) && $contextpage != 'poslist' ) { // If we are in select mode (massactionbutton defined) or if we have already selected and sent an action ($massaction) defined
$selected = 0 ;
if ( in_array ( $obj -> id , $arrayofselected )) {
$selected = 1 ;
2023-06-02 00:40:10 +02:00
}
2023-10-15 23:13:20 +02:00
print '<input id="cb' . $obj -> id . '" class="flat checkforselect" type="checkbox" name="toselect[]" value="' . $obj -> id . '"' . ( $selected ? ' checked="checked"' : '' ) . '>' ;
2022-06-24 13:07:28 +02:00
}
2023-10-15 23:13:20 +02:00
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
}
}
2022-06-24 13:07:28 +02:00
2023-10-15 23:13:20 +02:00
// No
2023-11-27 11:39:32 +01:00
if ( getDolGlobalString ( 'MAIN_VIEW_LINE_NUMBER_IN_LIST' )) {
2023-10-15 23:13:20 +02:00
print '<td>' . (( $offset * $limit ) + $i ) . '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2023-01-10 12:43:55 +01:00
}
2023-10-15 23:13:20 +02:00
}
2020-04-08 11:23:31 +02:00
2023-10-15 23:13:20 +02:00
// Ref
if ( ! empty ( $arrayfields [ 'f.ref' ][ 'checked' ])) {
print '<td class="nowraponall">' ;
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
print '<table class="nobordernopadding"><tr class="nocellnopadd">' ;
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
print '<td class="nobordernopadding nowraponall">' ;
if ( $contextpage == 'poslist' ) {
print dol_escape_htmltag ( $obj -> ref );
} else {
print $facturestatic -> getNomUrl ( 1 , '' , 200 , 0 , '' , 0 , 1 );
}
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
$filename = dol_sanitizeFileName ( $obj -> ref );
2024-11-16 01:55:35 +01:00
$filepath = $conf -> invoice -> multidir_output [ $obj -> entity ] ? ? $conf -> invoice -> dir_output ;
$filedir = $filepath . '/' . $filename ;
2024-11-19 03:44:50 +01:00
2023-10-15 23:13:20 +02:00
$urlsource = $_SERVER [ 'PHP_SELF' ] . '?id=' . $obj -> id ;
print $formfile -> getDocumentsLink ( $facturestatic -> element , $filename , $filedir );
print '</td>' ;
print '</tr>' ;
print '</table>' ;
print " </td> \n " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2016-09-29 07:01:58 +02:00
2023-10-15 23:13:20 +02:00
// Customer ref
if ( ! empty ( $arrayfields [ 'f.ref_client' ][ 'checked' ])) {
print '<td class="nowrap tdoverflowmax200">' ;
print dol_escape_htmltag ( $obj -> ref_client );
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
// Type
if ( ! empty ( $arrayfields [ 'f.type' ][ 'checked' ])) {
print '<td class="nowraponall tdoverflowmax100" title="' . $facturestatic -> getLibType () . '">' ;
print $facturestatic -> getLibType ( 2 );
print " </td> " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2016-09-29 07:01:58 +02:00
2023-10-18 02:33:14 +02:00
// Invoice Subtype
if ( ! empty ( $arrayfields [ 'f.subtype' ][ 'checked' ])) {
2023-11-14 02:42:02 +01:00
$labeltoshow = '' ;
if ( $facturestatic -> subtype > 0 ) {
$labeltoshow = $facturestatic -> getSubtypeLabel ( 'facture' );
}
print '<td class="nowraponall tdoverflowmax300" title="' . $labeltoshow . '">' ;
print $labeltoshow ;
2023-10-18 02:33:14 +02:00
print " </td> " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
}
}
2023-10-15 23:13:20 +02:00
// Date
if ( ! empty ( $arrayfields [ 'f.datef' ][ 'checked' ])) {
print '<td align="center" class="nowraponall">' ;
print dol_print_date ( $db -> jdate ( $obj -> datef ), 'day' );
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
// Date
if ( ! empty ( $arrayfields [ 'f.date_valid' ][ 'checked' ])) {
print '<td align="center" class="nowraponall">' ;
print dol_print_date ( $db -> jdate ( $obj -> date_valid ), 'day' );
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2020-04-06 23:38:30 +02:00
2023-10-15 23:13:20 +02:00
// Date limit
if ( ! empty ( $arrayfields [ 'f.date_lim_reglement' ][ 'checked' ])) {
print '<td align="center" class="nowraponall">' . dol_print_date ( $datelimit , 'day' );
if ( $facturestatic -> hasDelay ()) {
print img_warning ( $langs -> trans ( 'Alert' ) . ' - ' . $langs -> trans ( 'Late' ));
}
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
// Project ref
if ( ! empty ( $arrayfields [ 'p.ref' ][ 'checked' ])) {
print '<td class="nocellnopadd nowraponall">' ;
if ( $obj -> project_id > 0 ) {
print $projectstatic -> getNomUrl ( 1 );
}
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
// Project title
if ( ! empty ( $arrayfields [ 'p.title' ][ 'checked' ])) {
print '<td class="nowraponall">' ;
if ( $obj -> project_id > 0 ) {
print dol_escape_htmltag ( $projectstatic -> title );
}
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2019-05-10 15:11:06 +02:00
2023-10-15 23:13:20 +02:00
// Third party
if ( ! empty ( $arrayfields [ 's.nom' ][ 'checked' ])) {
2024-06-04 02:38:04 +02:00
print '<td class="tdoverflowmax150">' ;
2023-10-15 23:13:20 +02:00
if ( $contextpage == 'poslist' ) {
print dol_escape_htmltag ( $companystatic -> name );
} else {
print $companystatic -> getNomUrl ( 1 , 'customer' , 0 , 0 , - 1 , empty ( $arrayfields [ 's.name_alias' ][ 'checked' ]) ? 0 : 1 );
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
// Alias
if ( ! empty ( $arrayfields [ 's.name_alias' ][ 'checked' ])) {
print '<td class="tdoverflowmax150" title="' . dol_escape_htmltag ( $companystatic -> name_alias ) . '">' ;
print dol_escape_htmltag ( $companystatic -> name_alias );
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
}
}
// Parent company
if ( ! empty ( $arrayfields [ 's2.nom' ][ 'checked' ])) {
print '<td class="tdoverflowmax200">' ;
if ( $obj -> fk_parent > 0 ) {
if ( ! isset ( $company_url_list [ $obj -> fk_parent ])) {
$companyparent = new Societe ( $db );
$res = $companyparent -> fetch ( $obj -> fk_parent );
if ( $res > 0 ) {
$company_url_list [ $obj -> fk_parent ] = $companyparent -> getNomUrl ( 1 );
2022-10-17 15:08:32 +02:00
}
}
2023-10-15 23:13:20 +02:00
if ( isset ( $company_url_list [ $obj -> fk_parent ])) {
print $company_url_list [ $obj -> fk_parent ];
2022-10-17 15:08:32 +02:00
}
}
2023-10-15 23:13:20 +02:00
print " </td> " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2023-02-17 10:14:20 +01:00
}
2023-10-15 23:13:20 +02:00
}
// Customer Code
if ( ! empty ( $arrayfields [ 's.code_client' ][ 'checked' ])) {
print '<td class="tdoverflowmax150" title="' . dol_escape_htmltag ( $companystatic -> code_client ) . '">' ;
print dol_escape_htmltag ( $companystatic -> code_client );
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
// Town
if ( ! empty ( $arrayfields [ 's.town' ][ 'checked' ])) {
print '<td class="tdoverflowmax100" title="' . dol_escape_htmltag ( $obj -> town ) . '">' ;
print dol_escape_htmltag ( $obj -> town );
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
// Zip
if ( ! empty ( $arrayfields [ 's.zip' ][ 'checked' ])) {
print '<td class="nowraponall">' ;
print dol_escape_htmltag ( $obj -> zip );
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
// State
if ( ! empty ( $arrayfields [ 'state.nom' ][ 'checked' ])) {
2023-11-25 01:41:24 +01:00
print '<td class="tdoverflowmax100" title="' . dol_escape_htmltag ( $obj -> state_name ) . '">' . dol_escape_htmltag ( $obj -> state_name ) . " </td> \n " ;
2023-10-15 23:13:20 +02:00
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
// Country
if ( ! empty ( $arrayfields [ 'country.code_iso' ][ 'checked' ])) {
$tmparray = getCountry ( $obj -> fk_pays , 'all' );
2023-11-25 01:41:24 +01:00
print '<td class="center tdoverflowmax100" title="' . dol_escape_htmltag ( $tmparray [ 'label' ]) . '">' ;
print dol_escape_htmltag ( $tmparray [ 'label' ]);
2023-10-15 23:13:20 +02:00
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
// Type ent
if ( ! empty ( $arrayfields [ 'typent.code' ][ 'checked' ])) {
if ( ! is_array ( $typenArray ) || count ( $typenArray ) == 0 ) {
$typenArray = $formcompany -> typent_array ( 1 );
}
2024-12-13 12:00:57 +01:00
print '<td class="center tdoverflowmax100" title="' . dolPrintHTML ( $typenArray [ $obj -> typent_code ]) . '">' ;
2023-11-27 18:59:17 +01:00
if ( ! empty ( $obj -> typent_code )) {
2023-11-27 17:11:40 +01:00
print $typenArray [ $obj -> typent_code ];
2023-11-27 18:59:17 +01:00
}
2023-10-15 23:13:20 +02:00
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
}
}
// Staff
if ( ! empty ( $arrayfields [ 'staff.code' ][ 'checked' ])) {
if ( ! is_array ( $conf -> cache [ 'staff' ]) || count ( $conf -> cache [ 'staff' ]) == 0 ) {
$conf -> cache [ 'staff' ] = $formcompany -> effectif_array ( 1 );
2021-02-23 21:09:01 +01:00
}
2024-12-13 12:00:57 +01:00
print '<td class="center tdoverflowmax100" title="' . dolPrintHTML ( $conf -> cache [ 'staff' ][ $obj -> staff_code ]) . '">' ;
2023-10-15 23:13:20 +02:00
print $conf -> cache [ 'staff' ][ $obj -> staff_code ];
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
}
}
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
// Payment mode
if ( ! empty ( $arrayfields [ 'f.fk_mode_reglement' ][ 'checked' ])) {
$s = $form -> form_modes_reglement ( $_SERVER [ 'PHP_SELF' ], $obj -> fk_mode_reglement , 'none' , '' , - 1 , 0 , '' , 1 );
print '<td class="tdoverflowmax100" title="' . dol_escape_htmltag ( $s ) . '">' ;
print $s ;
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
// Payment terms
if ( ! empty ( $arrayfields [ 'f.fk_cond_reglement' ][ 'checked' ])) {
$s = $form -> form_conditions_reglement ( $_SERVER [ 'PHP_SELF' ], $obj -> fk_cond_reglement , 'none' , 0 , '' , - 1 , - 1 , 1 );
print '<td class="tdoverflowmax100" title="' . dol_escape_htmltag ( $s ) . '">' ;
print $s ;
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2019-04-09 18:26:00 +02:00
2023-10-15 23:13:20 +02:00
// Module Source
if ( ! empty ( $arrayfields [ 'f.module_source' ][ 'checked' ])) {
print '<td>' ;
print dol_escape_htmltag ( $obj -> module_source );
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2019-10-10 15:10:41 +02:00
2023-10-15 23:13:20 +02:00
// POS Terminal
if ( ! empty ( $arrayfields [ 'f.pos_source' ][ 'checked' ])) {
print '<td>' ;
print dol_escape_htmltag ( $obj -> pos_source );
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2019-10-10 15:10:41 +02:00
2023-10-15 23:13:20 +02:00
// Amount HT
if ( ! empty ( $arrayfields [ 'f.total_ht' ][ 'checked' ])) {
print '<td class="right nowraponall amount">' . price ( $obj -> total_ht ) . " </td> \n " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
if ( ! $i ) {
$totalarray [ 'pos' ][ $totalarray [ 'nbfield' ]] = 'f.total_ht' ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
$totalarray [ 'val' ][ 'f.total_ht' ] += $obj -> total_ht ;
}
// Amount VAT
if ( ! empty ( $arrayfields [ 'f.total_tva' ][ 'checked' ])) {
print '<td class="right nowraponall amount">' . price ( $obj -> total_tva ) . " </td> \n " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
if ( ! $i ) {
$totalarray [ 'pos' ][ $totalarray [ 'nbfield' ]] = 'f.total_tva' ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
$totalarray [ 'val' ][ 'f.total_tva' ] += $obj -> total_tva ;
}
// Amount LocalTax1
if ( ! empty ( $arrayfields [ 'f.total_localtax1' ][ 'checked' ])) {
print '<td class="right nowraponall amount">' . price ( $obj -> total_localtax1 ) . " </td> \n " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! $i ) {
$totalarray [ 'pos' ][ $totalarray [ 'nbfield' ]] = 'f.total_localtax1' ;
}
$totalarray [ 'val' ][ 'f.total_localtax1' ] += $obj -> total_localtax1 ;
}
// Amount LocalTax2
if ( ! empty ( $arrayfields [ 'f.total_localtax2' ][ 'checked' ])) {
print '<td class="right nowraponall amount">' . price ( $obj -> total_localtax2 ) . " </td> \n " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
if ( ! $i ) {
$totalarray [ 'pos' ][ $totalarray [ 'nbfield' ]] = 'f.total_localtax2' ;
}
$totalarray [ 'val' ][ 'f.total_localtax2' ] += $obj -> total_localtax2 ;
}
// Amount TTC
if ( ! empty ( $arrayfields [ 'f.total_ttc' ][ 'checked' ])) {
print '<td class="right nowraponall amount">' . price ( $obj -> total_ttc ) . " </td> \n " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! $i ) {
$totalarray [ 'pos' ][ $totalarray [ 'nbfield' ]] = 'f.total_ttc' ;
}
$totalarray [ 'val' ][ 'f.total_ttc' ] += $obj -> total_ttc ;
}
2020-04-01 17:09:01 +02:00
2023-10-15 23:13:20 +02:00
$userstatic -> id = $obj -> fk_user_author ;
$userstatic -> login = $obj -> login ;
$userstatic -> lastname = $obj -> lastname ;
$userstatic -> firstname = $obj -> firstname ;
$userstatic -> email = $obj -> user_email ;
$userstatic -> status = $obj -> user_statut ;
$userstatic -> entity = $obj -> entity ;
$userstatic -> photo = $obj -> photo ;
$userstatic -> office_phone = $obj -> office_phone ;
$userstatic -> office_fax = $obj -> office_fax ;
$userstatic -> user_mobile = $obj -> user_mobile ;
$userstatic -> job = $obj -> job ;
$userstatic -> gender = $obj -> gender ;
// Author
if ( ! empty ( $arrayfields [ 'u.login' ][ 'checked' ])) {
2025-01-14 16:51:03 +01:00
print '<td class="tdoverflowmax125">' ;
2023-10-15 23:13:20 +02:00
if ( $userstatic -> id ) {
print $userstatic -> getNomUrl ( - 1 );
} else {
print ' ' ;
}
print " </td> \n " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
}
}
if ( ! empty ( $arrayfields [ 'sale_representative' ][ 'checked' ])) {
// Sales representatives
print '<td>' ;
if ( $obj -> socid > 0 ) {
$listsalesrepresentatives = $companystatic -> getSalesRepresentatives ( $user );
if ( $listsalesrepresentatives < 0 ) {
dol_print_error ( $db );
}
$nbofsalesrepresentative = count ( $listsalesrepresentatives );
if ( $nbofsalesrepresentative > 6 ) {
// We print only number
print $nbofsalesrepresentative ;
} elseif ( $nbofsalesrepresentative > 0 ) {
$j = 0 ;
foreach ( $listsalesrepresentatives as $val ) {
$userstatic -> id = $val [ 'id' ];
$userstatic -> lastname = $val [ 'lastname' ];
$userstatic -> firstname = $val [ 'firstname' ];
$userstatic -> email = $val [ 'email' ];
$userstatic -> status = $val [ 'statut' ];
$userstatic -> entity = $val [ 'entity' ];
$userstatic -> photo = $val [ 'photo' ];
$userstatic -> login = $val [ 'login' ];
$userstatic -> office_phone = $val [ 'office_phone' ];
$userstatic -> office_fax = $val [ 'office_fax' ];
$userstatic -> user_mobile = $val [ 'user_mobile' ];
$userstatic -> job = $val [ 'job' ];
$userstatic -> gender = $val [ 'gender' ];
//print '<div class="float">':
print ( $nbofsalesrepresentative < 2 ) ? $userstatic -> getNomUrl ( - 1 , '' , 0 , 0 , 12 ) : $userstatic -> getNomUrl ( - 2 );
$j ++ ;
if ( $j < $nbofsalesrepresentative ) {
print ' ' ;
2021-05-17 18:31:19 +02:00
}
2023-10-15 23:13:20 +02:00
//print '</div>';
2021-05-17 18:31:19 +02:00
}
}
2023-10-15 23:13:20 +02:00
//else print $langs->trans("NoSalesRepresentativeAffected");
}
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-05-17 18:31:19 +02:00
}
2023-10-15 23:13:20 +02:00
}
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
if ( ! empty ( $arrayfields [ 'f.retained_warranty' ][ 'checked' ])) {
print '<td align="right">' . ( ! empty ( $obj -> retained_warranty ) ? price ( $obj -> retained_warranty ) . '%' : ' ' ) . '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
if ( ! empty ( $arrayfields [ 'dynamount_payed' ][ 'checked' ])) {
2024-09-28 13:05:24 +02:00
print '<td class="right nowraponall amount">' . ( ! empty ( $totalallpayments ) ? price ( $totalallpayments , 0 , $langs ) : ' ' ) . '</td>' ; // TODO Use a denormalized field
2023-10-15 23:13:20 +02:00
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! $i ) {
2024-09-28 13:05:24 +02:00
$totalarray [ 'pos' ][ $totalarray [ 'nbfield' ]] = 'dynamount_payed' ;
2021-02-23 21:09:01 +01:00
}
2024-09-28 13:05:24 +02:00
$totalarray [ 'val' ][ 'dynamount_payed' ] += $totalallpayments ;
2023-10-15 23:13:20 +02:00
}
2023-01-10 12:43:55 +01:00
2023-10-15 23:13:20 +02:00
// Pending amount
if ( ! empty ( $arrayfields [ 'rtp' ][ 'checked' ])) {
print '<td class="right nowraponall amount">' ;
2023-12-04 12:01:45 +01:00
print ( ! empty ( $remaintopay ) ? price ( $remaintopay , 0 , $langs ) : ' ' );
2023-10-15 23:13:20 +02:00
print '</td>' ; // TODO Use a denormalized field
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
}
if ( ! $i ) {
$totalarray [ 'pos' ][ $totalarray [ 'nbfield' ]] = 'rtp' ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
$totalarray [ 'val' ][ 'rtp' ] += $remaintopay ;
}
2017-10-13 13:28:26 +02:00
2020-02-27 14:10:00 +01:00
2023-10-15 23:13:20 +02:00
// Currency
if ( ! empty ( $arrayfields [ 'f.multicurrency_code' ][ 'checked' ])) {
print '<td class="nowraponall tdoverflowmax125" title="' . dol_escape_htmltag ( $obj -> multicurrency_code . ' - ' . $langs -> transnoentitiesnoconv ( 'Currency' . $obj -> multicurrency_code )) . '">' ;
2023-11-27 11:39:32 +01:00
if ( ! getDolGlobalString ( 'MAIN_SHOW_ONLY_CODE_MULTICURRENCY' )) {
2023-10-15 23:13:20 +02:00
print $langs -> transnoentitiesnoconv ( 'Currency' . $obj -> multicurrency_code );
} else {
print dol_escape_htmltag ( $obj -> multicurrency_code );
}
print " </td> \n " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2020-02-27 14:10:00 +01:00
2023-10-15 23:13:20 +02:00
// Currency rate
if ( ! empty ( $arrayfields [ 'f.multicurrency_tx' ][ 'checked' ])) {
print '<td class="nowraponall">' ;
$form -> form_multicurrency_rate ( $_SERVER [ 'PHP_SELF' ] . '?id=' . $obj -> rowid , $obj -> multicurrency_tx , 'none' , $obj -> multicurrency_code );
print " </td> \n " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
// Amount HT
if ( ! empty ( $arrayfields [ 'f.multicurrency_total_ht' ][ 'checked' ])) {
print '<td class="right nowraponall amount">' . price ( $obj -> multicurrency_total_ht ) . " </td> \n " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
// Amount VAT
if ( ! empty ( $arrayfields [ 'f.multicurrency_total_vat' ][ 'checked' ])) {
print '<td class="right nowraponall amount">' . price ( $obj -> multicurrency_total_vat ) . " </td> \n " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
// Amount TTC
if ( ! empty ( $arrayfields [ 'f.multicurrency_total_ttc' ][ 'checked' ])) {
print '<td class="right nowraponall amount">' . price ( $obj -> multicurrency_total_ttc ) . " </td> \n " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2023-11-24 16:30:31 +01:00
// Dyn amount
2023-10-15 23:13:20 +02:00
if ( ! empty ( $arrayfields [ 'multicurrency_dynamount_payed' ][ 'checked' ])) {
print '<td class="right nowraponall amount">' . ( ! empty ( $multicurrency_totalpay ) ? price ( $multicurrency_totalpay , 0 , $langs ) : ' ' ) . '</td>' ; // TODO Use a denormalized field
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2020-02-27 14:10:00 +01:00
2023-10-15 23:13:20 +02:00
// Pending amount
if ( ! empty ( $arrayfields [ 'multicurrency_rtp' ][ 'checked' ])) {
2024-09-28 13:40:07 +02:00
print '<td class="right nowraponall amount">' ;
2023-12-04 12:01:45 +01:00
print ( ! empty ( $multicurrency_remaintopay ) ? price ( $multicurrency_remaintopay , 0 , $langs ) : ' ' );
2023-10-15 23:13:20 +02:00
print '</td>' ; // TODO Use a denormalized field ?
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2020-02-27 14:10:00 +01:00
2023-10-15 23:13:20 +02:00
// Total buying or cost price
if ( ! empty ( $arrayfields [ 'total_pa' ][ 'checked' ])) {
print '<td class="right nowrap">' . price ( $marginInfo [ 'pa_total' ], 0 , $langs , 1 , - 1 , 'MT' ) . '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
$totalarray [ 'pos' ][ $totalarray [ 'nbfield' ]] = 'total_pa' ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
if ( empty ( $totalarray [ 'val' ][ 'total_pa' ])) {
$totalarray [ 'val' ][ 'total_pa' ] = 0 ;
2022-02-16 11:45:29 +01:00
}
2023-10-15 23:13:20 +02:00
$totalarray [ 'val' ][ 'total_pa' ] += $marginInfo [ 'pa_total' ];
}
// Total margin
if ( ! empty ( $arrayfields [ 'total_margin' ][ 'checked' ])) {
print '<td class="right nowrap">' . price ( $marginInfo [ 'total_margin' ], 0 , $langs , 1 , - 1 , 'MT' ) . '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
$totalarray [ 'pos' ][ $totalarray [ 'nbfield' ]] = 'total_margin' ;
}
if ( empty ( $totalarray [ 'val' ][ 'total_margin' ])) {
$totalarray [ 'val' ][ 'total_margin' ] = 0 ;
}
$totalarray [ 'val' ][ 'total_margin' ] += $marginInfo [ 'total_margin' ];
}
// Total margin rate
if ( ! empty ( $arrayfields [ 'total_margin_rate' ][ 'checked' ])) {
2024-03-26 13:41:49 +01:00
print '<td class="right nowrap">' . (( $marginInfo [ 'total_margin_rate' ] == '' ) ? '' : price ( $marginInfo [ 'total_margin_rate' ], 0 , '' , 0 , 0 , 2 ) . '%' ) . '</td>' ;
2023-10-15 23:13:20 +02:00
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
}
}
// Total mark rate
if ( ! empty ( $arrayfields [ 'total_mark_rate' ][ 'checked' ])) {
2024-03-26 13:41:49 +01:00
print '<td class="right nowrap">' . (( $marginInfo [ 'total_mark_rate' ] == '' ) ? '' : price ( $marginInfo [ 'total_mark_rate' ], 0 , '' , 0 , 0 , 2 ) . '%' ) . '</td>' ;
2023-10-15 23:13:20 +02:00
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
$totalarray [ 'pos' ][ $totalarray [ 'nbfield' ]] = 'total_mark_rate' ;
}
if ( $i >= $imaxinloop - 1 ) {
if ( ! empty ( $total_ht )) {
$totalarray [ 'val' ][ 'total_mark_rate' ] = price2num ( $total_margin * 100 / $total_ht , 'MT' );
} else {
$totalarray [ 'val' ][ 'total_mark_rate' ] = '' ;
2022-02-16 11:45:29 +01:00
}
}
2023-10-15 23:13:20 +02:00
}
2020-10-21 16:10:48 +02:00
2023-10-15 23:13:20 +02:00
// Extra fields
include DOL_DOCUMENT_ROOT . '/core/tpl/extrafields_list_print_fields.tpl.php' ;
// Fields from hook
2024-03-08 12:34:25 +01:00
$parameters = array ( 'arrayfields' => $arrayfields , 'obj' => $obj , 'i' => $i , 'totalarray' => & $totalarray );
2023-10-15 23:13:20 +02:00
$reshook = $hookmanager -> executeHooks ( 'printFieldListValue' , $parameters , $object , $action ); // Note that $action and $object may have been modified by hook
print $hookmanager -> resPrint ;
// Date creation
if ( ! empty ( $arrayfields [ 'f.datec' ][ 'checked' ])) {
print '<td class="nowraponall center">' ;
2025-02-18 13:56:44 +01:00
print dol_print_date ( $db -> jdate ( $obj -> date_creation ), 'dayhour' , 'tzuserrel' );
2023-10-15 23:13:20 +02:00
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
// Date modification
if ( ! empty ( $arrayfields [ 'f.tms' ][ 'checked' ])) {
print '<td class="nowraponall center">' ;
2025-02-18 13:56:44 +01:00
print dol_print_date ( $db -> jdate ( $obj -> date_modification ), 'dayhour' , 'tzuserrel' );
2023-10-15 23:13:20 +02:00
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
// Date closing
if ( ! empty ( $arrayfields [ 'f.date_closing' ][ 'checked' ])) {
print '<td class="nowraponall center">' ;
2025-02-18 13:56:44 +01:00
print dol_print_date ( $db -> jdate ( $obj -> date_closing ), 'dayhour' , 'tzuserrel' );
2023-10-15 23:13:20 +02:00
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
// Note public
if ( ! empty ( $arrayfields [ 'f.note_public' ][ 'checked' ])) {
2024-05-15 18:21:50 +02:00
print '<td class="sensiblehtmlcontent center">' ;
print dolPrintHTML ( $obj -> note_public );
2023-10-15 23:13:20 +02:00
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
// Note private
if ( ! empty ( $arrayfields [ 'f.note_private' ][ 'checked' ])) {
print '<td class="center">' ;
2024-05-15 18:21:50 +02:00
print dolPrintHTML ( $obj -> note_private );
2023-10-15 23:13:20 +02:00
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2022-04-15 11:32:53 +02:00
}
2023-10-15 23:13:20 +02:00
}
// Template Invoice
if ( ! empty ( $arrayfields [ 'f.fk_fac_rec_source' ][ 'checked' ])) {
print '<td class="center">' ;
if ( ! empty ( $obj -> fk_fac_rec_source )) {
$facrec = new FactureRec ( $db );
$result = $facrec -> fetch ( $obj -> fk_fac_rec_source );
if ( $result < 0 ) {
setEventMessages ( $facrec -> error , $facrec -> errors , 'errors' );
} else {
print $facrec -> getNomUrl ();
2023-01-10 12:43:55 +01:00
}
2022-04-15 11:32:53 +02:00
}
2023-10-15 23:13:20 +02:00
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
}
}
2024-12-16 13:45:48 +01:00
// Import key
if ( ! empty ( $arrayfields [ 'f.import_key' ][ 'checked' ])) {
print '<td class="nowrap center">' . dol_escape_htmltag ( $obj -> import_key ) . '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
}
}
2023-10-15 23:13:20 +02:00
// Status
if ( ! empty ( $arrayfields [ 'f.fk_statut' ][ 'checked' ])) {
2023-11-24 16:30:31 +01:00
print '<td class="nowrap center">' ;
2024-09-28 13:05:24 +02:00
print $facturestatic -> getLibStatut ( 5 , $totalallpayments );
2023-10-15 23:13:20 +02:00
print " </td> " ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
2023-10-15 23:13:20 +02:00
}
2017-10-13 13:28:26 +02:00
2025-01-22 09:03:45 +01:00
// Action column (Show the massaction button only when this page is not opened from the Extended POS)
2022-06-24 13:07:28 +02:00
2023-10-15 23:13:20 +02:00
if ( ! getDolGlobalString ( 'MAIN_CHECKBOX_LEFT_COLUMN' )) {
print '<td class="nowrap center">' ;
if (( $massactionbutton || $massaction ) && $contextpage != 'poslist' ) { // If we are in select mode (massactionbutton defined) or if we have already selected and sent an action ($massaction) defined
$selected = 0 ;
if ( in_array ( $obj -> id , $arrayofselected )) {
$selected = 1 ;
2022-06-24 13:07:28 +02:00
}
2023-10-15 23:13:20 +02:00
print '<input id="cb' . $obj -> id . '" class="flat checkforselect" type="checkbox" name="toselect[]" value="' . $obj -> id . '"' . ( $selected ? ' checked="checked"' : '' ) . '>' ;
}
print '</td>' ;
if ( ! $i ) {
$totalarray [ 'nbfield' ] ++ ;
2021-02-23 21:09:01 +01:00
}
}
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
print '</tr>' . " \n " ;
2017-10-13 13:28:26 +02:00
}
2023-10-15 23:13:20 +02:00
$i ++ ;
2017-10-13 13:28:26 +02:00
}
2023-10-15 23:13:20 +02:00
// Use correct digits number for totals
$totalarray [ 'val' ][ 'total_pa' ] = ( isset ( $totalarray [ 'val' ][ 'total_pa' ]) ? price2num ( $totalarray [ 'val' ][ 'total_pa' ], 'MT' ) : null );
$totalarray [ 'val' ][ 'total_margin' ] = ( isset ( $totalarray [ 'val' ][ 'total_margin' ]) ? price2num ( $totalarray [ 'val' ][ 'total_margin' ], 'MT' ) : null );
// Show total line
include DOL_DOCUMENT_ROOT . '/core/tpl/list_print_total.tpl.php' ;
}
// If no record found
if ( $num == 0 ) {
$colspan = 1 ;
foreach ( $arrayfields as $key => $val ) {
if ( ! empty ( $val [ 'checked' ])) {
$colspan ++ ;
2022-05-10 11:38:56 +02:00
}
}
2023-10-15 23:13:20 +02:00
print '<tr><td colspan="' . $colspan . '"><span class="opacitymedium">' . $langs -> trans ( " NoRecordFound " ) . '</span></td></tr>' ;
}
2022-05-10 11:38:56 +02:00
2023-10-15 23:13:20 +02:00
$db -> free ( $resql );
2017-06-13 18:50:31 +02:00
2024-03-08 12:34:25 +01:00
$parameters = array ( 'arrayfields' => $arrayfields , 'sql' => $sql );
2023-10-15 23:13:20 +02:00
$reshook = $hookmanager -> executeHooks ( 'printFieldListFooter' , $parameters , $object , $action ); // Note that $action and $object may have been modified by hook
print $hookmanager -> resPrint ;
2017-06-13 18:50:31 +02:00
2023-10-15 23:13:20 +02:00
print '</table>' . " \n " ;
print '</div>' . " \n " ;
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
print '</form>' . " \n " ;
2017-10-13 13:28:26 +02:00
2025-01-22 09:03:45 +01:00
// Show the file area only when this page is not opened from the Extended POS
2023-10-15 23:13:20 +02:00
if ( $contextpage != 'poslist' ) {
$hidegeneratedfilelistifempty = 1 ;
if ( $massaction == 'builddoc' || $action == 'remove_file' || $show_files ) {
$hidegeneratedfilelistifempty = 0 ;
}
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
// Show list of available documents
$urlsource = $_SERVER [ 'PHP_SELF' ] . '?sortfield=' . $sortfield . '&sortorder=' . $sortorder ;
$urlsource .= str_replace ( '&' , '&' , $param );
2017-10-13 13:28:26 +02:00
2023-10-15 23:13:20 +02:00
$filedir = $diroutputmassaction ;
$genallowed = $user -> hasRight ( " facture " , " lire " );
$delallowed = $user -> hasRight ( " facture " , " creer " );
$title = '' ;
2018-02-21 11:02:45 +01:00
2023-10-15 23:13:20 +02:00
print $formfile -> showdocuments ( 'massfilesarea_invoices' , '' , $filedir , $urlsource , 0 , $delallowed , '' , 1 , 1 , 0 , 48 , 1 , $param , $title , '' , '' , '' , null , $hidegeneratedfilelistifempty );
2012-06-09 19:16:31 +02:00
}
2018-07-30 17:28:44 +02:00
// End of page
2012-06-09 19:16:31 +02:00
llxFooter ();
$db -> close ();